diff --git a/src/hotspot/share/logging/log.hpp b/src/hotspot/share/logging/log.hpp index 068b640fb39..8455ed814ba 100644 --- a/src/hotspot/share/logging/log.hpp +++ b/src/hotspot/share/logging/log.hpp @@ -107,8 +107,6 @@ class LogTargetImpl; template class LogImpl { - private: - static const size_t LogBufferSize = 512; public: // Make sure no more than the maximum number of tags have been given. // The GuardTag allows this to be detected if/when it happens. If the GuardTag @@ -183,7 +181,7 @@ public: } static bool is_enabled() { - return LogImpl::is_level(level); + return LogTagSetMapping::tagset().is_level(level); } static bool develop_is_enabled() { @@ -194,7 +192,7 @@ public: static void print(const char* fmt, ...) ATTRIBUTE_PRINTF(1, 2) { va_list args; va_start(args, fmt); - LogImpl::vwrite(level, fmt, args); + LogTagSetMapping::tagset().vwrite(level, fmt, args); va_end(args); } diff --git a/src/hotspot/share/logging/logHandle.hpp b/src/hotspot/share/logging/logHandle.hpp index fad63649b28..7b0d5ef390a 100644 --- a/src/hotspot/share/logging/logHandle.hpp +++ b/src/hotspot/share/logging/logHandle.hpp @@ -32,7 +32,7 @@ // polluting the surrounding API with template functions. class LogHandle { private: - LogTagSet* _tagset; + LogTagSet* const _tagset; public: template @@ -43,7 +43,7 @@ public: return _tagset->is_level(level); } - LogTagSet* tagset() const { + LogTagSet* const tagset() const { return _tagset; } @@ -73,10 +73,10 @@ public: class LogTargetHandle { private: const LogLevelType _level; - LogTagSet* _tagset; + LogTagSet* const _tagset; public: - LogTargetHandle(LogLevelType level, LogTagSet* tagset) : _level(level), _tagset(tagset) {} + LogTargetHandle(LogLevelType level, LogTagSet* const tagset) : _level(level), _tagset(tagset) {} template LogTargetHandle(const LogTargetImpl& type_carrier) : diff --git a/src/hotspot/share/logging/logMessage.hpp b/src/hotspot/share/logging/logMessage.hpp index f8b44aa38d6..3b0e88fb79f 100644 --- a/src/hotspot/share/logging/logMessage.hpp +++ b/src/hotspot/share/logging/logMessage.hpp @@ -62,12 +62,13 @@ template class LogMessageImpl : public LogMessageBuffer { private: - LogImpl _log; bool _has_content; - + LogTagSet& _tagset; public: - LogMessageImpl() : _has_content(false) { - } + LogMessageImpl() : + _has_content(false), + _tagset(LogTagSetMapping::tagset()) + {} ~LogMessageImpl() { if (_has_content) { @@ -76,7 +77,7 @@ class LogMessageImpl : public LogMessageBuffer { } void flush() { - _log.write(*this); + _tagset.log(*this); reset(); } @@ -96,7 +97,7 @@ class LogMessageImpl : public LogMessageBuffer { #define LOG_LEVEL(level, name) \ bool is_##name() const { \ - return _log.is_level(LogLevel::level); \ + return _tagset.is_level(LogLevel::level); \ } LOG_LEVEL_LIST #undef LOG_LEVEL diff --git a/src/hotspot/share/logging/logStream.hpp b/src/hotspot/share/logging/logStream.hpp index b141be65a6a..3aa4a19ac66 100644 --- a/src/hotspot/share/logging/logStream.hpp +++ b/src/hotspot/share/logging/logStream.hpp @@ -64,16 +64,16 @@ public: // Constructor to support creation from a LogTarget instance. // // LogTarget(Debug, gc) log; - // LogStreamBase(log) stream; + // LogStream(log) stream; template LogStream(const LogTargetImpl& type_carrier) : _log_handle(level, &LogTagSetMapping::tagset()) {} // Constructor to support creation from typed (likely NULL) pointer. Mostly used by the logging framework. // - // LogStreamBase stream(log.debug()); + // LogStream stream(log.debug()); // or - // LogStreamBase stream((LogTargetImpl*)NULL); + // LogStream stream((LogTargetImpl*)NULL); template LogStream(const LogTargetImpl* type_carrier) : _log_handle(level, &LogTagSetMapping::tagset()) {} @@ -85,13 +85,13 @@ public: // // LogTarget(Debug, gc) log; // LogTargetHandle(log) handle; - // LogStreamBase stream(handle); + // LogStream stream(handle); LogStream(LogTargetHandle handle) : _log_handle(handle) {} // Constructor to support creation from a log level and tagset. // - // LogStreamBase(level, tageset); - LogStream(LogLevelType level, LogTagSet* tagset) : _log_handle(level, tagset) {} + // LogStream(level, tageset); + LogStream(LogLevelType level, LogTagSet* const tagset) : _log_handle(level, tagset) {} bool is_enabled() const { return _log_handle.is_enabled(); diff --git a/src/hotspot/share/logging/logTagSet.hpp b/src/hotspot/share/logging/logTagSet.hpp index f932a6d175a..10362d84a4a 100644 --- a/src/hotspot/share/logging/logTagSet.hpp +++ b/src/hotspot/share/logging/logTagSet.hpp @@ -165,7 +165,7 @@ public: // will instantiate the LogTagSetMapping template, which in turn creates the static field for that // tagset. This _tagset contains the configuration for those tags. template -LogTagSet LogTagSetMapping::_tagset(&LogPrefix::prefix, T0, T1, T2, T3, T4); +LogTagSet LogTagSetMapping::_tagset{&LogPrefix::prefix, T0, T1, T2, T3, T4}; extern const size_t vwrite_buffer_size; #endif // SHARE_LOGGING_LOGTAGSET_HPP