test/integration/MappingTestSyncSource.h

00001 /*
00002  * Funambol is a mobile platform developed by Funambol, Inc. 
00003  * Copyright (C) 2003 - 2007 Funambol, Inc.
00004  * 
00005  * This program is free software; you can redistribute it and/or modify it under
00006  * the terms of the GNU Affero General Public License version 3 as published by
00007  * the Free Software Foundation with the addition of the following permission 
00008  * added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
00009  * WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE 
00010  * WARRANTY OF NON INFRINGEMENT  OF THIRD PARTY RIGHTS.
00011  * 
00012  * This program is distributed in the hope that it will be useful, but WITHOUT
00013  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
00014  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
00015  * details.
00016  * 
00017  * You should have received a copy of the GNU Affero General Public License 
00018  * along with this program; if not, see http://www.gnu.org/licenses or write to
00019  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
00020  * MA 02110-1301 USA.
00021  * 
00022  * You can contact Funambol, Inc. headquarters at 643 Bair Island Road, Suite 
00023  * 305, Redwood City, CA 94063, USA, or at email address info@funambol.com.
00024  * 
00025  * The interactive user interfaces in modified source and object code versions
00026  * of this program must display Appropriate Legal Notices, as required under
00027  * Section 5 of the GNU Affero General Public License version 3.
00028  * 
00029  * In accordance with Section 7(b) of the GNU Affero General Public License
00030  * version 3, these Appropriate Legal Notices must retain the display of the
00031  * "Powered by Funambol" logo. If the display of the logo is not reasonably 
00032  * feasible for technical reasons, the Appropriate Legal Notices must display
00033  * the words "Powered by Funambol".
00034  */
00035 
00036 #ifndef INCL_MAPPING_TEST_SYNC_SOURCE
00037 #define INCL_MAPPING_TEST_SYNC_SOURCE
00038 
00040 #include "base/fscapi.h"
00041 #include "spds/constants.h"
00042 #include "spds/SyncItem.h"
00043 #include "spds/SyncMap.h"
00044 #include "spds/SyncStatus.h"
00045 #include "spds/SyncSource.h"
00046 #include "spds/SyncSourceConfig.h"
00047 #include "base/globalsdef.h"
00048 
00049 #include "event/SetListener.h"
00050 
00051 #include "event/SyncItemEvent.h"
00052 #include "event/SyncItemListener.h"
00053 
00054 BEGIN_NAMESPACE
00055 
00056 class  MappingTestSyncSource : public SyncSource {
00057 
00058 private:
00059     
00060     // it is an internal counter to make the card unique
00061     int count;
00062 
00063     // it returns a unique card 
00064     StringBuffer getNewCard();
00065 
00066 public:
00067     
00068     
00075     MappingTestSyncSource(const WCHAR* name, SyncSourceConfig *sc) ;
00076 
00077     // MappingTestSyncSource
00078     ~MappingTestSyncSource() {}
00079 
00080     /*
00081      * Return the first SyncItem of all.
00082      * It is used in case of slow or refresh sync
00083      * and retrieve the entire data source content.
00084      */
00085     SyncItem* getFirstItem(){ return NULL; }
00086 
00087     /*
00088      * Return the next SyncItem of all.
00089      * It is used in case of slow or refresh sync
00090      * and retrieve the entire data source content.
00091      */
00092     SyncItem* getNextItem(){ return NULL; }
00093 
00094     /*
00095      * Return the first SyncItem of new one. It is used in case of fast sync
00096      * and retrieve the new data source content.
00097      */
00098     SyncItem* getFirstNewItem();
00099 
00100     /*
00101      * Return the next SyncItem of new one. It is used in case of fast sync
00102      * and retrieve the new data source content.
00103      */
00104     SyncItem* getNextNewItem();
00105 
00106     /*
00107      * Return the first SyncItem of updated one. It is used in case of fast sync
00108      * and retrieve the new data source content.
00109      */
00110     SyncItem* getFirstUpdatedItem() { return NULL; }
00111 
00112     /*
00113      * Return the next SyncItem of updated one. It is used in case of fast sync
00114      * and retrieve the new data source content.
00115      */
00116     SyncItem* getNextUpdatedItem() { return NULL; }
00117 
00118     /*
00119      * Return the next SyncItem of updated one. It is used in case of fast sync
00120      * and retrieve the new data source content.
00121      */
00122 
00123     SyncItem* getFirstItemKey() { return NULL; }
00124 
00125     /*
00126      * Return the key of the next SyncItem of all.
00127      * It is used in case of refresh sync
00128      * and retrieve all the keys of the data source.
00129      */
00130      
00131     SyncItem* getNextItemKey() { return NULL; }
00132     /*
00133      * Return the first SyncItem of updated one. It is used in case of fast sync
00134      * and retrieve the new data source content.
00135      */
00136     SyncItem* getFirstDeletedItem(){ return NULL; }
00137 
00138     SyncItem* getNextDeletedItem(){ return NULL; }
00139 
00140     void setItemStatus(const WCHAR* key, int status);
00141 
00142     int addItem(SyncItem& item);
00143 
00144     int updateItem(SyncItem& item) { return 200; }
00145 
00146     int deleteItem(SyncItem& item) { return 200; }
00147     
00148     int removeAllItems() { return 0; }
00149     int beginSync();
00150 
00151     int endSync();
00152 
00153     ArrayElement* clone() { return 0; }
00154 };
00155 
00156 class SyncItemListenerClient: public SyncItemListener {
00157     static int itemcounter;
00158 public:
00159     SyncItemListenerClient() {}
00160     virtual ~SyncItemListenerClient() {}
00161         void itemAddedByServer(SyncItemEvent &event);
00162         void itemAddedByClient(SyncItemEvent &event);
00163         void itemDeletedByServer(SyncItemEvent &event);
00164         void itemDeletedByClient(SyncItemEvent &event) ;
00165         void itemUpdatedByServer(SyncItemEvent &event) ;
00166         void itemUpdatedByClient(SyncItemEvent &event);
00167 };
00168 
00169 class MappingException {
00170 
00171 public:
00172 
00173     MappingException() {}
00174     ~MappingException() {}
00175 
00176 };
00177 
00178 END_NAMESPACE
00179 
00181 #endif

Generated on Wed Jan 14 17:15:37 2009 for Funambol C++ Client Library by  doxygen 1.5.2