2 #ifndef _MADARA_NO_KARL_ 45 bool arg_can_change =
false;
46 result =
nodes_[0]->prune (arg_can_change);
48 if (!arg_can_change && dynamic_cast <LeafNode *> (
nodes_[0]) == 0)
69 "System call to_buffer is converting an argument to an " 70 "unmanaged buffer\n");
73 unsigned char * buffer =
74 nodes_[0]->evaluate (settings).to_unmanaged_buffer (size);
76 return_value.
set_file (buffer, size);
81 "System call to_buffer is converting 0 to a buffer\n");
84 unsigned char * buffer =
87 return_value.
set_file (buffer, size);
98 visitor.
visit (*
this);
101 #endif // _MADARA_NO_KARL_ This class encapsulates an entry in a KnowledgeBase.
virtual madara::knowledge::KnowledgeRecord evaluate(const madara::knowledge::KnowledgeUpdateSettings &settings)
Evaluates the expression tree.
virtual madara::knowledge::KnowledgeRecord item(void) const
Returns the value of the node.
madara::knowledge::KnowledgeRecord KnowledgeRecord
std::deque< ComponentNode * > ComponentNodes
a vector of Component Nodes
void set_file(const unsigned char *new_value, size_t size)
sets the value to an unknown file type
SystemCallToBuffer(madara::knowledge::ThreadSafeContext &context, const ComponentNodes &nodes)
Constructor.
logger::Logger * logger_
handle the context
This class stores variables and their values for use by any entity needing state information in a thr...
Defines a node that contains a madara::knowledge::KnowledgeRecord::Integer value. ...
virtual void accept(Visitor &visitor) const
Accepts a visitor subclassed from the Visitor class.
#define madara_logger_ptr_log(logger, level,...)
Fast version of the madara::logger::log method for Logger pointers.
Abstract base class for all visitors to all classes that derive from ComponentNode.
Interface for a MADARA system call.
virtual ~SystemCallToBuffer(void)
Destructor.
virtual madara::knowledge::KnowledgeRecord prune(bool &can_change)
Prunes the expression tree of unnecessary nodes.
Settings for applying knowledge updates.
virtual void visit(const LeafNode &node)=0
Visit a LeafNode.
unsigned char * to_unmanaged_buffer(size_t &size) const
returns an unmanaged buffer that the user will have to take care of (this is a copy of the internal v...