• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdepim API Reference
  • KDE Home
  • Contact Us
 

mailcommon

  • sources
  • kde-4.12
  • kdepim
  • mailcommon
  • filter
filteractionunsetstatus.cpp
Go to the documentation of this file.
1 /* -*- mode: C++; c-file-style: "gnu" -*-
2 
3  Copyright (c) 2012 Montel Laurent <montel@kde.org>
4 
5  This program is free software; you can redistribute it and/or modify it
6  under the terms of the GNU General Public License, version 2, as
7  published by the Free Software Foundation.
8 
9  This program is distributed in the hope that it will be useful, but
10  WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License along
15  with this program; if not, write to the Free Software Foundation, Inc.,
16  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18 
19 #include "filteractionunsetstatus.h"
20 
21 #include <KDE/KLocale>
22 using namespace MailCommon;
23 
24 FilterAction* FilterActionUnsetStatus::newAction()
25 {
26  return new FilterActionUnsetStatus;
27 }
28 
29 FilterActionUnsetStatus::FilterActionUnsetStatus( QObject *parent )
30  : FilterActionStatus( QLatin1String("unset status"), i18nc( "action: to unset the status", "Unset Status" ), parent )
31 {
32 }
33 
34 FilterAction::ReturnCode FilterActionUnsetStatus::process(ItemContext &context , bool) const
35 {
36  const int index = mParameterList.indexOf( mParameter );
37  if ( index < 1 )
38  return ErrorButGoOn;
39 
40  Akonadi::MessageStatus status;
41  status.setStatusFromFlags( context.item().flags() );
42 
43 
44  Akonadi::MessageStatus newStatus = FilterActionStatus::stati[ index - 1 ];
45  //Laurent unread status doesn't exist. And crash if we use "const Akonadi::Item::Flag flag = *(flags.begin());" etc. => if we unset "unread" we set read
46  if ( newStatus == Akonadi::MessageStatus::statusUnread() ) {
47  Akonadi::MessageStatus oldStatus = status;
48  newStatus.setRead( true );
49  if ( oldStatus != newStatus ) {
50  context.item().setFlags( newStatus.statusFlags() );
51  context.setNeedsFlagStore();
52  }
53  return GoOn;
54  }
55 
56  QSet<QByteArray> flags = newStatus.statusFlags();
57  const Akonadi::Item::Flag flag = *(flags.begin());
58  if ( context.item().hasFlag( flag ) ) {
59  context.item().clearFlag( flag );
60  context.setNeedsFlagStore();
61  }
62  return GoOn;
63 }
64 
65 SearchRule::RequiredPart FilterActionUnsetStatus::requiredPart() const
66 {
67  return SearchRule::Envelope;
68 }
69 
70 QString FilterActionUnsetStatus::sieveCode() const
71 {
72  QString flagCode;
73  const QString parameter = argsAsString();
74  if (parameter == QLatin1String("R")) {
75  flagCode = QLatin1String("\\\\Seen");
76  } else if (parameter == QLatin1String("D")) {
77  flagCode = QLatin1String("\\\\Deleted");
78  } else if (parameter == QLatin1String("A")) {
79  flagCode =QLatin1String("\\\\Answered");
80  } else {
81  qDebug()<<" FilterActionSetStatus::sieveCode() unknown flags"<<parameter;
82  flagCode = parameter;
83  }
84 
85  const QString result = QString::fromLatin1("removeflag \"%1\";").arg(flagCode);
86  return result;
87 }
88 
89 QStringList FilterActionUnsetStatus::sieveRequires() const
90 {
91  return QStringList() << QLatin1String("imap4flags");
92 }
93 
94 #include "filteractionunsetstatus.moc"
MailCommon::FilterActionUnsetStatus::process
ReturnCode process(ItemContext &context, bool applyOnOutbound) const
Execute action on given message (inside the item context).
Definition: filteractionunsetstatus.cpp:34
MailCommon::FilterActionStatus::argsAsString
QString argsAsString() const
Return extra arguments as string.
Definition: filteractionstatus.cpp:99
MailCommon::FilterAction::GoOn
Go on with applying filter actions.
Definition: filteraction.h:62
MailCommon::FilterActionStatus
Definition: filteractionstatus.h:26
QObject
filteractionunsetstatus.h
MailCommon::FilterAction
Abstract base class for mail filter actions.
Definition: filteraction.h:52
MailCommon::FilterActionUnsetStatus::sieveCode
QString sieveCode() const
Definition: filteractionunsetstatus.cpp:70
MailCommon::FilterActionWithStringList::mParameterList
QStringList mParameterList
Definition: filteractionwithstringlist.h:85
MailCommon::FilterAction::ErrorButGoOn
A non-critical error occurred.
Definition: filteraction.h:63
MailCommon::FilterActionStatus::stati
static Akonadi::MessageStatus stati[]
Definition: filteractionstatus.h:39
MailCommon::SearchRule::RequiredPart
RequiredPart
Definition: searchpattern.h:104
MailCommon::FilterActionUnsetStatus::newAction
static FilterAction * newAction()
Definition: filteractionunsetstatus.cpp:24
MailCommon::SearchRule::Envelope
Definition: searchpattern.h:105
MailCommon::FilterActionWithString::mParameter
QString mParameter
Definition: filteractionwithstring.h:91
MailCommon::FilterActionUnsetStatus::requiredPart
SearchRule::RequiredPart requiredPart() const
Returns the required part from the item that is needed for the action to operate. ...
Definition: filteractionunsetstatus.cpp:65
MailCommon::FilterAction::ReturnCode
ReturnCode
Describes the possible return codes of filter processing:
Definition: filteraction.h:60
MailCommon::ItemContext::item
Akonadi::Item & item()
Returns the item of the context.
Definition: itemcontext.cpp:30
context
const char * context
Definition: searchpatternedit.cpp:54
MailCommon::ItemContext::setNeedsFlagStore
void setNeedsFlagStore()
Marks that the item's flags has been changed and needs to be written back.
Definition: itemcontext.cpp:55
MailCommon::ItemContext
A helper class for the filtering process.
Definition: itemcontext.h:39
MailCommon::FilterActionUnsetStatus::sieveRequires
QStringList sieveRequires() const
Definition: filteractionunsetstatus.cpp:89
MailCommon::FilterActionUnsetStatus::FilterActionUnsetStatus
FilterActionUnsetStatus(QObject *parent=0)
Definition: filteractionunsetstatus.cpp:29
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:55:14 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

mailcommon

Skip menu "mailcommon"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

kdepim API Reference

Skip menu "kdepim API Reference"
  • akonadi_next
  • akregator
  • blogilo
  • calendarsupport
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt2
  • kjots
  • kleopatra
  • kmail
  • knode
  • knotes
  • kontact
  • korgac
  • korganizer
  • ktimetracker
  • libkdepim
  • libkleo
  • libkpgp
  • mailcommon
  • messagelist
  • messageviewer

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal