diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | bcb704366cb5e333a626c18c308c7e0448a8e69f (patch) | |
tree | f0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /kpf/src/ActiveMonitorItem.cpp | |
download | tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kpf/src/ActiveMonitorItem.cpp')
-rw-r--r-- | kpf/src/ActiveMonitorItem.cpp | 199 |
1 files changed, 199 insertions, 0 deletions
diff --git a/kpf/src/ActiveMonitorItem.cpp b/kpf/src/ActiveMonitorItem.cpp new file mode 100644 index 00000000..1cc8fdcb --- /dev/null +++ b/kpf/src/ActiveMonitorItem.cpp @@ -0,0 +1,199 @@ +/* + KPF - Public fileserver for KDE + + Copyright 2001 Rik Hemsley (rikkus) <[email protected]> + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to + deal in the Software without restriction, including without limitation the + rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +*/ + +#include <qpainter.h> +#include <kiconloader.h> + +#include "Defines.h" +#include "ActiveMonitorItem.h" +#include "Server.h" +#include "Utils.h" + +namespace KPF +{ + ActiveMonitorItem::ActiveMonitorItem(Server * server, QListView * parent) + : QListViewItem (parent), + server_ (server), + size_ (0), + sent_ (0) + { + setText(Host, server_->peerAddress().toString()); + setText(Resource, "..."); + setText(Response, "..."); + setText(Size, "..."); + setText(Sent, "..."); + + updateState(); + } + + ActiveMonitorItem::~ActiveMonitorItem() + { + // Empty. + } + + void + ActiveMonitorItem::paintCell + ( + QPainter * p, + const QColorGroup & g, + int c, + int w, + int a + ) + { + if (c != Progress) + { + QListViewItem::paintCell(p, g, c, w, a); + return; + } + + p->setPen(g.dark()); + + p->setPen(g.base()); + + p->drawRect(0, 0, w, height()); + + int maxBarLength = w - 4; + + int barLength = maxBarLength; + + if (0 != size_) + barLength = int((sent_ / double(size_)) * maxBarLength); + + p->fillRect(2, 2, barLength, height() - 4, g.highlight()); + } + + int + ActiveMonitorItem::width + ( + const QFontMetrics & fm, + const QListView * lv, + int c + ) const + { + switch (c) + { + case Status: + return 16; + break; + + case Progress: + return 32; + break; + + default: + return QListViewItem::width(fm, lv, c); + break; + } + } + + void + ActiveMonitorItem::updateState() + { + if (0 != server_) + { + switch (server_->state()) + { + case Server::WaitingForRequest: + setPixmap(Status, SmallIcon("connect_creating")); + break; + + case Server::WaitingForHeaders: + setPixmap(Status, SmallIcon("connect_creating")); + break; + + case Server::Responding: + setPixmap(Status, SmallIcon("connect_established")); + break; + + case Server::Finished: + setPixmap(Status, SmallIcon("connect_no")); + break; + } + } + } + + Server * + ActiveMonitorItem::server() + { + return server_; + } + + QDateTime + ActiveMonitorItem::death() const + { + return death_; + } + + void + ActiveMonitorItem::request() + { + if (0 != server_) + { + setText(Resource, server_->request().path()); + updateState(); + } + } + + void + ActiveMonitorItem::response() + { + if (0 != server_) + { + setText(Response, translatedResponseName(server_->response().code())); + + size_ = server_->response().size(); + + setText(Size, QString::number(size_)); + + updateState(); + } + } + + void + ActiveMonitorItem::output(ulong l) + { + if (0 != server_) + { + sent_ += l; + setText(Sent, QString::number(sent_)); + updateState(); + repaint(); + } + } + + void + ActiveMonitorItem::finished() + { + if (0 != server_) + { + death_ = server_->death(); + updateState(); + } + + server_ = 0L; + } + +} // End namespace KPF + +// vim:ts=2:sw=2:tw=78:et |