amxmodx/compiler/scasm/amx_compiler.h

111 lines
3.0 KiB
C
Raw Normal View History

2004-08-06 12:46:59 +04:00
/* 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: amx_compiler.h 835 2004-08-12 16:31:50Z dvander $
2004-08-06 12:46:59 +04:00
*/
#ifndef _INCLUDE_AMXCOMPILER_H
#define _INCLUDE_AMXCOMPILER_H
#define CHK_PARAMS(d) \
if (paramList.size() > d) \
{ \
CError->ErrorMsg(Warning_Param_Count, paramList.size(), d); \
} else if (paramList.size() < d) { \
CError->ErrorMsg(Err_Param_Count, paramList.size(), d); \
delete ASM; \
ASM = 0; \
}
#define PUSH_PARAM(n,sym) \
if (paramList.size() >= n) \
{ \
ASM->params.push_back(Eval(*(paramList[n-1]), sym)); \
2004-08-08 14:15:08 +04:00
lastCip+=cellsize; \
}
2004-08-06 12:46:59 +04:00
class rpn
{
public:
2004-08-11 13:42:15 +04:00
~rpn();
2004-08-06 12:46:59 +04:00
//TODO: use linked lists, but not std::list
std::vector<char> ops;
std::vector<CExpr> vals;
2004-08-06 12:46:59 +04:00
};
class Compiler
{
public:
Compiler();
~Compiler();
Compiler(std::string &f);
void Load(std::string &f);
bool Parse();
2004-08-11 13:42:15 +04:00
bool Compile(std::string &out);
2004-08-06 12:46:59 +04:00
int CurLine() { return curLine; }
ErrorMngr *ErrorHandler() { return CError; }
void PrintCodeList();
2004-08-06 12:46:59 +04:00
public:
int FindArguments(std::string &text, std::vector<std::string*> &List, int &end, bool simple = false);
2004-08-08 14:15:08 +04:00
void Clear();
int CipCount();
int CurCip() { return lastCip; }
Asm *CurAsm() { return curAsm; }
bool SetDebug();
bool SetPack();
bool SetDOpt();
int DerefSymbol(std::string &str, SymbolType sym = Sym_None);
bool IsSymbol(std::string &str);
private:
2004-08-06 12:46:59 +04:00
void ProcessDirective(std::string &text);
void Init();
void InitOpcodes();
int Eval(std::string &str, SymbolType sym = Sym_None);
CExpr EvalE(std::string &str, SymbolType sym = Sym_None);
CExpr EvalRpn(rpn *r, SymbolType sym);
2004-08-06 12:46:59 +04:00
OpToken OperToken(char c);
char OperChar(OpToken c);
void WriteCell(FILE *fp, ucell *c, int repeat);
2004-08-06 12:46:59 +04:00
private:
std::vector<Asm *> CodeList;
std::map<std::string,int> OpCodes;
std::stack<std::string> LabelStack;
2004-08-08 14:15:08 +04:00
char *Output;
2004-08-06 12:46:59 +04:00
ErrorMngr *CError;
SymbolList *CSymbols;
DefineMngr *CDefines;
MacroList *CMacros;
DataMngr *DAT;
ProcMngr *PROC;
LabelMngr *CLabels;
NativeMngr *CNatives;
std::string filename;
int curLine;
int lastCip;
int cellsize;
2004-08-08 14:15:08 +04:00
int stacksize;
bool debug;
bool pack;
bool dopt;
int bitsOut;
Asm *curAsm;
2004-08-06 12:46:59 +04:00
};
#endif //_INCLUDE_AMXCOMPILER_H