/* AMX Assembler * Copyright (C)2004 David "BAILOPAN" Anderson * * This software is provided 'as-is', without any express or implied * warranty. In no event will the authors be held liable for any damages * arising from the use of this software. * * Permission is granted to anyone to use this software for any purpose, * including commercial applications, and to alter it and redistribute it * freely, subject to the following restrictions: * * 1. The origin of this software must not be misrepresented; you must not * claim that you wrote the original software. If you use this software * in a product, an acknowledgment in the product documentation would be * appreciated but is not required. * 2. Altered source versions must be plainly marked as such, and must not be * misrepresented as being the original software. * 3. This notice may not be removed or altered from any source distribution. * * Version: $Id$ */ #ifndef _INCLUDE_AMXDATA_H #define _INCLUDE_AMXDATA_H class DataMngr { public: class Datum { public: Datum(); std::string symbol; CExpr e; bool db; int offset; int fill; bool zeroed; }; public: ~DataMngr(); DataMngr() { cellsize = 4; lastOffset = 0; cursize = 0; optimized = false; } DataMngr(int cell) { lastOffset = 0; cellsize = cell; cursize = 0; optimized = false; } void Add(std::string &s, CExpr &expr, bool db = false, int fill = 0); DataMngr::Datum *FindData(std::string &sym); void GetData(std::vector<DataMngr::Datum *> &dList); int GetOffset(std::string &sym); int GetSize(); void Clear(); void PrintTable(); void Optimize(); bool IsOptimized() { return optimized; } private: std::vector<DataMngr::Datum *> List; int lastOffset; int cellsize; int cursize; bool optimized; public: static const int nof = -1; }; #endif //_INCLUDE_AMXDATA_H