diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2023-10-22 21:21:51 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2023-10-22 21:21:51 (GMT) |
commit | f82e9975ea778a2ffa7692e864b9ed49dd651bad (patch) | |
tree | ac6df3c687f92d124b0b6f8541e9bfe983c22be2 /src | |
parent | 28c6a886ccde945cfd38f3d17fe99ff0f5d0d2c4 (diff) |
Do not expect initialized trackers when there is no real defined search pattern.
Diffstat (limited to 'src')
-rw-r--r-- | src/analysis/scan/patterns/tokens/node.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/analysis/scan/patterns/tokens/node.c b/src/analysis/scan/patterns/tokens/node.c index 604cf86..71fcf05 100644 --- a/src/analysis/scan/patterns/tokens/node.c +++ b/src/analysis/scan/patterns/tokens/node.c @@ -416,6 +416,17 @@ void g_scan_token_node_check_forward(const GScanTokenNode *node, GScanContext *c if (ocount > 0) { + /** + * Dans le cas où un unique noeud ne renvoie que vers un espace (par + * exemple : "$a = { [0] }"), il n'y a pas de résultats, donc pas + * d'initialisation. + * + * La réinitialisation des décomptes va tiquer pour cet état. La + * phase d'extension des résultats inexistants est ainsi sautée. + */ + if (count_pending_matches(matches) == 0) + goto offset_done; + reset_pending_matches_ttl(matches); pending_ptr = get_all_pending_matches(matches, &pcount); @@ -447,6 +458,8 @@ void g_scan_token_node_check_forward(const GScanTokenNode *node, GScanContext *c */ /* purge_pending_matches(matches); */ + offset_done: + disable_all_ranges_in_node_search_offset(&offset); } |