//========= Copyright (c), Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ //=============================================================================// #ifndef KVPACKER_H #define KVPACKER_H #ifdef _WIN32 #pragma once #endif #include "keyvalues.h" //----------------------------------------------------------------------------- // Purpose: Handles packing KeyValues binary packing and unpacking in a a // consistent way across all branches, including Steam. If you change // this packing format you need to do so in a backward compatible way // so that the Steam servers and all the various GCs can still talk to // each other. //----------------------------------------------------------------------------- class KVPacker { public: bool WriteAsBinary( KeyValues *pNode, CUtlBuffer &buffer ); bool ReadAsBinary( KeyValues *pNode, CUtlBuffer &buffer ); private: // These types are used for serialization of KeyValues nodes. // Do not renumber them or you will break serialization across // branches. enum EPackType { PACKTYPE_NONE = 0, PACKTYPE_STRING, PACKTYPE_INT, PACKTYPE_FLOAT, PACKTYPE_PTR, PACKTYPE_WSTRING, PACKTYPE_COLOR, PACKTYPE_UINT64, PACKTYPE_NULLMARKER, // used to mark the end of a block in the binary format }; }; #endif // KVPACKER_H