Export of internal Abseil changes
-- d6748c733a70cd74ad9b76a0c9cd6b3fe2cecacf by Xiaoyi Zhang <zhangxy@google.com>: Remove empty block, to address alerts reported in https://github.com/abseil/abseil-cpp/issues/368. PiperOrigin-RevId: 265099887 -- 232e2036b5668d6d1296b881f9347756d84541ee by Derek Mauro <dmauro@google.com>: Make the Linux Bazel CI scripts test with the exception mode explicitly set. PiperOrigin-RevId: 265092105 -- 942a40696c2c9b833be03e92d22a6ede7bccb6d4 by Xiaoyi Zhang <zhangxy@google.com>: Import https://github.com/abseil/abseil-cpp/pull/372. Suppress the unused variable warning on GCC, i.e. "-Wunused-variable". PiperOrigin-RevId: 265063925 -- 7ef90796b52cbdc260afc77cf47206f9356471d0 by Xiaoyi Zhang <zhangxy@google.com>: Add quotes to `ABSL_COMMON_INCLUDE_DIRS` since it's a list and may contain a `;`. This addresses https://github.com/abseil/abseil-cpp/issues/373. PiperOrigin-RevId: 265059077 -- 43f3ae742e00b83672ad6c5bc5b17fdb8f9fe6fe by Gennadiy Rozental <rogeeff@google.com>: Internal re-organization PiperOrigin-RevId: 264913945 -- 6a2adf9c08ee1d98cc6b2855a676345c6495294a by Andy Soffer <asoffer@google.com>: Publicly expose type names for uniform interval tags as in, for example, absl::IntervalClosedClosedTag, and add equality comparison operators. PiperOrigin-RevId: 264861162 -- 3c90c6e05fd61d56b419cd2d39dab8f17b8711b8 by Abseil Team <absl-team@google.com>: Add validity check on returned frame pointer. PiperOrigin-RevId: 264858823 -- 2db87e0cfa0c6bea7ba81684b834cb8a73b7d748 by Gennadiy Rozental <rogeeff@google.com>: Add MUST_USE_RESULT attribute to absl::GetFlag to prevent accidental misuse. PiperOrigin-RevId: 264782762 GitOrigin-RevId: d6748c733a70cd74ad9b76a0c9cd6b3fe2cecacf Change-Id: I169e9c5358e4f63000c1255e806d26b8afecf5ff
This commit is contained in:
parent
0302d1e5fa
commit
2d2d7fbc28
24 changed files with 550 additions and 393 deletions
|
|
@ -68,7 +68,7 @@ absl::Mutex* InitFlag(CommandLineFlag* flag) {
|
|||
{
|
||||
absl::MutexLock lock(mu);
|
||||
|
||||
if (!flag->retired && flag->def == nullptr) {
|
||||
if (!flag->IsRetired() && flag->def == nullptr) {
|
||||
// Need to initialize def and cur fields.
|
||||
flag->def = (*flag->make_init_value)();
|
||||
flag->cur = Clone(flag->op, flag->def);
|
||||
|
|
@ -94,16 +94,6 @@ absl::Mutex* CommandLineFlag::InitFlagIfNecessary() const
|
|||
return &this->locks->primary_mu;
|
||||
}
|
||||
|
||||
void CommandLineFlag::Destroy() const {
|
||||
// Values are heap allocated for retired and Abseil Flags.
|
||||
if (IsRetired() || IsAbseilFlag()) {
|
||||
if (this->cur) Delete(this->op, this->cur);
|
||||
if (this->def) Delete(this->op, this->def);
|
||||
}
|
||||
|
||||
delete this->locks;
|
||||
}
|
||||
|
||||
bool CommandLineFlag::IsModified() const {
|
||||
absl::MutexLock l(InitFlagIfNecessary());
|
||||
return modified;
|
||||
|
|
@ -159,87 +149,6 @@ std::string CommandLineFlag::CurrentValue() const {
|
|||
return Unparse(this->marshalling_op, this->cur);
|
||||
}
|
||||
|
||||
bool CommandLineFlag::HasValidatorFn() const {
|
||||
absl::MutexLock l(InitFlagIfNecessary());
|
||||
|
||||
return this->validator != nullptr;
|
||||
}
|
||||
|
||||
bool CommandLineFlag::SetValidatorFn(FlagValidator fn) {
|
||||
absl::MutexLock l(InitFlagIfNecessary());
|
||||
|
||||
// ok to register the same function over and over again
|
||||
if (fn == this->validator) return true;
|
||||
|
||||
// Can't set validator to a different function, unless reset first.
|
||||
if (fn != nullptr && this->validator != nullptr) {
|
||||
ABSL_INTERNAL_LOG(
|
||||
WARNING, absl::StrCat("Ignoring SetValidatorFn() for flag '", Name(),
|
||||
"': validate-fn already registered"));
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
this->validator = fn;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool CommandLineFlag::InvokeValidator(const void* value) const
|
||||
EXCLUSIVE_LOCKS_REQUIRED(this->locks->primary_mu) {
|
||||
if (!this->validator) {
|
||||
return true;
|
||||
}
|
||||
|
||||
(void)value;
|
||||
|
||||
ABSL_INTERNAL_LOG(
|
||||
FATAL,
|
||||
absl::StrCat("Flag '", Name(),
|
||||
"' of encapsulated type should not have a validator"));
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
void CommandLineFlag::SetCallback(
|
||||
const flags_internal::FlagCallback mutation_callback) {
|
||||
absl::MutexLock l(InitFlagIfNecessary());
|
||||
|
||||
callback = mutation_callback;
|
||||
|
||||
InvokeCallback();
|
||||
}
|
||||
|
||||
// If the flag has a mutation callback this function invokes it. While the
|
||||
// callback is being invoked the primary flag's mutex is unlocked and it is
|
||||
// re-locked back after call to callback is completed. Callback invocation is
|
||||
// guarded by flag's secondary mutex instead which prevents concurrent callback
|
||||
// invocation. Note that it is possible for other thread to grab the primary
|
||||
// lock and update flag's value at any time during the callback invocation.
|
||||
// This is by design. Callback can get a value of the flag if necessary, but it
|
||||
// might be different from the value initiated the callback and it also can be
|
||||
// different by the time the callback invocation is completed.
|
||||
// Requires that *primary_lock be held in exclusive mode; it may be released
|
||||
// and reacquired by the implementation.
|
||||
void CommandLineFlag::InvokeCallback()
|
||||
EXCLUSIVE_LOCKS_REQUIRED(this->locks->primary_mu) {
|
||||
if (!this->callback) return;
|
||||
|
||||
// The callback lock is guaranteed initialized, because *locks->primary_mu
|
||||
// exists.
|
||||
absl::Mutex* callback_mu = &this->locks->callback_mu;
|
||||
|
||||
// When executing the callback we need the primary flag's mutex to be unlocked
|
||||
// so that callback can retrieve the flag's value.
|
||||
this->locks->primary_mu.Unlock();
|
||||
|
||||
{
|
||||
absl::MutexLock lock(callback_mu);
|
||||
this->callback();
|
||||
}
|
||||
|
||||
this->locks->primary_mu.Lock();
|
||||
}
|
||||
|
||||
// Attempts to parse supplied `value` string using parsing routine in the `flag`
|
||||
// argument. If parsing is successful, it will try to validate that the parsed
|
||||
// value is valid for the specified 'flag'. Finally this function stores the
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue