akonadi
linkjobimpl_p.h
00001 /* 00002 Copyright (c) 2008,2009 Volker Krause <vkrause@kde.org> 00003 00004 This library is free software; you can redistribute it and/or modify it 00005 under the terms of the GNU Library General Public License as published by 00006 the Free Software Foundation; either version 2 of the License, or (at your 00007 option) any later version. 00008 00009 This library is distributed in the hope that it will be useful, but WITHOUT 00010 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00011 FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public 00012 License for more details. 00013 00014 You should have received a copy of the GNU Library General Public License 00015 along with this library; see the file COPYING.LIB. If not, write to the 00016 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 00017 02110-1301, USA. 00018 */ 00019 00020 #ifndef AKONADI_LINKJOBIMPL_P_H 00021 #define AKONADI_LINKJOBIMPL_P_H 00022 00023 #include "collection.h" 00024 #include "item.h" 00025 #include "job.h" 00026 #include "job_p.h" 00027 #include "protocolhelper_p.h" 00028 00029 #include <kdebug.h> 00030 #include <KLocale> 00031 00032 namespace Akonadi { 00033 00035 template <typename LinkJob> class LinkJobImpl : public JobPrivate 00036 { 00037 public: 00038 LinkJobImpl( Job *parent ) : JobPrivate( parent ) {} 00039 00040 inline void sendCommand( const char* asapCommand ) 00041 { 00042 LinkJob *q = static_cast<LinkJob*>( q_func() ); // Job would be enough already, but then we don't have access to the non-public stuff... 00043 if ( objectsToLink.isEmpty() ) { 00044 q->emitResult(); 00045 return; 00046 } 00047 if ( !destination.isValid() && destination.remoteId().isEmpty() ) { 00048 q->setError( Job::Unknown ); 00049 q->setErrorText( i18n( "No valid destination specified" ) ); 00050 q->emitResult(); 00051 return; 00052 } 00053 00054 QByteArray command = newTag(); 00055 try { 00056 command += ProtocolHelper::entitySetToByteArray( Collection::List() << destination, asapCommand ); 00057 } catch ( const std::exception &e ) { 00058 q->setError( Job::Unknown ); 00059 q->setErrorText( QString::fromUtf8( e.what() ) ); 00060 q->emitResult(); 00061 return; 00062 } 00063 00064 command += ProtocolHelper::entitySetToByteArray( objectsToLink, QByteArray() ); 00065 command += '\n'; 00066 00067 writeData( command ); 00068 } 00069 00070 Item::List objectsToLink; 00071 Collection destination; 00072 }; 00073 00074 } 00075 00076 #endif
This file is part of the KDE documentation.
Documentation copyright © 1996-2012 The KDE developers.
Generated on Thu Aug 2 2012 15:25:19 by doxygen 1.7.5 written by Dimitri van Heesch, © 1997-2006
Documentation copyright © 1996-2012 The KDE developers.
Generated on Thu Aug 2 2012 15:25:19 by doxygen 1.7.5 written by Dimitri van Heesch, © 1997-2006
KDE's Doxygen guidelines are available online.