From cbb8025fd6ba45664ed49e7f4d4c4e215fc77b01 Mon Sep 17 00:00:00 2001 From: Ben Gardner Date: Wed, 24 Nov 2010 10:51:39 -0600 Subject: [PATCH] Bail on template detection if we back up into a return and there is a boolean op in the angles. --- src/tokenize_cleanup.cpp | 7 +++---- tests/output/cpp/30108-templates3.cpp | 2 +- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/tokenize_cleanup.cpp b/src/tokenize_cleanup.cpp index 37ca0cf67a..386629c945 100644 --- a/src/tokenize_cleanup.cpp +++ b/src/tokenize_cleanup.cpp @@ -774,7 +774,7 @@ static void check_template(chunk_t *start) } else { - /* We may have something like "a< ... >", which is a template use + /* We may have something like "a< ... >", which is a template where * '...' may consist of anything except braces {}, a semicolon, and * unbalanced parens. * if we are inside an 'if' statement and hit a CT_BOOL, then it isn't a @@ -801,12 +801,11 @@ static void check_template(chunk_t *start) if ((pc->type == CT_SEMICOLON) || (pc->type == CT_BRACE_OPEN) || (pc->type == CT_BRACE_CLOSE) || - (pc->type == CT_SQUARE_CLOSE) || - (pc->type == CT_SEMICOLON)) + (pc->type == CT_SQUARE_CLOSE)) { break; } - if (pc->type == CT_IF) + if ((pc->type == CT_IF) || (pc->type == CT_RETURN)) { in_if = true; break; diff --git a/tests/output/cpp/30108-templates3.cpp b/tests/output/cpp/30108-templates3.cpp index 75ca08df05..df82000391 100644 --- a/tests/output/cpp/30108-templates3.cpp +++ b/tests/output/cpp/30108-templates3.cpp @@ -18,6 +18,6 @@ void test(void) return x != 0 && x >= 1 && x < 2 - && y > = 3 + && y >= 3 && y < 4; }