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

📄 xserializeengine.hpp

📁 基于属性证书的访问控制源代码,由c++编写,包括openssl,xercesc等
💻 HPP
📖 第 1 页 / 共 2 页
字号:
/* * The Apache Software License, Version 1.1 * * Copyright (c) 2003 The Apache Software Foundation.  All rights * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. * * 3. The end-user documentation included with the redistribution, *    if any, must include the following acknowledgment: *       "This product includes software developed by the *        Apache Software Foundation (http://www.apache.org/)." *    Alternately, this acknowledgment may appear in the software itself, *    if and wherever such third-party acknowledgments normally appear. * * 4. The names "Xerces" and "Apache Software Foundation" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact apache\@apache.org. * * 5. Products derived from this software may not be called "Apache", *    nor may "Apache" appear in their name, without prior written *    permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation, and was * originally based on software copyright (c) 1999, International * Business Machines, Inc., http://www.ibm.com .  For more information * on the Apache Software Foundation, please see * <http://www.apache.org/>. *//* * $Log: XSerializeEngine.hpp,v $ * Revision 1.14  2004/02/11 20:38:50  peiyongz * Fix to bug#26864, thanks to David Bertoni. * * Revision 1.13  2004/01/29 11:46:30  cargilld * Code cleanup changes to get rid of various compiler diagnostic messages. * * Revision 1.12  2004/01/16 21:55:18  peiyongz * maintain the same size on both 32/64 bit architecture * * Revision 1.11  2004/01/15 23:42:32  peiyongz * proper allignment for built-in datatype read/write * * Revision 1.10  2003/12/17 00:18:34  cargilld * Update to memory management so that the static memory manager (one used to call Initialize) is only for static data. * * Revision 1.9  2003/11/25 20:37:40  jberry * Cleanup build errors/warnings from CodeWarrior * * Revision 1.8  2003/11/11 22:48:13  knoaman * Serialization of XSAnnotation. * * Revision 1.7  2003/10/17 21:09:03  peiyongz * renaming methods * * Revision 1.6  2003/10/14 15:18:20  peiyongz * getMemoryManager() * * Revision 1.5  2003/10/09 19:11:53  peiyongz * Fix to linkage error on Solaris * * Revision 1.4  2003/10/07 19:38:31  peiyongz * API for Template_Class Object Serialization/Deserialization * * Revision 1.3  2003/09/25 22:22:00  peiyongz * Introduction of readString/writeString * * Revision 1.2  2003/09/19 04:29:11  neilg * fix compilation problems under GCC * * Revision 1.1  2003/09/18 18:31:24  peiyongz * OSU: Object Serialization Utilities * * $Id: XSerializeEngine.hpp,v 1.14 2004/02/11 20:38:50 peiyongz Exp $ * */#if !defined(XSERIALIZE_ENGINE_HPP)#define XSERIALIZE_ENGINE_HPP#include <xercesc/framework/BinOutputStream.hpp>#include <xercesc/util/BinInputStream.hpp>#include <xercesc/util/RefHashTableOf.hpp>#include <xercesc/util/ValueVectorOf.hpp>#include <xercesc/internal/XSerializationException.hpp>#include <xercesc/util/XMLExceptMsgs.hpp>XERCES_CPP_NAMESPACE_BEGINclass XSerializable;class XProtoType;class MemoryManager;class XSerializedObjectId;class XMLUTIL_EXPORT XSerializeEngine{public:    enum { mode_Store         , mode_Load     };        static const bool toReadBufferLen;    static int defaultBufferLen;    static int defaultDataLen;    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      *     manager          MemoryManager      *     bufSize          the size of the internal buffer      *      ***/    XSerializeEngine(BinInputStream*         inStream                   , MemoryManager* const    manager = XMLPlatformUtils::fgMemoryManager                   , 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      *     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 embeded Memory Manager      *      *  Return: MemoryManager      *      ***/    inline MemoryManager* getMemoryManager() 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

⌨️ 快捷键说明

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