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 /ksirc/puke/pprogress.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 'ksirc/puke/pprogress.cpp')
-rw-r--r-- | ksirc/puke/pprogress.cpp | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/ksirc/puke/pprogress.cpp b/ksirc/puke/pprogress.cpp new file mode 100644 index 00000000..75c7fa4b --- /dev/null +++ b/ksirc/puke/pprogress.cpp @@ -0,0 +1,133 @@ +#include <stdio.h> + + +#include <kdebug.h> + +#include "pprogress.h" + +PObject * +PProgress::createWidget(CreateArgs &ca) +{ + PProgress *pw = new PProgress(ca.parent); + KSProgress *ksp; + if(ca.parent != 0 && ca.parent->widget()->isWidgetType() == TRUE) + ksp = new KSProgress((QWidget *) ca.parent->widget()); + else + ksp = new KSProgress(); + pw->setWidget(ksp); + pw->setWidgetId(ca.pwI); + return pw; +} + + +PProgress::PProgress( PObject *parent) + : PWidget(parent) +{ + // kdDebug(5008) << "PProgress PProgress called" << endl; + ksp = 0; +} + +PProgress::~PProgress() +{ + // kdDebug(5008) << "PProgress: in destructor" << endl; + /* + delete widget(); // Delete the frame + ksp=0; // Set it to 0 + setWidget(ksp); // Now set all widget() calls to 0. + */ +} + +void PProgress::messageHandler(int fd, PukeMessage *pm) +{ + // kdDebug(5008) << "PProgress handler called" << endl; + PukeMessage pmRet; + if(widget() == 0){ + qWarning("Null widget"); + return; + } + switch(pm->iCommand){ + case PUKE_KSPROGRESS_SET_RANGE: + { + int start=0, stop=1; + int found = sscanf(pm->cArg, "%d\t%d", &start, &stop); + if(found != 2) + throw(errorCommandFailed(PUKE_INVALID,13)); + if(start >= stop){ + stop = start+1; + start = 0; + } + + widget()->setRange(start, stop); + pmRet.iCommand = PUKE_KSPROGRESS_SET_RANGE_ACK; + pmRet.iWinId = pm->iWinId; + pmRet.iArg = 0; + pmRet.cArg = 0; + emit outputMessage(fd, &pmRet); + break; + } + case PUKE_KSPROGRESS_SET_TOPTEXT: + widget()->setTopText(QString(pm->cArg)); + pmRet.iCommand = PUKE_KSPROGRESS_SET_TOPTEXT; + pmRet.iWinId = pm->iWinId; + pmRet.iArg = 0; + pmRet.cArg = 0; + emit outputMessage(fd, &pmRet); + break; + case PUKE_KSPROGRESS_SET_BOTTEXT: + widget()->setBotText(QString(pm->cArg)); + pmRet.iCommand = PUKE_KSPROGRESS_SET_BOTTEXT; + pmRet.iWinId = pm->iWinId; + pmRet.iArg = 0; + pmRet.cArg = 0; + emit outputMessage(fd, &pmRet); + break; + case PUKE_KSPROGRESS_SET_VALUE: + widget()->setValue(pm->iArg); + pmRet.iCommand = PUKE_KSPROGRESS_SET_VALUE_ACK; + pmRet.iWinId = pm->iWinId; + pmRet.iArg = 0; + pmRet.cArg = 0; + emit outputMessage(fd, &pmRet); + break; + default: + PWidget::messageHandler(fd, pm); + } +} + +void PProgress::cancelPressed(){ + kdDebug(5008) << "Cancel Pressed" << endl; + PukeMessage pmRet; + pmRet.iCommand = PUKE_KSPROGRESS_CANCEL_ACK; + pmRet.iWinId = widgetIden().iWinId; + pmRet.iArg = 0; + pmRet.cArg = 0; + emit outputMessage(widgetIden().fd, &pmRet); +} + +void PProgress::setWidget(QObject *_f) +{ + // kdDebug(5008) << "PProgress setWidget called" << endl; + if(_f != 0 && _f->inherits("KSProgress") == FALSE) + { + errorInvalidSet(_f); + return; + } + + ksp = (KSProgress *) _f; + if(widget() != 0){ + connect(widget(), SIGNAL(cancel()), + this, SLOT(cancelPressed())); + } + PWidget::setWidget(ksp); + +} + + +KSProgress *PProgress::widget() +{ + // kdDebug(5008) << "PProgress widget called" << endl; + return ksp; +} + +#include "pprogress.moc" + |