summaryrefslogtreecommitdiff
path: root/src/map/script-call.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/map/script-call.cpp')
-rw-r--r--src/map/script-call.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/map/script-call.cpp b/src/map/script-call.cpp
index 5541043..4de94d7 100644
--- a/src/map/script-call.cpp
+++ b/src/map/script-call.cpp
@@ -706,6 +706,28 @@ void run_func(ScriptState *st)
}
builtin_functions[func].func(st);
+ if (builtin_functions[func].ret != '\0') {
+ // this builtin is expected to return a value
+ script_data &back = st->stack->stack_datav.back();
+
+ if (builtin_functions[func].ret == 'i' && !back.is<ScriptDataInt>()) {
+ PRINTF("script-call:run_func: expected %s to push an integer but none was found. aborting script execution.\n"_fmt, builtin_functions[func].name);
+ st->state = ScriptEndState::END;
+ } else if (builtin_functions[func].ret == 's' && !back.is<ScriptDataStr>()) {
+ PRINTF("script-call:run_func: expected %s to push a string but none was found. aborting script execution.\n"_fmt, builtin_functions[func].name);
+ st->state = ScriptEndState::END;
+ } else if (builtin_functions[func].ret == 'v' && !back.is<ScriptDataStr>() && !back.is<ScriptDataInt>() && !back.is<ScriptDataParam>() && !back.is<ScriptDataVariable>()) {
+ PRINTF("script-call:run_func: expected %s to push a value but none was found. aborting script execution.\n"_fmt, builtin_functions[func].name);
+ st->state = ScriptEndState::END;
+ } else if (builtin_functions[func].ret == 'r' && !back.is<ScriptDataVariable>()) {
+ PRINTF("script-call:run_func: expected %s to push a variable reference but none was found. aborting script execution.\n"_fmt, builtin_functions[func].name);
+ st->state = ScriptEndState::END;
+ } else if (builtin_functions[func].ret == 'l' && !back.is<ScriptDataPos>()) {
+ PRINTF("script-call:run_func: expected %s to push a label pos but none was found. aborting script execution.\n"_fmt, builtin_functions[func].name);
+ st->state = ScriptEndState::END;
+ }
+ }
+
pop_stack(st->stack, start_sp, end_sp);
if (st->state == ScriptEndState::RETFUNC)