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

📄 wsm_sm.h

📁 SyncML ToolKits,学习syncml的参考工具包.非常好用.
💻 H
字号:
/*************************************************************************//* module:          SyncML WorkSpace Manager                             *//*                                                                       *//* file:            WSM_SM.h                                             *//* target system:   All                                                  *//* target OS:       All                                                  *//*                                                                       *//* Description                                                           *//* Storage Management for Workspace Manager API <BR>                     *//* Encapsulates OS dependent parts of WSM.                               *//*************************************************************************//* * 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. *  *//** * @version  @label */#ifndef _WSM_SM_H#define _WSM_SM_H#include <smldef.h>#ifdef __ANSI_C__/* sbuffer list */typedef struct smWinList_s {  char               *memName;      // name of buffer  char               *winH;         // reference to memory block  MemHandle_t         memH;         // handle of memory block  Byte_t              locked;       // is handle locked?  MemSize_t           memSize;      // size of memory block      struct smWinList_s *next;         // next list item} smWinList_t;typedef smWinList_t *WsmSmGlobals_t;#endif#ifdef __PALM_OS__#include <Pilot.h>/* dynamic buffer array */typedef struct smPalm_s {  Handle          smPalmH;          // reference to only memory block  MemHandle_t     smMemH;           // handle of only memory block  Byte_t          smLocked;         // is handle locked?} WsmSmGlobals_t;#endif#ifdef __EPOC_OS__/* sbuffer list */typedef struct smWinList_s {  char               *memName;      // name of buffer  char               *winH;         // reference to memory block  MemHandle_t         memH;         // handle of memory block  Byte_t              locked;       // is handle locked?  MemSize_t           memSize;      // size of memory block      struct smWinList_s *next;         // next list item} smWinList_t;typedef smWinList_t *WsmSmGlobals_t;#endif/** * FUNCTION: smCreate * * Creates a new memory block with name memName and size memSize. * * PRE-Condition:   OS does not know memName; memSize > 0 * * POST-Condition:  memName exists with size memSize;  *                  memH refers to new memory block. * * IN:      memName *          Name of new memory block * IN:      memSize *          Size of new memory block *  * OUT:     memH *          Handle to new memory block * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_USAGE, if memName is already known to the OS *          SML_ERR_INVALID_SIZE, if memSize <= 0 *          SML_ERR_NOT_ENOUGH_SPACE, if available memory < memSize * * @see  smDestroy */Ret_t smCreate (String_t memName, MemSize_t memSize, MemHandle_t *memH);/** * FUNCTION: smOpen * * Open connection to memory block with name memName. * * PRE-Condition:   OS does know memName * * POST-Condition:  memH refers to memory block memName * * IN:      memName *          Name of memory block to open *  * OUT:     memH *          Handle to opened memory block * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_PARAM, if memName is unknown * * @see  smClose */Ret_t smOpen (String_t memName, MemHandle_t *memH);/** * FUNCTION: smClose * * Close link to memory block. * * PRE-Condition:   memH is a valid memory block handle; memH is unlocked; *                  no pointers to records are in use * * POST-Condition:  memH is not valid anymore * * IN:      memH *          Handle to close * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_USAGE, if memH is locked * * @see  smOpen */Ret_t smClose (MemHandle_t memH);/** * FUNCTION: smDestroy * * Remove memory block memName within OS. * * PRE-Condition:   memName is a valid memory block name;  *                  memory block is not in use (i.e. no handles and  *                  pointers to this memory block are in use) * * POST-Condition:  memName is not a valid memory block name anymore * * IN:      memName *          Name of memory block to remove * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_PARAM, if memName is unknown *          SML_ERR_WRONG_USAGE, if memory block is still locked * * @see  smCreate */Ret_t smDestroy (String_t memName);/** * FUNCTION: smLock * * Map memory block memH to local address space. * * PRE-Condition:   memH is a valid handle; memory block is not locked * * POST-Condition:  pMem points to memory block memH;  *                  memory block is locked * * IN:      memH *          Handle to memory block *  * OUT:     pMem *          Pointer to memory block memH mapped in local address space * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_PARAM, if memH is unknown *          SML_ERR_WRONG_USAGE, if memH was already locked *          SML_ERR_UNSPECIFIC, if lock failed * * @see  smUnlock */Ret_t smLock (MemHandle_t memH, MemPtr_t *pMem);/** * FUNCTION: smUnlock * * Free pointer mapped to memH memory block. * * PRE-Condition:   memH is a valid handle; memory block is locked * * POST-Condition:  memory block is unlocked * * IN:      memH *          Handle to memory block * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_PARAM, if memH is unknown *          SML_ERR_WRONG_USAGE, if memH was already unlocked *          SML_ERR_UNSPECIFIC, if unlock failed * * @see  smLock */Ret_t smUnlock (MemHandle_t memH);/** * FUNCTION: smSetSize * * Set size of memory block memH to newSize. * * PRE-Condition:   memH is a valid handle; newSize > 0;  *                  memory block is unlocked * * POST-Condition:  memory block size = newSize * * IN:      memH *          Handle to memory block * IN:      newSize *          New size of memory block *  * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_PARAM, if memH is unknown *          SML_ERR_WRONG_USAGE, if memH is locked *          SML_ERR_INVALID_SIZE, if newSize <= 0 *          SML_ERR_NOT_ENOUGH_SPACE, if available memory < newSize * * @see  smGetSize */Ret_t smSetSize (MemHandle_t memH, MemSize_t newSize);/** * FUNCTION: smGetSize * * Get size of memory block memH. * * PRE-Condition:   memH is a valid handle * * POST-Condition:  actSize = memory block size * * IN:      memH *          Handle to memory block *  * OUT:     actSize *          Actual size of memory block * * RETURN:  SML_ERR_OK, if O.K. *          SML_ERR_WRONG_PARAM, if memH is unknown * * @see  smSetSize */Ret_t smGetSize (MemHandle_t memH, MemSize_t *actSize);#endif

⌨️ 快捷键说明

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