|  | // 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. | 
|  | // | 
|  | // INTERNAL header file for use by C++ code in this package. | 
|  |  | 
|  | #ifndef BAZEL_SRC_MAIN_NATIVE_UNIX_JNI_H__ | 
|  | #define BAZEL_SRC_MAIN_NATIVE_UNIX_JNI_H__ | 
|  |  | 
|  | #include <errno.h> | 
|  | #include <jni.h> | 
|  | #include <sys/stat.h> | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | namespace blaze_jni { | 
|  |  | 
|  | #if defined(__APPLE__) || defined(__FreeBSD__) || defined(__OpenBSD__) | 
|  | // stat64 is deprecated on OS X/BSD. | 
|  | typedef struct stat portable_stat_struct; | 
|  | #define portable_stat ::stat | 
|  | #define portable_lstat ::lstat | 
|  | #else | 
|  | typedef struct stat64 portable_stat_struct; | 
|  | #define portable_stat ::stat64 | 
|  | #define portable_lstat ::lstat64 | 
|  | #endif | 
|  |  | 
|  | #if !defined(ENODATA) | 
|  | # if defined(ENOATTR) | 
|  | #  define ENODATA ENOATTR | 
|  | # else | 
|  | #  error We do not know how to handle missing ENODATA | 
|  | # endif | 
|  | #endif | 
|  |  | 
|  | // Posts a JNI exception to the current thread with the specified | 
|  | // message plus the standard UNIX error message for the error number. | 
|  | // (Consistent with errors generated by java.io package.) | 
|  | // The exception's class is determined by the specified UNIX error number. | 
|  | extern void PostException(JNIEnv *env, int error_number, | 
|  | const std::string &message); | 
|  |  | 
|  | // Returns the standard error message for a given UNIX error number. | 
|  | extern std::string ErrorMessage(int error_number); | 
|  |  | 
|  | // Runs fstatat(2), if available, or sets errno to ENOSYS if not. | 
|  | int portable_fstatat(int dirfd, char *name, portable_stat_struct *statbuf, | 
|  | int flags); | 
|  |  | 
|  | // Encoding for different timestamps in a struct stat{}. | 
|  | enum StatTimes { | 
|  | STAT_ATIME,  // access | 
|  | STAT_MTIME,  // modification | 
|  | STAT_CTIME,  // status change | 
|  | }; | 
|  |  | 
|  | // Returns seconds from a stat buffer. | 
|  | int StatSeconds(const portable_stat_struct &statbuf, StatTimes t); | 
|  |  | 
|  | // Returns nanoseconds from a stat buffer. | 
|  | int StatNanoSeconds(const portable_stat_struct &statbuf, StatTimes t); | 
|  |  | 
|  | // Runs getxattr(2). If the attribute is not found, returns -1 and sets | 
|  | // attr_not_found to true. For all other errors, returns -1, sets attr_not_found | 
|  | // to false and leaves errno set to the error code returned by the system. | 
|  | ssize_t portable_getxattr(const char *path, const char *name, void *value, | 
|  | size_t size, bool *attr_not_found); | 
|  |  | 
|  | // Runs lgetxattr(2). If the attribute is not found, returns -1 and sets | 
|  | // attr_not_found to true. For all other errors, returns -1, sets attr_not_found | 
|  | // to false and leaves errno set to the error code returned by the system. | 
|  | ssize_t portable_lgetxattr(const char *path, const char *name, void *value, | 
|  | size_t size, bool *attr_not_found); | 
|  |  | 
|  | // Run sysctlbyname(3), only available on darwin | 
|  | int portable_sysctlbyname(const char *name_chars, void *mibp, size_t *sizep); | 
|  |  | 
|  | // Used to surround an region that we want sleep disabled for. | 
|  | // push_disable_sleep to start the area. | 
|  | // pop_disable_sleep to end the area. | 
|  | // Note that this is a stack so sleep will not be reenabled until the stack | 
|  | // is empty. | 
|  | // Returns 0 on success. | 
|  | // Returns -1 if sleep is not supported. | 
|  | int portable_push_disable_sleep(); | 
|  | int portable_pop_disable_sleep(); | 
|  |  | 
|  | // Starts up any infrastructure needed to do suspend monitoring. | 
|  | // May be called more than once. | 
|  | void portable_start_suspend_monitoring(); | 
|  |  | 
|  | // These need to be kept in sync with constants in | 
|  | // j/c/g/devtools/build/lib/buildtool/buildevent/SystemSuspensionEvent.java | 
|  | typedef enum  { | 
|  | SuspensionReasonSIGTSTP = 0, | 
|  | SuspensionReasonSIGCONT = 1, | 
|  | SuspensionReasonSleep = 2, | 
|  | SuspensionReasonWake = 3 | 
|  | } SuspensionReason; | 
|  |  | 
|  | // Declaration for callback function that is called by suspend monitoring | 
|  | // when a suspension is detected. | 
|  | extern void suspend_callback(SuspensionReason value); | 
|  |  | 
|  | // Starts up any infrastructure needed to do thermal monitoring. | 
|  | // May be called more than once. | 
|  | void portable_start_thermal_monitoring(); | 
|  |  | 
|  | // Declaration for callback function that is called by thermal monitoring | 
|  | // when a thermal event is detected. | 
|  | extern void thermal_callback(int value); | 
|  |  | 
|  | // Returns the current thermal load. | 
|  | int portable_thermal_load(); | 
|  |  | 
|  | // Starts up any infrastructure needed to do system load advisory monitoring. | 
|  | // May be called more than once. | 
|  | void portable_start_system_load_advisory_monitoring(); | 
|  |  | 
|  | // Declaration for callback function that is called by system load advisory | 
|  | // monitoring when a system load advisory event is detected. | 
|  | extern void system_load_advisory_callback(int value); | 
|  |  | 
|  | // Returns the system load advisory. | 
|  | int portable_system_load_advisory(); | 
|  |  | 
|  | // Starts up any infrastructure needed to do memory pressure monitoring. | 
|  | // May be called more than once. | 
|  | void portable_start_memory_pressure_monitoring(); | 
|  |  | 
|  | // These need to be kept in sync with constants in | 
|  | // j/c/g/devtools/build/lib/buildtool/buildevent/SystemMemoryPressureEvent.java | 
|  | typedef enum  { | 
|  | MemoryPressureLevelNormal = 0, | 
|  | MemoryPressureLevelWarning = 1, | 
|  | MemoryPressureLevelCritical = 2, | 
|  | } MemoryPressureLevel; | 
|  |  | 
|  | // Declaration for callback function that is called by memory pressure | 
|  | // monitoring when memory pressure is detected. | 
|  | extern void memory_pressure_callback(MemoryPressureLevel level); | 
|  |  | 
|  | // Returns the current memory pressure. | 
|  | MemoryPressureLevel portable_memory_pressure(); | 
|  |  | 
|  | // Starts up any infrastructure needed to do disk space monitoring. | 
|  | // May be called more than once. | 
|  | void portable_start_disk_space_monitoring(); | 
|  |  | 
|  | // These need to be kept in sync with constants in | 
|  | // j/c/g/devtools/build/lib/buildtool/buildevent/SystemDiskSpaceEvent.java | 
|  | typedef enum  { | 
|  | DiskSpaceLevelLow = 0, | 
|  | DiskSpaceLevelVeryLow = 1, | 
|  | } DiskSpaceLevel; | 
|  |  | 
|  | // Declaration for callback function that is called by disk space | 
|  | // monitoring when a disk space alert happens. | 
|  | extern void disk_space_callback(DiskSpaceLevel level); | 
|  |  | 
|  | // Starts up any infrastructure needed to do cpu speed monitoring. | 
|  | // May be called more than once. | 
|  | void portable_start_cpu_speed_monitoring(); | 
|  |  | 
|  | // Returns the current CPU speed. Return -1 in case of error. | 
|  | int portable_cpu_speed(); | 
|  |  | 
|  | // Declaration for callback function that is called by cpu speed | 
|  | // monitoring when a cpu speed alert happens. | 
|  | extern void cpu_speed_callback(int speed); | 
|  |  | 
|  | }  // namespace blaze_jni | 
|  |  | 
|  | #endif  // BAZEL_SRC_MAIN_NATIVE_UNIX_JNI_H__ |