X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=node.cpp;h=b6793f6c73b804b78101eca68389e6d49db3e4e4;hb=3f82360c5e0c61eccacdbaf3bd077852b9326f34;hp=b4d22fb9569c28cea70176abce6ce585c2b8b8c1;hpb=76a6e62c0a20bebba4c828f528f118a1f789b593;p=popboot.git diff --git a/node.cpp b/node.cpp index b4d22fb..b6793f6 100644 --- a/node.cpp +++ b/node.cpp @@ -34,17 +34,23 @@ bool Node::executed() const{ const Literals& Node::effects() const{ return _effects; } -void Node::satisfyCondition(std::string effect){ + +bool Node::satisfyCondition(std::string effect){ _preconditions.erase(_preconditions.find(effect)); + return _preconditions.size() == 0 && !_executed; } -void Node::execute(const Literals& effects){ - cerr << "Executing: " << _action->name() << endl; +bool Node::satisfyConditions(const Literals& effects){ for (Literals::const_iterator effect = effects.begin(); effect != effects.end(); ++effect){ cerr << "Satisfied effect: " << *effect << endl; _preconditions.erase(_preconditions.find(*effect)); } cerr << "Number of preconditions left: " << _preconditions.size() << endl; + return _preconditions.size() == 0 && !_executed; +} + +void Node::execute(){ + cerr << "Executing: " << _action->name() << endl; if(_executed) cerr << "Already executed" << endl; if ((_preconditions.size() != 0) || _executed) @@ -56,11 +62,11 @@ void Node::execute(const Literals& effects){ cerr << "Got returnvalue: " << value << ", number of effects: " << _effects.size() << endl; - 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; @@ -70,7 +76,7 @@ StartNode::StartNode(const Literals& init){ EndNode::EndNode(const Literals& goal){ Preconditions goalState; for(Literals::const_iterator g = goal.begin(); g != goal.end(); ++g) - goalState[*g] = true; + goalState[*g] = false; _action = new Action("finish",goalState,"",EffectsMap()); _preconditions = _action->preconditions(); }