1
<?xml version="1.0" encoding="iso-8859-1"?>
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">
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>
15
<table border="0" cellpadding="0" cellspacing="0" width="100%">
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"> </td><td class="postheader" valign="center"><a href="index.html"><font color="#004faf">Home</font></a> · <a href="classes.html"><font color="#004faf">All Classes</font></a> · <a href="mainclasses.html"><font color="#004faf">Main Classes</font></a> · <a href="annotated.html"><font color="#004faf">Annotated</font></a> · <a href="groups.html"><font color="#004faf">Grouped Classes</font></a> · <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> /****************************************************************************
22
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
24
** This file is part of the documentation of the Qt Toolkit.
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.
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.
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.
40
** Contact info@trolltech.com if any conditions of this licensing are
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.
46
****************************************************************************/
48
#include "connectionwidget.h"
50
#include <QtGui>
51
#include <QtSql>
53
ConnectionWidget::ConnectionWidget(QWidget *parent)
56
QVBoxLayout *layout = new QVBoxLayout(this);
57
tree = new QTreeWidget(this);
58
tree->setObjectName(QLatin1String("tree"));
59
tree->setHeaderLabels(QStringList(tr("database")));
60
tree->header()->setResizeMode(QHeaderView::Stretch);
61
QAction *refreshAction = new QAction(tr("Refresh"), tree);
62
connect(refreshAction, SIGNAL(triggered()), SLOT(refresh()));
63
tree->addAction(refreshAction);
64
tree->setContextMenuPolicy(Qt::ActionsContextMenu);
66
layout->addWidget(tree);
68
QMetaObject::connectSlotsByName(this);
71
ConnectionWidget::~ConnectionWidget()
75
static QString qDBCaption(const QSqlDatabase &db)
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());
85
void ConnectionWidget::refresh()
88
QStringList connectionNames = QSqlDatabase::connectionNames();
90
bool gotActiveDb = false;
91
for (int i = 0; i < connectionNames.count(); ++i) {
92
QTreeWidgetItem *root = new QTreeWidgetItem(tree);
93
QSqlDatabase db = QSqlDatabase::database(connectionNames.at(i), false);
94
root->setText(0, qDBCaption(db));
95
if (connectionNames.at(i) == activeDb) {
100
QStringList tables = db.tables();
101
for (int t = 0; t < tables.count(); ++t) {
102
QTreeWidgetItem *table = new QTreeWidgetItem(root);
103
table->setText(0, tables.at(t));
108
activeDb = connectionNames.value(0);
109
setActive(tree->topLevelItem(0));
112
tree->doItemsLayout(); // HACK
115
QSqlDatabase ConnectionWidget::currentDatabase() const
117
return QSqlDatabase::database(activeDb);
120
static void qSetBold(QTreeWidgetItem *item, bool bold)
122
QFont font = item->font(0);
124
item->setFont(0, font);
127
void ConnectionWidget::setActive(QTreeWidgetItem *item)
129
for (int i = 0; i < tree->topLevelItemCount(); ++i) {
130
if (tree->topLevelItem(i)->font(0).bold())
131
qSetBold(tree->topLevelItem(i), false);
137
qSetBold(item, true);
138
activeDb = QSqlDatabase::connectionNames().value(tree->indexOfTopLevelItem(item));
141
void ConnectionWidget::on_tree_itemActivated(QTreeWidgetItem *item, int /* column */)
147
if (!item->parent()) {
150
setActive(item->parent());
151
emit tableActivated(item->text(0));
154
<p /><address><hr /><div align="center">
155
<table width="100%" cellspacing="0" border="0"><tr class="address">
156
<td width="30%">Copyright © 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>