Imported Upstream version 0.8~alpha1
[platform/upstream/syncevolution.git] / src / client-api / src / c++ / common / base / util / ItemContainer.cpp
1 /*
2  * Funambol is a mobile platform developed by Funambol, Inc. 
3  * Copyright (C) 2003 - 2007 Funambol, Inc.
4  * 
5  * This program is free software; you can redistribute it and/or modify it under
6  * the terms of the GNU Affero General Public License version 3 as published by
7  * the Free Software Foundation with the addition of the following permission 
8  * added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
9  * WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE 
10  * WARRANTY OF NON INFRINGEMENT  OF THIRD PARTY RIGHTS.
11  * 
12  * This program is distributed in the hope that it will be useful, but WITHOUT
13  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
15  * details.
16  * 
17  * You should have received a copy of the GNU Affero General Public License 
18  * along with this program; if not, see http://www.gnu.org/licenses or write to
19  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
20  * MA 02110-1301 USA.
21  * 
22  * You can contact Funambol, Inc. headquarters at 643 Bair Island Road, Suite 
23  * 305, Redwood City, CA 94063, USA, or at email address info@funambol.com.
24  * 
25  * The interactive user interfaces in modified source and object code versions
26  * of this program must display Appropriate Legal Notices, as required under
27  * Section 5 of the GNU Affero General Public License version 3.
28  * 
29  * In accordance with Section 7(b) of the GNU Affero General Public License
30  * version 3, these Appropriate Legal Notices must retain the display of the
31  * "Powered by Funambol" logo. If the display of the logo is not reasonably 
32  * feasible for technical reasons, the Appropriate Legal Notices must display
33  * the words "Powered by Funambol".
34  */
35
36
37 #include "base/util/ItemContainer.h"
38 #include "base/util/utils.h"
39 #include "base/Log.h"
40 #include "base/globalsdef.h"
41
42 USE_NAMESPACE
43
44
45 ItemContainer::ItemContainer() {
46     allItems = new ArrayList();
47     newItems = new ArrayList();
48     updatedItems = new ArrayList();
49     deletedItems = new ArrayList();
50 }
51
52 ItemContainer::~ItemContainer() {
53     allItems->clear();
54     newItems->clear();
55     updatedItems->clear();
56     deletedItems->clear();
57 }
58 /**
59 * Function for ALL ITEMS ArrayList
60 */
61
62 void ItemContainer::addItemToAllItems(SyncItem* syncItem) {
63     if (syncItem == NULL)
64         return;
65     allItems->add(*syncItem);
66 }
67
68 int ItemContainer::getAllItemsSize() {
69     return allItems->size();
70 }
71
72 void ItemContainer::resetAllItems() {
73     allItems->clear();
74 }
75
76 ArrayList* ItemContainer::getAllItems() {
77     return allItems;
78 }
79
80 /**
81 * Function for NEW ITEMS ArrayList
82 */
83 void ItemContainer::addItemToNewItems(SyncItem* syncItem) {
84     if (syncItem == NULL)
85         return;
86     newItems->add(*syncItem);
87 }
88
89 int ItemContainer::getNewItemsSize() {
90     return newItems->size();
91 }
92
93 void ItemContainer::resetNewItems() {
94     newItems->clear();
95 }
96
97
98 ArrayList* ItemContainer::getNewItems() {
99     return newItems;
100 }
101
102 /**
103 * Function for UPDATED ITEMS ArrayList
104 */
105 void ItemContainer::addItemToUpdatedItems(SyncItem* syncItem) {
106     if (syncItem == NULL)
107         return;
108     updatedItems->add(*syncItem);
109 }
110
111 int ItemContainer::getUpdatedItemsSize() {
112     return updatedItems->size();
113 }
114
115 void ItemContainer::resetUpdatedItems() {
116     updatedItems->clear();
117 }
118
119
120 ArrayList* ItemContainer::getUpdatedItems() {
121     return updatedItems;
122 }
123
124 /**
125 * Function for DELETED ITEMS ArrayList
126 */
127 void ItemContainer::addItemToDeletedItems(SyncItem* syncItem) {
128     if (syncItem == NULL)
129         return;
130     deletedItems->add(*syncItem);
131 }
132
133 int ItemContainer::getDeletedItemsSize() {
134     return deletedItems->size();
135 }
136
137 void ItemContainer::resetDeletedItems() {
138     deletedItems->clear();
139 }
140
141
142 ArrayList* ItemContainer::getDeletedItems() {
143     return deletedItems;
144 }
145
146