akonadi
movejobimpl_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_MOVEJOBIMPL_P_H 00021 #define AKONADI_MOVEJOBIMPL_P_H 00022 00023 #include "collection.h" 00024 #include "job.h" 00025 #include "job_p.h" 00026 #include "protocolhelper_p.h" 00027 00028 #include <KLocale> 00029 00030 namespace Akonadi { 00031 00033 template <typename T, typename MoveJob> class MoveJobImpl : public JobPrivate 00034 { 00035 public: 00036 MoveJobImpl( Job *parent ) : JobPrivate( parent ) {} 00037 00038 inline void sendCommand( const char* asapCommand ) 00039 { 00040 MoveJob *q = static_cast<MoveJob*>( q_func() ); // Job would be enough already, but then we don't have access to the non-public stuff... 00041 if ( objectsToMove.isEmpty() ) { 00042 q->setError( Job::Unknown ); 00043 q->setErrorText( i18n( "No objects specified for moving" ) ); 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( objectsToMove, 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 command += ' '; 00064 if ( objectsToMove.first().isValid() ) // with all the checks done before this indicates now whether this is a UID or RID based operation 00065 command += QByteArray::number( destination.id() ); 00066 else 00067 command += ImapParser::quote( destination.remoteId().toUtf8() ); 00068 command += '\n'; 00069 writeData( command ); 00070 } 00071 00072 typename T::List objectsToMove; 00073 Collection destination; 00074 }; 00075 00076 } 00077 00078 #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.