6 Node::Node(const Action* action){
8 _preconditions = _action->preconditions();
15 Node::Node(const Node& node){
16 _action = node._action;
17 _preconditions = node._preconditions;
18 _executed = node._executed;
21 const Action* Node::action() const{
26 void Node::addChild(Node* node){
27 _children.push_back(node);
30 bool Node::executed() const{
34 const Literals& Node::effects() const{
38 bool Node::satisfyCondition(std::string effect){
39 _preconditions.erase(_preconditions.find(effect));
40 return _preconditions.size() == 0 && !_executed;
43 bool Node::satisfyConditions(const Literals& effects){
44 for (Literals::const_iterator effect = effects.begin(); effect != effects.end(); ++effect){
45 cerr << "Satisfied effect: " << *effect << endl;
46 _preconditions.erase(_preconditions.find(*effect));
48 cerr << "Number of preconditions left: " << _preconditions.size() << endl;
49 return _preconditions.size() == 0 && !_executed;
53 cerr << "Executing: " << _action->name() << endl;
55 cerr << "Already executed" << endl;
56 if ((_preconditions.size() != 0) || _executed)
60 int value = _action->execute();
61 _effects = _action->effects(value);
63 cerr << "Got returnvalue: " << value << ", number of effects: " << _effects.size() << endl;
67 const std::vector<Node*>& Node::children() const{
70 StartNode::StartNode(const Literals& init){
73 _action = new Action("start",Preconditions(),"", initial);
76 EndNode::EndNode(const Literals& goal){
77 Preconditions goalState;
78 for(Literals::const_iterator g = goal.begin(); g != goal.end(); ++g)
79 goalState[*g] = false;
80 _action = new Action("finish",goalState,"",EffectsMap());
81 _preconditions = _action->preconditions();