Sirikata
|
00001 /* Sirikata -- Variable Length Serializable Integer With 0xff delimiter 00002 * VariableLength.hpp 00003 * 00004 * Copyright (c) 2009, Daniel Reiter Horn 00005 * All rights reserved. 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions are 00009 * met: 00010 * * Redistributions of source code must retain the above copyright 00011 * notice, this list of conditions and the following disclaimer. 00012 * * Redistributions in binary form must reproduce the above copyright 00013 * notice, this list of conditions and the following disclaimer in 00014 * the documentation and/or other materials provided with the 00015 * distribution. 00016 * * Neither the name of Sirikata nor the names of its contributors may 00017 * be used to endorse or promote products derived from this software 00018 * without specific prior written permission. 00019 * 00020 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 00021 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 00022 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 00023 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER 00024 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00025 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00026 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00027 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00028 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00029 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00030 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00031 */ 00032 namespace Sirikata { 00033 class VariableLength : protected vuint32 { 00034 uint8 mDelimiter; 00035 public: 00036 enum { 00037 MAX_SERIALIZED_LENGTH=vuint32::MAX_SERIALIZED_LENGTH+1 00038 }; 00039 00040 bool operator == (const VariableLength&other)const { 00041 return mData==other.mData; 00042 } 00043 bool operator != (const VariableLength&other)const { 00044 return mData!=other.mData; 00045 } 00046 bool operator < (const VariableLength&other)const { 00047 return mData<other.mData; 00048 } 00049 uint32 read() { 00050 return vuint32::read(); 00051 } 00052 unsigned int serializedSize() const { 00053 return vuint32::serializedSize()+1; 00054 } 00055 unsigned int serialize(uint8 *destination, unsigned int maxsize) const { 00056 if (maxsize>=1) { 00057 *destination=mDelimiter; 00058 return vuint32::serialize(destination+1,maxsize-1)+1; 00059 }else return false; 00060 } 00061 bool unserialize(const uint8*src, unsigned int&size) { 00062 if (size==0) return false; 00063 if (*src<128) return false; 00064 mDelimiter=*src; 00065 bool retval= vuint32::unserialize(src+1,size); 00066 size++; 00067 return retval; 00068 } 00069 00070 VariableLength(){ 00071 mData=0; 00072 mDelimiter=0xff; 00073 } 00074 VariableLength(uint32 num) { 00075 mData=num; 00076 mDelimiter=0xff; 00077 } 00078 struct Hasher:public vuint32::Hasher { 00079 00080 }; 00081 }; 00082 }