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_ALERT_CODE 00037 #define INCL_ALERT_CODE 00038 /** @cond DEV */ 00039 00040 #include "base/fscapi.h" 00041 00042 00043 #define DISPLAY 100 00044 #define TWO_WAY 200 00045 #define SLOW 201 00046 #define ONE_WAY_FROM_CLIENT 202 00047 #define REFRESH_FROM_CLIENT 203 00048 #define ONE_WAY_FROM_SERVER 204 00049 #define REFRESH_FROM_SERVER 205 00050 #define TWO_WAY_BY_SERVER 206 00051 #define ONE_WAY_FROM_CLIENT_BY_SERVER 207 00052 #define REFRESH_FROM_CLIENT_BY_SERVER 208 00053 #define ONE_WAY_FROM_SERVER_BY_SERVER 209 00054 #define REFRESH_FROM_SERVER_BY_SERVER 210 00055 #define RESULT_ALERT 221 00056 #define NEXT_MESSAGE 222 00057 #define NO_END_OF_DATA 223 00058 00059 00060 00061 /** 00062 * Determines if the given code is an initialization code, such as one of: 00063 * <ul> 00064 * <li> TWO_WAY 00065 * <li> SLOW 00066 * <li> ONE_WAY_FROM_CLIENT 00067 * <li> REFRESH_FROM_CLIENT 00068 * <li> ONE_WAY_FROM_SERVER 00069 * <li> REFRESH_FROM_SERVER 00070 * <li> TWO_WAY_BY_SERVER 00071 * <li> ONE_WAY_FROM_CLIENT_BY_SERVE 00072 * <li> REFRESH_FROM_CLIENT_BY_SERVER 00073 * <li> ONE_WAY_FROM_SERVER_BY_SERVER 00074 * <li> REFRESH_FROM_SERVER_BY_SERVER 00075 * </ul> 00076 * 00077 * @param code the code to be checked 00078 * 00079 * @return true if the code is an initialization code, false otherwise 00080 */ 00081 bool isInitializationCode(int code) { 00082 return ( (code == TWO_WAY ) 00083 || (code == SLOW ) 00084 || (code == ONE_WAY_FROM_CLIENT ) 00085 || (code == REFRESH_FROM_CLIENT ) 00086 || (code == ONE_WAY_FROM_SERVER ) 00087 || (code == REFRESH_FROM_SERVER ) 00088 || (code == TWO_WAY_BY_SERVER ) 00089 || (code == ONE_WAY_FROM_CLIENT_BY_SERVER) 00090 || (code == REFRESH_FROM_CLIENT_BY_SERVER) 00091 || (code == ONE_WAY_FROM_SERVER_BY_SERVER) 00092 || (code == REFRESH_FROM_SERVER_BY_SERVER) 00093 ); 00094 } 00095 00096 00097 /** 00098 * Determines if the given code represents a client only action, such as is 00099 * one of: 00100 * <ul> 00101 * <li>ONE_WAY_FROM_CLIENT</li> 00102 * <li>REFRESH_FROM_CLIENT</li> 00103 * </ul> 00104 * 00105 * @param code the code to be checked 00106 * 00107 * @return true if the code represents a client only action, false otherwise 00108 */ 00109 bool isClientOnlyCode(int code) { 00110 return ( (code == ONE_WAY_FROM_CLIENT) 00111 || (code == REFRESH_FROM_CLIENT) 00112 ); 00113 } 00114 00115 /** @endcond */ 00116 #endif // INCL_ALERT_CODE