You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

79 lines
2.1 KiB

  1. // -*- C++ -*-
  2. // Module: Log4CPLUS
  3. // File: tracelogger.h
  4. // Created: 1/2009
  5. // Author: Vaclav Haisman
  6. //
  7. //
  8. // Copyright 2009-2010 Tad E. Smith
  9. //
  10. // Licensed under the Apache License, Version 2.0 (the "License");
  11. // you may not use this file except in compliance with the License.
  12. // You may obtain a copy of the License at
  13. //
  14. // http://www.apache.org/licenses/LICENSE-2.0
  15. //
  16. // Unless required by applicable law or agreed to in writing, software
  17. // distributed under the License is distributed on an "AS IS" BASIS,
  18. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  19. // See the License for the specific language governing permissions and
  20. // limitations under the License.
  21. /** @file */
  22. #ifndef LOG4CPLUS_TRACELOGGER_H
  23. #define LOG4CPLUS_TRACELOGGER_H
  24. #include <log4cplus/config.hxx>
  25. #if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE)
  26. #pragma once
  27. #endif
  28. #include <log4cplus/logger.h>
  29. namespace log4cplus
  30. {
  31. /**
  32. * This class is used to produce "Trace" logging. When an instance of
  33. * this class is created, it will log a <code>"ENTER: " + msg</code>
  34. * log message if TRACE_LOG_LEVEL is enabled for <code>logger</code>.
  35. * When an instance of this class is destroyed, it will log a
  36. * <code>"ENTER: " + msg</code> log message if TRACE_LOG_LEVEL is enabled
  37. * for <code>logger</code>.
  38. * <p>
  39. * @see LOG4CPLUS_TRACE
  40. */
  41. class TraceLogger
  42. {
  43. public:
  44. TraceLogger(const Logger& l, const log4cplus::tstring& _msg,
  45. const char* _file=NULL, int _line=-1)
  46. : logger(l), msg(_msg), file(_file), line(_line)
  47. { if(logger.isEnabledFor(TRACE_LOG_LEVEL))
  48. logger.forcedLog(TRACE_LOG_LEVEL, LOG4CPLUS_TEXT("ENTER: ") + msg, file, line);
  49. }
  50. ~TraceLogger()
  51. { if(logger.isEnabledFor(TRACE_LOG_LEVEL))
  52. logger.forcedLog(TRACE_LOG_LEVEL, LOG4CPLUS_TEXT("EXIT: ") + msg, file, line);
  53. }
  54. private:
  55. TraceLogger (TraceLogger const &);
  56. TraceLogger & operator = (TraceLogger const &);
  57. Logger logger;
  58. log4cplus::tstring msg;
  59. const char* file;
  60. int line;
  61. };
  62. } // log4cplus
  63. #endif // LOG4CPLUS_TRACELOGGER_H