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 | ce4a32fe52ef09d8f5ff1dd22c001110902b60a2 (patch) | |
tree | 5ac38a06f3dde268dc7927dc155896926aaf7012 /kutils/kcmoduleproxyIfaceImpl.cpp | |
download | tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.tar.gz tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.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/kdelibs@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kutils/kcmoduleproxyIfaceImpl.cpp')
-rw-r--r-- | kutils/kcmoduleproxyIfaceImpl.cpp | 129 |
1 files changed, 129 insertions, 0 deletions
diff --git a/kutils/kcmoduleproxyIfaceImpl.cpp b/kutils/kcmoduleproxyIfaceImpl.cpp new file mode 100644 index 000000000..5d1ae15fe --- /dev/null +++ b/kutils/kcmoduleproxyIfaceImpl.cpp @@ -0,0 +1,129 @@ +/* + * Copyright (C) 2004 Frans Englich <frans.englich@telia.com> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License version 2 as published by the Free Software Foundation. + * + * This library 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 + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public License + * along with this library; see the file COPYING.LIB. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + */ + +#include <qcstring.h> +#include <qdatastream.h> + +#include <dcopclient.h> + +#include <kapplication.h> +#include <kcmoduleproxy.h> +#include <kdebug.h> + +#include "kcmoduleproxyIfaceImpl.h" + + +#include <qmessagebox.h> + +KCModuleProxyIfaceImpl::KCModuleProxyIfaceImpl( const QCString& name, + KCModuleProxy* const client ) + : DCOPObject( name ), QObject( 0, name ), + p( const_cast<KCModuleProxy *>( client )) +{ + connect( p, SIGNAL( changed(bool)), + SLOT( changedRelay(bool))); + connect( p, SIGNAL( quickHelpChanged()), + SLOT( quickHelpRelay())); +} + +void KCModuleProxyIfaceImpl::save() +{ + kdDebug(711) << k_funcinfo << endl; + p->save(); +} + +void KCModuleProxyIfaceImpl::load() +{ + kdDebug(711) << k_funcinfo << endl; + p->load(); +} + +void KCModuleProxyIfaceImpl::defaults() +{ + kdDebug(711) << k_funcinfo << endl; + p->defaults(); +} + +QString KCModuleProxyIfaceImpl::applicationName() +{ + return kapp->caption(); +} + +QString KCModuleProxyIfaceImpl::quickHelp() +{ + return p->quickHelp(); +} + +bool KCModuleProxyIfaceImpl::changed() +{ + return p->changed(); +} + +void KCModuleProxyIfaceImpl::changedRelay( bool c ) +{ + QByteArray data; + QDataStream stream(data, IO_WriteOnly); + stream << c; + emitDCOPSignal( "changed(bool)", data ); +} + +void KCModuleProxyIfaceImpl::quickHelpRelay() +{ + QByteArray data; + emitDCOPSignal( "quickHelpChanged()", data ); +} + +/***************************************************************/ + + + + +/***************************************************************/ +KCModuleProxyRootCommunicatorImpl::KCModuleProxyRootCommunicatorImpl + ( const QCString& name, KCModuleProxy* const client ) + : DCOPObject( name ), QObject( 0, name ), + p( const_cast<KCModuleProxy *>( client )) +{ + /* + * Connect kcmshell's KCModuleProxy's change signal + * to us, such that we act as a proxy for + * KCModuleProxy's API. + */ + + /* Note, we don't use KCModuleProxy::d->dcopClient */ + kapp->dcopClient()->connectDCOPSignal( 0, p->dcopName(), + "changed(bool)", objId(), "changed(bool)", false ); + + kapp->dcopClient()->connectDCOPSignal( 0, p->dcopName(), + "quickHelpChanged()", objId(), "quickHelpChanged()", false ); +} + +/* Reimplementations of DCOP members */ +void KCModuleProxyRootCommunicatorImpl::changed( bool c ) +{ + kdDebug(711) << k_funcinfo << endl; + p->moduleChanged( c ); +} + +void KCModuleProxyRootCommunicatorImpl::quickHelpChanged() +{ + kdDebug(711) << k_funcinfo << endl; + p->emitQuickHelpChanged(); +} + +#include "kcmoduleproxyIfaceImpl.moc" |