mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-06-26 10:54:26 +02:00
A3t
- Inserts implicit AND operators into filters that otherwise don't.
This commit is contained in:
parent
3add6c3c7e
commit
3e7052b500
2 changed files with 18 additions and 43 deletions
60
src/A3t.cpp
60
src/A3t.cpp
|
@ -519,18 +519,31 @@ Tree* A3t::captureFirst (const std::string& arg)
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
const std::string A3t::getFilterExpression ()
|
const std::string A3t::getFilterExpression ()
|
||||||
{
|
{
|
||||||
// Insert implicit "and", "(" and ")" operators.
|
|
||||||
patchInfix ();
|
|
||||||
|
|
||||||
// TODO Construct an efficient ID/UUID clause.
|
// TODO Construct an efficient ID/UUID clause.
|
||||||
|
|
||||||
// Locate and extract the filter elements.
|
// Locate and extract the filter elements.
|
||||||
std::string filter = "";
|
std::string filter = "";
|
||||||
|
std::vector <Tree*>::iterator prev = _tree->_branches.begin ();
|
||||||
std::vector <Tree*>::iterator i;
|
std::vector <Tree*>::iterator i;
|
||||||
for (i = _tree->_branches.begin (); i != _tree->_branches.end (); ++i)
|
for (i = _tree->_branches.begin (); i != _tree->_branches.end (); ++i)
|
||||||
{
|
{
|
||||||
if ((*i)->hasTag ("FILTER") && ! (*i)->hasTag ("PSEUDO"))
|
if ((*i)->hasTag ("FILTER") && ! (*i)->hasTag ("PSEUDO"))
|
||||||
{
|
{
|
||||||
|
// Two consecutive FILTER, non-OP arguments that are not "(" or ")" need
|
||||||
|
// an "AND" operator inserted between them.
|
||||||
|
//
|
||||||
|
// ) <non-op> --> ) and <non-op>
|
||||||
|
// <non-op> ( --> <non-op> <and> (
|
||||||
|
// ) ( --> ) and (
|
||||||
|
// <non-op> <non-op> --> <non-op> and <non-op>
|
||||||
|
//
|
||||||
|
if (i != prev &&
|
||||||
|
(((*prev)->hasTag ("FILTER") && ! (*prev)->hasTag ("OP")) || (*prev)->attribute ("raw") == ")") &&
|
||||||
|
(! (*i)->hasTag ("OP") || (*i)->attribute ("raw") == "("))
|
||||||
|
{
|
||||||
|
filter += " AND";
|
||||||
|
}
|
||||||
|
|
||||||
if ((*i)->hasTag ("ID"))
|
if ((*i)->hasTag ("ID"))
|
||||||
{
|
{
|
||||||
// TODO Construct sequence clause clause.
|
// TODO Construct sequence clause clause.
|
||||||
|
@ -707,6 +720,8 @@ const std::string A3t::getFilterExpression ()
|
||||||
|
|
||||||
filter += (*i)->attribute ("raw");
|
filter += (*i)->attribute ("raw");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
prev = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1200,45 +1215,6 @@ void A3t::findModifications ()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Insert 'and' operators between adjacent non-operators.
|
|
||||||
//
|
|
||||||
// ) <non-op> --> ) and <non-op>
|
|
||||||
// <non-op> ( --> <non-op> <and> (
|
|
||||||
// ) ( --> ) and (
|
|
||||||
// <non-op> <non-op> --> <non-op> and <non-op>
|
|
||||||
//
|
|
||||||
void A3t::patchInfix ()
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
if (input.size () == 1)
|
|
||||||
return input;
|
|
||||||
|
|
||||||
Arg previous ("?", Arg::cat_op);
|
|
||||||
|
|
||||||
A3 modified;
|
|
||||||
modified._limit = input._limit;
|
|
||||||
|
|
||||||
std::vector <Arg>::const_iterator arg;
|
|
||||||
for (arg = input.begin (); arg != input.end (); ++arg)
|
|
||||||
{
|
|
||||||
// Old-style filters need 'and' conjunctions.
|
|
||||||
if ((previous._category != Arg::cat_op || previous._raw == ")") &&
|
|
||||||
(arg->_category != Arg::cat_op || arg->_raw == "("))
|
|
||||||
{
|
|
||||||
modified.push_back (Arg ("and", Arg::cat_op));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now insert the adjacent non-operator.
|
|
||||||
modified.push_back (*arg);
|
|
||||||
previous = *arg;
|
|
||||||
}
|
|
||||||
|
|
||||||
modified.dump ("A3::infix");
|
|
||||||
return modified;
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// Validate the parse tree.
|
// Validate the parse tree.
|
||||||
void A3t::validate ()
|
void A3t::validate ()
|
||||||
|
|
|
@ -71,7 +71,6 @@ private:
|
||||||
void findOperator ();
|
void findOperator ();
|
||||||
void findFilter ();
|
void findFilter ();
|
||||||
void findModifications ();
|
void findModifications ();
|
||||||
void patchInfix ();
|
|
||||||
void validate ();
|
void validate ();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue