- Removal of alias load/resolve code, which (1) needs a rewrite, and (2) belongs
  in the Parser.
This commit is contained in:
Paul Beckingham 2014-07-03 19:04:48 -04:00
parent 6145869f43
commit 5b9413b02c
5 changed files with 1 additions and 177 deletions

View file

@ -1,122 +0,0 @@
////////////////////////////////////////////////////////////////////////////////
//
// Copyright 2006 - 2014, Paul Beckingham, Federico Hernandez.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
//
// http://www.opensource.org/licenses/mit-license.php
//
////////////////////////////////////////////////////////////////////////////////
#include <cmake.h>
#include <iostream> // TODO Remove
#include <vector>
#include <Alias.h>
#include <Context.h>
#include <Lexer.h>
#include <Tree.h>
#include <text.h>
extern Context context;
// Alias expansion limit. Any more indicates some kind of error.
const int safetyValveDefault = 10;
////////////////////////////////////////////////////////////////////////////////
Alias::Alias ()
{
}
////////////////////////////////////////////////////////////////////////////////
Alias::~Alias ()
{
}
////////////////////////////////////////////////////////////////////////////////
void Alias::load ()
{
_aliases.clear ();
std::vector <std::string> vars;
context.config.all (vars);
std::vector <std::string>::iterator var;
for (var = vars.begin (); var != vars.end (); ++var)
if (var->substr (0, 6) == "alias.")
_aliases[var->substr (6)] = context.config.get (*var);
}
////////////////////////////////////////////////////////////////////////////////
// An alias must be a distinct word on the command line.
//
// TODO This is straight word substitution. What this really needs is node
// insertion, for more advanced aliases.
void Alias::resolve (Tree* tree)
{
bool something;
int safety_valve = safetyValveDefault;
do
{
something = false;
std::string command;
std::vector <Tree*>::iterator i;
for (i = tree->_branches.begin (); i != tree->_branches.end (); ++i)
{
// Parser override operator.
if ((*i)->attribute ("raw") == "--")
break;
// Skip known args.
if (! (*i)->hasTag ("?"))
continue;
std::map <std::string, std::string>::iterator a;
if ((*i)->_branches.size ())
{
std::vector <Tree*>::iterator b;
for (b = (*i)->_branches.begin (); b != (*i)->_branches.end (); ++b)
{
a = _aliases.find ((*b)->attribute ("raw"));
if (a != _aliases.end ())
{
(*b)->attribute ("raw", a->second);
something = true;
}
}
}
else
{
a = _aliases.find ((*i)->attribute ("raw"));
if (a != _aliases.end ())
{
(*i)->attribute ("raw", a->second);
something = true;
}
}
}
}
while (something && --safety_valve > 0);
if (safety_valve <= 0)
context.debug (format ("Nested alias limit of {1} reached.", safetyValveDefault));
}
////////////////////////////////////////////////////////////////////////////////

View file

@ -1,47 +0,0 @@
////////////////////////////////////////////////////////////////////////////////
//
// Copyright 2006 - 2014, Paul Beckingham, Federico Hernandez.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
//
// http://www.opensource.org/licenses/mit-license.php
//
////////////////////////////////////////////////////////////////////////////////
#ifndef INCLUDED_ALIAS
#define INCLUDED_ALIAS
#include <string>
#include <map>
#include <Tree.h>
class Alias
{
public:
Alias ();
~Alias ();
void load ();
void resolve (Tree*);
public:
std::map <std::string, std::string> _aliases;
};
#endif

View file

@ -5,8 +5,7 @@ include_directories (${CMAKE_SOURCE_DIR}
${CMAKE_SOURCE_DIR}/src/columns
${TASK_INCLUDE_DIRS})
set (task_SRCS Alias.cpp Alias.h
Color.cpp Color.h
set (task_SRCS Color.cpp Color.h
Config.cpp Config.h
Context.cpp Context.h
DOM.cpp DOM.h

View file

@ -144,10 +144,6 @@ int Context::initialize (int argc, const char** argv)
parser.applyOverrides ();
createDefaultConfig ();
// Handle Aliases.
alias.load ();
alias.resolve (parser.tree ());
// Initialize the color rules, if necessary.
if (color ())
initializeColorRules ();

View file

@ -34,7 +34,6 @@
#include <TDB2.h>
#include <Hooks.h>
#include <DOM.h>
#include <Alias.h>
#include <Path.h>
#include <File.h>
#include <Directory.h>
@ -89,7 +88,6 @@ public:
Config config;
TDB2 tdb2;
Alias alias;
Hooks hooks;
DOM dom;