MADARA  3.4.1
SystemCallPrint.cpp
Go to the documentation of this file.
1 
2 #ifndef _MADARA_NO_KARL_
3 
8 
11  : SystemCallNode(context, nodes)
12 {
13 }
14 
15 // Dtor
17 
19  void) const
20 {
21  return madara::knowledge::KnowledgeRecord(nodes_.size());
22 }
23 
28  bool& can_change)
29 {
30  // user can always change a function, and we have no control over
31  // what it does. Consequently, a function node cannot be pruned out
32  // under any situation
33  can_change = true;
34 
36 
37  if (nodes_.size() > 0)
38  {
39  bool arg_can_change = false;
40  result = nodes_[0]->prune(arg_can_change);
41 
42  if (!arg_can_change && dynamic_cast<LeafNode*>(nodes_[0]) == 0)
43  {
44  delete nodes_[0];
45  nodes_[0] = new LeafNode(*(this->logger_), result);
46  }
47  }
48  else
49  {
51  "madara::expression::SystemCallPrint: "
52  "KARL COMPILE ERROR:"
53  "System call size requires an argument\n");
54 
55  throw exceptions::KarlException("madara::expression::SystemCallPrint: "
56  "KARL COMPILE ERROR: "
57  "System call size requires an argument\n");
58  }
59 
60  return result;
61 }
62 
68 {
69  knowledge::KnowledgeRecord return_value;
70 
71  if (nodes_.size() == 1)
72  {
74  "madara::expression::SystemCallPrint: "
75  "System call print is printing the first argument and returning the"
76  " size of the first argument\n");
77 
78  std::string statement(nodes_[0]->evaluate(settings).to_string());
79 
80  context_.print(statement, 0);
81 
82  return_value = knowledge::KnowledgeRecord(0);
83  }
84  else if (nodes_.size() == 2)
85  {
86  std::string statement(nodes_[0]->evaluate(settings).to_string());
87  unsigned int log_level =
88  (unsigned int)nodes_[1]->evaluate(settings).to_integer();
89 
91  "madara::expression::SystemCallPrint: "
92  "System call print is printing the first argument at log level %d.\n",
93  log_level);
94 
95  context_.print(statement, log_level);
96 
97  return_value = knowledge::KnowledgeRecord(0);
98  }
99  else
100  {
102  "madara::expression::SystemCallPrint: "
103  "KARL RUNTIME ERROR:"
104  "System call size requires an argument\n");
105 
106  throw exceptions::KarlException("madara::expression::SystemCallPrint: "
107  "KARL RUNTIME ERROR: "
108  "System call size requires an argument\n");
109  }
110 
111  return return_value;
112 }
113 
114 // accept a visitor
116  madara::expression::Visitor& visitor) const
117 {
118  visitor.visit(*this);
119 }
120 
121 #endif // _MADARA_NO_KARL_
#define madara_logger_ptr_log(loggering, level,...)
Fast version of the madara::logger::log method for Logger pointers.
Definition: Logger.h:41
const ThreadSafeContext * context_
madara::knowledge::KnowledgeRecord KnowledgeRecord
An exception for unrecoverable KaRL compilation issues.
Definition: KarlException.h:21
Defines a node that contains a madara::knowledge::KnowledgeRecord::Integer value.
Definition: LeafNode.h:25
Interface for a MADARA system call.
virtual madara::knowledge::KnowledgeRecord evaluate(const madara::knowledge::KnowledgeUpdateSettings &settings)
Evaluates the expression tree.
SystemCallPrint(madara::knowledge::ThreadSafeContext &context, const ComponentNodes &nodes)
Constructor.
virtual madara::knowledge::KnowledgeRecord prune(bool &can_change)
Prunes the expression tree of unnecessary nodes.
virtual madara::knowledge::KnowledgeRecord item(void) const
Returns the value of the node.
virtual void accept(Visitor &visitor) const
Accepts a visitor subclassed from the Visitor class.
virtual ~SystemCallPrint(void)
Destructor.
Abstract base class for all visitors to all classes that derive from ComponentNode.
Definition: Visitor.h:93
virtual void visit(const LeafNode &node)=0
Visit a LeafNode.
This class encapsulates an entry in a KnowledgeBase.
Settings for applying knowledge updates.
This class stores variables and their values for use by any entity needing state information in a thr...
std::deque< ComponentNode * > ComponentNodes
a vector of Component Nodes
constexpr string_t string