mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-07-07 20:06:36 +02:00
Parser
- ::findPattern was performing the wrong scan, and needed branch pruning outside the iterator loop.
This commit is contained in:
parent
ce7f6b6492
commit
8b904a57f4
1 changed files with 30 additions and 30 deletions
|
@ -805,11 +805,14 @@ std::string Parser::getCommand () const
|
||||||
// /pattern/ --> description ~ pattern
|
// /pattern/ --> description ~ pattern
|
||||||
void Parser::findPattern ()
|
void Parser::findPattern ()
|
||||||
{
|
{
|
||||||
// context.debug ("Parser::findPattern");
|
bool action = true;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
action = false;
|
||||||
|
|
||||||
std::vector <Tree*> prune;
|
std::vector <Tree*> prune;
|
||||||
std::vector <Tree*> nodes;
|
std::vector <Tree*> nodes;
|
||||||
collect (nodes, collectAll);
|
collect (nodes);
|
||||||
std::vector <Tree*>::iterator i;
|
std::vector <Tree*>::iterator i;
|
||||||
for (i = nodes.begin (); i != nodes.end (); ++i)
|
for (i = nodes.begin (); i != nodes.end (); ++i)
|
||||||
{
|
{
|
||||||
|
@ -821,7 +824,7 @@ void Parser::findPattern ()
|
||||||
{
|
{
|
||||||
(*i)->unTag ("?");
|
(*i)->unTag ("?");
|
||||||
(*i)->tag ("PATTERN");
|
(*i)->tag ("PATTERN");
|
||||||
prune.push_back (*i);
|
(*i)->removeAllBranches ();
|
||||||
|
|
||||||
Tree* branch = (*i)->addBranch (new Tree ("argPat"));
|
Tree* branch = (*i)->addBranch (new Tree ("argPat"));
|
||||||
branch->attribute ("raw", "description");
|
branch->attribute ("raw", "description");
|
||||||
|
@ -833,15 +836,12 @@ void Parser::findPattern ()
|
||||||
branch = (*i)->addBranch (new Tree ("argPat"));
|
branch = (*i)->addBranch (new Tree ("argPat"));
|
||||||
branch->attribute ("raw", pattern);
|
branch->attribute ("raw", pattern);
|
||||||
branch->tag ("STRING");
|
branch->tag ("STRING");
|
||||||
|
action = true;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// Prune branches outside the loop.
|
while (action);
|
||||||
for (i = prune.begin (); i != prune.end (); ++i)
|
|
||||||
(*i)->removeAllBranches ();
|
|
||||||
|
|
||||||
// if (prune.size ())
|
|
||||||
// context.debug (_tree->dump ());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue