Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 #include <ros/console.h>
00038 #include <ompl/util/Console.h>
00039
00040 namespace ompl_ros_inteface
00041 {
00042 class OutputHandlerROS : public ompl::msg::OutputHandler
00043 {
00044 public:
00045
00046 OutputHandlerROS(void) : OutputHandler()
00047 {
00048 }
00049 virtual void log(const std::string &text, ompl::msg::LogLevel level, const char *filename, int line)
00050 {
00051 switch (level)
00052 {
00053 case ompl::msg::LOG_INFO:
00054 {
00055 ROSCONSOLE_DEFINE_LOCATION(true, ::ros::console::levels::Info, std::string(ROSCONSOLE_NAME_PREFIX) + ".ompl");
00056 if (ROS_UNLIKELY(enabled))
00057 {
00058 ::ros::console::print(NULL, loc.logger_, loc.level_, filename, line, "", "%s", text.c_str());
00059 }
00060 }
00061 break;
00062 case ompl::msg::LOG_WARN:
00063 {
00064 ROSCONSOLE_DEFINE_LOCATION(true, ::ros::console::levels::Warn, std::string(ROSCONSOLE_NAME_PREFIX) + ".ompl");
00065 if (ROS_UNLIKELY(enabled))
00066 {
00067 ::ros::console::print(NULL, loc.logger_, loc.level_, filename, line, "", "%s", text.c_str());
00068 }
00069 }
00070 break;
00071 case ompl::msg::LOG_ERROR:
00072 {
00073 ROSCONSOLE_DEFINE_LOCATION(true, ::ros::console::levels::Error, std::string(ROSCONSOLE_NAME_PREFIX) + ".ompl");
00074 if (ROS_UNLIKELY(enabled))
00075 {
00076 ::ros::console::print(NULL, loc.logger_, loc.level_, filename, line, "", "%s", text.c_str());
00077 }
00078 }
00079 break;
00080 default:
00081
00082 {
00083 ROSCONSOLE_DEFINE_LOCATION(true, ::ros::console::levels::Debug, std::string(ROSCONSOLE_NAME_PREFIX) + ".ompl");
00084 if (ROS_UNLIKELY(enabled))
00085 {
00086 ::ros::console::print(NULL, loc.logger_, loc.level_, filename, line, "", "%s", text.c_str());
00087 }
00088 }
00089 break;
00090 }
00091 }
00092
00093 };
00094
00095 struct RegisterOH
00096 {
00097 RegisterOH(void)
00098 {
00099 static OutputHandlerROS oh_ros;
00100 useOutputHandler(&oh_ros);
00101 }
00102 };
00103
00104 static RegisterOH proxy;
00105 }