Index: third_party/cld/base/vlog_is_on.h |
=================================================================== |
--- third_party/cld/base/vlog_is_on.h (revision 0) |
+++ third_party/cld/base/vlog_is_on.h (revision 0) |
@@ -0,0 +1,141 @@ |
+// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+// Defines the VLOG_IS_ON macro that controls the variable-verbosity |
+// conditional logging. |
+// |
+// It's used by VLOG and VLOG_IF in logging.h |
+// and by RAW_VLOG in raw_logging.h to trigger the logging. |
+// |
+// It can also be used directly e.g. like this: |
+// if (VLOG_IS_ON(2)) { |
+// // do some logging preparation and logging |
+// // that can't be accomplished e.g. via just VLOG(2) << ...; |
+// } |
+// |
+// The truth value that VLOG_IS_ON(level) returns is determined by |
+// the three verbosity level flags: |
+// --v=<n> Gives the default maximal active V-logging level; |
+// 0 is the default. |
+// Normally positive values are used for V-logging levels. |
+// --vmodule=<str> Gives the per-module maximal V-logging levels to override |
+// the value given by --v. |
+// E.g. "my_module=2,foo*=3" would change the logging level |
+// for all code in source files "my_module.*" and "foo*.*" |
+// ("-inl" suffixes are also disregarded for this matching). |
+// --silent_init When true has the effect of increasing |
+// the argument of VLOG_IS_ON by 1, |
+// thus suppressing one more level of verbose logging. |
+// |
+// SetVLOGLevel helper function is provided to do limited dynamic control over |
+// V-logging by overriding the per-module settings given via --vmodule flag. |
+// |
+// CAVEAT: --vmodule functionality is not available in non gcc compilers. |
+// |
+ |
+#ifndef BASE_VLOG_IS_ON_H_ |
+#define BASE_VLOG_IS_ON_H_ |
+ |
+#include "base/atomicops.h" |
+#include "base/basictypes.h" |
+#include "base/port.h" |
+#include "third_party/cld/base/commandlineflags.h" |
+#include "third_party/cld/base/log_severity.h" |
+ |
+DECLARE_int32(v); // in vlog_is_on.cc |
+DECLARE_bool(silent_init); // in google.cc |
+ |
+#if defined(__GNUC__) |
+// We pack an int16 verbosity level and an int16 epoch into an |
+// Atomic32 at every VLOG_IS_ON() call site. The level determines |
+// whether the site should log, and the epoch determines whether the |
+// site is stale and should be reinitialized. A verbosity level of |
+// kUseFlag (-1) indicates that the value of FLAGS_v should be used as |
+// the verbosity level. When the site is (re)initialized, a verbosity |
+// level for the current source file is retrieved from an internal |
+// list. This list is mutated through calls to SetVLOGLevel() and |
+// mutations to the --vmodule flag. New log sites are initialized |
+// with a stale epoch and a verbosity level of kUseFlag. |
+// |
+// TODO(llansing): Investigate using GCC's __builtin_constant_p() to |
+// generate less code at call sites where verbositylevel is known to |
+// be a compile-time constant. |
+#define VLOG_IS_ON(verboselevel) \ |
+ ({ static Atomic32 site__ = ::base::internal::kDefaultSite; \ |
+ ::base::internal::VLogEnabled(&site__, (verboselevel), __FILE__); }) |
+#else |
+// GNU extensions not available, so we do not support --vmodule. |
+// Dynamic value of FLAGS_v always controls the logging level. |
+// |
+// TODO(llansing): Investigate supporting --vmodule on other platforms. |
+#define VLOG_IS_ON(verboselevel) \ |
+ (FLAGS_v >= (verboselevel) + FLAGS_silent_init) |
+#endif |
+ |
+// Set VLOG(_IS_ON) level for module_pattern to log_level. |
+// This lets us dynamically control what is normally set by the --vmodule flag. |
+// Returns the level that previously applied to module_pattern. |
+// NOTE: To change the log level for VLOG(_IS_ON) sites |
+// that have already executed after/during InitGoogle, |
+// one needs to supply the exact --vmodule pattern that applied to them. |
+// (If no --vmodule pattern applied to them |
+// the value of FLAGS_v will continue to control them.) |
+int SetVLOGLevel(const char* module_pattern, int log_level); |
+ |
+// Private implementation details. No user-serviceable parts inside. |
+namespace base { |
+namespace internal { |
+ |
+// Each log site determines whether its log level is up to date by |
+// comparing its epoch to this global epoch. Whenever the program's |
+// vmodule configuration changes (ex: SetVLOGLevel is called), the |
+// global epoch is advanced, invalidating all site epochs. |
+extern Atomic32 vlog_epoch; |
+ |
+// A log level of kUseFlag means "read the logging level from FLAGS_v." |
+const int kUseFlag = -1; |
+ |
+// Log sites use FLAGS_v by default, and have an initial epoch of 0. |
+const Atomic32 kDefaultSite = kUseFlag << 16; |
+ |
+// The global epoch is the least significant half of an Atomic32, and |
+// may only be accessed through atomic operations. |
+inline Atomic32 GlobalEpoch() { return Acquire_Load(&vlog_epoch) & 0x0000FFFF; } |
+ |
+// The least significant half of a site is the epoch. |
+inline int SiteEpoch(Atomic32 site) { return site & 0x0000FFFF; } |
+ |
+// The most significant half of a site is the logging level. |
+inline int SiteLevel(Atomic32 site) { return site >> 16; } |
+ |
+// Construct a logging site from a logging level and epoch. |
+inline Atomic32 Site(int level, int epoch) { |
+ return ((level & 0x0000FFFF) << 16) | (epoch & 0x0000FFFF); |
+} |
+ |
+// Attempt to initialize or reinitialize a VLOG site. Returns the |
+// level of the log site, regardless of whether the attempt succeeds |
+// or fails. |
+// site: The address of the log site's state. |
+// fname: The filename of the current source file. |
+int InitVLOG(Atomic32* site, const char* fname); |
+ |
+// Determine whether verbose logging should occur at a given log site. |
+// |
+// TODO(llansing): Find a way to eliminate FLAGS_silent_init from this |
+// function while preserving the silent initialization behavior. The |
+// common-case code path shouldn't pay for silent initialization. |
+inline bool VLogEnabled(Atomic32* site, int32 level, const char* const file) { |
+ const Atomic32 site_copy = Acquire_Load(site); |
+ const int32 site_level = |
+ PREDICT_TRUE(SiteEpoch(site_copy) == GlobalEpoch()) ? |
+ SiteLevel(site_copy) : InitVLOG(site, file); |
+ return (site_level == kUseFlag ? FLAGS_v : site_level) >= |
+ (level + FLAGS_silent_init); |
+} |
+ |
+} // namespace internal |
+} // namespace base |
+ |
+#endif // BASE_VLOG_IS_ON_H_ |
Property changes on: third_party\cld\base\vlog_is_on.h |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |