|  | // Copyright 2014 The Bazel Authors. All rights reserved. | 
|  | // | 
|  | // Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | // you may not use this file except in compliance with the License. | 
|  | // You may obtain a copy of the License at | 
|  | // | 
|  | //    http://www.apache.org/licenses/LICENSE-2.0 | 
|  | // | 
|  | // Unless required by applicable law or agreed to in writing, software | 
|  | // distributed under the License is distributed on an "AS IS" BASIS, | 
|  | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | // See the License for the specific language governing permissions and | 
|  | // limitations under the License. | 
|  | // | 
|  | // blaze_util.h: Miscellaneous utility functions used by the blaze.cc | 
|  | //               Blaze client. | 
|  | // | 
|  |  | 
|  | #ifndef BAZEL_SRC_MAIN_CPP_BLAZE_UTIL_H_ | 
|  | #define BAZEL_SRC_MAIN_CPP_BLAZE_UTIL_H_ | 
|  |  | 
|  | #include <sys/types.h> | 
|  |  | 
|  | #include <map> | 
|  | #include <sstream> | 
|  | #include <string> | 
|  | #include <vector> | 
|  |  | 
|  | namespace blaze { | 
|  |  | 
|  | extern const char kServerPidFile[]; | 
|  |  | 
|  | // If 'arg' matches 'key=value', returns address of 'value'. | 
|  | // If it matches 'key' alone, returns address of next_arg. | 
|  | // Returns NULL otherwise. | 
|  | const char* GetUnaryOption(const char *arg, | 
|  | const char *next_arg, | 
|  | const char *key); | 
|  |  | 
|  | // Returns true iff 'arg' equals 'key'. | 
|  | // Dies with a syntax error if arg starts with 'key='. | 
|  | // Returns false otherwise. | 
|  | bool GetNullaryOption(const char *arg, const char *key); | 
|  |  | 
|  | // Searches for 'key' in 'args' using GetUnaryOption. Arguments found after '--' | 
|  | // are omitted from the search. | 
|  | // Returns the value of the 'key' flag iff it occurs in args. | 
|  | // Returns NULL otherwise. | 
|  | const char* SearchUnaryOption(const std::vector<std::string>& args, | 
|  | const char* key); | 
|  |  | 
|  | // Searches for '--flag_name' and '--noflag_name' in 'args' using | 
|  | // GetNullaryOption. Arguments found after '--' are omitted from the search. | 
|  | // Returns true if '--flag_name' is a flag in args and '--noflag_name' does not | 
|  | // appear after its last occurrence. If neither '--flag_name' nor | 
|  | // '--noflag_name' appear, returns 'default_value'. Otherwise, returns false. | 
|  | bool SearchNullaryOption(const std::vector<std::string>& args, | 
|  | const std::string& flag_name, | 
|  | const bool default_value); | 
|  |  | 
|  | // Returns true iff arg is a valid command line argument for bazel. | 
|  | bool IsArg(const std::string& arg); | 
|  |  | 
|  | // Returns the flag value as an absolute path. For legacy reasons, it accepts | 
|  | // the empty string as cwd. | 
|  | // TODO(b/109874628): Assess if removing the empty string case would break | 
|  | // legitimate uses, and if not, remove it. | 
|  | std::string AbsolutePathFromFlag(const std::string& value); | 
|  |  | 
|  | // Wait to see if the server process terminates. Checks the server's status | 
|  | // immediately, and repeats the check every 100ms until approximately | 
|  | // wait_seconds elapses or the server process terminates. Returns true if a | 
|  | // check sees that the server process terminated. Logs to stderr after 5, 10, | 
|  | // and 30 seconds if the wait lasts that long. | 
|  | bool AwaitServerProcessTermination(int pid, const std::string& output_base, | 
|  | unsigned int wait_seconds); | 
|  |  | 
|  | // The number of seconds the client will wait for the server process to | 
|  | // terminate itself after the client receives the final response from a command | 
|  | // that shuts down the server. After waiting this time, if the server process | 
|  | // remains, the client will forcibly kill the server. | 
|  | extern const unsigned int kPostShutdownGracePeriodSeconds; | 
|  |  | 
|  | // The number of seconds the client will wait for the server process to | 
|  | // terminate after the client forcibly kills the server. After waiting this | 
|  | // time, if the server process remains, the client will die. | 
|  | extern const unsigned int kPostKillGracePeriodSeconds; | 
|  |  | 
|  | // Returns the string representation of `value`. | 
|  | // Workaround for mingw where std::to_string is not implemented. | 
|  | // See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=52015. | 
|  | template <typename T> | 
|  | std::string ToString(const T &value) { | 
|  | #if defined(__CYGWIN__) || defined(__MINGW32__) | 
|  | std::ostringstream oss; | 
|  | oss << value; | 
|  | return oss.str(); | 
|  | #else | 
|  | return std::to_string(value); | 
|  | #endif | 
|  | } | 
|  |  | 
|  | // Control the output of debug information by debug_log. | 
|  | // Revisit once client logging is fixed (b/32939567). | 
|  | void SetDebugLog(bool enabled); | 
|  |  | 
|  | // Returns true if this Bazel instance is running inside of a Bazel test. | 
|  | // This method observes the TEST_TMPDIR envvar. | 
|  | bool IsRunningWithinTest(); | 
|  |  | 
|  | // What WithEnvVar should do with an environment variable | 
|  | enum EnvVarAction { UNSET, SET }; | 
|  |  | 
|  | // What WithEnvVar should do with an environment variable | 
|  | struct EnvVarValue { | 
|  | // What should be done with the given variable | 
|  | EnvVarAction action; | 
|  |  | 
|  | // The value of the variable; ignored if action == UNSET | 
|  | std::string value; | 
|  |  | 
|  | EnvVarValue() {} | 
|  |  | 
|  | EnvVarValue(EnvVarAction action, const std::string& value) | 
|  | : action(action), | 
|  | value(value) {} | 
|  | }; | 
|  |  | 
|  | // While this class is in scope, the specified environment variables will be set | 
|  | // to a specified value (or unset). When it leaves scope, changed variables will | 
|  | // be set to their original values. | 
|  | class WithEnvVars { | 
|  | private: | 
|  | std::map<std::string, EnvVarValue> _old_values; | 
|  |  | 
|  | void SetEnvVars(const std::map<std::string, EnvVarValue>& vars); | 
|  |  | 
|  | public: | 
|  | WithEnvVars(const std::map<std::string, EnvVarValue>& vars); | 
|  | ~WithEnvVars(); | 
|  | }; | 
|  |  | 
|  | }  // namespace blaze | 
|  |  | 
|  | #endif  // BAZEL_SRC_MAIN_CPP_BLAZE_UTIL_H_ |