diff options
author | Lance <Lance@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2006-05-22 12:38:12 +0000 |
---|---|---|
committer | Lance <Lance@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2006-05-22 12:38:12 +0000 |
commit | 22e1db931f45226b27f7b84e0c1e183aaef56842 (patch) | |
tree | 5e00e0dd38a4b2d20f3dfd397fd10857d3a0950a /src/map | |
parent | de7175c5bc24b6e8f3b87540ae93f40a75df2df2 (diff) | |
download | hercules-22e1db931f45226b27f7b84e0c1e183aaef56842.tar.gz hercules-22e1db931f45226b27f7b84e0c1e183aaef56842.tar.bz2 hercules-22e1db931f45226b27f7b84e0c1e183aaef56842.tar.xz hercules-22e1db931f45226b27f7b84e0c1e183aaef56842.zip |
- Fixed some of the leaks.. still fixing..
git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@6691 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src/map')
-rw-r--r-- | src/map/npc.c | 2 | ||||
-rw-r--r-- | src/map/script.c | 11 |
2 files changed, 11 insertions, 2 deletions
diff --git a/src/map/npc.c b/src/map/npc.c index 4278d8d27..f68fa4e49 100644 --- a/src/map/npc.c +++ b/src/map/npc.c @@ -1381,7 +1381,7 @@ int npc_unload (struct npc_data *nd) aFree(nd->u.scr.timer_event);
if (nd->u.scr.src_id == 0) {
if(nd->u.scr.script) {
- aFree(nd->u.scr.script);
+ script_free_code(nd->u.scr.script);
nd->u.scr.script = NULL;
}
if (nd->u.scr.label_list) {
diff --git a/src/map/script.c b/src/map/script.c index 413468eb7..777714a84 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -11882,6 +11882,15 @@ int script_config_read(char *cfgName) return script_config_read_sub(cfgName);
}
+static int do_final_userfunc_sub (DBKey key,void *data,va_list ap){
+ struct script_code *code = (struct script_code *)data;
+ if(code){
+ script_free_vars( &code->script_vars );
+ aFree( code->script_buf );
+ }
+ return 0;
+}
+
/*==========================================
* I
*------------------------------------------
@@ -11894,7 +11903,7 @@ int do_final_script() mapreg_db->destroy(mapreg_db,NULL);
mapregstr_db->destroy(mapregstr_db,NULL);
scriptlabel_db->destroy(scriptlabel_db,NULL);
- userfunc_db->destroy(userfunc_db,NULL);
+ userfunc_db->destroy(userfunc_db,do_final_userfunc_sub);
if(sleep_db) {
struct linkdb_node *n = (struct linkdb_node *)sleep_db;
while(n) {
|