/***** * * TOra - An Oracle Toolkit for DBA's and developers * Copyright (C) 2003-2005 Quest Software, Inc * Portions Copyright (C) 2005 Other Contributors * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; only version 2 of * the License is valid for this program. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * As a special exception, you have permission to link this program * with the Oracle Client libraries and distribute executables, as long * as you follow the requirements of the GNU GPL in regard to all of the * software in the executable aside from Oracle client libraries. * * Specifically you are not permitted to link this program with the * Qt/UNIX, Qt/Windows or Qt Non Commercial products of TrollTech. * And you are not permitted to distribute binaries compiled against * these libraries without written consent from Quest Software, Inc. * Observe that this does not disallow linking to the Qt Free Edition. * * You may link this product with any GPL'd Qt library such as Qt/Free * * All trademarks belong to their respective owners. * *****/ #include "utils.h" #include "toconf.h" #include "toconnection.h" #include "tomain.h" #include "tonoblockquery.h" #include "toresultline.h" #include "tosql.h" #include "totool.h" #include #include "toresultline.moc" toResultLine::toResultLine(QWidget *parent, const char *name) : toLineChart(parent, name) { connect(&Poll, SIGNAL(timeout()), this, SLOT(poll())); LastStamp = 0; Flow = true; Columns = 0; Query = NULL; Started = false; } toResultLine::~toResultLine() { delete Query; } void toResultLine::start(void) { if (!Started) { try { connect(timer(), SIGNAL(timeout()), this, SLOT(refresh())); } TOCATCH Started = true; } } void toResultLine::stop(void) { if (Started) { try { disconnect(timer(), SIGNAL(timeout()), this, SLOT(refresh())); } TOCATCH Started = false; } } void toResultLine::query(const QString &sql, const toQList ¶m, bool first) { if (!handled() || Query) return ; start(); setSQLParams(sql, param); try { First = first; Query = new toNoBlockQuery(connection(), toQuery::Background, sql, param); Poll.start(100); } TOCATCH } void toResultLine::poll(void) { try { if (Query && Query->poll()) { toQDescList desc; if (!Columns) { desc = Query->describe(); Columns = desc.size(); } if (First) { if ( desc.empty() ) desc = Query->describe(); clear(); std::list labels; for (toQDescList::iterator i = desc.begin();i != desc.end();i++) if (i != desc.begin()) labels.insert(labels.end(), (*i).Name); setLabels(labels); } while (Query->poll() && !Query->eof()) { unsigned int num = 0; QString lab = Query->readValue(); num++; std::list vals; while (!Query->eof() && num < Columns) { vals.insert(vals.end(), Query->readValue().toDouble()); num++; } if (Flow) { time_t now = time(NULL); if (now != LastStamp) { if (LastValues.size() > 0) { std::list dispVal; std::list::iterator i = vals.begin(); std::list::iterator j = LastValues.begin(); while (i != vals.end() && j != LastValues.end()) { dispVal.insert(dispVal.end(), (*i - *j) / (now - LastStamp)); i++; j++; } std::list tmp = transform(dispVal); addValues(tmp, lab); } LastValues = vals; LastStamp = now; } } else { std::list tmp = transform(vals); addValues(tmp, lab); } } if (Query->eof()) { Poll.stop(); Columns = 0; delete Query; Query = NULL; update(); } } } catch (const QString &exc) { delete Query; Query = NULL; Poll.stop(); toStatusMessage(exc); } } std::list toResultLine::transform(std::list &input) { return input; } void toResultLine::connectionChanged(void) { toResult::connectionChanged(); clear(); } void toResultLine::addMenues(QPopupMenu *popup) { if (sqlName().length()) { popup->insertSeparator(); popup->insertItem(tr("Edit SQL..."), this, SLOT(editSQL())); } } void toResultLine::editSQL(void) { toMainWidget()->editSQL(sqlName()); }