41 #ifndef CRL_MULTISENSE_EXCEPTION_HH 42 #define CRL_MULTISENSE_EXCEPTION_HH 52 #ifdef CRL_DEBUG_SYSLOG 54 #define CRL_DEBUG_REDIRECTION syslog(LOG_USER|LOG_INFO, 56 #define CRL_DEBUG_REDIRECTION fprintf(stderr, 57 #endif // CRL_DEBUG_SYSLOG 60 #define CRL_FILENAME \ 61 (strrchr(__FILE__,'\\') \ 62 ? strrchr(__FILE__,'\\')+1 \ 65 #define CRL_FILENAME \ 66 (strrchr(__FILE__,'/') \ 67 ? strrchr(__FILE__,'/')+1 \ 71 #define CRL_EXCEPTION(fmt, ...) \ 73 throw crl::multisense::details::utility::Exception("%s(%d): %s: " fmt,CRL_FILENAME,__LINE__, \ 74 CRL_PRETTY_FUNCTION,##__VA_ARGS__); \ 77 #define CRL_EXCEPTION_RAW(fmt) \ 79 throw crl::multisense::details::utility::Exception("%s(%d): %s: " fmt,CRL_FILENAME,__LINE__, \ 80 CRL_PRETTY_FUNCTION); \ 83 #define CRL_DEBUG(fmt, ...) \ 85 double now = crl::multisense::details::utility::TimeStamp::getCurrentTime(); \ 86 CRL_DEBUG_REDIRECTION "[%.3f] %s(%d): %s: " fmt,now,CRL_FILENAME,__LINE__, \ 87 CRL_PRETTY_FUNCTION,##__VA_ARGS__); \ 90 #define CRL_DEBUG_RAW(fmt) \ 92 double now = crl::multisense::details::utility::TimeStamp::getCurrentTime(); \ 93 CRL_DEBUG_REDIRECTION "[%.3f] %s(%d): %s: " fmt,now,CRL_FILENAME,__LINE__, \ 94 CRL_PRETTY_FUNCTION); \ 98 namespace multisense {
110 Exception(
const char *failureReason, ...);
111 Exception(
const std::string& failureReason);
114 virtual const
char*
what() const throw();
Exception(const char *failureReason,...)
virtual const char * what() const