1*9356374aSAndroid Build Coastguard Worker // 2*9356374aSAndroid Build Coastguard Worker // Copyright 2019 The Abseil Authors. 3*9356374aSAndroid Build Coastguard Worker // 4*9356374aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 5*9356374aSAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 6*9356374aSAndroid Build Coastguard Worker // You may obtain a copy of the License at 7*9356374aSAndroid Build Coastguard Worker // 8*9356374aSAndroid Build Coastguard Worker // https://www.apache.org/licenses/LICENSE-2.0 9*9356374aSAndroid Build Coastguard Worker // 10*9356374aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 11*9356374aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 12*9356374aSAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*9356374aSAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 14*9356374aSAndroid Build Coastguard Worker // limitations under the License. 15*9356374aSAndroid Build Coastguard Worker #include "absl/flags/usage.h" 16*9356374aSAndroid Build Coastguard Worker 17*9356374aSAndroid Build Coastguard Worker #include <stdlib.h> 18*9356374aSAndroid Build Coastguard Worker 19*9356374aSAndroid Build Coastguard Worker #include <string> 20*9356374aSAndroid Build Coastguard Worker 21*9356374aSAndroid Build Coastguard Worker #include "absl/base/attributes.h" 22*9356374aSAndroid Build Coastguard Worker #include "absl/base/config.h" 23*9356374aSAndroid Build Coastguard Worker #include "absl/base/const_init.h" 24*9356374aSAndroid Build Coastguard Worker #include "absl/base/internal/raw_logging.h" 25*9356374aSAndroid Build Coastguard Worker #include "absl/base/thread_annotations.h" 26*9356374aSAndroid Build Coastguard Worker #include "absl/flags/internal/usage.h" 27*9356374aSAndroid Build Coastguard Worker #include "absl/strings/string_view.h" 28*9356374aSAndroid Build Coastguard Worker #include "absl/synchronization/mutex.h" 29*9356374aSAndroid Build Coastguard Worker 30*9356374aSAndroid Build Coastguard Worker namespace absl { 31*9356374aSAndroid Build Coastguard Worker ABSL_NAMESPACE_BEGIN 32*9356374aSAndroid Build Coastguard Worker namespace flags_internal { 33*9356374aSAndroid Build Coastguard Worker namespace { 34*9356374aSAndroid Build Coastguard Worker ABSL_CONST_INIT absl::Mutex usage_message_guard(absl::kConstInit); 35*9356374aSAndroid Build Coastguard Worker ABSL_CONST_INIT std::string* program_usage_message 36*9356374aSAndroid Build Coastguard Worker ABSL_GUARDED_BY(usage_message_guard) = nullptr; 37*9356374aSAndroid Build Coastguard Worker } // namespace 38*9356374aSAndroid Build Coastguard Worker } // namespace flags_internal 39*9356374aSAndroid Build Coastguard Worker 40*9356374aSAndroid Build Coastguard Worker // -------------------------------------------------------------------- 41*9356374aSAndroid Build Coastguard Worker // Sets the "usage" message to be used by help reporting routines. SetProgramUsageMessage(absl::string_view new_usage_message)42*9356374aSAndroid Build Coastguard Workervoid SetProgramUsageMessage(absl::string_view new_usage_message) { 43*9356374aSAndroid Build Coastguard Worker absl::MutexLock l(&flags_internal::usage_message_guard); 44*9356374aSAndroid Build Coastguard Worker 45*9356374aSAndroid Build Coastguard Worker if (flags_internal::program_usage_message != nullptr) { 46*9356374aSAndroid Build Coastguard Worker ABSL_INTERNAL_LOG(FATAL, "SetProgramUsageMessage() called twice."); 47*9356374aSAndroid Build Coastguard Worker std::exit(1); 48*9356374aSAndroid Build Coastguard Worker } 49*9356374aSAndroid Build Coastguard Worker 50*9356374aSAndroid Build Coastguard Worker flags_internal::program_usage_message = new std::string(new_usage_message); 51*9356374aSAndroid Build Coastguard Worker } 52*9356374aSAndroid Build Coastguard Worker 53*9356374aSAndroid Build Coastguard Worker // -------------------------------------------------------------------- 54*9356374aSAndroid Build Coastguard Worker // Returns the usage message set by SetProgramUsageMessage(). 55*9356374aSAndroid Build Coastguard Worker // Note: We able to return string_view here only because calling 56*9356374aSAndroid Build Coastguard Worker // SetProgramUsageMessage twice is prohibited. ProgramUsageMessage()57*9356374aSAndroid Build Coastguard Workerabsl::string_view ProgramUsageMessage() { 58*9356374aSAndroid Build Coastguard Worker absl::MutexLock l(&flags_internal::usage_message_guard); 59*9356374aSAndroid Build Coastguard Worker 60*9356374aSAndroid Build Coastguard Worker return flags_internal::program_usage_message != nullptr 61*9356374aSAndroid Build Coastguard Worker ? absl::string_view(*flags_internal::program_usage_message) 62*9356374aSAndroid Build Coastguard Worker : "Warning: SetProgramUsageMessage() never called"; 63*9356374aSAndroid Build Coastguard Worker } 64*9356374aSAndroid Build Coastguard Worker 65*9356374aSAndroid Build Coastguard Worker ABSL_NAMESPACE_END 66*9356374aSAndroid Build Coastguard Worker } // namespace absl 67