diff options
author | Arnold D. Robbins <arnold@skeeve.com> | 2013-09-22 16:57:11 +0300 |
---|---|---|
committer | Arnold D. Robbins <arnold@skeeve.com> | 2013-09-22 16:57:11 +0300 |
commit | da83b6857bf0a67b15fc75d31a0b6802ac9baffe (patch) | |
tree | 399e9f1ec800b5405f9b494060481a8420480caf /regex_internal.c | |
parent | e149eb882355f427d43928324145c971a0562c5e (diff) | |
parent | 8aa14c5f3cf78f90b589785a9ffe5f7f02050b37 (diff) | |
download | egawk-da83b6857bf0a67b15fc75d31a0b6802ac9baffe.tar.gz egawk-da83b6857bf0a67b15fc75d31a0b6802ac9baffe.tar.bz2 egawk-da83b6857bf0a67b15fc75d31a0b6802ac9baffe.zip |
Merge branch 'master' into comment
Diffstat (limited to 'regex_internal.c')
-rw-r--r-- | regex_internal.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/regex_internal.c b/regex_internal.c index 5f77bcb0..c7de18b6 100644 --- a/regex_internal.c +++ b/regex_internal.c @@ -1451,7 +1451,18 @@ re_dfa_add_node (re_dfa_t *dfa, re_token_t token) new_eclosures = re_realloc (dfa->eclosures, re_node_set, new_nodes_alloc); if (BE (new_nexts == NULL || new_indices == NULL || new_edests == NULL || new_eclosures == NULL, 0)) - return -1; + { + /* if any are not NULL, free them, avoid leaks */ + if (new_nexts != NULL) + re_free(new_nexts); + if (new_indices != NULL) + re_free(new_indices); + if (new_edests != NULL) + re_free(new_edests); + if (new_eclosures != NULL) + re_free(new_eclosures); + return -1; + } dfa->nexts = new_nexts; dfa->org_indices = new_indices; dfa->edests = new_edests; |