summaryrefslogtreecommitdiff
path: root/src/analysis
diff options
context:
space:
mode:
authorCyrille Bagard <nocbos@gmail.com>2023-10-22 21:21:51 (GMT)
committerCyrille Bagard <nocbos@gmail.com>2023-10-22 21:21:51 (GMT)
commitf82e9975ea778a2ffa7692e864b9ed49dd651bad (patch)
treeac6df3c687f92d124b0b6f8541e9bfe983c22be2 /src/analysis
parent28c6a886ccde945cfd38f3d17fe99ff0f5d0d2c4 (diff)
Do not expect initialized trackers when there is no real defined search pattern.
Diffstat (limited to 'src/analysis')
-rw-r--r--src/analysis/scan/patterns/tokens/node.c13
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);
}