// 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 #include "cutils/log.h" #include "cutils/properties.h" #include "cutils/threads.h" extern "C" { int property_get(const char* key, char* value, const char* default_value) { return 0; } 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); switch (priority) { case ANDROID_LOG_VERBOSE: case ANDROID_LOG_DEBUG: FX_LOGVF(DEBUG, local_tag, file, line, format, ap); break; case ANDROID_LOG_WARN: FX_LOGVF(WARNING, local_tag, file, line, format, ap); break; case ANDROID_LOG_ERROR: FX_LOGVF(ERROR, local_tag, file, line, format, ap); break; case ANDROID_LOG_FATAL: FX_LOGVF(FATAL, local_tag, file, line, format, ap); break; case ANDROID_LOG_INFO: default: FX_LOGVF(INFO, local_tag, file, line, format, ap); break; } 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); FX_LOGVF(ERROR, local_tag, file, line, format, ap); va_end(ap); abort(); } int sync_wait(int fd, int timeout) { return -1; } pid_t gettid() { static thread_local pid_t id = 0; if (!id) { static std::atomic next_thread_id{1}; id = next_thread_id++; } return id; } }