⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 smldef.h

📁 SyncML ToolKits,学习syncml的参考工具包.非常好用.
💻 H
字号:
/*************************************************************************//* module:          Type definitions for SyncML                          *//*                                                                       */   /* file:            SMLDef.h                                             *//* target system:   all                                                  *//* target OS:       all                                                  *//*                                                                       */   /* Description:                                                          */   /* Platform independent header with syncML types and definitions         *//*************************************************************************//* * Copyright Notice * Copyright (c) Ericsson, IBM, Lotus, Matsushita Communication  * Industrial Co., Ltd., Motorola, Nokia, Openwave Systems, Inc.,  * Palm, Inc., Psion, Starfish Software, Symbian, Ltd. (2001). * All Rights Reserved. * Implementation of all or part of any Specification may require  * licenses under third party intellectual property rights,  * including without limitation, patent rights (such a third party  * may or may not be a Supporter). The Sponsors of the Specification  * are not responsible and shall not be held responsible in any  * manner for identifying or failing to identify any or all such  * third party intellectual property rights. *  * THIS DOCUMENT AND THE INFORMATION CONTAINED HEREIN ARE PROVIDED  * ON AN "AS IS" BASIS WITHOUT WARRANTY OF ANY KIND AND ERICSSON, IBM,  * LOTUS, MATSUSHITA COMMUNICATION INDUSTRIAL CO. LTD, MOTOROLA,  * NOKIA, PALM INC., PSION, STARFISH SOFTWARE AND ALL OTHER SYNCML  * SPONSORS DISCLAIM ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING  * BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION  * HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF  * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT  * SHALL ERICSSON, IBM, LOTUS, MATSUSHITA COMMUNICATION INDUSTRIAL CO.,  * LTD, MOTOROLA, NOKIA, PALM INC., PSION, STARFISH SOFTWARE OR ANY  * OTHER SYNCML SPONSOR BE LIABLE TO ANY PARTY FOR ANY LOSS OF  * PROFITS, LOSS OF BUSINESS, LOSS OF USE OF DATA, INTERRUPTION OF  * BUSINESS, OR FOR DIRECT, INDIRECT, SPECIAL OR EXEMPLARY, INCIDENTAL,  * PUNITIVE OR CONSEQUENTIAL DAMAGES OF ANY KIND IN CONNECTION WITH  * THIS DOCUMENT OR THE INFORMATION CONTAINED HEREIN, EVEN IF ADVISED  * OF THE POSSIBILITY OF SUCH LOSS OR DAMAGE. *  * The above notice and this paragraph must be included on all copies  * of this document that are made. *  */#ifndef _SML_DEF_H  #define _SML_DEF_H/************************************************************************* *  Definitions *************************************************************************//** * include target/compiler specific defines/options/settings  **/#include <define.h>/** * =================================== * Common all-purpose type definitions * =================================== **//**  * ================================== * Basic data types  * ================================== **/typedef short         Short_t;      // short integer,  16 Bytestypedef long          Long_t;       // long integer,   32 Bytestypedef char*         String_t;     // String pointer, typedef unsigned char Byte_t;       // a single bytetypedef Byte_t        Boolean_t;    // a boolean#ifndef NULL                        // a NULL pointer  #define NULL (void*) 0#endiftypedef Short_t       Ret_t;        // Return Type of API Commandstypedef Long_t        Length_t;     // System dependent string lengthtypedef Short_t       MemHandle_t;  // Memory object Handle typedef unsigned char *MemPtr_t;    // Memory object Pointertypedef void          *VoidPtr_t;   // Void Pointertypedef Long_t        MemSize_t;    // System dependent memory object sizetypedef unsigned char MemByte_t;    // Memory elementtypedef unsigned int  Flag_t;       // A generic flag type. This type is used to                                     // declare variables in structures wherever                                      // flags are used./** * ================================== * Definitions used in the SyncML API * ================================== **//** * Application callback function displaying output strings to the user **/ typedef void (*smlPrintFunc) (String_t outputString);/**  * structure describing the options and setting of this syncml process  **/typedef struct sml_options_s {  smlPrintFunc  defaultPrintFunc;       // default application callback for displaying strings,  MemSize_t     maxWorkspaceAvailMem;   // size which all workspaces in total MUST not exceed} *SmlOptionsPtr_t, SmlOptions_t;/** * Reference of an instance **/#ifdef NOWSMtypedef void *InstanceID_t;          // without wsm, instance ID is direct pointer to instance info#else typedef MemHandle_t InstanceID_t;    // Handle, used as a unique ID of #endif                               // an synchronization instance /** * Type of used encoding **/typedef enum {	SML_UNDEF = 0,        SML_WBXML,        SML_XML} SmlEncoding_t;/** %%% added luz 2003-07-31: * SyncML version **/typedef enum {  SML_VERS_UNDEF = 0,  SML_VERS_1_0,  SML_VERS_1_1,  SML_NUM_VERS} SmlVersion_t;/**  * structure describing the options of an instance,  **/typedef struct sml_instance_options_s {  SmlEncoding_t encoding;               // Used encoding type,  MemSize_t     workspaceSize;          // size of the workspace to allocate (instance buffer size if NOWSM defined)  #ifndef NOWSM  String_t      workspaceName;          // name of the workspace  #else  MemSize_t     maxOutgoingSize;        // max size of outgoing message, 0 if no restriction    #endif} *SmlInstanceOptionsPtr_t, SmlInstanceOptions_t;/** * Processing modes **/typedef enum {  SML_DO_NOTHING = 0,  SML_FIRST_COMMAND,  SML_NEXT_COMMAND,  SML_NEXT_MESSAGE,  SML_ALL_COMMANDS} SmlProcessMode_t;/** * Requested buffer pointer position **/typedef enum {  SML_FIRST_DATA_ITEM = 0,  SML_FIRST_FREE_ITEM} SmlBufPtrPos_t;/** * SyncML Protocol Management and Command Elements (PE) **/typedef enum {    SML_PE_UNDEF = 0,    SML_PE_ERROR,    SML_PE_ADD,    SML_PE_ALERT,    SML_PE_ATOMIC_START,    SML_PE_ATOMIC_END,    SML_PE_COPY,    SML_PE_DELETE,    SML_PE_EXEC,    SML_PE_GET,    SML_PE_MAP,    SML_PE_PUT,    SML_PE_RESULTS,    SML_PE_SEARCH,    SML_PE_SEQUENCE_START,    SML_PE_SEQUENCE_END,    SML_PE_STATUS,    SML_PE_SYNC_START,    SML_PE_SYNC_END,    SML_PE_REPLACE,    SML_PE_HEADER,    SML_PE_PUT_GET,    SML_PE_CMD_GROUP,    SML_PE_GENERIC,    SML_PE_FINAL} SmlProtoElement_t;#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -