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.

77 lines
2.4 KiB

  1. // -*- C++ -*-
  2. // Copyright (C) 2010-2013, Vaclav Haisman. All rights reserved.
  3. //
  4. // Redistribution and use in source and binary forms, with or without modifica-
  5. // tion, are permitted provided that the following conditions are met:
  6. //
  7. // 1. Redistributions of source code must retain the above copyright notice,
  8. // this list of conditions and the following disclaimer.
  9. //
  10. // 2. Redistributions in binary form must reproduce the above copyright notice,
  11. // this list of conditions and the following disclaimer in the documentation
  12. // and/or other materials provided with the distribution.
  13. //
  14. // THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  15. // INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  16. // FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  17. // APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
  18. // INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU-
  19. // DING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  20. // OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  21. // ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  22. // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  23. // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  24. #ifndef LOG4CPLUS_MDC_H_HEADER
  25. #define LOG4CPLUS_MDC_H_HEADER
  26. #include <log4cplus/config.hxx>
  27. #if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE)
  28. #pragma once
  29. #endif
  30. #include <log4cplus/tstring.h>
  31. #include <map>
  32. namespace log4cplus
  33. {
  34. typedef std::map<tstring, tstring> MappedDiagnosticContextMap;
  35. class LOG4CPLUS_EXPORT MDC
  36. {
  37. public:
  38. /**
  39. * Clear any nested diagnostic information if any. This method is
  40. * useful in cases where the same thread can be potentially used
  41. * over and over in different unrelated contexts.
  42. */
  43. void clear();
  44. void put (tstring const & key, tstring const & value);
  45. bool get (tstring * value, tstring const & key) const;
  46. void remove (tstring const & key);
  47. MappedDiagnosticContextMap const & getContext () const;
  48. // Public ctor and dtor but only to be used by internal::DefaultContext.
  49. MDC ();
  50. virtual ~MDC ();
  51. private:
  52. LOG4CPLUS_PRIVATE static MappedDiagnosticContextMap * getPtr ();
  53. };
  54. LOG4CPLUS_EXPORT MDC & getMDC ();
  55. } // namespace log4cplus
  56. #endif // LOG4CPLUS_MDC_H_HEADER