summaryrefslogtreecommitdiff
path: root/ext/syck/syck.c
diff options
context:
space:
mode:
authormame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-07-31 15:44:51 +0000
committermame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-07-31 15:44:51 +0000
commite4416992d80bcfa1c1727832c07ecece5f5934ab (patch)
tree267200119ec986231f3f1936c4376c1bd9d4b838 /ext/syck/syck.c
parent9de7bcff88b3337a76bd21c6552f39cd4c12115f (diff)
* ext/syck/syck.c (syck_free_parser): fix memory leak by
YAML::Syck.compile. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18297 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/syck/syck.c')
-rw-r--r--ext/syck/syck.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/ext/syck/syck.c b/ext/syck/syck.c
index dbf753337e..92b7566d1a 100644
--- a/ext/syck/syck.c
+++ b/ext/syck/syck.c
@@ -229,6 +229,22 @@ syck_st_free( SyckParser *p )
}
}
+typedef struct {
+ long hash;
+ char *buffer;
+ long length;
+ long remaining;
+ int printed;
+} bytestring_t;
+
+int
+syck_st_free_syms( void *key, bytestring_t *sav, void *dummy )
+{
+ S_FREE(sav->buffer);
+ S_FREE(sav);
+ return ST_CONTINUE;
+}
+
void
syck_free_parser( SyckParser *p )
{
@@ -237,6 +253,7 @@ syck_free_parser( SyckParser *p )
*/
if ( p->syms != NULL )
{
+ st_foreach( p->syms, syck_st_free_syms, 0 );
st_free_table( p->syms );
p->syms = NULL;
}