// Copyright 2016 The SwiftShader 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. // debug.cpp: Debugging utilities. #include "common/debug.h" #ifdef __ANDROID__ #include <utils/String8.h> #if ANDROID_PLATFORM_SDK_VERSION < 27 #include <cutils/log.h> #elif ANDROID_PLATFORM_SDK_VERSION >= 27 #include <log/log.h> #else #error "ANDROID_PLATFORM_SDK_VERSION is not defined" #endif #endif #include <stdio.h> #include <stdarg.h> namespace es { #if defined(__ANDROID__) && !defined(ANDROID_HOST_BUILD) static void output(const char *format, va_list vararg) { ALOGI("%s", android::String8::formatV(format, vararg).string()); } #else static void output(const char *format, va_list vararg) { if(false) { static FILE* file = nullptr; if(!file) { file = fopen(TRACE_OUTPUT_FILE, "w"); } if(file) { vfprintf(file, format, vararg); // fflush(file); } } } #endif void trace(const char *format, ...) { va_list vararg; va_start(vararg, format); output(format, vararg); va_end(vararg); } }