From 6862448c7d3dcc5a0ee4b2a491408076249c4e29 Mon Sep 17 00:00:00 2001 From: skotlex Date: Thu, 21 Dec 2006 18:12:29 +0000 Subject: - Applied Rayce's suggestions and fixes to the script engine (http://www.eathena.ws/board/index.php?showtopic=129185) git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@9554 54d463be-8e91-2dee-dedb-b68131a5f0ec --- src/map/script.c | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) (limited to 'src') diff --git a/src/map/script.c b/src/map/script.c index a493322cc..5f4de13e4 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -567,7 +567,7 @@ const char* parse_simpleexpr(const char *p) p=parse_subexpr(p+1,-1); p=skip_space(p); if((*p++)!=')') - disp_error_message("parse_simpleexpr: unmatch ')'",p); + disp_error_message("parse_simpleexpr: unmatch ')'",p-1); } else if(isdigit(*p) || ((*p=='-' || *p=='+') && isdigit(p[1]))){ char *np; i=strtoul(p,&np,0); @@ -606,7 +606,7 @@ const char* parse_simpleexpr(const char *p) p=parse_subexpr(p+1,-1); p=skip_space(p); if((*p++)!=']') - disp_error_message("parse_simpleexpr: unmatch ']'",p); + disp_error_message("parse_simpleexpr: unmatch ']'",p-1); add_scriptc(C_FUNC); } else if(str_data[l].type == C_USERFUNC || str_data[l].type == C_USERFUNC_POS) { add_scriptl(search_str("callsub")); @@ -720,7 +720,7 @@ const char* parse_subexpr(const char* p,int limit) } plist[i]=p; if(*(p++)!=')') - disp_error_message("parse_subexpr: func request '(' ')'",p); + disp_error_message("parse_subexpr: func request '(' ')'",p-1); if(arg) { if( (arg[j]==0 && i!=j) || (arg[j]=='*' && istack->sp; for(i=end_sp-1;i>=0 && st->stack->stack_data[i].type!=C_ARG;i--); - if(i==0){ + if(i<=0){ //Crash fix when missing "push_val" causes current pointer to become -1. from Rayce (jA) if(battle_config.error_log) ShowError("function not found\n"); // st->stack->sp=0; @@ -4884,6 +4886,7 @@ int buildin_getarraysize(struct script_state *st) if( prefix!='$' && prefix!='@' && prefix!='.' ){ ShowWarning("buildin_copyarray: illegal scope !\n"); + push_val(st->stack,C_INT,0); return 1; } @@ -9441,6 +9444,9 @@ int buildin_strmobinfo(struct script_state *st) case 7: push_val(st->stack,C_INT,mob_db(class_)->job_exp); break; + default: + push_val(st->stack,C_INT,0); + break; } return 0; } @@ -10728,6 +10734,9 @@ int buildin_getsavepoint(struct script_state *st) case 2: push_val(st->stack,C_INT,y); break; + default: + push_val(st->stack,C_INT,0); + break; } return 0; } @@ -11190,6 +11199,8 @@ int buildin_getrefine(struct script_state *st) struct map_session_data *sd; if ((sd = script_rid2sd(st))!= NULL) push_val(st->stack, C_INT, sd->status.inventory[current_equip_item_index].refine); + else + push_val(st->stack,C_INT,0); return 0; } -- cgit v1.2.3-60-g2f50