summaryrefslogtreecommitdiff
path: root/src/map/script.hpp
diff options
context:
space:
mode:
authorBen Longbons <b.r.longbons@gmail.com>2012-08-30 17:37:27 -0700
committerBen Longbons <b.r.longbons@gmail.com>2012-09-03 16:23:10 -0700
commit31544d2b6973931be7fdec898ea3672bea831de2 (patch)
treedcf946429b406f39297404be662b0a840094e477 /src/map/script.hpp
parent41974ae5265fbc23a06f276f9e008d5dad020e0b (diff)
downloadtmwa-31544d2b6973931be7fdec898ea3672bea831de2.tar.gz
tmwa-31544d2b6973931be7fdec898ea3672bea831de2.tar.bz2
tmwa-31544d2b6973931be7fdec898ea3672bea831de2.tar.xz
tmwa-31544d2b6973931be7fdec898ea3672bea831de2.zip
Fix compiler errors of C++ conversion
Diffstat (limited to 'src/map/script.hpp')
-rw-r--r--src/map/script.hpp60
1 files changed, 50 insertions, 10 deletions
diff --git a/src/map/script.hpp b/src/map/script.hpp
index a96bc5a..6b345c4 100644
--- a/src/map/script.hpp
+++ b/src/map/script.hpp
@@ -2,13 +2,48 @@
#ifndef SCRIPT_HPP
#define SCRIPT_HPP
+// values are private, but gcc < 4.6 doesn't
+// support forward-declared enums
+enum class ScriptCode : uint8_t
+#ifdef RECENT_GCC
+;
+#else
+{
+ // types and specials
+ NOP, POS, INT, PARAM, FUNC, STR, CONSTSTR, ARG,
+ NAME, EOL, RETINFO,
+
+ // unary and binary operators
+ LOR, LAND, LE, LT, GE, GT, EQ, NE,
+ XOR, OR, AND, ADD, SUB, MUL, DIV, MOD, NEG, LNOT,
+ NOT, R_SHIFT, L_SHIFT,
+
+ // really nasty workaround for gcc < 4.6
+
+ x20, x21, x22, x23, x24, x25, x26, x27, x28, x29, x2a, x2b, x2c, x2d, x2e, x2f,
+ x30, x31, x32, x33, x34, x35, x36, x37, x38, x39, x3a, x3b, x3c, x3d, x3e, x3f,
+ x40, x41, x42, x43, x44, x45, x46, x47, x48, x49, x4a, x4b, x4c, x4d, x4e, x4f,
+ x50, x51, x52, x53, x54, x55, x56, x57, x58, x59, x5a, x5b, x5c, x5d, x5e, x5f,
+ x60, x61, x62, x63, x64, x65, x66, x67, x68, x69, x6a, x6b, x6c, x6d, x6e, x6f,
+ x70, x71, x72, x73, x74, x75, x76, x77, x78, x79, x7a, x7b, x7c, x7d, x7e, x7f,
+ x80, x81, x82, x83, x84, x85, x86, x87, x88, x89, x8a, x8b, x8c, x8d, x8e, x8f,
+ x90, x91, x92, x93, x94, x95, x96, x97, x98, x99, x9a, x9b, x9c, x9d, x9e, x9f,
+ xa0, xa1, xa2, xa3, xa4, xa5, xa6, xa7, xa8, xa9, xaa, xab, xac, xad, xae, xaf,
+ xb0, xb1, xb2, xb3, xb4, xb5, xb6, xb7, xb8, xb9, xba, xbb, xbc, xbd, xbe, xbf,
+ xc0, xc1, xc2, xc3, xc4, xc5, xc6, xc7, xc8, xc9, xca, xcb, xcc, xcd, xce, xcf,
+ xd0, xd1, xd2, xd3, xd4, xd5, xd6, xd7, xd8, xd9, xda, xdb, xdc, xdd, xde, xdf,
+ xe0, xe1, xe2, xe3, xe4, xe5, xe6, xe7, xe8, xe9, xea, xeb, xec, xed, xee, xef,
+ xf0, xf1, xf2, xf3, xf4, xf5, xf6, xf7, xf8, xf9, xfa, xfb, xfc, xfd, xfe, xff,
+};
+#endif
+
struct script_data
{
- int type;
+ ScriptCode type;
union
{
int num;
- char *str;
+ const char *str;
} u;
};
@@ -17,33 +52,38 @@ struct script_stack
int sp, sp_max;
struct script_data *stack_data;
};
+
struct script_state
{
struct script_stack *stack;
int start, end;
int pos, state;
int rid, oid;
- char *script, *new_script;
+ const ScriptCode *script, *new_script;
int defsp, new_pos, new_defsp;
};
-unsigned char *parse_script (unsigned char *, int);
+const ScriptCode *parse_script (const char *, int);
typedef struct argrec
{
- char *name;
- union
+ const char *name;
+ union _aru
{
int i;
- char *s;
+ const char *s;
+
+ _aru() = default;
+ _aru(int n) : i(n) {}
+ _aru(const char *z) : s(z) {}
} v;
} argrec_t;
-int run_script_l (unsigned char *, int, int, int, int, argrec_t * args);
-int run_script (unsigned char *, int, int, int);
+int run_script_l (const ScriptCode *, int, int, int, int, argrec_t * args);
+int run_script (const ScriptCode *, int, int, int);
struct dbt *script_get_label_db (void);
struct dbt *script_get_userfunc_db (void);
-int script_config_read (char *cfgName);
+int script_config_read (const char *cfgName);
int do_init_script (void);
int do_final_script (void);