logger.h
Go to the documentation of this file.
1 // Copyright 2021 PickNik Inc.
2 //
3 // Redistribution and use in source and binary forms, with or without
4 // modification, are permitted provided that the following conditions are met:
5 //
6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer.
8 //
9 // * Redistributions in binary form must reproduce the above copyright
10 // notice, this list of conditions and the following disclaimer in the
11 // documentation and/or other materials provided with the distribution.
12 //
13 // * Neither the name of the PickNik Inc. nor the names of its
14 // contributors may be used to endorse or promote products derived from
15 // this software without specific prior written permission.
16 //
17 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 // POSSIBILITY OF SUCH DAMAGE.
28 
29 /* Author: Tyler Weaver
30  Desc: [boost].SML ros logger
31 */
32 
33 #pragma once
34 
35 // C++
36 #include <string>
37 
38 // ROS
39 #include <ros/ros.h>
40 
41 // [boost].SML
42 #include <boost_sml/sml.hpp>
43 
44 // logger struct
45 struct SmlRosLogger {
46  SmlRosLogger(const std::string& name) : name_(name) {}
47 
48  template <class SM, class TEvent>
49  void log_process_event(const TEvent&) {
50  ROS_DEBUG_NAMED(name_ + ".sm.process_event", "[%s][process_event] %s",
51  boost::sml::aux::get_type_name<SM>(),
52  boost::sml::aux::get_type_name<TEvent>());
53  }
54 
55  template <class SM, class TGuard, class TEvent>
56  void log_guard(const TGuard&, const TEvent&, bool result) {
57  ROS_DEBUG_NAMED(name_ + ".sm.guard", "[%s][guard] %s %s %s",
58  boost::sml::aux::get_type_name<SM>(),
59  boost::sml::aux::get_type_name<TGuard>(),
60  boost::sml::aux::get_type_name<TEvent>(),
61  (result ? "[OK]" : "[Reject]"));
62  }
63 
64  template <class SM, class TAction, class TEvent>
65  void log_action(const TAction&, const TEvent&) {
66  ROS_DEBUG_NAMED(name_ + ".sm.action", "[%s][action] %s %s",
67  boost::sml::aux::get_type_name<SM>(),
68  boost::sml::aux::get_type_name<TAction>(),
69  boost::sml::aux::get_type_name<TEvent>());
70  }
71 
72  template <class SM, class TSrcState, class TDstState>
73  void log_state_change(const TSrcState& src, const TDstState& dst) {
74  ROS_DEBUG_NAMED(name_ + ".sm.state_change", "[%s][transition] %s -> %s",
75  boost::sml::aux::get_type_name<SM>(), src.c_str(),
76  dst.c_str());
77  }
78 
79  const std::string name_;
80 }; // struct SmlRosLogger
SmlRosLogger(const std::string &name)
Definition: logger.h:46
void log_process_event(const TEvent &)
Definition: logger.h:49
void log_guard(const TGuard &, const TEvent &, bool result)
Definition: logger.h:56
const std::string name_
Definition: logger.h:79
#define ROS_DEBUG_NAMED(name,...)
void log_action(const TAction &, const TEvent &)
Definition: logger.h:65
void log_state_change(const TSrcState &src, const TDstState &dst)
Definition: logger.h:73


boost_sml
Author(s): boost-experimental (https://github.com/boost-experimental)
autogenerated on Thu Jan 26 2023 03:14:00