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

kabc

  • sources
  • kde-4.14
  • kdepimlibs
  • kabc
impp.cpp
1 /*
2  This file is part of libkabc.
3  Copyright (c) 2015 Laurent Montel <montel@kde.org>
4 
5  This library is free software; you can redistribute it and/or
6  modify it under the terms of the GNU Library General Public
7  License as published by the Free Software Foundation; either
8  version 2 of the License, or (at your option) any later version.
9 
10  This library is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  Library General Public License for more details.
14 
15  You should have received a copy of the GNU Library General Public License
16  along with this library; see the file COPYING.LIB. If not, write to
17  the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18  Boston, MA 02110-1301, USA.
19 */
20 
21 #include "impp.h"
22 
23 #include <QMap>
24 #include <qstringlist.h>
25 
26 using namespace KABC;
27 
28 class Impp::Private : public QSharedData
29 {
30 public:
31  Private()
32  {
33  }
34 
35  Private( const Private &other )
36  : QSharedData( other )
37  {
38  address = other.address;
39  imType = other.imType;
40  parameters = other.parameters;
41  }
42  QMap<QString, QStringList> parameters;
43  QString address;
44  QString imType;
45 };
46 
47 Impp::Impp()
48  : d(new Private)
49 {
50 
51 }
52 
53 Impp::Impp(const Impp &other)
54  : d( other.d )
55 {
56 }
57 
58 Impp::Impp(const QString &address)
59  : d(new Private)
60 {
61  d->address = address;
62 }
63 
64 Impp::~Impp()
65 {
66 
67 }
68 
69 bool Impp::isValid() const
70 {
71  return !d->address.isEmpty() && !d->imType.isEmpty();
72 }
73 
74 void Impp::setIMType(const QString &type)
75 {
76  d->imType = type;
77 }
78 
79 QString Impp::imType() const
80 {
81  return d->imType;
82 }
83 
84 void Impp::setAddress(const QString &address)
85 {
86  d->address = address;
87 }
88 
89 QString Impp::address() const
90 {
91  return d->address;
92 }
93 
94 void Impp::setParameters(const QMap<QString, QStringList> &params)
95 {
96  d->parameters = params;
97 }
98 
99 QMap<QString, QStringList> Impp::parameters() const
100 {
101  return d->parameters;
102 }
103 
104 bool Impp::operator==(const Impp &other) const
105 {
106  return (d->parameters == other.parameters()) && (d->address == other.address()) && (d->imType == other.imType());
107 }
108 
109 bool Impp::operator!=(const Impp &other) const
110 {
111  return !( other == *this );
112 }
113 
114 Impp &Impp::operator=(const Impp &other)
115 {
116  if ( this != &other ) {
117  d = other.d;
118  }
119 
120  return *this;
121 }
122 
123 QString Impp::toString() const
124 {
125  QString str;
126  str += QString::fromLatin1( "Impp {\n" );
127  str += QString::fromLatin1( " address: %1\n" ).arg( d->address );
128  str += QString::fromLatin1( " type: %1\n" ).arg( d->imType );
129  if (!d->parameters.isEmpty()) {
130  QMapIterator<QString, QStringList> i(d->parameters);
131  QString param;
132  while (i.hasNext()) {
133  i.next();
134  param += QString::fromLatin1("%1 %2").arg(i.key()).arg(i.value().join(QLatin1String(",")));
135  }
136  str += QString::fromLatin1( " parameters: %1\n" ).arg( param );
137  }
138  str += QString::fromLatin1( "}\n" );
139  return str;
140 }
141 
142 
143 QDataStream &KABC::operator<<(QDataStream &s, const Impp &impp)
144 {
145  return s << impp.d->parameters << impp.d->address << impp.d->imType;
146 }
147 
148 QDataStream &KABC::operator>>(QDataStream &s, Impp &impp)
149 {
150  s >> impp.d->parameters >> impp.d->address >> impp.d->imType;
151  return s;
152 }
QDataStream
QMap< QString, QStringList >
KABC::operator<<
QDataStream & operator<<(QDataStream &stream, const Address &address)
Serializes the address object into the stream.
Definition: address.cpp:680
QSharedData
QMapIterator
QString::isEmpty
bool isEmpty() const
QString
KABC::operator>>
QDataStream & operator>>(QDataStream &stream, Address &address)
Initializes the address object from the stream.
Definition: address.cpp:688
QLatin1String
QString::fromLatin1
QString fromLatin1(const char *str, int size)
QString::arg
QString arg(qlonglong a, int fieldWidth, int base, const QChar &fillChar) const
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:38:38 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

kabc

Skip menu "kabc"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • 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