Program Listing for File Ground.h
↰ Return to documentation for file (/tmp/ws/src/ros2_planning_system/plansys2_pddl_parser/include/plansys2_pddl_parser/Ground.h
)
#pragma once
#include "plansys2_msgs/msg/node.hpp"
#include "plansys2_msgs/msg/tree.hpp"
#include "plansys2_pddl_parser/Lifted.h"
namespace parser { namespace pddl {
class Ground : public ParamCond {
public:
Lifted * lifted;
Ground()
: ParamCond(), lifted( 0 ) {}
Ground( const std::string s, const IntVec & p = IntVec() )
: ParamCond( s, p ), lifted( 0 ) {}
Ground( Lifted * l, const IntVec & p = IntVec() )
: ParamCond( l->name, p ), lifted( l ) {}
Ground( const Ground * g, Domain & d );
void PDDLPrint( std::ostream & s, unsigned indent, const TokenStruct< std::string > & ts, const Domain & d ) const override;
plansys2_msgs::msg::Node::SharedPtr getTree( plansys2_msgs::msg::Tree & tree, const Domain & d, const std::vector<std::string> & replace = {} ) const override;
void parse( Stringreader & f, TokenStruct< std::string > & ts, Domain & d );
void addParams( int m, unsigned n ) {
for ( unsigned i = 0; i < params.size(); ++i )
if ( params[i] >= m ) params[i] += n;
}
Condition * copy( Domain & d ) {
return new Ground( this, d );
}
};
typedef std::vector< Ground * > GroundVec;
} } // namespaces