- Implemented attmod expansion.
This commit is contained in:
Paul Beckingham 2014-04-27 13:15:29 -07:00
parent 9ee3e03922
commit 1e796bb276

View file

@ -563,132 +563,100 @@ const std::string A3t::getFilterExpression ()
}
else if ((*i)->hasTag ("ATTMOD"))
{
// TODO name.mod:value --> name <op> value
// name.mod:value --> name <op> value
if (filter != "")
filter += ' ';
filter += "<attmod>";
/*
std::string name;
std::string mod;
std::string value;
std::string sense;
extract_attmod (arg->_raw, name, mod, value, sense);
std::string name = (*i)->attribute ("name");
std::string mod = (*i)->attribute ("modifier");
std::string value = (*i)->attribute ("value");
std::string sense = (*i)->attribute ("sense"); // TODO Not used. Why?
// name.before:value --> name < value
if (mod == "before" || mod == "under" || mod == "below")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("<", Arg::cat_op));
expanded.push_back (Arg (value, implied, Arg::cat_literal));
filter += name + " < " + value;
}
// name.after:value --> name > value
else if (mod == "after" || mod == "over" || mod == "above")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg (">", Arg::cat_op));
expanded.push_back (Arg (value, implied, Arg::cat_literal));
filter += name + " > " + value;
}
// name.none: --> name == ""
else if (mod == "none")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("=", Arg::cat_op));
expanded.push_back (Arg ("", implied, Arg::cat_none));
filter += name + " == ''";
}
// name.any: --> name != ""
else if (mod == "any")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("!=", Arg::cat_op));
expanded.push_back (Arg ("", implied, Arg::cat_none));
filter += name + " != ''";
}
// name.is:value --> name = value
else if (mod == "is" || mod == "equals")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("=", Arg::cat_op));
expanded.push_back (Arg (value, implied, Arg::cat_none));
filter += name + " == " + value;
}
// name.isnt:value --> name != value
else if (mod == "isnt" || mod == "not")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("!=", Arg::cat_op));
expanded.push_back (Arg (value, implied, Arg::cat_none));
filter += name + " != " + value;
}
// name.has:value --> name ~ value
else if (mod == "has" || mod == "contains")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("~", Arg::cat_op));
expanded.push_back (Arg (value, Arg::type_string, Arg::cat_rx));
filter += name + " ~ " + value;
}
// name.hasnt:value --> name !~ value
else if (mod == "hasnt")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("!~", Arg::cat_op));
expanded.push_back (Arg (value, Arg::type_string, Arg::cat_rx));
filter += name + " !~ " + value;
}
// name.startswith:value --> name ~ ^value
else if (mod == "startswith" || mod == "left")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("~", Arg::cat_op));
expanded.push_back (Arg ("^" + value, Arg::type_string, Arg::cat_rx));
filter += name + " ~ '^" + value + "'";
}
// name.endswith:value --> name ~ value$
else if (mod == "endswith" || mod == "right")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("~", Arg::cat_op));
expanded.push_back (Arg (value + "$", Arg::type_string, Arg::cat_rx));
filter += name + " ~ '" + value + "$'";
}
// name.word:value --> name ~ \bvalue\b
else if (mod == "word")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("~", Arg::cat_op));
#ifdef DARWIN
expanded.push_back (Arg (value, Arg::type_string, Arg::cat_literal));
#if defined (DARWIN)
filter += name + " ~ " + value;
#elif defined (SOLARIS)
filter += name + " ~ '\\<" + value + "\\>'";
#else
#ifdef SOLARIS
expanded.push_back (Arg ("\\<" + value + "\\>", Arg::type_string, Arg::cat_rx));
#else
expanded.push_back (Arg ("\\b" + value + "\\b", Arg::type_string, Arg::cat_rx));
#endif
filter += name + " ~ '\\b" + value + "\\b'";
#endif
}
// name.noword:value --> name !~ \bvalue\n
else if (mod == "noword")
{
expanded.push_back (Arg (name, Arg::type_string, Arg::cat_dom));
expanded.push_back (Arg ("!~", Arg::cat_op));
#ifdef DARWIN
expanded.push_back (Arg (value, Arg::type_string, Arg::cat_literal));
#if defined (DARWIN)
filter += name + " !~ " + value;
#elif defined (SOLARIS)
filter += name + " !~ '\\<" + value + "\\>'";
#else
#ifdef SOLARIS
expanded.push_back (Arg ("\\<" + value + "\\>", Arg::type_string, Arg::cat_rx));
#else
expanded.push_back (Arg ("\\b" + value + "\\b", Arg::type_string, Arg::cat_rx));
#endif
filter += name + " !~ '\\b" + value + "\\b'";
#endif
}
else
throw format (STRING_A3_UNKNOWN_ATTMOD, mod);
*/
}
else if ((*i)->hasTag ("ATTRIBUTE"))
{