MADARA  3.4.1
SystemCallLogLevel.cpp
Go to the documentation of this file.
1 
2 #ifndef _MADARA_NO_KARL_
3 
7 
10  : SystemCallNode(context, nodes)
11 {
12 }
13 
14 // Dtor
16 
18  void) const
19 {
20  return madara::knowledge::KnowledgeRecord(nodes_.size());
21 }
22 
28 {
29  // user can always change a function, and we have no control over
30  // what it does. Consequently, a function node cannot be pruned out
31  // under any situation
32  can_change = true;
33 
35 
36  if (nodes_.size() > 0)
37  {
38  bool arg_can_change = false;
39  result = nodes_[0]->prune(arg_can_change);
40 
41  if (!arg_can_change && dynamic_cast<LeafNode*>(nodes_[0]) == 0)
42  {
43  delete nodes_[0];
44  nodes_[0] = new LeafNode(*(this->logger_), result);
45  }
46  }
47 
48  if (nodes_.size() > 1)
49  {
51  "madara::expression::SystemCallLogLevel: "
52  "KARL COMPILE ERROR:"
53  "System call log_level requires 0 or 1 arguments,"
54  " e.g., log_level (10) or log_level ()--which returns the log level\n");
55 
57  "madara::expression::SystemCallLogLevel: "
58  "KARL COMPILE ERROR: "
59  "System call log_level requires 0 or 1 arguments,"
60  " e.g., log_level (10) or log_level ()--which returns the log level\n");
61  }
62 
63  return result;
64 }
65 
71 {
72  knowledge::KnowledgeRecord return_value;
73 
74  if (nodes_.size() == 1)
75  {
77  "madara::expression::SystemCallLogLevel: "
78  "System call log_level is setting log level\n");
79 
80  int level = (int)nodes_[0]->evaluate(settings).to_integer();
81 
82  logger_->set_level(level);
83 
85  "madara::expression::SystemCallLogLevel: "
86  "System call log_level has set log level to %d\n",
87  level);
88 
89  return knowledge::KnowledgeRecord(level);
90  }
91  else if (nodes_.size() == 0)
92  {
94  "madara::expression::SystemCallLogLevel: "
95  "System call log_level is returning log level.\n");
96 
97  return knowledge::KnowledgeRecord(logger_->get_level());
98  }
99  else if (nodes_.size() > 1)
100  {
102  "madara::expression::SystemCallLogLevel: "
103  "KARL RUNTIME ERROR:"
104  "System call log_level requires 0 or 1 arguments,"
105  " e.g., log_level (10) or log_level ()--which returns the log level\n");
106 
108  "madara::expression::SystemCallLogLevel: "
109  "KARL RUNTIME ERROR: "
110  "System call log_level requires 0 or 1 arguments,"
111  " e.g., log_level (10) or log_level ()--which returns the log level\n");
112  }
113 
114  return return_value;
115 }
116 
117 // accept a visitor
119  madara::expression::Visitor& visitor) const
120 {
121  visitor.visit(*this);
122 }
123 
124 #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
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
SystemCallLogLevel(madara::knowledge::ThreadSafeContext &context, const ComponentNodes &nodes)
Constructor.
virtual madara::knowledge::KnowledgeRecord item(void) const
Returns the value of the node.
virtual madara::knowledge::KnowledgeRecord prune(bool &can_change)
Prunes the expression tree of unnecessary nodes.
virtual ~SystemCallLogLevel(void)
Destructor.
virtual void accept(Visitor &visitor) const
Accepts a visitor subclassed from the Visitor class.
virtual madara::knowledge::KnowledgeRecord evaluate(const madara::knowledge::KnowledgeUpdateSettings &settings)
Evaluates the expression tree.
Interface for a MADARA system call.
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