diff options
author | Lance <Lance@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2006-05-31 05:27:49 +0000 |
---|---|---|
committer | Lance <Lance@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2006-05-31 05:27:49 +0000 |
commit | a6fa88b228e6f2d0bb7e0847254108da7b9c6114 (patch) | |
tree | 5bb4a3d390e9489eae7ba49dbbdbbdf7f51290c9 /src | |
parent | 78b8c9896c2f4170e7fa0ea502ac1026525f8174 (diff) | |
download | hercules-a6fa88b228e6f2d0bb7e0847254108da7b9c6114.tar.gz hercules-a6fa88b228e6f2d0bb7e0847254108da7b9c6114.tar.bz2 hercules-a6fa88b228e6f2d0bb7e0847254108da7b9c6114.tar.xz hercules-a6fa88b228e6f2d0bb7e0847254108da7b9c6114.zip |
[Fixed]:
- Logic errors in run_script
git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@6875 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src')
-rw-r--r-- | src/map/script.c | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/src/map/script.c b/src/map/script.c index 6aa75d0fa..95b97ac9f 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -11467,14 +11467,17 @@ int run_script(struct script_code *rootscript,int pos,int rid,int oid) st->state = RUN; st->script = rootscript; - if (sd && sd->stack) { // if there's a sd and a stack - back it up and restore it if possible. - bck_script = sd->npc_script; - bck_scriptroot = sd->npc_scriptroot; - bck_scriptstate = sd->npc_scriptstate; - bck_stack = sd->stack; - sd->stack = NULL; - bck_npcid = sd->npc_id; - sd->npc_id = st->oid; + if (sd){ + if(sd->stack) { + // if there's a sd and a stack - back it up and restore it if possible. + bck_script = sd->npc_script; + bck_scriptroot = sd->npc_scriptroot; + bck_scriptstate = sd->npc_scriptstate; + bck_stack = sd->stack; + sd->stack = NULL; + bck_npcid = sd->npc_id; + } + sd->npc_id = oid; } } st->pos = pos; |