1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-15 19:49:54 +00:00
openmw-tes3mp/components/compiler/extensions.hpp

116 lines
4.6 KiB
C++
Raw Normal View History

2010-07-03 07:54:01 +00:00
#ifndef COMPILER_EXTENSIONS_H_INCLUDED
2014-02-10 21:53:16 +00:00
#define COMPILER_EXTENSIONS_H_INCLUDED
2010-07-03 07:54:01 +00:00
#include <string>
#include <map>
#include <vector>
#include <components/interpreter/types.hpp>
2010-07-03 07:54:01 +00:00
namespace Compiler
{
class Literals;
/// Typedef for script arguments string
/** Every character reperesents an argument to the command. All arguments are required until a /, after which
every argument is optional. <BR>
Eg: fff/f represents 3 required floats followed by one optional float <BR>
f - Float <BR>
c - String, case smashed <BR>
l - Integer <BR>
s - Short <BR>
S - String, case preserved <BR>
2016-01-02 23:08:05 +00:00
x - Optional, ignored string argument. Emits a parser warning when this argument is supplied. <BR>
X - Optional, ignored numeric expression. Emits a parser warning when this argument is supplied. <BR>
z - Optional, ignored string or numeric argument. Emits a parser warning when this argument is supplied. <BR>
j - A piece of junk (either . or a specific keyword)
**/
typedef std::string ScriptArgs;
/// Typedef for script return char
/** The character represents the type of data being returned. <BR>
f - float <BR>
S - String (Cell names) <BR>
l - Integer
**/
typedef char ScriptReturn;
/// \brief Collection of compiler extensions
2010-07-03 07:54:01 +00:00
class Extensions
{
struct Function
{
char mReturn;
ScriptArgs mArguments;
int mCode;
int mCodeExplicit;
int mSegment;
};
struct Instruction
{
ScriptArgs mArguments;
int mCode;
int mCodeExplicit;
int mSegment;
};
2010-07-03 07:54:01 +00:00
int mNextKeywordIndex;
std::map<std::string, int> mKeywords;
std::map<int, Function> mFunctions;
std::map<int, Instruction> mInstructions;
2010-07-03 07:54:01 +00:00
public:
2010-07-03 07:54:01 +00:00
Extensions();
2010-07-03 07:54:01 +00:00
int searchKeyword (const std::string& keyword) const;
///< Return extension keyword code, that is assigned to the string \a keyword.
/// - if no match is found 0 is returned.
/// - keyword must be all lower case.
bool isFunction (int keyword, ScriptReturn& returnType, ScriptArgs& argumentType,
bool& explicitReference) const;
///< Is this keyword registered with a function? If yes, return return and argument
/// types.
/// \param explicitReference In: has explicit reference; Out: set to false, if
/// explicit reference is not available for this instruction.
bool isInstruction (int keyword, ScriptArgs& argumentType,
bool& explicitReference) const;
///< Is this keyword registered with a function? If yes, return argument types.
/// \param explicitReference In: has explicit reference; Out: set to false, if
/// explicit reference is not available for this instruction.
void registerFunction (const std::string& keyword, ScriptReturn returnType,
const ScriptArgs& argumentType, int code, int codeExplicit = -1);
///< Register a custom function
/// - keyword must be all lower case.
/// - keyword must be unique
/// - if explicit references are not supported, segment5codeExplicit must be set to -1
/// \note Currently only segment 3 and segment 5 opcodes are supported.
void registerInstruction (const std::string& keyword,
const ScriptArgs& argumentType, int code, int codeExplicit = -1);
///< Register a custom instruction
/// - keyword must be all lower case.
/// - keyword must be unique
/// - if explicit references are not supported, segment5codeExplicit must be set to -1
/// \note Currently only segment 3 and segment 5 opcodes are supported.
void generateFunctionCode (int keyword, std::vector<Interpreter::Type_Code>& code,
Literals& literals, const std::string& id, int optionalArguments) const;
///< Append code for function to \a code.
void generateInstructionCode (int keyword, std::vector<Interpreter::Type_Code>& code,
Literals& literals, const std::string& id, int optionalArguments) const;
///< Append code for function to \a code.
2011-01-12 17:24:00 +00:00
void listKeywords (std::vector<std::string>& keywords) const;
2014-06-15 13:58:01 +00:00
///< Append all known keywords to \a kaywords.
2010-07-03 07:54:01 +00:00
};
}
#endif