ros_logger.cpp
Go to the documentation of this file.
1 /*
2  * Copyright 2019-2021 The urg_stamped Authors
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #include <iostream>
18 #include <sstream>
19 #include <string>
20 
21 #include <ros/ros.h>
22 
23 #include <scip2/logger.h>
24 
25 namespace
26 {
27 class ROSOutStreamBuffer : public std::stringbuf
28 {
29 public:
30  enum Type
31  {
32  LOG_DEBUG,
33  LOG_INFO,
34  LOG_WARN,
35  LOG_ERROR,
36  LOG_FATAL,
37  };
38  Type type_;
39  std::string prefix_;
40 
41  explicit ROSOutStreamBuffer(Type type)
42  : type_(type)
43  {
44  }
45  virtual int sync()
46  {
47  std::string log = str();
48  if (!log.empty() && log.back() == '\n')
49  log.pop_back();
50 
51  if (ros::ok())
52  {
53  switch (type_)
54  {
55  case LOG_DEBUG:
56  ROS_DEBUG("%s%s", prefix_.c_str(), log.c_str());
57  break;
58  case LOG_INFO:
59  ROS_INFO("%s%s", prefix_.c_str(), log.c_str());
60  break;
61  case LOG_WARN:
62  ROS_WARN("%s%s", prefix_.c_str(), log.c_str());
63  break;
64  case LOG_ERROR:
65  ROS_ERROR("%s%s", prefix_.c_str(), log.c_str());
66  break;
67  case LOG_FATAL:
68  ROS_FATAL("%s%s", prefix_.c_str(), log.c_str());
69  break;
70  }
71  }
72  else
73  {
74  // Fallback to stderr/stdout after ros::shutdown.
75  switch (type_)
76  {
77  case LOG_DEBUG:
78  break;
79  case LOG_INFO:
80  case LOG_WARN:
81  std::cout << prefix_ << log << std::endl;
82  break;
83  case LOG_ERROR:
84  case LOG_FATAL:
85  std::cerr << prefix_ << log << std::endl;
86  break;
87  }
88  }
89  str("");
90  return 0;
91  }
92 
93  void setPrefix(const std::string& prefix)
94  {
95  prefix_ = prefix;
96  }
97 };
98 
99 ROSOutStreamBuffer debug_buf(ROSOutStreamBuffer::LOG_DEBUG);
100 ROSOutStreamBuffer info_buf(ROSOutStreamBuffer::LOG_INFO);
101 ROSOutStreamBuffer warn_buf(ROSOutStreamBuffer::LOG_WARN);
102 ROSOutStreamBuffer error_buf(ROSOutStreamBuffer::LOG_ERROR);
103 ROSOutStreamBuffer fatal_buf(ROSOutStreamBuffer::LOG_FATAL);
104 std::ostream debug_logger(&debug_buf);
105 std::ostream info_logger(&info_buf);
106 std::ostream warn_logger(&warn_buf);
107 std::ostream error_logger(&error_buf);
108 std::ostream fatal_logger(&fatal_buf);
109 } // namespace
110 
111 namespace urg_stamped
112 {
113 void setROSLogger(const std::string& prefix)
114 {
115  debug_buf.setPrefix(prefix);
116  info_buf.setPrefix(prefix);
117  warn_buf.setPrefix(prefix);
118  error_buf.setPrefix(prefix);
119  fatal_buf.setPrefix(prefix);
120  scip2::logger::setDebugLogger(&debug_logger);
121  scip2::logger::setInfoLogger(&info_logger);
122  scip2::logger::setWarnLogger(&warn_logger);
123  scip2::logger::setErrorLogger(&error_logger);
124  scip2::logger::setFatalLogger(&fatal_logger);
125 }
126 } // namespace urg_stamped
type_
std::string type_
Definition: logger.cpp:34
logger.h
scip2::logger::setFatalLogger
void setFatalLogger(std::ostream *l)
Definition: logger.cpp:88
ros.h
scip2::logger::setWarnLogger
void setWarnLogger(std::ostream *l)
Definition: logger.cpp:80
ros::ok
ROSCPP_DECL bool ok()
scip2::logger::setDebugLogger
void setDebugLogger(std::ostream *l)
Definition: logger.cpp:72
ROS_DEBUG
#define ROS_DEBUG(...)
ROS_WARN
#define ROS_WARN(...)
scip2::logger::setErrorLogger
void setErrorLogger(std::ostream *l)
Definition: logger.cpp:84
ROS_FATAL
#define ROS_FATAL(...)
urg_stamped::setROSLogger
void setROSLogger(const std::string &prefix)
Definition: ros_logger.cpp:113
ROS_ERROR
#define ROS_ERROR(...)
urg_stamped
Definition: device_state_estimator.h:35
ROS_INFO
#define ROS_INFO(...)
scip2::logger::setInfoLogger
void setInfoLogger(std::ostream *l)
Definition: logger.cpp:76


urg_stamped
Author(s): Atsushi Watanabe
autogenerated on Wed Dec 18 2024 03:10:57