X-Git-Url: https://ruin.nu/git/?p=popboot.git;a=blobdiff_plain;f=node.cpp;h=24da8b1dd60c36d9575151630ca3e990905b9ef2;hp=1efdf6a03199e01f882e27e4d4d7de499f01a27b;hb=HEAD;hpb=c9c72023d15decebe700ad0bfe3e8cbac9a85248 diff --git a/node.cpp b/node.cpp index 1efdf6a..24da8b1 100644 --- a/node.cpp +++ b/node.cpp @@ -1,10 +1,11 @@ #include "node.h" #include +#include using namespace std; -Node::Node(const Action& action){ +Node::Node(const Action* action){ _action = action; - _preconditions = _action.preconditions(); + _preconditions = _action->preconditions(); _executed = false; } Node::Node(){ @@ -17,7 +18,7 @@ Node::Node(const Node& node){ _executed = node._executed; } -const Action& Node::action() const{ +const Action* Node::action() const{ return _action; } @@ -34,40 +35,50 @@ const Literals& Node::effects() const{ return _effects; } -void Node::execute(const Literals& effects){ +bool Node::satisfyCondition(std::string effect){ + _preconditions.erase(_preconditions.find(effect)); + return _preconditions.size() == 0 && !_executed; +} + +bool Node::satisfyConditions(const Literals& effects){ for (Literals::const_iterator effect = effects.begin(); effect != effects.end(); ++effect){ _preconditions.erase(_preconditions.find(*effect)); } + return _preconditions.size() == 0 && !_executed; +} + +void Node::execute(){ + if(_executed) + cerr << "Already executed " << _action->name() << endl; if ((_preconditions.size() != 0) || _executed) return; - if (_preconditions.size() != 0){ - for (Preconditions::iterator precond = _preconditions.begin(); precond != _preconditions.end(); ++precond){ - if (precond->second) - return; - } - } - _executed = true; - int value = _action.execute(); - _effects = _action.effects(value); + int value = _action->execute(); + _effects = _action->effects(value); - for(vector::iterator child = _children.begin(); child != _children.end(); ++child){ - (*child)->execute(effects); - } } +const std::vector& Node::children() const{ + return _children; +} StartNode::StartNode(const Literals& init){ EffectsMap initial; initial[0] = init; - _action = Action("start",Preconditions(),"", initial); + _action = new Action("start",Preconditions(),"", initial); + _executed = true; + _effects = init; +} + +const Preconditions& Node::preconditions() const{ + return _preconditions; } EndNode::EndNode(const Literals& goal){ Preconditions goalState; for(Literals::const_iterator g = goal.begin(); g != goal.end(); ++g) - goalState[*g] = true; - _action = Action("finish",goalState,"",EffectsMap()); - _preconditions = _action.preconditions(); + goalState[*g] = false; + _action = new Action("finish",goalState,"",EffectsMap()); + _preconditions = _action->preconditions(); }