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

akonadi

  • sources
  • kde-4.14
  • kdepimlibs
  • akonadi
collectionquotaattribute.cpp
1 /*
2  Copyright (C) 2009 Kevin Ottens <ervin@kde.org>
3 
4  This library is free software; you can redistribute it and/or modify it
5  under the terms of the GNU Library General Public License as published by
6  the Free Software Foundation; either version 2 of the License, or (at your
7  option) any later version.
8 
9  This library is distributed in the hope that it will be useful, but WITHOUT
10  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
12  License for more details.
13 
14  You should have received a copy of the GNU Library General Public License
15  along with this library; see the file COPYING.LIB. If not, write to the
16  Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17  02110-1301, USA.
18 */
19 
20 #include "collectionquotaattribute.h"
21 
22 #include <QtCore/QByteArray>
23 
24 using namespace Akonadi;
25 
26 class CollectionQuotaAttribute::Private
27 {
28 public:
29  Private(qint64 currentValue, qint64 maxValue)
30  : mCurrentValue(currentValue)
31  , mMaximumValue(maxValue)
32  {
33  }
34 
35  qint64 mCurrentValue;
36  qint64 mMaximumValue;
37 };
38 
39 CollectionQuotaAttribute::CollectionQuotaAttribute()
40  : d(new Private(-1, -1))
41 {
42 }
43 
44 CollectionQuotaAttribute::CollectionQuotaAttribute(qint64 currentValue, qint64 maxValue)
45  : d(new Private(currentValue, maxValue))
46 {
47 }
48 
49 CollectionQuotaAttribute::~CollectionQuotaAttribute()
50 {
51  delete d;
52 }
53 
54 void CollectionQuotaAttribute::setCurrentValue(qint64 value)
55 {
56  d->mCurrentValue = value;
57 }
58 
59 void CollectionQuotaAttribute::setMaximumValue(qint64 value)
60 {
61  d->mMaximumValue = value;
62 }
63 
64 qint64 CollectionQuotaAttribute::currentValue() const
65 {
66  return d->mCurrentValue;
67 }
68 
69 qint64 CollectionQuotaAttribute::maximumValue() const
70 {
71  return d->mMaximumValue;
72 }
73 
74 QByteArray CollectionQuotaAttribute::type() const
75 {
76  static const QByteArray sType( "collectionquota" );
77  return sType;
78 }
79 
80 Akonadi::Attribute *CollectionQuotaAttribute::clone() const
81 {
82  return new CollectionQuotaAttribute(d->mCurrentValue, d->mMaximumValue);
83 }
84 
85 QByteArray CollectionQuotaAttribute::serialized() const
86 {
87  return QByteArray::number(d->mCurrentValue)
88  + ' '
89  + QByteArray::number(d->mMaximumValue);
90 }
91 
92 void CollectionQuotaAttribute::deserialize(const QByteArray &data)
93 {
94  d->mCurrentValue = -1;
95  d->mMaximumValue = -1;
96 
97  const QList<QByteArray> items = data.simplified().split(' ');
98 
99  if (items.isEmpty()) {
100  return;
101  }
102 
103  d->mCurrentValue = items[0].toLongLong();
104 
105  if (items.size() < 2) {
106  return;
107  }
108 
109  d->mMaximumValue = items[1].toLongLong();
110 }
QByteArray::split
QList< QByteArray > split(char sep) const
QByteArray
Akonadi::CollectionQuotaAttribute::serialized
virtual QByteArray serialized() const
Returns a QByteArray representation of the attribute which will be storaged.
Definition: collectionquotaattribute.cpp:85
Akonadi::CollectionQuotaAttribute::setCurrentValue
void setCurrentValue(qint64 value)
Sets the current quota value for the collection.
Definition: collectionquotaattribute.cpp:54
Akonadi::Attribute
Provides interface for custom attributes for Entity.
Definition: attribute.h:138
QList::size
int size() const
Akonadi::CollectionQuotaAttribute::setMaximumValue
void setMaximumValue(qint64 value)
Sets the maximum quota value for the collection.
Definition: collectionquotaattribute.cpp:59
Akonadi::CollectionQuotaAttribute::currentValue
qint64 currentValue() const
Returns the current quota value in bytes.
Definition: collectionquotaattribute.cpp:64
QList::isEmpty
bool isEmpty() const
Akonadi::CollectionQuotaAttribute::CollectionQuotaAttribute
CollectionQuotaAttribute()
Creates a new collection quota attribute.
Definition: collectionquotaattribute.cpp:39
QByteArray::number
QByteArray number(int n, int base)
QList< QByteArray >
Akonadi::CollectionQuotaAttribute::maximumValue
qint64 maximumValue() const
Returns the maximum quota value in bytes.
Definition: collectionquotaattribute.cpp:69
QByteArray::simplified
QByteArray simplified() const
Akonadi::CollectionQuotaAttribute::deserialize
virtual void deserialize(const QByteArray &data)
Sets the data of this attribute, using the same encoding as returned by toByteArray().
Definition: collectionquotaattribute.cpp:92
Akonadi::CollectionQuotaAttribute::type
virtual QByteArray type() const
Returns the type of the attribute.
Definition: collectionquotaattribute.cpp:74
Akonadi::CollectionQuotaAttribute::~CollectionQuotaAttribute
~CollectionQuotaAttribute()
Destroys the collection quota attribute.
Definition: collectionquotaattribute.cpp:49
Akonadi::CollectionQuotaAttribute::clone
virtual Attribute * clone() const
Creates a copy of this attribute.
Definition: collectionquotaattribute.cpp:80
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:38:02 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

akonadi

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

kdepimlibs API Reference

Skip menu "kdepimlibs API Reference"
  • akonadi
  •   contact
  •   kmime
  •   socialutils
  • kabc
  • kalarmcal
  • kblog
  • kcal
  • kcalcore
  • kcalutils
  • kholidays
  • kimap
  • kioslave
  •   imap4
  •   mbox
  •   nntp
  • kldap
  • kmbox
  • kmime
  • kontactinterface
  • kpimidentities
  • kpimtextedit
  • kpimutils
  • kresources
  • ktnef
  • kxmlrpcclient
  • mailtransport
  • microblog
  • qgpgme
  • syndication
  •   atom
  •   rdf
  •   rss2

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