diff options
author | mame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-09-12 11:02:21 +0000 |
---|---|---|
committer | mame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-09-12 11:02:21 +0000 |
commit | eca8de632c8e6ba7a5f96f4e1bf53a12556e1cc6 (patch) | |
tree | 80cf936f90548d47e8ec491d16555e82da18c0f3 | |
parent | d1724ecbd206091602c480081c91a7e90b54e4bf (diff) |
* regparse.c (parse_exp): fix resource leak.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19299 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | regparse.c | 5 |
2 files changed, 8 insertions, 1 deletions
@@ -1,3 +1,7 @@ +Fri Sep 12 20:00:22 2008 Yusuke Endoh <mame@tsg.ne.jp> + + * regparse.c (parse_exp): fix resource leak. + Fri Sep 12 01:21:22 2008 Yusuke Endoh <mame@tsg.ne.jp> * ext/syck/node.c (syck_replace_str2): fix wrong check to free ptr. diff --git a/regparse.c b/regparse.c index 3d2c57a25a..168b175758 100644 --- a/regparse.c +++ b/regparse.c @@ -5387,7 +5387,10 @@ parse_exp(Node** np, OnigToken* tok, int term, if (tok->u.repeat.possessive != 0) { Node* en; en = node_new_enclose(ENCLOSE_STOP_BACKTRACK); - CHECK_NULL_RETURN_MEMERR(en); + if (IS_NULL(en)) { + onig_node_free(qn); + return ONIGERR_MEMORY; + } NENCLOSE(en)->target = qn; qn = en; } |