| // 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. | 
 | #ifndef BAZEL_SRC_MAIN_CPP_UTIL_PORT_H_ | 
 | #define BAZEL_SRC_MAIN_CPP_UTIL_PORT_H_ | 
 |  | 
 | #include <stddef.h>  // For size_t on Linux, Darwin | 
 |  | 
 | #include <cinttypes>  // For size_t on Windows | 
 |  | 
 | // GCC-specific features | 
 | #if defined(__GNUC__) && !defined(SWIG) | 
 |  | 
 | // | 
 | // Tell the compiler to do printf format string checking if the | 
 | // compiler supports it; see the 'format' attribute in | 
 | // <http://gcc.gnu.org/onlinedocs/gcc-4.3.0/gcc/Function-Attributes.html>. | 
 | // | 
 | // N.B.: As the GCC manual states, "[s]ince non-static C++ methods | 
 | // have an implicit 'this' argument, the arguments of such methods | 
 | // should be counted from two, not one." | 
 | // | 
 | #define PRINTF_ATTRIBUTE(string_index, first_to_check) \ | 
 |   __attribute__((__format__ \ | 
 |     (__printf__, string_index, first_to_check))) | 
 |  | 
 | #define ATTRIBUTE_UNUSED __attribute__ ((__unused__)) | 
 |  | 
 | #else  // Not GCC | 
 |  | 
 | #define PRINTF_ATTRIBUTE(string_index, first_to_check) | 
 | #define ATTRIBUTE_UNUSED | 
 |  | 
 | #endif  // GCC | 
 |  | 
 | // HAVE_ATTRIBUTE | 
 | // | 
 | // A function-like feature checking macro that is a wrapper around | 
 | // `__has_attribute`, which is defined by GCC 5+ and Clang and evaluates to a | 
 | // nonzero constant integer if the attribute is supported or 0 if not. | 
 | // | 
 | // It evaluates to zero if `__has_attribute` is not defined by the compiler. | 
 | // | 
 | // GCC: https://gcc.gnu.org/gcc-5/changes.html | 
 | // Clang: https://clang.llvm.org/docs/LanguageExtensions.html | 
 | #ifdef __has_attribute | 
 | #define HAVE_ATTRIBUTE(x) __has_attribute(x) | 
 | #else | 
 | #define HAVE_ATTRIBUTE(x) (0) | 
 | #endif | 
 |  | 
 | // ATTRIBUTE_NORETURN | 
 | // | 
 | // Tells the compiler that a given function never returns. | 
 | #if defined(SWIG) | 
 | #define ATTRIBUTE_NORETURN | 
 | #elif HAVE_ATTRIBUTE(noreturn) || (defined(__GNUC__) && !defined(__clang__)) | 
 | #define ATTRIBUTE_NORETURN __attribute__((noreturn)) | 
 | #else | 
 | #define ATTRIBUTE_NORETURN | 
 | #endif | 
 |  | 
 |  | 
 | // Linux I/O priorities support is available only in later versions of glibc. | 
 | // Therefore, we include some of the needed definitions here.  May need to | 
 | // be removed once we switch to a new version of glibc | 
 | // (As of 10/24/08 it is unclear when glibc support will become available.) | 
 | enum IOPriorityClass { | 
 |   // No I/O priority value has yet been set.  The kernel may assign I/O | 
 |   // priority based on the process nice value. | 
 |   IOPRIO_CLASS_NONE, | 
 |  | 
 |   // Real-time, highest priority. Given first access to the disk at | 
 |   // every opportunity. Use with care: one such process can STARVE | 
 |   // THE ENTIRE SYSTEM. Has 8 priority levels (0-7). | 
 |   IOPRIO_CLASS_RT, | 
 |  | 
 |   // Best-effort, default for any process. Has 8 priority levels (0-7). | 
 |   IOPRIO_CLASS_BE, | 
 |  | 
 |   // Idle, lowest priority. Processes running at this level only get | 
 |   // I/O time when no one else needs the disk, and MAY BECOME | 
 |   // STARVED if higher priority processes are constantly accessing | 
 |   // the disk.  With the "anticipatory" I/O scheduler, mapped to | 
 |   // IOPRIO_CLASS_BE, level 3. | 
 |   IOPRIO_CLASS_IDLE, | 
 | }; | 
 |  | 
 | enum { | 
 |   IOPRIO_WHO_PROCESS = 1, | 
 |   IOPRIO_WHO_PGRP, | 
 |   IOPRIO_WHO_USER, | 
 | }; | 
 |  | 
 | #ifndef IOPRIO_CLASS_SHIFT | 
 | #define IOPRIO_CLASS_SHIFT 13 | 
 | #endif | 
 |  | 
 | #ifndef IOPRIO_PRIO_VALUE | 
 | #define IOPRIO_PRIO_VALUE(class, data) (((class) << IOPRIO_CLASS_SHIFT) | data) | 
 | #endif | 
 |  | 
 | namespace blaze_util { | 
 |  | 
 | int sys_ioprio_set(int which, int who, int ioprio); | 
 |  | 
 | }  // namespace blaze_util | 
 |  | 
 | // The arraysize(arr) macro returns the # of elements in an array arr. | 
 | // The expression is a compile-time constant, and therefore can be | 
 | // used in defining new arrays, for example.  If you use arraysize on | 
 | // a pointer by mistake, you will get a compile-time error. | 
 |  | 
 | // This template function declaration is used in defining arraysize. | 
 | // Note that the function doesn't need an implementation, as we only | 
 | // use its type. | 
 | template <typename T, size_t N> | 
 | char (&ArraySizeHelper(T (&array)[N]))[N]; | 
 |  | 
 | // That gcc wants both of these prototypes seems mysterious. VC, for | 
 | // its part, can't decide which to use (another mystery). Matching of | 
 | // template overloads: the final frontier. | 
 | template <typename T, size_t N> | 
 | char (&ArraySizeHelper(const T (&array)[N]))[N]; | 
 |  | 
 | #define arraysize(array) (sizeof(ArraySizeHelper(array))) | 
 |  | 
 | #ifdef _WIN32 | 
 | // TODO(laszlocsomor) 2016-11-28: move pid_t usage out of global_variables.h and | 
 | // wherever else it appears. Find some way to not have to declare a pid_t here, | 
 | // either by making PID handling platform-independent or some other idea; remove | 
 | // the following typedef afterwards. | 
 | #ifndef __MINGW32__ | 
 | typedef int pid_t; | 
 | #endif  // __MINGW32__ | 
 | #endif  // _WIN32 | 
 |  | 
 | #endif  // BAZEL_SRC_MAIN_CPP_UTIL_PORT_H_ |