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 | 460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch) | |
tree | 67208f7c145782a7e90b123b982ca78d88cc2c87 /korganizer/urihandler.cpp | |
download | tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.tar.gz tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.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/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'korganizer/urihandler.cpp')
-rw-r--r-- | korganizer/urihandler.cpp | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/korganizer/urihandler.cpp b/korganizer/urihandler.cpp new file mode 100644 index 000000000..6bbd45d2f --- /dev/null +++ b/korganizer/urihandler.cpp @@ -0,0 +1,94 @@ +/* + This file is part of KOrganizer. + + Copyright (c) 2003 Cornelius Schumacher <[email protected]> + + 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + + As a special exception, permission is given to link this program + with any edition of Qt, and distribute the resulting executable, + without including the source code for Qt in the source distribution. +*/ + +#include "urihandler.h" + +#ifndef KORG_NODCOP +#include <dcopclient.h> +#include "kmailIface_stub.h" +#endif + +#include <kiconloader.h> +#include <krun.h> +#include <kapplication.h> +#include <kprocess.h> +#include <kdebug.h> + +bool UriHandler::process( const QString &uri ) +{ + kdDebug(5850) << "UriHandler::process(): " << uri << endl; + +#ifndef KORG_NODCOP + if ( uri.startsWith( "kmail:" ) ) { + // make sure kmail is running or the part is shown + kapp->startServiceByDesktopPath("kmail"); + + // parse string, show + int colon = uri.find( ':' ); + // extract 'number' from 'kmail:<number>/<id>' + QString serialNumberStr = uri.mid( colon + 1 ); + serialNumberStr = serialNumberStr.left( serialNumberStr.find( '/' ) ); + + KMailIface_stub kmailIface( "kmail", "KMailIface" ); + kmailIface.showMail( serialNumberStr.toUInt(), QString() ); + return true; + } else if ( uri.startsWith( "mailto:" ) ) { + KApplication::kApplication()->invokeMailer( uri.mid(7), QString::null ); + return true; + } else if ( uri.startsWith( "uid:" ) ) { + DCOPClient *client = KApplication::kApplication()->dcopClient(); + const QByteArray noParamData; + const QByteArray paramData; + QByteArray replyData; + QCString replyTypeStr; + bool foundAbbrowser = client->call( "kaddressbook", "KAddressBookIface", + "interfaces()", noParamData, + replyTypeStr, replyData ); + if ( foundAbbrowser ) { + //KAddressbook is already running, so just DCOP to it to bring up the contact editor +#if KDE_IS_VERSION( 3, 2, 90 ) + kapp->updateRemoteUserTimestamp("kaddressbook"); +#endif + DCOPRef kaddressbook( "kaddressbook", "KAddressBookIface" ); + kaddressbook.send( "showContactEditor", uri.mid( 6 ) ); + return true; + } else { + /* + KaddressBook is not already running. Pass it the UID of the contact via the command line while starting it - its neater. + We start it without its main interface + */ + QString iconPath = KGlobal::iconLoader()->iconPath( "go", KIcon::Small ); + QString tmpStr = "kaddressbook --editor-only --uid "; + tmpStr += KProcess::quote( uri.mid( 6 ) ); + KRun::runCommand( tmpStr, "KAddressBook", iconPath ); + return true; + } + } + else { // no special URI, let KDE handle it + new KRun(KURL( uri )); + } +#endif + + return false; +} |