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

📄 xserializeengine.hpp

📁 经典开源游戏glest的源代码
💻 HPP
📖 第 1 页 / 共 2 页
字号:
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at *  *      http://www.apache.org/licenses/LICENSE-2.0 *  * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *//* * $Id: XSerializeEngine.hpp 568078 2007-08-21 11:43:25Z amassari $ */#if !defined(XSERIALIZE_ENGINE_HPP)#define XSERIALIZE_ENGINE_HPP#include <xercesc/util/RefHashTableOf.hpp>#include <xercesc/util/ValueVectorOf.hpp>#include <xercesc/util/XMLExceptMsgs.hpp>#include <xercesc/internal/XSerializationException.hpp>XERCES_CPP_NAMESPACE_BEGINclass XSerializable;class XProtoType;class MemoryManager;class XSerializedObjectId;class BinOutputStream;class BinInputStream;class XMLGrammarPool;class XMLGrammarPoolImpl;class XMLStringPool;class XMLUTIL_EXPORT XSerializeEngine{public:    enum { mode_Store         , mode_Load     };        static const bool toReadBufferLen;    typedef unsigned int   XSerializedObjectId_t;    /***      *      *  Destructor       *      ***/    ~XSerializeEngine();    /***      *      *  Constructor for de-serialization(loading)      *      *  Application needs to make sure that the instance of      *  BinInputStream, persists beyond the life of this      *  SerializeEngine.      *      *  Param      *     inStream         input stream      *     gramPool         Grammar Pool      *     bufSize          the size of the internal buffer      *      ***/    XSerializeEngine(BinInputStream*         inStream                   , XMLGrammarPool* const   gramPool                   , unsigned long           bufSize = 8192 );    /***      *      *  Constructor for serialization(storing)      *      *  Application needs to make sure that the instance of      *  BinOutputStream, persists beyond the life of this      *  SerializeEngine.      *      *  Param      *     outStream        output stream      *     gramPool         Grammar Pool      *     bufSize          the size of the internal buffer      *      ***/    XSerializeEngine(BinOutputStream*        outStream                   , XMLGrammarPool* const   gramPool                   , unsigned long           bufSize = 8192 );    /***      *      *  Deprecated      *      *  Constructor for de-serialization(loading)      *      *  Application needs to make sure that the instance of      *  BinInputStream, persists beyond the life of this      *  SerializeEngine.      *      *  Param      *     inStream         input stream      *     manager          MemoryManager      *     bufSize          the size of the internal buffer      *      ***/    XSerializeEngine(BinInputStream*         inStream                   , MemoryManager* const    manager = XMLPlatformUtils::fgMemoryManager                   , unsigned long           bufSize = 8192 );        /***      *      *  Deprecated      *      *  Constructor for serialization(storing)      *      *  Application needs to make sure that the instance of      *  BinOutputStream, persists beyond the life of this      *  SerializeEngine.      *      *  Param      *     outStream        output stream      *     manager          MemoryManager      *     bufSize          the size of the internal buffer      *      ***/    XSerializeEngine(BinOutputStream*        outStream                   , MemoryManager* const    manager = XMLPlatformUtils::fgMemoryManager                   , unsigned long           bufSize = 8192 );    /***      *      *  When serialization, flush out the internal buffer      *      *  Return:       *      ***/    void flush();    /***      *      *  Checking if the serialize engine is doing serialization(storing)      *      *  Return: true, if it is       *          false, otherwise      *      ***/    inline bool isStoring() const;    /***      *      *  Checking if the serialize engine is doing de-serialization(loading)      *      *  Return: true, if it is       *          false, otherwise      *      ***/    inline bool isLoading() const;    /***      *      *  Get the GrammarPool      *      *  Return: XMLGrammarPool      *      ***/    XMLGrammarPool* getGrammarPool() const;    /***      *      *  Get the StringPool      *      *  Return: XMLStringPool      *      ***/    XMLStringPool* getStringPool() const;    /***      *      *  Get the embeded Memory Manager      *      *  Return: MemoryManager      *      ***/    MemoryManager* getMemoryManager() const;    /***      *      *  Get the storer level (the level of the serialize engine      *  which created the binary stream that this serialize engine      *  is loading).      *      *  The level returned is meaningful only when      *  the engine isLoading.      *      *  Return: level      *      ***/    inline unsigned short getStorerLevel() const;    /***      *      *  Write object to the internal buffer.      *      *  Param      *     objectToWrite:    the object to be serialized      *      *  Return:      *      ***/           void           write(XSerializable* const objectToWrite);    /***      *      *  Write prototype info to the internal buffer.      *      *  Param      *     protoType:    instance of prototype      *      *  Return:      *      ***/           void           write(XProtoType* const protoType);    /***      *      *  Write a stream of XMLByte to the internal buffer.      *      *  Param      *     toWrite:   the stream of XMLByte to write      *     writeLen:  the length of the stream      *      *  Return:      *      ***/           void           write(const XMLByte* const toWrite                               ,      int            writeLen);    /***      *      *  Write a stream of XMLCh to the internal buffer.      *      *  Param      *     toWrite:   the stream of XMLCh to write      *     writeLen:  the length of the stream      *      *  Return:      *      ***/           void           write(const XMLCh* const toWrite                               ,      int          writeLen);    /***      *      *  Write a stream of XMLCh to the internal buffer.      *      *  Write the bufferLen first if requested, then the length      *  of the stream followed by the stream.      *      *  Param      *     toWrite:        the stream of XMLCh to write      *     bufferLen:      the maximum size of the buffer      *     toWriteBufLen:  specify if the bufferLen need to be written or not      *      *  Return:      *      ***/           void           writeString(const XMLCh* const toWrite                                    , const int          bufferLen = 0                                    , bool               toWriteBufLen = false);    /***      *      *  Write a stream of XMLByte to the internal buffer.      *      *  Write the bufferLen first if requested, then the length      *  of the stream followed by the stream.      *      *  Param      *     toWrite:        the stream of XMLByte to write      *     bufferLen:      the maximum size of the buffer      *     toWriteBufLen:  specify if the bufferLen need to be written or not      *      *  Return:      *      ***/           void           writeString(const XMLByte* const toWrite                                    , const int            bufferLen = 0                                    , bool                 toWriteBufLen = false);    static const bool toWriteBufferLen;    /***      *      *  Read/Create object from the internal buffer.      *      *  Param      *     protoType:    an instance of prototype of the object anticipated      *      *  Return:          to object read/created      *      ***/	       XSerializable* read(XProtoType* const protoType);    /***      *      *  Read prototype object from the internal buffer.      *  Verify if the same prototype object found in buffer.      *      *  Param      *     protoType:    an instance of prototype of the object anticipated      *     objTag:       the object Tag to an existing object      *      *  Return:          true  : if matching found      *                   false : otherwise      *      ***/           bool           read(XProtoType* const    protoType		                     , XSerializedObjectId_t*       objTag);    /***      *      *  Read XMLByte stream from the internal buffer.      *      *  Param      *     toRead:   the buffer to hold the XMLByte stream      *     readLen:  the length of the XMLByte to read in      *      *  Return:      *      ***/           void           read(XMLByte* const toRead                             , int            readLen);    /***      *      *  Read XMLCh stream from the internal buffer.      *      *  Param      *     toRead:   the buffer to hold the XMLCh stream      *     readLen:  the length of the XMLCh to read in      *      *  Return:      *      ***/           void           read(XMLCh* const toRead                             , int          readLen);    /***      *      *  Read a stream of XMLCh from the internal buffer.      *      *  Read the bufferLen first if requested, then the length      *  of the stream followed by the stream.      *      *  Param      *     toRead:       the pointer to the buffer to hold the XMLCh stream      *     bufferLen:    the size of the buffer created      *     dataLen:       the length of the stream      *     toReadBufLen: specify if the bufferLen need to be read or not      *      *  Return:      *      ***/           void           readString(XMLCh*&        toRead                                   , int&           bufferLen                                   , int&           dataLen                                   , bool           toReadBufLen = false);     /***       *       *  Read a stream of XMLCh from the internal buffer.       *       *  Read the bufferLen first if requested, then the length       *  of the stream followed by the stream.       *       *  Param       *     toRead:       the pointer to the buffer to hold the XMLCh stream       *     bufferLen:    the size of the buffer created       *       *  Return:       *       ***/            inline void     readString(XMLCh*&        toRead                                    , int&            bufferLen);      /***       *       *  Read a stream of XMLCh from the internal buffer.       *       *  Param       *     toRead:       the pointer to the buffer to hold the XMLCh stream       *       *  Return:       *       ***/            inline void      readString(XMLCh*&        toRead);    /***      *      *  Read a stream of XMLByte from the internal buffer.      *      *  Read the bufferLen first if requested, then the length      *  of the stream followed by the stream.      *      *  Param      *     toRead:       the pointer to the buffer to hold the XMLByte stream      *     bufferLen:    the size of the buffer created      *     dataLen:       the length of the stream      *     toReadBufLen: specify if the bufferLen need to be read or not      *      *  Return:      *      ***/           void           readString(XMLByte*&      toRead                                   , int&           bufferLen                                   , int&           dataLen                                   , bool           toReadBufLen = false);     /***       *       *  Read a stream of XMLByte from the internal buffer.       *       *  Read the bufferLen first if requested, then the length       *  of the stream followed by the stream.

⌨️ 快捷键说明

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