~chris.gagnon/+junk/qtpim-coverage

« back to all changes in this revision

Viewing changes to src/organizer/requests/qorganizeritemremoverequest.cpp

  • Committer: chris.gagnon
  • Date: 2013-12-10 23:09:37 UTC
  • Revision ID: chris.gagnon@canonical.com-20131210230937-2akf1ft1edcttk87
first post

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
 
4
** Contact: http://www.qt-project.org/legal
 
5
**
 
6
** This file is part of the QtOrganizer module of the Qt Toolkit.
 
7
**
 
8
** $QT_BEGIN_LICENSE:LGPL$
 
9
** Commercial License Usage
 
10
** Licensees holding valid commercial Qt licenses may use this file in
 
11
** accordance with the commercial license agreement provided with the
 
12
** Software or, alternatively, in accordance with the terms contained in
 
13
** a written agreement between you and Digia.  For licensing terms and
 
14
** conditions see http://qt.digia.com/licensing.  For further information
 
15
** use the contact form at http://qt.digia.com/contact-us.
 
16
**
 
17
** GNU Lesser General Public License Usage
 
18
** Alternatively, this file may be used under the terms of the GNU Lesser
 
19
** General Public License version 2.1 as published by the Free Software
 
20
** Foundation and appearing in the file LICENSE.LGPL included in the
 
21
** packaging of this file.  Please review the following information to
 
22
** ensure the GNU Lesser General Public License version 2.1 requirements
 
23
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
 
24
**
 
25
** In addition, as a special exception, Digia gives you certain additional
 
26
** rights.  These rights are described in the Digia Qt LGPL Exception
 
27
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
 
28
**
 
29
** GNU General Public License Usage
 
30
** Alternatively, this file may be used under the terms of the GNU
 
31
** General Public License version 3.0 as published by the Free Software
 
32
** Foundation and appearing in the file LICENSE.GPL included in the
 
33
** packaging of this file.  Please review the following information to
 
34
** ensure the GNU General Public License version 3.0 requirements will be
 
35
** met: http://www.gnu.org/copyleft/gpl.html.
 
36
**
 
37
**
 
38
** $QT_END_LICENSE$
 
39
**
 
40
****************************************************************************/
 
41
 
 
42
#include <qorganizeritemremoverequest.h>
 
43
#include <private/qorganizeritemrequests_p.h>
 
44
 
 
45
QT_BEGIN_NAMESPACE_ORGANIZER
 
46
 
 
47
/*!
 
48
    \class QOrganizerItemRemoveRequest
 
49
    \brief The QOrganizerItemRemoveRequest class allows a client to asynchronously request that certain
 
50
           organizer items be removed from a backend.
 
51
    \inmodule QtOrganizer
 
52
    \ingroup organizer-requests
 
53
 
 
54
    This request will remove the items and all the occurrences (both generated and persisted) of the
 
55
    given items.
 
56
 */
 
57
 
 
58
/*!
 
59
    Constructs a new organizer item remove request whose parent is the specified \a parent.
 
60
*/
 
61
QOrganizerItemRemoveRequest::QOrganizerItemRemoveRequest(QObject *parent)
 
62
    : QOrganizerAbstractRequest(new QOrganizerItemRemoveRequestPrivate, parent)
 
63
{
 
64
}
 
65
 
 
66
/*!
 
67
    Frees memory in use by this request.
 
68
*/
 
69
QOrganizerItemRemoveRequest::~QOrganizerItemRemoveRequest()
 
70
{
 
71
    QOrganizerAbstractRequestPrivate::notifyEngine(this);
 
72
}
 
73
 
 
74
/*!
 
75
  Sets the organizer item which will be removed to \a item.
 
76
  Equivalent to calling:
 
77
  \code
 
78
      setOrganizerItems(QList<QOrganizerItem>() << item);
 
79
  \endcode
 
80
 */
 
81
void QOrganizerItemRemoveRequest::setItem(const QOrganizerItem &item)
 
82
{
 
83
    Q_D(QOrganizerItemRemoveRequest);
 
84
    QMutexLocker ml(&d->m_mutex);
 
85
    d->m_organizeritems.clear();
 
86
    d->m_organizeritems.append(item);
 
87
}
 
88
 
 
89
/*! Sets the organizer items which will be removed to \a items
 
90
*/
 
91
void QOrganizerItemRemoveRequest::setItems(const QList<QOrganizerItem> &items)
 
92
{
 
93
    Q_D(QOrganizerItemRemoveRequest);
 
94
    QMutexLocker ml(&d->m_mutex);
 
95
    d->m_organizeritems = items;
 
96
}
 
97
 
 
98
/*!
 
99
    Returns the list of IDs of organizer items which will be removed.
 
100
*/
 
101
QList<QOrganizerItem> QOrganizerItemRemoveRequest::items() const
 
102
{
 
103
    Q_D(const QOrganizerItemRemoveRequest);
 
104
    QMutexLocker ml(&d->m_mutex);
 
105
    return d->m_organizeritems;
 
106
}
 
107
 
 
108
/*!
 
109
    Returns the map of input organizer item list indices to errors which occurred.
 
110
*/
 
111
QMap<int, QOrganizerManager::Error> QOrganizerItemRemoveRequest::errorMap() const
 
112
{
 
113
    Q_D(const QOrganizerItemRemoveRequest);
 
114
    QMutexLocker ml(&d->m_mutex);
 
115
    return d->m_errors;
 
116
}
 
117
 
 
118
#include "moc_qorganizeritemremoverequest.cpp"
 
119
 
 
120
QT_END_NAMESPACE_ORGANIZER