From 9ad5c7b5e23b4940e7a3ea3ca3a6fb77e6a8fab0 Mon Sep 17 00:00:00 2001 From: tpearson Date: Wed, 20 Jan 2010 02:37:40 +0000 Subject: Updated to final KDE3 ktorrent release (2.2.6) git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/ktorrent@1077377 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- plugins/stats/ChartDrawer.cc | 473 +++++++++++++++++++++++++++++ plugins/stats/ChartDrawer.h | 281 +++++++++++++++++ plugins/stats/ChartDrawerData.cc | 100 ++++++ plugins/stats/ChartDrawerData.h | 123 ++++++++ plugins/stats/Makefile.am | 18 ++ plugins/stats/PeerMonitor.cc | 187 ++++++++++++ plugins/stats/PeerMonitor.h | 123 ++++++++ plugins/stats/StatsCon.cc | 113 +++++++ plugins/stats/StatsCon.h | 94 ++++++ plugins/stats/StatsPluginPrefs.cc | 88 ++++++ plugins/stats/StatsPluginPrefs.h | 66 ++++ plugins/stats/StatsPluginPrefsPage.cc | 29 ++ plugins/stats/StatsPluginPrefsPage.h | 44 +++ plugins/stats/StatsSpd.cc | 138 +++++++++ plugins/stats/StatsSpd.h | 113 +++++++ plugins/stats/ktstatsplugin.desktop | 24 ++ plugins/stats/ktstatsplugin.kcfg | 60 ++++ plugins/stats/sprefwgt.ui | 517 ++++++++++++++++++++++++++++++++ plugins/stats/statsconwgt.ui | 48 +++ plugins/stats/statsplugin.cc | 321 ++++++++++++++++++++ plugins/stats/statsplugin.h | 153 ++++++++++ plugins/stats/statspluginsettings.kcfgc | 7 + plugins/stats/statsspdwgt.ui | 56 ++++ 23 files changed, 3176 insertions(+) create mode 100644 plugins/stats/ChartDrawer.cc create mode 100644 plugins/stats/ChartDrawer.h create mode 100644 plugins/stats/ChartDrawerData.cc create mode 100644 plugins/stats/ChartDrawerData.h create mode 100644 plugins/stats/Makefile.am create mode 100644 plugins/stats/PeerMonitor.cc create mode 100644 plugins/stats/PeerMonitor.h create mode 100644 plugins/stats/StatsCon.cc create mode 100644 plugins/stats/StatsCon.h create mode 100644 plugins/stats/StatsPluginPrefs.cc create mode 100644 plugins/stats/StatsPluginPrefs.h create mode 100644 plugins/stats/StatsPluginPrefsPage.cc create mode 100644 plugins/stats/StatsPluginPrefsPage.h create mode 100644 plugins/stats/StatsSpd.cc create mode 100644 plugins/stats/StatsSpd.h create mode 100644 plugins/stats/ktstatsplugin.desktop create mode 100644 plugins/stats/ktstatsplugin.kcfg create mode 100644 plugins/stats/sprefwgt.ui create mode 100644 plugins/stats/statsconwgt.ui create mode 100644 plugins/stats/statsplugin.cc create mode 100644 plugins/stats/statsplugin.h create mode 100644 plugins/stats/statspluginsettings.kcfgc create mode 100644 plugins/stats/statsspdwgt.ui (limited to 'plugins/stats') diff --git a/plugins/stats/ChartDrawer.cc b/plugins/stats/ChartDrawer.cc new file mode 100644 index 0000000..75142e6 --- /dev/null +++ b/plugins/stats/ChartDrawer.cc @@ -0,0 +1,473 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "ChartDrawer.h" + +#ifdef USE_SOLARIS +#include +int isinf(double x) { return !finite(x) && x==x; } +#endif + + +namespace kt { + +ChartDrawer::ChartDrawer(QWidget *p, wgtsize_t x_max, wgtsize_t y_max, bool autom, const QString & uname) : QWidget(p), mXMax(x_max), mYMax(y_max), mAutoMax(autom), + mUnitName(uname), mMMode(MaxModeExact) +{ + setBackgroundColor("white"); +} + +ChartDrawer::~ChartDrawer() +{ + QToolTip::remove(this); +} + +ChartDrawer::wgtsize_t ChartDrawer::GetXMax() const +{ + return mXMax; +} + +ChartDrawer::wgtsize_t ChartDrawer::GetYMax() const +{ + return mYMax; +} + +void ChartDrawer::SetXMax(const wgtsize_t x) +{ + mXMax = x; + + for(size_t i = 0; i < mEls.size(); i++) + { + mEls[i].pmVals -> resize(x, 0.0); + } +} + +void ChartDrawer::SetYMax(const wgtsize_t y) +{ + mYMax = y; +} + +inline ChartDrawer::wgtsize_t ChartDrawer::GetYScale() const +{ + return height() / 8; +} + + +inline ChartDrawer::wgtunit_t ChartDrawer::TrY(const ChartDrawer::wgtunit_t y) const +{ + return height() - y; +} + +void ChartDrawer::paintEvent ( QPaintEvent *) +{ + QPainter pnt( this ); + + DrawScale(pnt); + DrawFrame(pnt); + DrawChart(pnt); + +} + +inline ChartDrawer::wgtunit_t ChartDrawer::height() const +{ + return QWidget::height() - 15; +} + +inline ChartDrawer::wgtunit_t ChartDrawer::width() const +{ + return QWidget::width() - 65; +} + +void ChartDrawer::DrawFrame(QPainter & rPnt ) +{ + QPen op = rPnt.pen(); + rPnt.setPen(QPen("#000", 3)); + + rPnt.drawLine(0, TrY(0), width()+3, TrY(0)); + rPnt.drawLine(width()+1, TrY(0), width()+1, TrY(QWidget::height())); + + QFont oldf(rPnt.font()); + QFont newf(oldf); + newf.setWeight(QFont::Bold); + newf.setPointSize(10); + newf.setUnderline(1); + + rPnt.setFont(newf); + rPnt.drawText(width() + 30, TrY(-7), mUnitName); + rPnt.setFont(oldf); + + rPnt.setPen(op); +} + +void ChartDrawer::DrawScale(QPainter & rPnt ) +{ + + if(!mYMax) + { + return; + } + + QPen op = rPnt.pen(); + QPen ep("#eee", 1, Qt::DashLine); + QPen lp("#666", 2, Qt::DotLine); + QPen tp("#000"); + + rPnt.setPen(ep); + + for(wgtsize_t i = 1; i < width(); i += 10) + { + rPnt.drawLine(i, TrY(0), i, TrY(height())); + } + + for(wgtsize_t i = 0; i < height(); i += 10) + { + rPnt.drawLine(0, TrY(i), width(), TrY(i)); + } + + rPnt.setPen(lp); + rPnt.drawLine(0, TrY(height() - 10), width(), TrY(height() - 10)); + rPnt.setPen(tp); + rPnt.drawText(width() + 4, TrY(height() - 10) + 4, QString::number (mYMax)); + + for(wgtsize_t i = 0; i < height() - 15 ; i += GetYScale()) + { + rPnt.setPen(lp); + rPnt.drawLine(0, TrY(i), width(), TrY(i)); + rPnt.setPen(tp); + rPnt.drawText(width() + 4, TrY(i) + 4, QString::number ( (mYMax / 8.0 ) * ( i / static_cast(GetYScale() )), 'f', 1 ) ); + } + + rPnt.setPen(op); +} + +void ChartDrawer::DrawChart(QPainter & rPnt) +{ + + QPen op = rPnt.pen(); + + uint32_t skip_max = 0; + + for(size_t i = 0; i < mEls.size(); i++) + { + rPnt.setPen( *mEls[i].GetPen() ); + + for(size_t j = 1; j < mEls[i].pmVals -> size() - 1; j++) + { + rPnt.drawLine( + FindXScreenCoords(j-1), + TrY(FindYScreenCoords(mEls[i].pmVals -> at(j-1))), + FindXScreenCoords(j), + TrY(FindYScreenCoords(mEls[i].pmVals -> at(j))) + ); + } +// + rPnt.drawLine( + FindXScreenCoords(mEls[i].pmVals -> size() - 2), + TrY(FindYScreenCoords(mEls[i].pmVals -> at(mEls[i].pmVals -> size() - 2))), + width(), + TrY(FindYScreenCoords(mEls[i].pmVals -> at(mEls[i].pmVals -> size() - 1))) + ); + + // -------------------- + // Line on top + // ------------ + QPen myop(rPnt.pen()); + QPen topl(myop); + topl.setStyle(Qt::DotLine); + rPnt.setPen(topl); + rPnt.drawLine(0, TrY(FindYScreenCoords(mEls[i].pmVals -> at(mEls[i].pmVals -> size() - 1))), width(), TrY(FindYScreenCoords(mEls[i].pmVals -> at(mEls[i].pmVals -> size() - 1))) ); + rPnt.setPen(myop); + + QFont oldf(rPnt.font()); + QFont newf(oldf); + newf.setWeight(QFont::Bold); + newf.setPointSize(8); + + rPnt.setFont(newf); + rPnt.drawText(5 + (i * 50), TrY(FindYScreenCoords(mEls[i].pmVals -> at(mEls[i].pmVals -> size() - 1))) + 11, QString::number (mEls[i].pmVals -> at(mEls[i].pmVals -> size() - 1), 'f', 2 ) ); + + + //------------------ + // max + //------------------ + + if(mMarkMax[i]) + { + rPnt.setPen(topl); + std::pair max = mEls[i] . Max(); + + rPnt.drawLine( + FindXScreenCoords(max.second), TrY(0), FindXScreenCoords(max.second), TrY(height()) + ); + + rPnt.setPen(myop); + + rPnt.setFont(newf); + QString maxv(QString::number (max.first, 'f', 2)); + + if(FindXScreenCoords(max.second) < 35) + { + rPnt.drawText(FindXScreenCoords(max.second) + 5, TrY(height() - (10 * (i - skip_max)) ) + 10, maxv ) ; + } else { + rPnt.drawText(FindXScreenCoords(max.second) - 35 , TrY(height() - (10 * (i - skip_max)) ) + 10, maxv ) ; + } + } else { + skip_max++; + } + + rPnt.setFont(oldf); + rPnt.setPen(op); + } + + rPnt.setPen(op); +} + +inline ChartDrawer::wgtunit_t ChartDrawer::FindXScreenCoords(const double x) const +{ + return static_cast((width() / static_cast(mXMax)) * x) ; +} + +inline ChartDrawer::wgtunit_t ChartDrawer::FindYScreenCoords(const double y) const +{ + return static_cast(((height()) / static_cast(mYMax)) * y) ; +} + +void ChartDrawer::EnableAutoMax(bool a) +{ + mAutoMax = a; +} + +void ChartDrawer::AddValue(const size_t idx, const double val, bool u ) +{ + + if( idx >= mEls.size() ) + { + return; + } + + ChartDrawerData::val_t::iterator it = mEls[idx].pmVals -> begin(); + + while(it != mEls[idx] .pmVals -> end() ) + { + *it = *(it + 1); + it++; + } + +#ifdef USE_SOLARIS + if(isnand(val) || (isinf(val))) +#else + if(std::isnan(val) || (std::isinf(val))) +#endif + { + *(mEls[idx].pmVals -> end() -1) = 0.0; + } else { + *(mEls[idx].pmVals -> end() -1) = val; + } + + if(mAutoMax) + { + if( (mMMode == MaxModeTop) && (val > mYMax) ) + { + mYMax = static_cast(val) + 3; + + } else if(mMMode == MaxModeExact) { + FindSetMax(); + } + } + + if(u) + { + update(); + } + +} + +void ChartDrawer::AddValues(ChartDrawerData Cdd, const bool max) +{ + if(Cdd.pmVals -> size() != mXMax) + { + Cdd.pmVals -> resize(mXMax, 0.0); + } + + mEls.push_back(Cdd); + mMarkMax.push_back(max); + + MakeLegendTooltip(); +} + +void ChartDrawer::AddValues(ChartDrawerData Cdd, const size_t idx, const bool max) +{ + if(Cdd.pmVals -> size() != mXMax) + { + Cdd.pmVals -> resize(mXMax, 0.0); + } + + if(idx >= mEls.size()) + { + mEls.push_back(Cdd); + } else { + mEls.insert(mEls.begin() + idx, Cdd); + } + + if(idx >= mMarkMax.size()) + { + mMarkMax.push_back(max); + } else { + mMarkMax.insert(mMarkMax.begin() + idx, max); + } + + MakeLegendTooltip(); +} + +void ChartDrawer::AddValuesCnt(const QString & rN, const bool max) +{ + mEls.push_back(ChartDrawerData(mXMax, rN)); + mMarkMax.push_back(max); + + MakeLegendTooltip(); +} + +void ChartDrawer::AddValuesCnt(const QPen & rP, const QString & rN, const bool max) +{ + mEls.push_back(ChartDrawerData(rP, mXMax, rN)); + mMarkMax.push_back(max); + + MakeLegendTooltip(); +} + +void ChartDrawer::SetUnitName(const QString & rN) +{ + mUnitName = rN; +} + +QString ChartDrawer::GetUnitName() const +{ + return mUnitName; +} + +void ChartDrawer::mouseDoubleClickEvent ( QMouseEvent * evt ) +{ + FindSetMax(); + + emit DoubleClicked(evt); +} + +void ChartDrawer::EnableMaxDrawAt(const size_t at, const bool e) +{ + if(at >= mMarkMax.size()) + { + return; + } + + mMarkMax[at] = e; +} + +void ChartDrawer::RemoveValuesCnt(const size_t idx) +{ + if(idx >= mEls.size()) + { + return; + } + + mEls.erase(mEls.begin() + idx); + + if(idx <= mMarkMax.size()) + { + mMarkMax.erase(mMarkMax.begin() + idx); + } + + MakeLegendTooltip(); + +} + +void ChartDrawer::Zero(const size_t idx) +{ + if(idx >= mEls.size()) + { + return; + } + + std::fill(mEls[idx].pmVals -> begin(), mEls[idx].pmVals -> end(), 0.0); + + if(mAutoMax) + { + mYMax = 1; + } +} + +void ChartDrawer::MakeLegendTooltip() +{ + QToolTip::remove(this); + + QString helpstr(QString("%1:

").arg(i18n("Legend"))); + QMimeSourceFactory* factory = QMimeSourceFactory::defaultFactory(); + std::vector img; + + for(size_t i = 0; i < mEls.size(); i++) + { + img.push_back(QImage(16,16, 32)); + img[i].fill(mEls[i].GetPen() -> color().pixel()); + + for(uint8_t px = 0; px < 16; px++) + { + img[i].setPixel(px, 0, 0); //t + img[i].setPixel(0, px, 0); //l + img[i].setPixel(px, 15, 0); //b + img[i].setPixel(15, px, 0); //r + } + + factory->setImage(mEls[i].GetName().replace(' ', '_') + "-" + QString::number(i), img[i]); + helpstr += QString("  -  %2
").arg(mEls[i].GetName().replace(" ", "_") + "-" + QString::number(i)).arg( mEls[i].GetName() ); + } + + QToolTip::add(this, helpstr); +} + +void ChartDrawer::FindSetMax() +{ + wgtsize_t mymax = 1; + + for(val_t::const_iterator it = mEls.begin(); it != mEls.end(); ++it) + { + for(ChartDrawerData::val_t::const_iterator subit = it -> pmVals -> begin(); subit != it -> pmVals -> end(); ++subit) + { + if ( (*subit) > mymax ) + { + mymax = static_cast(*subit) + 3; + } + } + } + + mYMax = mymax; +} + +void ChartDrawer::SetMaxMode(const MaxMode mm) +{ + mMMode = mm; +} + +ChartDrawer::MaxMode ChartDrawer::GetMaxMode() const +{ + return mMMode; +} + +} //NS end + +#include "ChartDrawer.moc" diff --git a/plugins/stats/ChartDrawer.h b/plugins/stats/ChartDrawer.h new file mode 100644 index 0000000..741240e --- /dev/null +++ b/plugins/stats/ChartDrawer.h @@ -0,0 +1,281 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef CHARTDRAWER_H_ +#define CHARTDRAWER_H_ + +#include +#include +#include +#include +#include +#include + +#include + +#include +#include +#include //fill + +#include "ChartDrawerData.h" + +namespace kt { + +/** +\brief Widget for drawing line charts +\author Krzysztof Kundzicz +*/ +class ChartDrawer : public QWidget +{ + Q_OBJECT + + public: + ///Type used as widget size unit + typedef uint32_t wgtsize_t; + ///Type used as unit in chart + typedef int64_t wgtunit_t; + /** + \brief Type used for data storing + \sa ChartDrawerData + */ + typedef std::vector val_t; + ///Determines max mode + enum MaxMode { MaxModeTop, MaxModeExact }; + + private: + ///Maximum X value + wgtsize_t mXMax; + ///Maximum Y value + wgtsize_t mYMax; + ///Auto maximum setting + bool mAutoMax; + ///Chart data + val_t mEls; + ///Name of the chart unit + QString mUnitName; + ///Mark max + std::vector mMarkMax; + ///Max mode + MaxMode mMMode; + + ///Paint event handler + void paintEvent ( QPaintEvent * ); + /** + \brief Draws chart's frame + \param rPnt Painter on which things will be drawn + */ + void DrawFrame(QPainter &rPnt); + /** + \brief Draws chart's scale + \param rPnt Painter on which things will be drawn + */ + void DrawScale(QPainter &rPnt); + /** + \brief Draws chart + \param rPnt Painter on which things will be drawn + */ + void DrawChart(QPainter &rPnt); + + /** + \brief Gets distance between two values on OY + \return Distance + */ + inline wgtsize_t GetYScale() const; + + /** + \brief Translates widget Y coord to cartesian + \param y Coord + \return Coord + */ + inline wgtunit_t TrY(const wgtunit_t y) const; + /** + \brief Returns charts height + \return Height + + Return only height of the chart's inside the frame — not the whole widget's + */ + inline wgtunit_t height() const; + /** + \brief Returns charts width + \return Width + + Return only width of the chart's inside the frame — not the whole widget's + */ + inline wgtunit_t width() const; + + /** + \brief Finds screen X coord on the widget + \param x Coord + \return Screen coord + \warning Thera are rounding errors + */ + inline wgtunit_t FindXScreenCoords(const double x) const; + /** + \brief Finds screen Y coord on the widget + \param y Coord + \return Screen coord + \warning Thera are rounding errors + */ + inline wgtunit_t FindYScreenCoords(const double y) const; + + ///Sets tooltip with legend + void MakeLegendTooltip(); + + public: + /** + \brief Widget's constructor + \param p Parent + \param x_max Maximum X size + \param y_max Maximum Y size + \param autom Whether athomagically set the maximum Y size + \param uname Unit name + */ + ChartDrawer(QWidget *p = 0, wgtsize_t x_max = 2, wgtsize_t y_max = 1, bool autom = true, const QString & uname = "KB/s"); + ~ChartDrawer(); + + /** + \brief Gets maximum X + \return Maximum X + */ + wgtsize_t GetXMax() const; + /** + \brief Gets maximum Y + \return Maximum Y + */ + wgtsize_t GetYMax() const; + + /** + \brief Sets the units name + \param rN Name + + \note It'l be drawn on the chart + */ + void SetUnitName(const QString & rN); + + /** + \brief Gets unit name + \return name + */ + QString GetUnitName() const; + /** + \brief Doubleclick handler + \param evt Mouse event + */ + void mouseDoubleClickEvent ( QMouseEvent * evt ); + + /** + \brief Gets mode of OY axis maximum drawing + \return mode + */ + MaxMode GetMaxMode() const; + + + public slots: + /** + \brief Adds value to given dataset + \param idx Dataset index + \param val Value to add + \param update Whether update widget after adding + */ + void AddValue(const size_t idx, const double val, bool update = true); + /** + \brief Adds dataset + \param Cdd Dataset + \param max Whether mark maximum of this dataset + */ + void AddValues(ChartDrawerData Cdd, const bool max = true); + /** + \brief Adds dataset + \param Cdd Dataset + \param idx Where + \param max Whether mark maximum of this dataset + */ + void AddValues(ChartDrawerData Cdd, const size_t idx, const bool max = true); + /** + \brief Adds empty dataset + \param rN Set's data name + \param max Whether mark maximum of this dataset + */ + void AddValuesCnt(const QString & rN, const bool max = true); + /** + \brief Adds empty dataset + \param rP Pen that will be used to drawing + \param rN Dataset name + \param max Whether mark maximum of this dataset + */ + void AddValuesCnt(const QPen & rP, const QString & rN, const bool max = true ); + + /** + \brief Removes dataset + \param idx Dataset index + */ + void RemoveValuesCnt(const size_t idx); + /** + \brief Zeroes values + \param idx Dataset index + */ + void Zero(const size_t idx); + + ///Finds and sets maximum + void FindSetMax(); + + /** + \brief Toggles marking of the maximum Y value on given dataset + \param at dataset + \param e Toggle? + */ + void EnableMaxDrawAt(const size_t, const bool); + /** + \brief Toggles automatic max Y scale settin + \param a Toggle? + */ + void EnableAutoMax(bool a); + + /** + \brief Sets maximum X + \param x X size + */ + void SetXMax(const wgtsize_t x); + /** + \brief Sets maximum Y + \param y Y size + */ + void SetYMax(const wgtsize_t x); + + /** + \brief Sets mode of max of OY axis + \param mm Mode + */ + void SetMaxMode(const MaxMode mm); + + + signals: + /** + \brief Emited when widget is doubleclicked + \param evt Mouse event + */ + void DoubleClicked(QMouseEvent * evt); + +}; + +} + +#endif + diff --git a/plugins/stats/ChartDrawerData.cc b/plugins/stats/ChartDrawerData.cc new file mode 100644 index 0000000..9a49a95 --- /dev/null +++ b/plugins/stats/ChartDrawerData.cc @@ -0,0 +1,100 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "ChartDrawerData.h" + +namespace kt { + +ChartDrawerData::ChartDrawerData(const QString & rN) : pmQp(new QPen("#000", 1, Qt::SolidLine)), pmVals(new val_t(2, 0.0)), mName(rN) +{ +} + +ChartDrawerData::ChartDrawerData(const size_t s, const QString & rN) : pmQp(new QPen("#000", 1, Qt::SolidLine)), pmVals(new val_t(s, 0.0)), mName(rN) +{ +} + +ChartDrawerData::ChartDrawerData(const QPen & rQp, const QString & rN) : pmQp(new QPen(rQp)), pmVals(new val_t(2, 0.0)), mName(rN) +{ +} + +ChartDrawerData::ChartDrawerData(const QPen & rQp, const size_t s, const QString & rN) : pmQp(new QPen(rQp)), pmVals(new val_t(s, 0.0)), mName(rN) +{ +} + +ChartDrawerData::ChartDrawerData(const ChartDrawerData & rS) +{ + pmQp = new QPen(*rS.pmQp); + pmVals = new val_t(*rS.pmVals); + mName = rS.mName; +} + +ChartDrawerData::~ChartDrawerData() +{ + delete pmQp; + delete pmVals; +} + +const ChartDrawerData::val_t * ChartDrawerData::GetVals() const +{ + return pmVals; +} + +const QPen * ChartDrawerData::GetPen() const +{ + return pmQp; +} + +void ChartDrawerData::SetPen(const QPen & rQp) +{ + delete pmQp; + pmQp = new QPen(rQp); +} + +std::pair ChartDrawerData::Max() const +{ + + double max = 0.0; + size_t cpos = 0; + size_t maxpos = 0; + + for(val_t::iterator it = pmVals -> begin(); it != pmVals -> end(); it++) + { + if(max <= *it) + { + max = *it; + maxpos = cpos; + } + + cpos++; + } + + return std::make_pair(max, maxpos); +} + +QString ChartDrawerData::GetName() const +{ + return mName; +} +void ChartDrawerData::SetName( const QString & rN ) +{ + mName = rN; +} + +} // NS end diff --git a/plugins/stats/ChartDrawerData.h b/plugins/stats/ChartDrawerData.h new file mode 100644 index 0000000..561e76a --- /dev/null +++ b/plugins/stats/ChartDrawerData.h @@ -0,0 +1,123 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef CHARTDRAWERDATA_H_ +#define CHARTDRAWERDATA_H_ + +#include +#include +#include + +namespace kt { + +class ChartDrawer; + +/** +\brief Container for data used by ChartDrawer +\author Krzysztof Kundzicz +*/ +class ChartDrawerData +{ + friend class ChartDrawer; + + public: + ///Type for stroring values + typedef std::vector val_t; + + private: + ///Pen used for drawing + QPen * pmQp; + ///Values + val_t * pmVals; + ///Name of set + QString mName; + + public: + /** + \brief Constructor + \param rN Name + */ + ChartDrawerData(const QString & rN); + /** + \brief Copy constructor + \param rS Source + */ + ChartDrawerData(const ChartDrawerData &); + /** + \brief Constructor + \param s Size + \param rN Name + */ + ChartDrawerData(const size_t s, const QString & rN); + /** + \brief Constructor + \param rQp Pen used for drawing + \param rN Name + */ + ChartDrawerData(const QPen & rQp, const QString & rN); + /** + \brief Constructor + \param rQp Pen used for drawing + \param s Size + \param rN Name + */ + ChartDrawerData(const QPen & rQp, const size_t s, const QString & rN); + + ///Destructor + ~ChartDrawerData(); + + /** + \brief Gets values + \return Pointer to values container + */ + const val_t * GetVals() const; + /** + \brief Gets pen + \return Pointer pen + */ + const QPen * GetPen() const; + /** + \brief Gets name + \return Name + */ + QString GetName() const; + + /** + \brief Sets pen + \param rQp Pen + */ + void SetPen(const QPen & rQp); + /** + \brief Sets name + \param rN Name + */ + void SetName( const QString & rN ); + + /** + \brief Finds maximum value + \return Pair with value and position + */ + std::pair Max() const; + +}; + +} + +#endif diff --git a/plugins/stats/Makefile.am b/plugins/stats/Makefile.am new file mode 100644 index 0000000..e04f417 --- /dev/null +++ b/plugins/stats/Makefile.am @@ -0,0 +1,18 @@ +INCLUDES = -I$(top_builddir)/libktorrent -I$(top_builddir)/ktorrent/libktorrent \ + -I$(srcdir)/../../libktorrent $(all_includes) + +METASOURCES = AUTO + +kde_module_LTLIBRARIES = ktstatsplugin.la + +ktstatsplugin_la_LDFLAGS = -module $(KDE_PLUGIN) $(LIB_KDECORE) $(LIB_KDEUI) $(LIB_KPARTS) $(all_libraries) +ktstatsplugin_la_SOURCES = ChartDrawerData.cc ChartDrawer.cc statsspdwgt.ui statsconwgt.ui StatsSpd.cc StatsCon.cc sprefwgt.ui statspluginsettings.kcfgc \ + StatsPluginPrefsPage.cc StatsPluginPrefs.cc statsplugin.cc + +ktstatsplugin_la_LIBADD = $(LIB_QT) ../../libktorrent/libktorrent.la + +noinst_HEADERS = ChartDrawerData.h ChartDrawer.h StatsSpd.h StatsCon.h StatsPluginPrefsPage.h StatsPluginPrefs.h statsplugin.h + +kde_services_DATA = ktstatsplugin.desktop +kde_kcfg_DATA = ktstatsplugin.kcfg +KDE_CXXFLAGS = $(USE_EXCEPTIONS) $(USE_RTTI) diff --git a/plugins/stats/PeerMonitor.cc b/plugins/stats/PeerMonitor.cc new file mode 100644 index 0000000..a4cf449 --- /dev/null +++ b/plugins/stats/PeerMonitor.cc @@ -0,0 +1,187 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "PeerMonitor.h" + +namespace kt { + +PeerMonitor::PeerMonitor(kt::TorrentInterface * pTi, std::map * pM) : kt::MonitorInterface(), QObject(), pmTorIface(pTi), pmPeerMMgr(pM) +{ + +} + +PeerMonitor::~PeerMonitor() +{ +} + +void PeerMonitor::peerAdded (kt::PeerInterface *peer) +{ + QMutexLocker lock(&mtx); + + mPeers.push_back( peer ); +} + +void PeerMonitor::peerRemoved (kt::PeerInterface *peer) +{ + + QMutexLocker lock(&mtx); + + data_t::iterator it = std::find(mPeers.begin(), mPeers.end(), peer); + + if(it != mPeers.end()) + { + mPeers.erase(it); + // *it = 0; + } + +} + +void PeerMonitor::downloadStarted (kt::ChunkDownloadInterface *) +{ + +} + +void PeerMonitor::downloadRemoved (kt::ChunkDownloadInterface *) +{ + +} + +void PeerMonitor::stopped () +{ + QMutexLocker lock(&mtx); + + std::fill(mPeers.begin(), mPeers.end(), static_cast( 0 ) ); +// mPeers.clear(); +} + +void PeerMonitor::destroyed () +{ + if(pmPeerMMgr -> find(pmTorIface -> getInfoHash()) != pmPeerMMgr -> end() ) + { + pmTorIface -> setMonitor(0); + pmPeerMMgr -> erase(pmTorIface -> getInfoHash()); + delete this; + } + +} + +double PeerMonitor::LeechersUpSpeed() +{ + QMutexLocker lock(&mtx); + + double spd = 0.0; + + //without it'll segfault/SIGABRT on stop as in meantime the iterator from + // mPeers will be invalidated + + for( data_t::const_iterator it = mPeers.begin(); it != mPeers.end(); it++) + { + if((it != mPeers.end()) && *it && ( (*it) -> getStats().perc_of_file < 100.0) ) + { + spd += (*it) -> getStats().download_rate; + } + } + + return spd; +} + +double PeerMonitor::LeechersDownSpeed() +{ + QMutexLocker lock(&mtx); + + double spd = 0.0; + + + for( data_t::const_iterator it = mPeers.begin(); it != mPeers.end(); it++) + { + if((it != mPeers.end()) && *it && ( (*it) -> getStats().perc_of_file < 100.0) ) + { + spd += (*it) -> getStats().upload_rate; + } + } + + return spd; + +} + +double PeerMonitor::SeedersUpSpeed() +{ + QMutexLocker lock(&mtx); + + double spd = 0.0; + + + for( data_t::const_iterator it = mPeers.begin(); it != mPeers.end(); it++) + { + if((it != mPeers.end()) && *it && ( (*it) -> getStats().perc_of_file == 100.0) ) + { + spd += (*it) -> getStats().download_rate; + } + + } + + return spd; + +} + +uint64_t PeerMonitor::GetLeechers() +{ + QMutexLocker lock(&mtx); + + uint64_t l = 0; + + + for( data_t::const_iterator it = mPeers.begin(); it != mPeers.end(); it++) + { + if((it != mPeers.end()) && *it && ( (*it) -> getStats().perc_of_file != 100.0) ) + { + l++; + } + + } + + return l; +} + +uint64_t PeerMonitor::GetSeeders() +{ + QMutexLocker lock(&mtx); + + uint64_t s = 0; + + + for( data_t::const_iterator it = mPeers.begin(); it != mPeers.end(); it++) + { + if((it != mPeers.end()) && *it && ( (*it) -> getStats().perc_of_file == 100) ) + { + s++; + } + + } + + return s; +} + +kt::TorrentInterface * PeerMonitor::GetTorIface() const +{ + return pmTorIface; +} + +} //NS end diff --git a/plugins/stats/PeerMonitor.h b/plugins/stats/PeerMonitor.h new file mode 100644 index 0000000..d1ef4fc --- /dev/null +++ b/plugins/stats/PeerMonitor.h @@ -0,0 +1,123 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef PEERMONITOR_H_ +#define PEERMONITOR_H_ + +#include + +#include +#include +#include +#include + +#include +#include +#include + +namespace kt { + +/** +\brief Monitors peers +\author Krzysztof Kundzicz + +Used for peers statistics + +\warning Don't use it, as There Can Be Only One™ and the infowidgetplugin relays on it +*/ + +class PeerMonitor : public MonitorInterface, public QObject +{ + public: + ///Type of conteiner of pointers to peers + typedef std::list data_t; + + private: + /** + \brief Mutex + + Used for locking conteiner with pointers to peers + */ + QMutex mtx; + ///Container with pointers to peers + data_t mPeers; + ///Monitored torrent + TorrentInterface * pmTorIface; + /** + \brief Pointer to PeerMonitor „manager” + + \li \c Key: Monitored torrent hash + \li \c Value \c type: Pointer to peer monitor + */ + std::map *pmPeerMMgr; + + public: + /** + \brief Constructor + \param pTi Pointer to monitored torrent + \param pM Pointer to PeerMonitor „manager” + */ + PeerMonitor(TorrentInterface * pTi, std::map * pM); + virtual ~PeerMonitor(); + + virtual void peerAdded (PeerInterface *peer); + virtual void peerRemoved (PeerInterface *peer); + virtual void downloadStarted (ChunkDownloadInterface *cd); + virtual void downloadRemoved (ChunkDownloadInterface *cd); + virtual void stopped(); + virtual void destroyed () ; + + /** + \brief Gets speed @ which leechers are uploading to us + \return Speed + */ + double LeechersUpSpeed() ; + /** + \brief Gets speed @ which leechers are downloading from us + \return Speed + */ + double LeechersDownSpeed(); + /** + \brief Gets speed @ which seeders are uploading to us + \return Speed + */ + double SeedersUpSpeed() ; + /** + \brief Gets leechers count to which we are connected + \return Count + */ + uint64_t GetLeechers() ; + /** + \brief Gets seeders count to which we are connected + \return Count + */ + uint64_t GetSeeders() ; + + /** + \brief Gets pointer to monitored torrent + \return Pointer to monitored torrent + */ + TorrentInterface * GetTorIface() const; + +}; + +} + +#endif diff --git a/plugins/stats/StatsCon.cc b/plugins/stats/StatsCon.cc new file mode 100644 index 0000000..069ba75 --- /dev/null +++ b/plugins/stats/StatsCon.cc @@ -0,0 +1,113 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "StatsCon.h" + +namespace kt { + +StatsCon::StatsCon(QWidget * p) : StatsConWgt(p), pmPeersConCht(new ChartDrawer(PeersConGbw, StatsPluginSettings::connectionsMeasurements())), + pmDHTCht(new ChartDrawer(DHTGbw, StatsPluginSettings::dHTMeasurements())) +{ + PeersConGbw->setColumnLayout(0, Qt::Vertical ); + PeersConGbw->layout()->setSpacing( 6 ); + PeersConGbw->layout()->setMargin( 11 ); + + pmPeersConLay = new QVBoxLayout(PeersConGbw -> layout()); + + DHTGbw->setColumnLayout(0, Qt::Vertical ); + DHTGbw->layout()->setSpacing( 6 ); + DHTGbw->layout()->setMargin( 11 ); + + pmDHTLay = new QVBoxLayout(DHTGbw -> layout()); + + //------------- + + pmPeersConLay -> addWidget(pmPeersConCht); + pmDHTLay -> addWidget(pmDHTCht); + + //----------- + + pmPeersConCht -> SetUnitName("n"); + + pmPeersConCht -> AddValuesCnt(QPen("#f00"), i18n("Leechers connected")); + pmPeersConCht -> AddValuesCnt(QPen("#900"), i18n("Leechers in swarms")); + pmPeersConCht -> AddValuesCnt(QPen("#00f"), i18n("Seeders connected")); + pmPeersConCht -> AddValuesCnt(QPen("#009"), i18n("Seeders in swarms")); + pmPeersConCht -> AddValuesCnt(QPen("#0a0"), i18n("Average connected leechers per torrent")); + pmPeersConCht -> AddValuesCnt(QPen("#060"), i18n("Average connected seeders per torrent")); + pmPeersConCht -> AddValuesCnt(QPen("#099"), i18n("Average connected leechers per running torrent")); + pmPeersConCht -> AddValuesCnt(QPen("#055"), i18n("Average connected seeders per running torrent")); + + + pmDHTCht -> SetUnitName("n"); + + pmDHTCht -> AddValuesCnt(QPen("#f00"), i18n("Nodes")); + pmDHTCht -> AddValuesCnt(QPen("#00f"), i18n("Tasks")); +} + +StatsCon::~StatsCon() +{ + delete pmPeersConCht; + delete pmDHTCht; + + delete pmPeersConLay; + delete pmDHTLay; +} + +void StatsCon::AddPeersConVal(const size_t idx, const double val) +{ + pmPeersConCht -> AddValue(idx, val , false ); +} + +void StatsCon::AddDHTVal(const size_t idx, const double val) +{ + pmDHTCht -> AddValue(idx, val, false); +} + +void StatsCon::UpdateCharts() +{ + pmPeersConCht -> update(); + pmDHTCht -> update(); +} + +void StatsCon::ZeroPeersConn(const size_t idx) +{ + pmPeersConCht -> Zero(idx); +} + +void StatsCon::ChangeConnMsmtCnt(const size_t cnt) +{ + pmPeersConCht -> SetXMax(cnt); +} + +void StatsCon::ChangeDHTMsmtCnt(const size_t cnt) +{ + pmDHTCht -> SetXMax(cnt); +} + +void StatsCon::ChangeChartsMaxMode(const ChartDrawer::MaxMode mm) +{ + pmPeersConCht -> SetMaxMode(mm); + pmDHTCht -> SetMaxMode(mm); +} + +} //NS + +#include "StatsCon.moc" diff --git a/plugins/stats/StatsCon.h b/plugins/stats/StatsCon.h new file mode 100644 index 0000000..9d60048 --- /dev/null +++ b/plugins/stats/StatsCon.h @@ -0,0 +1,94 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef STATSCON_H_ +#define STATSCON_H_ + +#include +#include +#include +#include + +#include "statspluginsettings.h" +#include "statsconwgt.h" +#include "ChartDrawer.h" + +namespace kt { + +class StatsCon : public StatsConWgt +{ + Q_OBJECT + private: + ///Layout of peers connections + QVBoxLayout * pmPeersConLay; + ///Layout of DHT stats + QVBoxLayout * pmDHTLay; + + ///Chart widget of peers connted + ChartDrawer * pmPeersConCht; + ///Chart widget of DHT + ChartDrawer * pmDHTCht; + + public: + StatsCon(QWidget * p = 0); + virtual ~StatsCon(); + /** + \brief Adds value to peers connections chart + \param idx Dataset index + \param val Value + */ + void AddPeersConVal(const size_t idx, const double val); + /** + \brief Adds value to DHT chart + \param idx Dataset index + \param val Value + */ + void AddDHTVal(const size_t idx, const double val); + + /** + \brief Zeroes data on given idx @ peers connections chart + \param idx Dataset index + */ + void ZeroPeersConn(const size_t idx); + + /** + \brief Changes connections chart's measurments count + \param cnt Measurements + */ + void ChangeConnMsmtCnt(const size_t cnt); + /** + \brief Changes DHT chart's measurments count + \param cnt Measurements + */ + void ChangeDHTMsmtCnt(const size_t cnt); + /** + \brief Changes charts OY axis maximum mode + \param mm Mode + */ + void ChangeChartsMaxMode(const ChartDrawer::MaxMode mm); + public slots: + ///Updates charts + void UpdateCharts(); + +}; + +} // NS + +#endif diff --git a/plugins/stats/StatsPluginPrefs.cc b/plugins/stats/StatsPluginPrefs.cc new file mode 100644 index 0000000..07cfa23 --- /dev/null +++ b/plugins/stats/StatsPluginPrefs.cc @@ -0,0 +1,88 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "StatsPluginPrefs.h" + +namespace kt { + +StatsPluginPrefs::StatsPluginPrefs() : PrefPageInterface(i18n("Statistics"), i18n("Statistics options"), KGlobal::iconLoader()->loadIcon("ktimemon",KIcon::NoGroup)), pmUi(0) +{ +} + +StatsPluginPrefs::~StatsPluginPrefs() +{ +} + +bool StatsPluginPrefs::apply () +{ + StatsPluginSettings::setUpdateChartsEveryGuiUpdates(pmUi -> GuiUpdatesSbw -> value()); + StatsPluginSettings::setGatherDataEveryMs(pmUi -> DataIvalSbw -> value()); + StatsPluginSettings::setPeersSpeedDataIval(pmUi -> PeersSpdUpdIvalSbw -> value()); + + StatsPluginSettings::setPeersSpeed(pmUi -> PeersSpdCbw -> isChecked()); + StatsPluginSettings::setDrawSeedersInSwarms(pmUi -> ConnSdrInSwaCbw -> isChecked()); + StatsPluginSettings::setDrawLeechersInSwarms(pmUi -> ConnLchInSwaCbw -> isChecked()); + + StatsPluginSettings::setDownloadMeasurements(pmUi -> DownloadMrmtSbw -> value()); + StatsPluginSettings::setPeersSpeedMeasurements(pmUi -> PeersSpdMrmtSbw -> value()); + StatsPluginSettings::setUploadMeasurements(pmUi -> UploadMrmtSbw -> value()); + StatsPluginSettings::setConnectionsMeasurements(pmUi -> ConnsMrmtSbw -> value()); + StatsPluginSettings::setDHTMeasurements(pmUi -> DHTMrmtSbw -> value()); + StatsPluginSettings::setMaxSpdMode(pmUi -> MaxSpdModeCbw -> currentItem()); + + StatsPluginSettings::writeConfig(); + + emit Applied(); + + return true; +} + +void StatsPluginPrefs::createWidget (QWidget *parent) +{ + pmUi = new StatsPluginPrefsPage(parent); +} + +void StatsPluginPrefs::updateData () +{ + pmUi -> GuiUpdatesSbw -> setValue(StatsPluginSettings::updateChartsEveryGuiUpdates()); + pmUi -> DataIvalSbw -> setValue(StatsPluginSettings::gatherDataEveryMs()); + pmUi -> PeersSpdUpdIvalSbw -> setValue(StatsPluginSettings::peersSpeedDataIval()); + + pmUi -> PeersSpdCbw -> setChecked(StatsPluginSettings::peersSpeed()); + pmUi -> ConnSdrInSwaCbw -> setChecked(StatsPluginSettings::drawSeedersInSwarms()); + pmUi -> ConnLchInSwaCbw -> setChecked(StatsPluginSettings::drawLeechersInSwarms()); + + pmUi -> DownloadMrmtSbw -> setValue(StatsPluginSettings::downloadMeasurements()); + pmUi -> PeersSpdMrmtSbw -> setValue(StatsPluginSettings::peersSpeedMeasurements()); + pmUi -> UploadMrmtSbw -> setValue(StatsPluginSettings::uploadMeasurements()); + pmUi -> ConnsMrmtSbw -> setValue(StatsPluginSettings::connectionsMeasurements()); + pmUi -> DHTMrmtSbw -> setValue(StatsPluginSettings::dHTMeasurements()); + pmUi -> MaxSpdModeCbw -> setCurrentItem(StatsPluginSettings::maxSpdMode()); +} + +void StatsPluginPrefs::deleteWidget () +{ + delete pmUi; +} + + +} //NS end + +#include "StatsPluginPrefs.moc" diff --git a/plugins/stats/StatsPluginPrefs.h b/plugins/stats/StatsPluginPrefs.h new file mode 100644 index 0000000..6d563ec --- /dev/null +++ b/plugins/stats/StatsPluginPrefs.h @@ -0,0 +1,66 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef STATSPLUGINPREFS_H_ +#define STATSPLUGINPREFS_H_ + +#include +#include +#include + +#include +#include +#include + +#include + +#include "StatsPluginPrefsPage.h" +#include "statspluginsettings.h" + +namespace kt { + +/** +\brief Prefs page +\author Krzysztof Kundzicz +*/ +class StatsPluginPrefs : public QObject, public PrefPageInterface +{ + Q_OBJECT + + private: + ///Widget + StatsPluginPrefsPage *pmUi; + public: + ///Constructor + StatsPluginPrefs(); + ///Destructor + virtual ~StatsPluginPrefs(); + + virtual bool apply (); + virtual void createWidget (QWidget *parent); + virtual void updateData (); + virtual void deleteWidget (); + signals: + void Applied(); +}; + +} + +#endif diff --git a/plugins/stats/StatsPluginPrefsPage.cc b/plugins/stats/StatsPluginPrefsPage.cc new file mode 100644 index 0000000..1278127 --- /dev/null +++ b/plugins/stats/StatsPluginPrefsPage.cc @@ -0,0 +1,29 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "StatsPluginPrefsPage.h" + +namespace kt { + +StatsPluginPrefsPage::StatsPluginPrefsPage(QWidget *p) : sprefwgt(p) +{ +} + +}// NS END diff --git a/plugins/stats/StatsPluginPrefsPage.h b/plugins/stats/StatsPluginPrefsPage.h new file mode 100644 index 0000000..59bd9f1 --- /dev/null +++ b/plugins/stats/StatsPluginPrefsPage.h @@ -0,0 +1,44 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef STATSPLUGINPREFSPAGE_H_ +#define STATSPLUGINPREFSPAGE_H_ + +#include "sprefwgt.h" + +namespace kt { + +/** +\brief Prefs widget +\author Krzysztof Kundzicz +*/ +class StatsPluginPrefsPage : public sprefwgt +{ + public: + /** + \brief Constructor + \param p Parent + */ + StatsPluginPrefsPage(QWidget * p = 0); +}; + +} + +#endif diff --git a/plugins/stats/StatsSpd.cc b/plugins/stats/StatsSpd.cc new file mode 100644 index 0000000..e4f9d53 --- /dev/null +++ b/plugins/stats/StatsSpd.cc @@ -0,0 +1,138 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "StatsSpd.h" + +namespace kt { + +StatsSpd::StatsSpd(QWidget *p) : StatsSpdWgt(p), + pmDownCht(new ChartDrawer(DownSpeedGbw, StatsPluginSettings::downloadMeasurements())), + pmPeersSpdCht(new ChartDrawer(PeersSpdGbw, StatsPluginSettings::peersSpeedMeasurements())), + pmUpCht(new ChartDrawer(UpSpeedGbw, StatsPluginSettings::uploadMeasurements())) +{ + + DownSpeedGbw->setColumnLayout(0, Qt::Vertical ); + DownSpeedGbw->layout()->setSpacing( 6 ); + DownSpeedGbw->layout()->setMargin( 11 ); + + pmDSpdLay = new QVBoxLayout(DownSpeedGbw -> layout()); + + UpSpeedGbw->setColumnLayout(0, Qt::Vertical ); + UpSpeedGbw->layout()->setSpacing( 6 ); + UpSpeedGbw->layout()->setMargin( 11 ); + + pmUSpdLay = new QVBoxLayout(UpSpeedGbw -> layout()); + + PeersSpdGbw->setColumnLayout(0, Qt::Vertical ); + PeersSpdGbw->layout()->setSpacing( 6 ); + PeersSpdGbw->layout()->setMargin( 11 ); + + pmPeersSpdLay = new QVBoxLayout(PeersSpdGbw -> layout()); + + //----------------- + + pmUSpdLay -> addWidget(pmUpCht); + pmDSpdLay -> addWidget(pmDownCht); + pmPeersSpdLay -> addWidget(pmPeersSpdCht); + + // ---------------- + + pmUpCht -> AddValuesCnt(QPen("#f00"), i18n("Current")); + pmDownCht -> AddValuesCnt(QPen("#f00"), i18n("Current")); + + pmUpCht -> AddValuesCnt(QPen("#00f"), i18n("Average")); + pmDownCht -> AddValuesCnt(QPen("#00f"), i18n("Average")); + + pmUpCht -> AddValuesCnt(i18n("Limit"), 0); + pmDownCht -> AddValuesCnt(i18n("Limit"), 0); + +// pmUpCht -> AddValuesCnt(QPen("#f0f"), i18n("Current torrent")); +// pmDownCht -> AddValuesCnt(QPen("#f0f"), i18n("Current torrent")); +// + + + pmPeersSpdCht -> AddValuesCnt(QPen("#090"), i18n("Average from leecher")); + pmPeersSpdCht -> AddValuesCnt(QPen("#f00"), i18n("Average to leecher")); + pmPeersSpdCht -> AddValuesCnt(QPen("#00f"), i18n("Average from seeder")); + pmPeersSpdCht -> AddValuesCnt(QPen("magenta"), i18n("From leechers")); + pmPeersSpdCht -> AddValuesCnt(QPen("orange"), i18n("From seeders")); + +} + +StatsSpd::~StatsSpd() +{ + delete pmUpCht; + delete pmDownCht; + delete pmPeersSpdCht; + + delete pmUSpdLay; + delete pmDSpdLay; + delete pmPeersSpdLay; + +} + +void StatsSpd::AddUpSpdVal(const size_t idx, const double val) +{ + pmUpCht -> AddValue(idx, val, false); +} + +void StatsSpd::AddDownSpdVal(const size_t idx, const double val) +{ + pmDownCht -> AddValue(idx, val , false); +} + +void StatsSpd::AddPeersSpdVal(const size_t idx, const double val) +{ + pmPeersSpdCht -> AddValue(idx, val , false); +} + +void StatsSpd::UpdateCharts() +{ + pmUpCht -> update(); + pmDownCht -> update(); + pmPeersSpdCht -> update(); +} + +void StatsSpd::ChangeDownMsmtCnt(const size_t cnt) +{ + pmDownCht -> SetXMax(cnt); +} + +void StatsSpd::ChangePrsSpdMsmtCnt(const size_t cnt) +{ + pmPeersSpdCht -> SetXMax(cnt); +} + +void StatsSpd::ChangeUpMsmtCnt(const size_t cnt) +{ + pmUpCht -> SetXMax(cnt); +} + +void StatsSpd::ChangeChartsMaxMode(const ChartDrawer::MaxMode mm) +{ + pmUpCht -> SetMaxMode(mm); + pmDownCht -> SetMaxMode(mm); + pmPeersSpdCht -> SetMaxMode(mm); +} + + +} //NS end + +#include "StatsSpd.moc" diff --git a/plugins/stats/StatsSpd.h b/plugins/stats/StatsSpd.h new file mode 100644 index 0000000..7ba8d43 --- /dev/null +++ b/plugins/stats/StatsSpd.h @@ -0,0 +1,113 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef STATSSPD_H_ +#define STATSSPD_H_ + +#include +#include +#include +#include + +#include "statspluginsettings.h" +#include "statsspdwgt.h" +#include "ChartDrawer.h" + +namespace kt { + +/** +\brief Main widget of stats plugin +\author Krzysztof Kundzicz +*/ +class StatsSpd : public StatsSpdWgt +{ + Q_OBJECT + + private: + ///Layout of upload speed + QVBoxLayout * pmUSpdLay; + ///Layout of down speed + QVBoxLayout * pmDSpdLay; + ///Layout of peers speed + QVBoxLayout * pmPeersSpdLay; + + ///Chart widget of download speed + ChartDrawer * pmDownCht; + ///Chart widget of peers speed + ChartDrawer * pmPeersSpdCht; + ///Chart widget of upload speed + ChartDrawer * pmUpCht; + + public: + /** + \brief Constructor + \param p Parent + */ + StatsSpd(QWidget *p = 0); + ///Destructor + virtual ~StatsSpd(); + + /** + \brief Adds value to upload speed chart + \param idx Dataset index + \param val Value + **/ + void AddUpSpdVal(const size_t idx, const double val); + /** + \brief Adds value to download speed chart + \param idx Dataset index + \param val Value + **/ + void AddDownSpdVal(const size_t idx, const double val); + /** + \brief Adds value to peers speed chart + \param idx Dataset index + \param val Value + **/ + void AddPeersSpdVal(const size_t idx, const double val); + /** + \brief Changes download chart's measurments count + \param cnt Measurements + */ + void ChangeDownMsmtCnt(const size_t cnt); + /** + \brief Changes peers speed chart's measurments count + \param cnt Measurements + */ + void ChangePrsSpdMsmtCnt(const size_t cnt); + /** + \brief Changes upload chart's measurments count + \param cnt Measurements + */ + void ChangeUpMsmtCnt(const size_t cnt); + /** + \brief Changes charts OY axis maximum mode + \param mm Mode + */ + void ChangeChartsMaxMode(const ChartDrawer::MaxMode mm); + + public slots: + ///Updates charts + void UpdateCharts(); +}; + +} + +#endif diff --git a/plugins/stats/ktstatsplugin.desktop b/plugins/stats/ktstatsplugin.desktop new file mode 100644 index 0000000..79e620f --- /dev/null +++ b/plugins/stats/ktstatsplugin.desktop @@ -0,0 +1,24 @@ +[Desktop Entry] +Type=Service +Name=StatsPlugin +Name[bg]=Приставка за статистика +Name[de]=Statistik-Modul +Name[es]=Complemento de estadísticas +Name[et]=Statistikaplugin +Name[it]=Plugin statistiche +Name[nds]=Statistik-Moduul +Name[nl]=Statistiekenplugin +Name[pl]=Wtyczka statystyk +Name[pt]='Plugin' de Estatísticas +Name[pt_BR]=Plugin de Estatísticas +Name[sr]=Прикључак за статистику +Name[sr@Latn]=Priključak za statistiku +Name[sv]=Statistikinsticksprogram +Name[tr]=Arama Eklentisi +Name[uk]=Втулок статистики +Name[xx]=xxStatsPluginxx +Name[zh_CN]=统计插件 +Comment= +Comment[xx]=xxxx +ServiceTypes=KTorrent/Plugin +X-KDE-Library=ktstatsplugin diff --git a/plugins/stats/ktstatsplugin.kcfg b/plugins/stats/ktstatsplugin.kcfg new file mode 100644 index 0000000..43c5dd4 --- /dev/null +++ b/plugins/stats/ktstatsplugin.kcfg @@ -0,0 +1,60 @@ + + + + + + + + 4 + + + + 1000 + + + + true + + + + 4 + + + + false + + + + false + + + + + 256 + + + + 256 + + + + 256 + + + + 512 + + + + 512 + + + + + 1 + + + diff --git a/plugins/stats/sprefwgt.ui b/plugins/stats/sprefwgt.ui new file mode 100644 index 0000000..7b6674a --- /dev/null +++ b/plugins/stats/sprefwgt.ui @@ -0,0 +1,517 @@ + +sprefwgt + + + sprefwgt + + + + 0 + 0 + 600 + 480 + + + + + unnamed + + + 0 + + + + groupBox1 + + + Update + + + + unnamed + + + + layout2 + + + + unnamed + + + + textLabel1 + + + Update charts every + + + GuiUpdatesSbw + + + + + GuiUpdatesSbw + + + 429496729 + + + 1 + + + 4 + + + + + textLabel2 + + + GUI updates + + + GuiUpdatesSbw + + + + + + + layout4 + + + + unnamed + + + + textLabel3 + + + Gather data every + + + spinBox2 + + + + + DataIvalSbw + + + 999999999 + + + 1 + + + 250 + + + 1000 + + + + + textLabel4 + + + miliseconds + + + spinBox2 + + + + + + + + + groupBox5 + + + Maximum + + + + unnamed + + + + layout11 + + + + unnamed + + + + textLabel1_4 + + + Maximum speed scale mode: + + + + + + Top + + + + + Exact + + + + MaxSpdModeCbw + + + 1 + + + See 'What's this' for more help + + + Set maximum value on OY scale as: +- Top: Globally achieved maximum speed +- Exact: Maximum achieved speed visible on chart + + + + + + + + + groupBox3 + + + Peers speed + + + + unnamed + + + + layout3 + + + + unnamed + + + + PeersSpdCbw + + + Peers speed: + + + true + + + + + textLabel1_2 + + + update every + + + + + PeersSpdUpdIvalSbw + + + 999999999 + + + 1 + + + 4 + + + + + textLabel2_2 + + + chart data updates + + + + + + + textLabel3_2 + + + Gathering data about many connected peers can be CPU consuming. + + + WordBreak|AlignVCenter + + + + + + + groupBox11 + + + Peers connections + + + Large values can obscure charts of connected peers + + + + unnamed + + + + layout7 + + + + unnamed + + + + ConnSdrInSwaCbw + + + Show seeders in swarms + + + + + ConnLchInSwaCbw + + + Show leechers in swarms + + + + + + + + + groupBox8 + + + Measurements count + + + + unnamed + + + + layout5 + + + + unnamed + + + + textLabel1_3 + + + Download + + + + + DownloadMrmtSbw + + + 999999999 + + + 1 + + + 256 + + + + + + + layout5_2 + + + + unnamed + + + + textLabel1_3_2 + + + Peers speed + + + + + PeersSpdMrmtSbw + + + 999999999 + + + 1 + + + 256 + + + + + + + layout5_3 + + + + unnamed + + + + textLabel1_3_3 + + + Upload + + + + + UploadMrmtSbw + + + 999999999 + + + 1 + + + 256 + + + + + + + layout5_5 + + + + unnamed + + + + textLabel1_3_5 + + + Connections + + + + + ConnsMrmtSbw + + + 999999999 + + + 1 + + + 512 + + + + + + + layout5_4 + + + + unnamed + + + + textLabel1_3_4 + + + DHT + + + + + DHTMrmtSbw + + + 999999999 + + + 1 + + + 512 + + + + + + + + + spacer3 + + + Vertical + + + Expanding + + + + 20 + 40 + + + + + + + + PeersSpdCbw + toggled(bool) + textLabel2_2 + setEnabled(bool) + + + PeersSpdCbw + toggled(bool) + PeersSpdUpdIvalSbw + setEnabled(bool) + + + PeersSpdCbw + toggled(bool) + textLabel1_2 + setEnabled(bool) + + + + diff --git a/plugins/stats/statsconwgt.ui b/plugins/stats/statsconwgt.ui new file mode 100644 index 0000000..07753dc --- /dev/null +++ b/plugins/stats/statsconwgt.ui @@ -0,0 +1,48 @@ + +StatsConWgt + + + StatsConWgt + + + + 0 + 0 + 600 + 480 + + + + + unnamed + + + + layout3 + + + + unnamed + + + + PeersConGbw + + + Peers + + + + + DHTGbw + + + DHT + + + + + + + + diff --git a/plugins/stats/statsplugin.cc b/plugins/stats/statsplugin.cc new file mode 100644 index 0000000..d3d1b03 --- /dev/null +++ b/plugins/stats/statsplugin.cc @@ -0,0 +1,321 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#include "statsplugin.h" + +K_EXPORT_COMPONENT_FACTORY(ktstatsplugin, KGenericFactory("ktstatsplugin")) + +namespace kt +{ + +StatsPlugin::StatsPlugin(QObject* parent, const char* qt_name, const QStringList& args): + Plugin(parent, qt_name, args, "Statistics", i18n("Statistics"),"Krzysztof Kundzicz", "athantor@gmail.com", i18n("Shows transfers statistics"),"ktimemon"), pmUiSpd(0), pmUiCon(0), pmPrefsUi(0), pmUpdTmr(0) +{ + mUpAvg = std::make_pair(0.0, 0.0); + mDownAvg = std::make_pair(0.0, 0.0); + mLeechAvg = std::make_pair(0, 0); + mRunningLeechAvg = std::make_pair(0, 0); + mSeedAvg = std::make_pair(0, 0); + mRunningSeedAvg = std::make_pair(0, 0); +} + +StatsPlugin::~StatsPlugin() +{ +} + +void StatsPlugin::load() +{ + + mUpdCtr = 1; + mPeerSpdUpdCtr = 1; + + pmUiSpd = new StatsSpd(dynamic_cast(parent())); + pmUiCon = new StatsCon(dynamic_cast(parent())); + pmPrefsUi = new StatsPluginPrefs(); + pmUpdTmr = new QTimer(this); + + connect(pmUpdTmr, SIGNAL(timeout () ), this, SLOT(UpdateData())); + connect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(RestartTimer())); + connect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(TogglePeersSpdCht())); + connect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ToggleLchInSwmDrawing())); + connect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ToggleSdrInSwmDrawing())); + connect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ChangeMsmtsCounts())); + connect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ChangeMaxMode())); + + TogglePeersSpdCht(); + ChangeMaxMode(); + + pmUpdTmr -> start(StatsPluginSettings::gatherDataEveryMs()); + + getGUI() -> addToolWidget(pmUiSpd,"ktimemon" ,i18n("Speed statistics"), GUIInterface::DOCK_BOTTOM); + getGUI() -> addToolWidget(pmUiCon,"ktimemon" ,i18n("Connection statistics"), GUIInterface::DOCK_BOTTOM); + getGUI() -> addPrefPage (pmPrefsUi); + +} + +void StatsPlugin::unload() +{ + getGUI() -> removeToolWidget(pmUiSpd); + getGUI() -> removeToolWidget(pmUiCon); + getGUI() -> removePrefPage(pmPrefsUi); + + disconnect(pmUpdTmr, SIGNAL(timeout()), this, SLOT(UpdateData())); + disconnect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(RestartTimer())); + disconnect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(TogglePeersSpdCht())); + disconnect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ToggleLchInSwmDrawing())); + disconnect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ToggleSdrInSwmDrawing())); + disconnect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ChangeMsmtsCounts())); + disconnect(pmPrefsUi, SIGNAL(Applied()), this, SLOT(ChangeMaxMode())); + + delete pmUiSpd; + delete pmUiCon; + delete pmPrefsUi; + delete pmUpdTmr; +} + +bool StatsPlugin::versionCheck(const QString& rVer) const +{ + return rVer == KT_VERSION_MACRO; +} + +void StatsPlugin::guiUpdate() +{ + if(mUpdCtr >= StatsPluginSettings::updateChartsEveryGuiUpdates()) + { + pmUiSpd -> UpdateCharts(); + pmUiCon -> UpdateCharts(); + mUpdCtr = 1; + + } else { + mUpdCtr++; + } +} + +void StatsPlugin::UpdateData() +{ + uint32_t lcon = 0; + uint32_t lswa = 0; + uint32_t scon = 0; + uint32_t sswa = 0; + uint32_t rlcon = 0; + uint32_t rlswa = 0; + uint32_t rscon = 0; + uint32_t rsswa = 0; + + uint32_t ld = 0; + uint32_t lu = 0; + uint32_t sd = 0; + + //--------------------------------------- + + mDownAvg.first += getCore() -> getStats() . download_speed; + mDownAvg.second++; + + mUpAvg.first += getCore() -> getStats() . upload_speed; + mUpAvg.second++; + + pmUiSpd -> AddDownSpdVal(0, getCore() -> getStats() . download_speed / 1024.0); + pmUiSpd -> AddUpSpdVal(0, getCore() -> getStats() . upload_speed / 1024.0); + + pmUiSpd -> AddDownSpdVal(1, (mDownAvg.first / mDownAvg.second) / 1024.0 ); + pmUiSpd -> AddUpSpdVal(1, (mUpAvg.first / mUpAvg.second) / 1024.0 ); + + pmUiSpd -> AddDownSpdVal(2, getCore() -> getMaxDownloadSpeed () ); + pmUiSpd -> AddUpSpdVal(2, getCore() -> getMaxUploadSpeed ()); + +// if(getGUI()-> getCurrentTorrent()) +// { +// pmUi -> AddDownSpdVal(3, getGUI()-> getCurrentTorrent() -> getStats() . download_rate / 1024.0); +// pmUi -> AddUpSpdVal(3, getGUI()-> getCurrentTorrent() -> getStats() . upload_rate / 1024.0); +// } else { +// pmUi -> AddDownSpdVal(3, 0.0); +// pmUi -> AddUpSpdVal(3, 0.0); +// } + + // ------ + + bt::QueueManager::iterator tor = getCore() -> getQueueManager () -> begin(); + + while(tor != getCore() -> getQueueManager () -> end()) + { + lcon += (*tor) -> getStats().leechers_connected_to; + lswa += (*tor) -> getStats().leechers_total; + scon += (*tor) -> getStats().seeders_connected_to; + sswa += (*tor) -> getStats().seeders_total; + + mLeechAvg.first += lcon; + mLeechAvg.second += lswa; + mSeedAvg.first += scon; + mSeedAvg.second += sswa; + + if(StatsPluginSettings::peersSpeed() && ( mPeerSpdUpdCtr >= StatsPluginSettings::peersSpeedDataIval() ) ) + { + bt::TorrentControl * tc = dynamic_cast( *tor ); + const bt::PeerManager * pm = tc->getPeerMgr(); + if(tc && pm) + { + for(bt::PeerManager::CItr it = pm -> beginPeerList(); it != pm -> endPeerList (); ++it) + { + if(it && (*it) ) + { + if(!(*it) -> isSeeder()) + { + ld += (*it) -> getDownloadRate(); + lu += (*it) -> getUploadRate(); + } else { + sd += (*it) -> getDownloadRate(); + } + } + } + } + } + + + if( (*tor) -> getStats().started) + { + + rlcon += (*tor) -> getStats().leechers_connected_to; + rlswa += (*tor) -> getStats().leechers_total; + rscon += (*tor) -> getStats().seeders_connected_to; + rsswa += (*tor) -> getStats().seeders_total; + + mRunningLeechAvg.first += rlcon; + mRunningLeechAvg.second += rlswa; + mRunningSeedAvg.first += rscon; + mRunningSeedAvg.second += rsswa; + } + + tor++; + } + + // ------ + + if(StatsPluginSettings::peersSpeed() ) + { + if( mPeerSpdUpdCtr >= StatsPluginSettings::peersSpeedDataIval() ) + { + pmUiSpd -> AddPeersSpdVal(0, (ld / (lcon * 1.0)) / 1024.0); + pmUiSpd -> AddPeersSpdVal(1, (lu / (lcon * 1.0)) / 1024.0); + pmUiSpd -> AddPeersSpdVal(2, (sd / (lswa * 1.0)) / 1024.0); + pmUiSpd -> AddPeersSpdVal(3, ld / 1024.0); + pmUiSpd -> AddPeersSpdVal(4, sd / 1024.0); + + mPeerSpdUpdCtr = 1; + } else { + mPeerSpdUpdCtr++; + } + } + + pmUiCon -> AddPeersConVal(0, lcon); + if(StatsPluginSettings::drawLeechersInSwarms()) + { + pmUiCon -> AddPeersConVal(1, lswa); + } + pmUiCon -> AddPeersConVal(2, scon); + if(StatsPluginSettings::drawSeedersInSwarms()) + { + pmUiCon -> AddPeersConVal(3, sswa); + } + + double cnt = getCore() -> getQueueManager() -> count() * 1.0; + double rcnt = getCore() -> getQueueManager() -> getNumRunning() * 1.0; + + pmUiCon -> AddPeersConVal(4, lcon / cnt ); + pmUiCon -> AddPeersConVal(5, scon / cnt ); + pmUiCon -> AddPeersConVal(6, lcon / rcnt); + pmUiCon -> AddPeersConVal(7, scon / rcnt ); + + // ----- + + if( bt::Globals::instance().getDHT().isRunning() ) + { + pmUiCon -> AddDHTVal(0, bt::Globals::instance().getDHT(). getStats().num_peers); + pmUiCon -> AddDHTVal(1, bt::Globals::instance().getDHT(). getStats().num_tasks); + } +} + +void StatsPlugin::RestartTimer() +{ + if( (!pmUpdTmr) || (!pmUpdTmr -> isActive())) + { + return; + } + + pmUpdTmr -> stop(); + pmUpdTmr -> start(StatsPluginSettings::gatherDataEveryMs()); +} + +void StatsPlugin::TogglePeersSpdCht() +{ + if(StatsPluginSettings::peersSpeed()) + { + if(pmUiSpd -> PeersSpdGbw -> isHidden()) + { + pmUiSpd -> PeersSpdGbw -> setHidden(false); + } + } else { + if(!pmUiSpd -> PeersSpdGbw -> isHidden()) + { + pmUiSpd -> PeersSpdGbw -> setHidden(true); + } + } +} + +void StatsPlugin::ToggleLchInSwmDrawing() +{ + if(!StatsPluginSettings::drawLeechersInSwarms()) + { + pmUiCon -> ZeroPeersConn(1); + } +} + +void StatsPlugin::ToggleSdrInSwmDrawing() +{ + if(!StatsPluginSettings::drawSeedersInSwarms()) + { + pmUiCon -> ZeroPeersConn(3); + } +} + +void StatsPlugin::ChangeMsmtsCounts() +{ + pmUiSpd -> ChangeDownMsmtCnt(StatsPluginSettings::downloadMeasurements()); + pmUiSpd -> ChangePrsSpdMsmtCnt(StatsPluginSettings::peersSpeedMeasurements()); + pmUiSpd -> ChangeUpMsmtCnt(StatsPluginSettings::uploadMeasurements()); + pmUiCon -> ChangeConnMsmtCnt(StatsPluginSettings::connectionsMeasurements()); + pmUiCon -> ChangeDHTMsmtCnt(StatsPluginSettings::dHTMeasurements()); +} + +void StatsPlugin::ChangeMaxMode() +{ + if(StatsPluginSettings::maxSpdMode() == 0) + { + pmUiSpd -> ChangeChartsMaxMode(ChartDrawer::MaxModeTop); + pmUiCon -> ChangeChartsMaxMode(ChartDrawer::MaxModeTop); + + } else if (StatsPluginSettings::maxSpdMode() == 1) { + pmUiSpd -> ChangeChartsMaxMode(ChartDrawer::MaxModeExact); + pmUiCon -> ChangeChartsMaxMode(ChartDrawer::MaxModeExact); + } +} + +} // NS end + +#include "statsplugin.moc" diff --git a/plugins/stats/statsplugin.h b/plugins/stats/statsplugin.h new file mode 100644 index 0000000..14f1fcd --- /dev/null +++ b/plugins/stats/statsplugin.h @@ -0,0 +1,153 @@ +/*************************************************************************** + * Copyright © 2007 by Krzysztof Kundzicz * + * athantor@gmail.com * + * * + * 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; either version 2 of the License, or * + * (at your option) any later version. * + * * + * 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. * + ***************************************************************************/ + +#ifndef StatsPlugin_H_ +#define StatsPlugin_H_ + +#include + +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "StatsSpd.h" +#include "StatsCon.h" +#include "StatsPluginPrefs.h" +#include "statspluginsettings.h" +#include // std::pair + +namespace kt { + +/** +\brief Statistics plugin +\author Krzysztof Kundzicz +\version 200705191548 +*/ +class StatsPlugin : public Plugin +{ + Q_OBJECT + + private: + ///Speed UI of the plugin + StatsSpd * pmUiSpd; + ///Connections UI of the plugin + StatsCon * pmUiCon; + ///UI of the pref page + StatsPluginPrefs * pmPrefsUi; + /** + \brief Average upload speed data + + \li \c first: Total speed + \li \c second: Measurements count + */ + std::pair mUpAvg; + /** + \brief Average download speed data + + \li \c first: Total speed + \li \c second: Measurements count + */ + std::pair mDownAvg; + /** + \brief Leechers stats + + \li \c first: connected + \li \c second: swarm + */ + std::pair mLeechAvg; + /** + \brief Leechers stats on running torrents + + \li \c first: connected + \li \c second: swarm + */ + std::pair mRunningLeechAvg; + /** + \brief Seeders stats + + \li \c first: connected + \li \c second: swarm + */ + std::pair mSeedAvg; + /** + \brief Seeders stats on running torrents + + \li \c first: connected + \li \c second: swarm + */ + std::pair mRunningSeedAvg; + + ///Data update timer + QTimer * pmUpdTmr; + + ///Update ctr + uint32_t mUpdCtr; + uint32_t mPeerSpdUpdCtr; + + private slots: + ///Updates stat data + void UpdateData(); + /** + \brief Restarts timer + + Restarts timer when the interval of data gathering has been changed + */ + void RestartTimer(); + ///Toggles peers speed chart + void TogglePeersSpdCht(); + ///Toggles drawing of total leechers in swarms + void ToggleLchInSwmDrawing(); + ///Toggles drawing of total seeders in swarms + void ToggleSdrInSwmDrawing(); + ///Changes measurements counts + void ChangeMsmtsCounts(); + ///Changes OY max mode + void ChangeMaxMode(); + + public: + /** + \brief Constructor + \param parent Parent + \param qt_name + \param args + */ + StatsPlugin(QObject* parent, const char* qt_name, const QStringList& args); + ///Destructor + virtual ~StatsPlugin(); + + virtual void load(); + virtual void unload(); + virtual bool versionCheck(const QString&) const; + virtual void guiUpdate(); +}; + +} + +#endif + diff --git a/plugins/stats/statspluginsettings.kcfgc b/plugins/stats/statspluginsettings.kcfgc new file mode 100644 index 0000000..d809d30 --- /dev/null +++ b/plugins/stats/statspluginsettings.kcfgc @@ -0,0 +1,7 @@ +# Code generation options for kconfig_compiler +File=ktstatsplugin.kcfg +ClassName=StatsPluginSettings +Namespace=kt +Singleton=true +Mutators=true +# will create the necessary code for setting those variables diff --git a/plugins/stats/statsspdwgt.ui b/plugins/stats/statsspdwgt.ui new file mode 100644 index 0000000..162bf9c --- /dev/null +++ b/plugins/stats/statsspdwgt.ui @@ -0,0 +1,56 @@ + +StatsSpdWgt + + + StatsSpdWgt + + + + 0 + 0 + 600 + 480 + + + + + unnamed + + + + layout5 + + + + unnamed + + + + DownSpeedGbw + + + Download + + + + + PeersSpdGbw + + + Peers + + + + + UpSpeedGbw + + + Upload + + + + + + + + -- cgit v1.2.1