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 "qcontactcollectionsaverequest.h"
36
37#include "qcontactrequests_p.h"
38
39QT_BEGIN_NAMESPACE_CONTACTS
40
41/*!
42 \class QContactCollectionSaveRequest
43 \brief The QContactCollectionSaveRequest class allows a client to asynchronously save collections
44 to a backend.
45 \inmodule QtContacts
46 \ingroup contact-requests
47 */
48
49/*!
50 Constructs a new collection save request whose parent is the specified \a parent.
51*/
52QContactCollectionSaveRequest::QContactCollectionSaveRequest(QObject *parent)
53 : QContactAbstractRequest(new QContactCollectionSaveRequestPrivate, parent)
54{
55}
56
57/*!
58 Frees memory in use by this request.
59*/
60QContactCollectionSaveRequest::~QContactCollectionSaveRequest()
61{
62}
63
64/*!
65 Sets the collection which will be saved to \a collection.
66*/
67void QContactCollectionSaveRequest::setCollection(const QContactCollection &collection)
68{
69 Q_D(QContactCollectionSaveRequest);
70 QMutexLocker ml(&d->m_mutex);
71 d->m_collections.clear();
72 d->m_collections.append(t: collection);
73}
74
75/*!
76 Sets the list of collections which will be saved to \a collections.
77*/
78void QContactCollectionSaveRequest::setCollections(const QList<QContactCollection> &collections)
79{
80 Q_D(QContactCollectionSaveRequest);
81 QMutexLocker ml(&d->m_mutex);
82 d->m_collections = collections;
83}
84
85/*!
86 Returns the collections which will be saved by this request if called prior to calling start(),
87 otherwise returns the (possibly updated) collections which have been saved.
88*/
89QList<QContactCollection> QContactCollectionSaveRequest::collections() const
90{
91 Q_D(const QContactCollectionSaveRequest);
92 QMutexLocker ml(&d->m_mutex);
93 return d->m_collections;
94}
95
96/*!
97 Returns the map of input definition list indices to errors which occurred.
98*/
99QMap<int, QContactManager::Error> QContactCollectionSaveRequest::errorMap() const
100{
101 Q_D(const QContactCollectionSaveRequest);
102 QMutexLocker ml(&d->m_mutex);
103 return d->m_errors;
104}
105
106#include "moc_qcontactcollectionsaverequest.cpp"
107
108QT_END_NAMESPACE_CONTACTS
109

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