diff options
author | toms <toms@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2006-08-23 13:29:05 +0000 |
---|---|---|
committer | toms <toms@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2006-08-23 13:29:05 +0000 |
commit | feeb1b0df2e02b06e68e1c6ab53d673798213ba4 (patch) | |
tree | 6de2f7a3735b5ea498b8580c406285b721b98c11 /src | |
parent | 060105016caf3edd7e2528412a42d6323a27921a (diff) | |
download | hercules-feeb1b0df2e02b06e68e1c6ab53d673798213ba4.tar.gz hercules-feeb1b0df2e02b06e68e1c6ab53d673798213ba4.tar.bz2 hercules-feeb1b0df2e02b06e68e1c6ab53d673798213ba4.tar.xz hercules-feeb1b0df2e02b06e68e1c6ab53d673798213ba4.zip |
- Fixed a possible SIGSEGV on buildin_maprespawnguildid if the map is unknown
- Added debug on "Inifity loop" to know which script is making this loop
git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@8451 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src')
-rw-r--r-- | src/login_sql/login.c | 2 | ||||
-rw-r--r-- | src/map/script.c | 6 |
2 files changed, 6 insertions, 2 deletions
diff --git a/src/login_sql/login.c b/src/login_sql/login.c index 6adfa48f3..d1f280c24 100644 --- a/src/login_sql/login.c +++ b/src/login_sql/login.c @@ -2300,7 +2300,7 @@ void sql_config_read(const char *cfgName){ /* Kalaspuff, to get login_db */ void do_final(void) {
//sync account when terminating.
//but no need when you using DBMS (mysql)
- ShowStatus("Terminating...\n"); + ShowStatus("Terminating...\n");
mmo_db_close();
online_db->destroy(online_db, NULL);
if (gm_account_db)
diff --git a/src/map/script.c b/src/map/script.c index cf101f156..40cf9e31a 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -2659,6 +2659,7 @@ void run_script_main(struct script_state *st) st->state = RUN; if( gotocount>0 && (--gotocount)<=0 ){ ShowError("run_script: infinity loop !\n"); + report_src(st); st->state=END; } } @@ -2706,6 +2707,7 @@ void run_script_main(struct script_state *st) } if( cmdcount>0 && (--cmdcount)<=0 ){ ShowError("run_script: infinity loop !\n"); + report_src(st); st->state=END; } } @@ -8591,6 +8593,7 @@ int buildin_maprespawnguildid_sub(struct block_list *bl,va_list ap) } return 0; } + int buildin_maprespawnguildid(struct script_state *st) { char *mapname=conv_str(st,& (st->stack->stack_data[st->start+2])); @@ -8599,7 +8602,8 @@ int buildin_maprespawnguildid(struct script_state *st) int m=map_mapname2mapid(mapname); - if(m) map_foreachinmap(buildin_maprespawnguildid_sub,m,BL_CHAR,g_id,flag); + if(m != -1) + map_foreachinmap(buildin_maprespawnguildid_sub,m,BL_CHAR,g_id,flag); return 0; } |