OrocosComponentLibrary
2.7.0
|
00001 #include "logging/Category.hpp" 00002 #include <rtt/Logger.hpp> 00003 #include <log4cpp/NDC.hh> 00004 #include <log4cpp/HierarchyMaintainer.hh> 00005 00006 using namespace RTT; 00007 00008 namespace OCL { 00009 namespace logging { 00010 00011 Category::Category(const std::string& name, 00012 log4cpp::Category* parent, 00013 log4cpp::Priority::Value priority) : 00014 log4cpp::Category(name, parent, priority), 00015 log_port( convertName(name) ) 00016 { 00017 } 00018 00019 Category::~Category() 00020 { 00021 } 00022 00023 void Category::log(log4cpp::Priority::Value priority, 00024 const RTT::rt_string& message) throw() 00025 { 00026 if (isPriorityEnabled(priority)) 00027 { 00028 _logUnconditionally2(priority, message); 00029 } 00030 } 00031 00032 void Category::debug(const RTT::rt_string& message) throw() 00033 { 00034 if (isPriorityEnabled(log4cpp::Priority::DEBUG)) 00035 _logUnconditionally2(log4cpp::Priority::DEBUG, message); 00036 } 00037 00038 void Category::info(const RTT::rt_string& message) throw() 00039 { 00040 if (isPriorityEnabled(log4cpp::Priority::INFO)) 00041 _logUnconditionally2(log4cpp::Priority::INFO, message); 00042 } 00043 00044 void Category::notice(const RTT::rt_string& message) throw() 00045 { 00046 if (isPriorityEnabled(log4cpp::Priority::NOTICE)) 00047 _logUnconditionally2(log4cpp::Priority::NOTICE, message); 00048 } 00049 00050 void Category::warn(const RTT::rt_string& message) throw() 00051 { 00052 if (isPriorityEnabled(log4cpp::Priority::WARN)) 00053 _logUnconditionally2(log4cpp::Priority::WARN, message); 00054 } 00055 00056 void Category::error(const RTT::rt_string& message) throw() 00057 { 00058 if (isPriorityEnabled(log4cpp::Priority::ERROR)) 00059 _logUnconditionally2(log4cpp::Priority::ERROR, message); 00060 } 00061 00062 void Category::crit(const RTT::rt_string& message) throw() 00063 { 00064 if (isPriorityEnabled(log4cpp::Priority::CRIT)) 00065 _logUnconditionally2(log4cpp::Priority::CRIT, message); 00066 } 00067 00068 void Category::alert(const RTT::rt_string& message) throw() 00069 { 00070 if (isPriorityEnabled(log4cpp::Priority::ALERT)) 00071 _logUnconditionally2(log4cpp::Priority::ALERT, message); 00072 } 00073 00074 void Category::emerg(const RTT::rt_string& message) throw() 00075 { 00076 if (isPriorityEnabled(log4cpp::Priority::EMERG)) 00077 _logUnconditionally2(log4cpp::Priority::EMERG, message); 00078 } 00079 00080 void Category::fatal(const RTT::rt_string& message) throw() 00081 { 00082 if (isPriorityEnabled(log4cpp::Priority::FATAL)) 00083 _logUnconditionally2(log4cpp::Priority::FATAL, message); 00084 } 00085 00086 00087 void Category::_logUnconditionally2(log4cpp::Priority::Value priority, 00088 const RTT::rt_string& message) throw() 00089 { 00090 try 00091 { 00092 OCL::logging::LoggingEvent event(RTT::rt_string(getName().c_str()), 00093 RTT::rt_string(message.c_str()), 00094 // NDC's are not real-time 00095 // RTT::rt_string(log4cpp::NDC::get().c_str()), 00096 RTT::rt_string(""), 00097 priority); 00098 callAppenders(event); 00099 } 00100 catch (std::bad_alloc& e) 00101 { 00102 // \todo do what? 00103 // std::cerr << "Failed to log event: out of real-time memory" << std::endl; 00105 } 00106 } 00107 00108 void Category::callAppenders(const OCL::logging::LoggingEvent& event) throw() 00109 { 00110 log_port.write( event ); 00111 00112 // let our parent categories append (if they want to) 00113 if (getAdditivity() && (getParent() != NULL)) 00114 { 00115 OCL::logging::Category* parent = dynamic_cast<OCL::logging::Category*>(getParent()); 00116 if (parent) 00117 { 00118 parent->callAppenders(event); 00119 } 00120 // else we don't use non-realtime parent Category's! 00121 } 00122 } 00123 00124 std::string Category::convertName(const std::string& name) 00125 { 00126 std::string rc(name); 00127 00128 std::replace_if(rc.begin(), 00129 rc.end(), 00130 std::bind2nd(std::equal_to<char>(), '.'), 00131 '_'); 00132 00133 return rc; 00134 } 00135 00136 log4cpp::Category* Category::createOCLCategory(const std::string& name, 00137 log4cpp::Category* parent, 00138 log4cpp::Priority::Value priority) 00139 { 00140 // do _NOT_ log from within this function! You will cause a lockup due to 00141 // recursive calls to log4cpp, if you use RTT w/ log4cpp support. 00142 00143 // \todo try catch on memory exceptions or failures? 00144 OCL::logging::Category* c = new OCL::logging::Category(name, parent, priority); 00145 return c; 00146 } 00147 00148 CategoryStream Category::getRTStream(log4cpp::Priority::Value priority) 00149 { 00150 return CategoryStream(this, isPriorityEnabled(priority) ? 00151 priority : log4cpp::Priority::NOTSET); 00152 } 00153 00154 bool Category::connectToLogPort(RTT::base::PortInterface& otherPort) 00155 { 00156 return otherPort.connectTo(&log_port); 00157 } 00158 00159 // namespaces 00160 } 00161 }