summaryrefslogtreecommitdiff
path: root/src/shared/cplusplus/Parser.cpp
diff options
context:
space:
mode:
authorRoberto Raggi <roberto.raggi@nokia.com>2009-10-22 16:46:26 +0200
committerRoberto Raggi <roberto.raggi@nokia.com>2009-10-22 16:48:06 +0200
commit2a7fa04101bf487f4fd6dd04297573f62157d41a (patch)
tree3707690d1ca2ec3fbde9cfd1be0d1964e9fa91a3 /src/shared/cplusplus/Parser.cpp
parent8175e4e4c62bb5a587329ca5bb5c4c35508370d4 (diff)
downloadqt-creator-2a7fa04101bf487f4fd6dd04297573f62157d41a.tar.gz
Released the memory allocated in the memory pool when backtracking from Parser::parseTemplateId().
Diffstat (limited to 'src/shared/cplusplus/Parser.cpp')
-rw-r--r--src/shared/cplusplus/Parser.cpp32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/shared/cplusplus/Parser.cpp b/src/shared/cplusplus/Parser.cpp
index 8f3bd549ce..24851c991d 100644
--- a/src/shared/cplusplus/Parser.cpp
+++ b/src/shared/cplusplus/Parser.cpp
@@ -88,6 +88,30 @@ int DebugRule::depth = 0;
# define DEBUG_THIS_RULE() do {} while (0)
#endif
+class Parser::Rewind
+{
+ Parser *_parser;
+ MemoryPool::State _state;
+
+public:
+ inline Rewind(Parser *parser)
+ : _parser(parser) {}
+
+ inline void operator()(unsigned tokenIndex)
+ { rewind(tokenIndex); }
+
+ inline void mark()
+ { _state = _parser->_pool->state(); }
+
+ inline void rewind(unsigned tokenIndex)
+ {
+ _parser->rewind(tokenIndex);
+
+ if (_state.isValid())
+ _parser->_pool->rewind(_state);
+ }
+};
+
Parser::Parser(TranslationUnit *unit)
: _translationUnit(unit),
_control(_translationUnit->control()),
@@ -302,6 +326,11 @@ bool Parser::parseClassOrNamespaceName(NameAST *&node)
bool Parser::parseTemplateId(NameAST *&node)
{
DEBUG_THIS_RULE();
+
+ const unsigned start = cursor();
+ Rewind rewind(this);
+ rewind.mark();
+
if (LA() == T_IDENTIFIER && LA(2) == T_LESS) {
TemplateIdAST *ast = new (_pool) TemplateIdAST;
ast->identifier_token = consumeToken();
@@ -315,6 +344,9 @@ bool Parser::parseTemplateId(NameAST *&node)
}
}
}
+
+ rewind(start);
+
return false;
}