// 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 #include #include #include namespace blaze { extern const char kServerPidFile[]; // Returns the given path in absolute form. Does not change paths that are // already absolute. // // If called from working directory "/bar": // MakeAbsolute("foo") --> "/bar/foo" // MakeAbsolute("/foo") ---> "/foo" // MakeAbsolute("C:/foo") ---> "C:/foo" std::string MakeAbsolute(const std::string &path); // 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& 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& args, const std::string& flag_name, const bool default_value); // Enable messages mostly of interest to developers. bool VerboseLogging(); // Read the JVM version from a string. The string should contain the output of a // "java -version" execution and is supposed to contain a string of the form // 'version "version-number"' in the first 255 bytes. If the string is found, // version-number is returned, else the empty string is returned. std::string ReadJvmVersion(const std::string &version_string); // Returns true iff jvm_version is at least the version specified by // version_spec. // jvm_version is supposed to be a string specifying a java runtime version // as specified by the JSR-56 appendix A. version_spec is supposed to be a // version is the format [0-9]+(.[1-9]+)*. bool CheckJavaVersionIsAtLeast(const std::string &jvm_version, const std::string &version_spec); // Returns true iff arg is a valid command line argument for bazel. bool IsArg(const std::string& arg); // 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 std::string ToString(const T &value) { std::ostringstream oss; oss << value; return oss.str(); } // Control the output of debug information by debug_log. // Revisit once client logging is fixed (b/32939567). void SetDebugLog(bool enabled); // Output debug information from client. // Revisit once client logging is fixed (b/32939567). void debug_log(const char *format, ...); } // namespace blaze #endif // BAZEL_SRC_MAIN_CPP_BLAZE_UTIL_H_