// Copyright 2018 The Fuchsia Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include #include #include #include #include #include #include #include #if defined(__Fuchsia__) #include #include #else #include #endif #include "cutils/log.h" #include "cutils/properties.h" extern "C" { #if !defined(__Fuchsia__) static void linux_log_prefix(const char *prefix, const char *file, int line, const char *format, va_list ap, ...) { char buf[50]; char *dup = strdup(file); if (!dup) return; snprintf(buf, sizeof(buf), "[%s(%d)]", basename(dup), line); fprintf(stderr, "%s", buf); vfprintf(stderr, format, ap); fprintf(stderr, "\n"); free(dup); } #endif int property_get(const char* key, char* value, const char* default_value) { return 0; } // According to https://developer.android.com/ndk/reference/group/logging, // some log levels "Should typically be disabled for a release apk." static constexpr bool include_debug_logging() { #if defined(DEBUG) return true; #else return false; #endif } int __android_log_print(int priority, const char* tag, const char* file, int line, const char* format, ...) { const char* local_tag = tag; if (!local_tag) { local_tag = ""; } va_list ap; va_start(ap, format); #if defined(__Fuchsia__) switch (priority) { case ANDROID_LOG_VERBOSE: case ANDROID_LOG_DEBUG: if (include_debug_logging()) { gfxstream_fuchsia_log(FUCHSIA_LOG_DEBUG, local_tag, file, line, format, ap); } break; case ANDROID_LOG_INFO: if (include_debug_logging()) { gfxstream_fuchsia_log(FUCHSIA_LOG_INFO, local_tag, file, line, format, ap); } break; case ANDROID_LOG_WARN: gfxstream_fuchsia_log(FUCHSIA_LOG_WARNING, local_tag, file, line, format, ap); break; case ANDROID_LOG_ERROR: gfxstream_fuchsia_log(FUCHSIA_LOG_ERROR, local_tag, file, line, format, ap); break; case ANDROID_LOG_FATAL: gfxstream_fuchsia_log(FUCHSIA_LOG_FATAL, local_tag, file, line, format, ap); break; default: gfxstream_fuchsia_log(FUCHSIA_LOG_INFO, local_tag, file, line, format, ap); break; } #else // Should we check include_debug_logging() here? linux_log_prefix(local_tag, file, line, format, ap); #endif return 1; } void __android_log_assert(const char* condition, const char* tag, const char* file, int line, const char* format, ...) { const char* local_tag = tag; if (!local_tag) { local_tag = ""; } va_list ap; va_start(ap, format); #if defined(__Fuchsia__) gfxstream_fuchsia_log(FUCHSIA_LOG_ERROR, local_tag, file, line, format, ap); #else linux_log_prefix(local_tag, file, line, format, ap); #endif va_end(ap); abort(); } int sync_wait(int fd, int timeout) { return -1; } }