~oif-team/ubuntu/natty/qt4-x11/xi2.1

« back to all changes in this revision

Viewing changes to doc/html/demos-sqlbrowser-connectionwidget-cpp.html

  • Committer: Bazaar Package Importer
  • Author(s): Adam Conrad
  • Date: 2005-08-24 04:09:09 UTC
  • Revision ID: james.westby@ubuntu.com-20050824040909-xmxe9jfr4a0w5671
Tags: upstream-4.0.0
ImportĀ upstreamĀ versionĀ 4.0.0

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<?xml version="1.0" encoding="iso-8859-1"?>
 
2
<!DOCTYPE html
 
3
    PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "DTD/xhtml1-strict.dtd">
 
4
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
 
5
<head>
 
6
    <title>Qt 4.0: connectionwidget.cpp Example File (demos/sqlbrowser/connectionwidget.cpp)</title>
 
7
    <style>h3.fn,span.fn { margin-left: 1cm; text-indent: -1cm; }
 
8
a:link { color: #004faf; text-decoration: none }
 
9
a:visited { color: #672967; text-decoration: none }
 
10
td.postheader { font-family: sans-serif }
 
11
tr.address { font-family: sans-serif }
 
12
body { background: #ffffff; color: black; }</style>
 
13
</head>
 
14
<body>
 
15
<table border="0" cellpadding="0" cellspacing="0" width="100%">
 
16
<tr>
 
17
<td align="left" valign="top" width="32"><img src="images/qt-logo.png" align="left" width="32" height="32" border="0" /></td>
 
18
<td width="1">&nbsp;&nbsp;</td><td class="postheader" valign="center"><a href="index.html"><font color="#004faf">Home</font></a>&nbsp;&middot; <a href="classes.html"><font color="#004faf">All&nbsp;Classes</font></a>&nbsp;&middot; <a href="mainclasses.html"><font color="#004faf">Main&nbsp;Classes</font></a>&nbsp;&middot; <a href="annotated.html"><font color="#004faf">Annotated</font></a>&nbsp;&middot; <a href="groups.html"><font color="#004faf">Grouped&nbsp;Classes</font></a>&nbsp;&middot; <a href="functions.html"><font color="#004faf">Functions</font></a></td>
 
19
<td align="right" valign="top" width="230"><img src="images/trolltech-logo.png" align="right" width="203" height="32" border="0" /></td></tr></table><h1 align="center">connectionwidget.cpp Example File<br /><small><small>demos/sqlbrowser/connectionwidget.cpp</small></small></h1>
 
20
<pre>&nbsp;   /****************************************************************************
 
21
    **
 
22
    ** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
 
23
    **
 
24
    ** This file is part of the documentation of the Qt Toolkit.
 
25
    **
 
26
    ** This file may be distributed under the terms of the Q Public License
 
27
** as defined by Trolltech AS of Norway and appearing in the file
 
28
** LICENSE.QPL included in the packaging of this file.
 
29
**
 
30
** This file may be distributed and/or modified under the terms of the
 
31
** GNU General Public License version 2 as published by the Free Software
 
32
** Foundation and appearing in the file LICENSE.GPL included in the
 
33
** packaging of this file.
 
34
**
 
35
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
 
36
**   information about Qt Commercial License Agreements.
 
37
** See http://www.trolltech.com/qpl/ for QPL licensing information.
 
38
** See http://www.trolltech.com/gpl/ for GPL licensing information.
 
39
**
 
40
** Contact info@trolltech.com if any conditions of this licensing are
 
41
** not clear to you.
 
42
    **
 
43
    ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
 
44
    ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 
45
    **
 
46
    ****************************************************************************/
 
47
 
 
48
    #include &quot;connectionwidget.h&quot;
 
49
 
 
50
    #include &lt;QtGui&gt;
 
51
    #include &lt;QtSql&gt;
 
52
 
 
53
    ConnectionWidget::ConnectionWidget(QWidget *parent)
 
54
        : QWidget(parent)
 
55
    {
 
56
        QVBoxLayout *layout = new QVBoxLayout(this);
 
57
        tree = new QTreeWidget(this);
 
58
        tree-&gt;setObjectName(QLatin1String(&quot;tree&quot;));
 
59
        tree-&gt;setHeaderLabels(QStringList(tr(&quot;database&quot;)));
 
60
        tree-&gt;header()-&gt;setResizeMode(QHeaderView::Stretch);
 
61
        QAction *refreshAction = new QAction(tr(&quot;Refresh&quot;), tree);
 
62
        connect(refreshAction, SIGNAL(triggered()), SLOT(refresh()));
 
63
        tree-&gt;addAction(refreshAction);
 
64
        tree-&gt;setContextMenuPolicy(Qt::ActionsContextMenu);
 
65
 
 
66
        layout-&gt;addWidget(tree);
 
67
 
 
68
        QMetaObject::connectSlotsByName(this);
 
69
    }
 
70
 
 
71
    ConnectionWidget::~ConnectionWidget()
 
72
    {
 
73
    }
 
74
 
 
75
    static QString qDBCaption(const QSqlDatabase &amp;db)
 
76
    {
 
77
        QString nm = db.driverName();
 
78
        nm.append(QLatin1Char(':'));
 
79
        if (!db.userName().isEmpty())
 
80
            nm.append(db.userName()).append(QLatin1Char('@'));
 
81
        nm.append(db.databaseName());
 
82
        return nm;
 
83
    }
 
84
 
 
85
    void ConnectionWidget::refresh()
 
86
    {
 
87
        tree-&gt;clear();
 
88
        QStringList connectionNames = QSqlDatabase::connectionNames();
 
89
 
 
90
        bool gotActiveDb = false;
 
91
        for (int i = 0; i &lt; connectionNames.count(); ++i) {
 
92
            QTreeWidgetItem *root = new QTreeWidgetItem(tree);
 
93
            QSqlDatabase db = QSqlDatabase::database(connectionNames.at(i), false);
 
94
            root-&gt;setText(0, qDBCaption(db));
 
95
            if (connectionNames.at(i) == activeDb) {
 
96
                gotActiveDb = true;
 
97
                setActive(root);
 
98
            }
 
99
            if (db.isOpen()) {
 
100
                QStringList tables = db.tables();
 
101
                for (int t = 0; t &lt; tables.count(); ++t) {
 
102
                    QTreeWidgetItem *table = new QTreeWidgetItem(root);
 
103
                    table-&gt;setText(0, tables.at(t));
 
104
                }
 
105
            }
 
106
        }
 
107
        if (!gotActiveDb) {
 
108
            activeDb = connectionNames.value(0);
 
109
            setActive(tree-&gt;topLevelItem(0));
 
110
        }
 
111
 
 
112
        tree-&gt;doItemsLayout(); // HACK
 
113
    }
 
114
 
 
115
    QSqlDatabase ConnectionWidget::currentDatabase() const
 
116
    {
 
117
        return QSqlDatabase::database(activeDb);
 
118
    }
 
119
 
 
120
    static void qSetBold(QTreeWidgetItem *item, bool bold)
 
121
    {
 
122
        QFont font = item-&gt;font(0);
 
123
        font.setBold(bold);
 
124
        item-&gt;setFont(0, font);
 
125
    }
 
126
 
 
127
    void ConnectionWidget::setActive(QTreeWidgetItem *item)
 
128
    {
 
129
        for (int i = 0; i &lt; tree-&gt;topLevelItemCount(); ++i) {
 
130
            if (tree-&gt;topLevelItem(i)-&gt;font(0).bold())
 
131
                qSetBold(tree-&gt;topLevelItem(i), false);
 
132
        }
 
133
 
 
134
        if (!item)
 
135
            return;
 
136
 
 
137
        qSetBold(item, true);
 
138
        activeDb = QSqlDatabase::connectionNames().value(tree-&gt;indexOfTopLevelItem(item));
 
139
    }
 
140
 
 
141
    void ConnectionWidget::on_tree_itemActivated(QTreeWidgetItem *item, int /* column */)
 
142
    {
 
143
 
 
144
        if (!item)
 
145
            return;
 
146
 
 
147
        if (!item-&gt;parent()) {
 
148
            setActive(item);
 
149
        } else {
 
150
            setActive(item-&gt;parent());
 
151
            emit tableActivated(item-&gt;text(0));
 
152
        }
 
153
    }</pre>
 
154
<p /><address><hr /><div align="center">
 
155
<table width="100%" cellspacing="0" border="0"><tr class="address">
 
156
<td width="30%">Copyright &copy; 2005 <a href="trolltech.html">Trolltech</a></td>
 
157
<td width="40%" align="center"><a href="trademarks.html">Trademarks</a></td>
 
158
<td width="30%" align="right"><div align="right">Qt 4.0.0</div></td>
 
159
</tr></table></div></address></body>
 
160
</html>