1/****************************************************************************
2**
3** Copyright (C) 2015 The Qt Company Ltd.
4** Copyright (C) 2015 Canonical Ltd
5** Contact: http://www.qt.io/licensing/
6**
7** This file is part of the QtContacts module of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:LGPL21$
10** Commercial License Usage
11** Licensees holding valid commercial Qt licenses may use this file in
12** accordance with the commercial license agreement provided with the
13** Software or, alternatively, in accordance with the terms contained in
14** a written agreement between you and The Qt Company. For licensing terms
15** and conditions see http://www.qt.io/terms-conditions. For further
16** information use the contact form at http://www.qt.io/contact-us.
17**
18** GNU Lesser General Public License Usage
19** Alternatively, this file may be used under the terms of the GNU Lesser
20** General Public License version 2.1 or version 3 as published by the Free
21** Software Foundation and appearing in the file LICENSE.LGPLv21 and
22** LICENSE.LGPLv3 included in the packaging of this file. Please review the
23** following information to ensure the GNU Lesser General Public License
24** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
25** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
26**
27** As a special exception, The Qt Company gives you certain additional
28** rights. These rights are described in The Qt Company LGPL Exception
29** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
30**
31** $QT_END_LICENSE$
32**
33****************************************************************************/
34
35#include "qcontactcollectionremoverequest.h"
36
37#include "qcontactrequests_p.h"
38
39QT_BEGIN_NAMESPACE_CONTACTS
40
41/*!
42 \class QContactCollectionRemoveRequest
43 \brief The QContactCollectionRemoveRequest class allows a client to asynchronously remove
44 collections from a backend.
45 \inmodule QtContacts
46 \ingroup contact-requests
47 */
48
49/*!
50 Constructs a new collection remove request whose parent is the specified \a parent.
51*/
52QContactCollectionRemoveRequest::QContactCollectionRemoveRequest(QObject *parent)
53 : QContactAbstractRequest(new QContactCollectionRemoveRequestPrivate, parent)
54{
55}
56
57/*!
58 Frees memory in use by this request.
59*/
60QContactCollectionRemoveRequest::~QContactCollectionRemoveRequest()
61{
62}
63
64/*!
65 Sets the ID of collection which will be removed by this request to \a collectionId.
66*/
67void QContactCollectionRemoveRequest::setCollectionId(const QContactCollectionId &collectionId)
68{
69 Q_D(QContactCollectionRemoveRequest);
70 QMutexLocker ml(&d->m_mutex);
71 d->m_collectionIds.clear();
72 d->m_collectionIds.append(t: collectionId);
73}
74
75/*!
76 Sets the list of IDs of collections which will be removed by this request to \a collectionIds.
77*/
78void QContactCollectionRemoveRequest::setCollectionIds(const QList<QContactCollectionId> &collectionIds)
79{
80 Q_D(QContactCollectionRemoveRequest);
81 QMutexLocker ml(&d->m_mutex);
82 d->m_collectionIds = collectionIds;
83}
84
85/*!
86 Returns the list of IDs of collections which will be removed by this request.
87*/
88QList<QContactCollectionId> QContactCollectionRemoveRequest::collectionIds() const
89{
90 Q_D(const QContactCollectionRemoveRequest);
91 QMutexLocker ml(&d->m_mutex);
92 return d->m_collectionIds;
93}
94
95/*!
96 Returns any errors which occurred during the request.
97*/
98QMap<int, QContactManager::Error> QContactCollectionRemoveRequest::errorMap() const
99{
100 Q_D(const QContactCollectionRemoveRequest);
101 QMutexLocker ml(&d->m_mutex);
102 return d->m_errors;
103}
104
105#include "moc_qcontactcollectionremoverequest.cpp"
106
107QT_END_NAMESPACE_CONTACTS
108

source code of qtpim/src/contacts/requests/qcontactcollectionremoverequest.cpp