author | rehn |
Wed, 10 Aug 2016 09:24:42 +0200 | |
changeset 40355 | e9770c31b4f1 |
parent 38292 | 73a0be9b2f47 |
child 40884 | 0e28c526f5d3 |
permissions | -rw-r--r-- |
33097 | 1 |
/* |
40355 | 2 |
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. |
33097 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
7 |
* published by the Free Software Foundation. |
|
8 |
* |
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
13 |
* accompanied this code). |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License version |
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
18 |
* |
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
|
20 |
* or visit www.oracle.com if you need additional information or have any |
|
21 |
* questions. |
|
22 |
* |
|
23 |
*/ |
|
24 |
#ifndef SHARE_VM_LOGGING_LOGTAGSET_HPP |
|
25 |
#define SHARE_VM_LOGGING_LOGTAGSET_HPP |
|
26 |
||
27 |
#include "logging/logDecorators.hpp" |
|
28 |
#include "logging/logLevel.hpp" |
|
29 |
#include "logging/logOutputList.hpp" |
|
37247 | 30 |
#include "logging/logPrefix.hpp" |
33097 | 31 |
#include "logging/logTag.hpp" |
32 |
#include "utilities/globalDefinitions.hpp" |
|
33 |
||
38263
a7488329ad27
8145934: Make ttyLocker equivalent for Unified Logging framework
mlarsson
parents:
37463
diff
changeset
|
34 |
class LogMessageBuffer; |
a7488329ad27
8145934: Make ttyLocker equivalent for Unified Logging framework
mlarsson
parents:
37463
diff
changeset
|
35 |
|
33097 | 36 |
// The tagset represents a combination of tags that occur in a log call somewhere. |
37 |
// Tagsets are created automatically by the LogTagSetMappings and should never be |
|
38 |
// instantiated directly somewhere else. |
|
39 |
class LogTagSet VALUE_OBJ_CLASS_SPEC { |
|
40 |
private: |
|
41 |
static LogTagSet* _list; |
|
38292
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
42 |
static size_t _ntagsets; |
33097 | 43 |
|
38292
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
44 |
LogTagSet* const _next; |
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
45 |
size_t _ntags; |
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
46 |
LogTagType _tag[LogTag::MaxTags]; |
33097 | 47 |
|
38292
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
48 |
LogOutputList _output_list; |
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
49 |
LogDecorators _decorators; |
33097 | 50 |
|
37247 | 51 |
typedef size_t (*PrefixWriter)(char* buf, size_t size); |
38292
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
52 |
PrefixWriter _write_prefix; |
37247 | 53 |
|
33097 | 54 |
// Keep constructor private to prevent incorrect instantiations of this class. |
55 |
// Only LogTagSetMappings can create/contain instances of this class. |
|
56 |
// The constructor links all tagsets together in a global list of tagsets. |
|
57 |
// This list is used during configuration to be able to update all tagsets |
|
58 |
// and their configurations to reflect the new global log configuration. |
|
37247 | 59 |
LogTagSet(PrefixWriter prefix_writer, LogTagType t0, LogTagType t1, LogTagType t2, LogTagType t3, LogTagType t4); |
33097 | 60 |
|
37247 | 61 |
template <LogTagType T0, LogTagType T1, LogTagType T2, LogTagType T3, LogTagType T4, LogTagType GuardTag> |
33097 | 62 |
friend class LogTagSetMapping; |
63 |
||
64 |
public: |
|
38292
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
65 |
static void describe_tagsets(outputStream* out); |
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
66 |
static void list_all_tagsets(outputStream* out); |
73a0be9b2f47
8146948: Enable listing of LogTagSets and add support for LogTagSet descriptions
mlarsson
parents:
38263
diff
changeset
|
67 |
|
33097 | 68 |
static LogTagSet* first() { |
69 |
return _list; |
|
70 |
} |
|
71 |
||
37463
a4581cbe32cd
8153731: Increase max tag combinations for UL expression (config)
rehn
parents:
37247
diff
changeset
|
72 |
static size_t ntagsets() { |
a4581cbe32cd
8153731: Increase max tag combinations for UL expression (config)
rehn
parents:
37247
diff
changeset
|
73 |
return _ntagsets; |
a4581cbe32cd
8153731: Increase max tag combinations for UL expression (config)
rehn
parents:
37247
diff
changeset
|
74 |
} |
a4581cbe32cd
8153731: Increase max tag combinations for UL expression (config)
rehn
parents:
37247
diff
changeset
|
75 |
|
33097 | 76 |
LogTagSet* next() { |
77 |
return _next; |
|
78 |
} |
|
79 |
||
80 |
size_t ntags() const { |
|
81 |
return _ntags; |
|
82 |
} |
|
83 |
||
37200 | 84 |
LogTagType tag(size_t idx) const { |
85 |
return _tag[idx]; |
|
86 |
} |
|
87 |
||
33097 | 88 |
bool contains(LogTagType tag) const { |
89 |
for (size_t i = 0; _tag[i] != LogTag::__NO_TAG; i++) { |
|
90 |
if (tag == _tag[i]) { |
|
91 |
return true; |
|
92 |
} |
|
93 |
} |
|
94 |
return false; |
|
95 |
} |
|
96 |
||
34316
4d876653d940
8142952: Unified Logging framework does not allow multiple -Xlog: arguments.
mlarsson
parents:
33097
diff
changeset
|
97 |
LogLevelType level_for(const LogOutput* output) const { |
4d876653d940
8142952: Unified Logging framework does not allow multiple -Xlog: arguments.
mlarsson
parents:
33097
diff
changeset
|
98 |
return _output_list.level_for(output); |
4d876653d940
8142952: Unified Logging framework does not allow multiple -Xlog: arguments.
mlarsson
parents:
33097
diff
changeset
|
99 |
} |
4d876653d940
8142952: Unified Logging framework does not allow multiple -Xlog: arguments.
mlarsson
parents:
33097
diff
changeset
|
100 |
|
33097 | 101 |
void set_output_level(LogOutput* output, LogLevelType level) { |
102 |
_output_list.set_output_level(output, level); |
|
103 |
} |
|
104 |
||
105 |
// Refresh the decorators for this tagset to contain the decorators for all |
|
106 |
// of its current outputs combined with the given decorators. |
|
34316
4d876653d940
8142952: Unified Logging framework does not allow multiple -Xlog: arguments.
mlarsson
parents:
33097
diff
changeset
|
107 |
void update_decorators(const LogDecorators& decorator = LogDecorators::None); |
33097 | 108 |
|
34316
4d876653d940
8142952: Unified Logging framework does not allow multiple -Xlog: arguments.
mlarsson
parents:
33097
diff
changeset
|
109 |
int label(char *buf, size_t len, const char* separator = ",") const; |
33097 | 110 |
bool has_output(const LogOutput* output); |
37241
b9961c99c356
8152538: UL doesn't inline the LogTagSet::is_level check
stefank
parents:
37200
diff
changeset
|
111 |
|
b9961c99c356
8152538: UL doesn't inline the LogTagSet::is_level check
stefank
parents:
37200
diff
changeset
|
112 |
// The implementation of this function is put here to ensure |
b9961c99c356
8152538: UL doesn't inline the LogTagSet::is_level check
stefank
parents:
37200
diff
changeset
|
113 |
// that it is inline:able by the log_is_enabled(level, ...) macro. |
b9961c99c356
8152538: UL doesn't inline the LogTagSet::is_level check
stefank
parents:
37200
diff
changeset
|
114 |
bool is_level(LogLevelType level) const { |
b9961c99c356
8152538: UL doesn't inline the LogTagSet::is_level check
stefank
parents:
37200
diff
changeset
|
115 |
return _output_list.is_level(level); |
b9961c99c356
8152538: UL doesn't inline the LogTagSet::is_level check
stefank
parents:
37200
diff
changeset
|
116 |
} |
33097 | 117 |
void log(LogLevelType level, const char* msg); |
38263
a7488329ad27
8145934: Make ttyLocker equivalent for Unified Logging framework
mlarsson
parents:
37463
diff
changeset
|
118 |
void log(const LogMessageBuffer& msg); |
37247 | 119 |
|
120 |
ATTRIBUTE_PRINTF(3, 4) |
|
121 |
void write(LogLevelType level, const char* fmt, ...); |
|
122 |
||
123 |
template <LogLevelType Level> |
|
124 |
ATTRIBUTE_PRINTF(2, 3) |
|
125 |
void write(const char* fmt, ...) { |
|
126 |
va_list args; |
|
127 |
va_start(args, fmt); |
|
128 |
vwrite(Level, fmt, args); |
|
129 |
va_end(args); |
|
130 |
} |
|
131 |
||
132 |
ATTRIBUTE_PRINTF(3, 0) |
|
133 |
void vwrite(LogLevelType level, const char* fmt, va_list args); |
|
33097 | 134 |
}; |
135 |
||
136 |
template <LogTagType T0, LogTagType T1 = LogTag::__NO_TAG, LogTagType T2 = LogTag::__NO_TAG, |
|
37247 | 137 |
LogTagType T3 = LogTag::__NO_TAG, LogTagType T4 = LogTag::__NO_TAG, |
138 |
LogTagType GuardTag = LogTag::__NO_TAG> |
|
33097 | 139 |
class LogTagSetMapping : public AllStatic { |
140 |
private: |
|
37247 | 141 |
// Verify number of logging tags does not exceed maximum supported. |
142 |
STATIC_ASSERT(GuardTag == LogTag::__NO_TAG); |
|
33097 | 143 |
static LogTagSet _tagset; |
144 |
||
145 |
public: |
|
146 |
static LogTagSet& tagset() { |
|
147 |
return _tagset; |
|
148 |
} |
|
149 |
}; |
|
150 |
||
151 |
// Instantiate the static field _tagset for all tagsets that are used for logging somewhere. |
|
152 |
// (This must be done here rather than the .cpp file because it's a template.) |
|
153 |
// Each combination of tags used as template arguments to the Log class somewhere (via macro or not) |
|
154 |
// will instantiate the LogTagSetMapping template, which in turn creates the static field for that |
|
155 |
// tagset. This _tagset contains the configuration for those tags. |
|
37247 | 156 |
template <LogTagType T0, LogTagType T1, LogTagType T2, LogTagType T3, LogTagType T4, LogTagType GuardTag> |
157 |
LogTagSet LogTagSetMapping<T0, T1, T2, T3, T4, GuardTag>::_tagset(&LogPrefix<T0, T1, T2, T3, T4>::prefix, T0, T1, T2, T3, T4); |
|
33097 | 158 |
|
159 |
#endif // SHARE_VM_LOGGING_LOGTAGSET_HPP |