1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2006 The Android Open Source Project 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #include "include/private/base/SkDebug.h" 9*c8dee2aaSAndroid Build Coastguard Worker #include "include/private/base/SkFeatures.h" 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #if defined(SK_BUILD_FOR_ANDROID) 12*c8dee2aaSAndroid Build Coastguard Worker 13*c8dee2aaSAndroid Build Coastguard Worker #include <stdio.h> 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker #ifdef LOG_TAG 16*c8dee2aaSAndroid Build Coastguard Worker #undef LOG_TAG 17*c8dee2aaSAndroid Build Coastguard Worker #endif 18*c8dee2aaSAndroid Build Coastguard Worker #define LOG_TAG "skia" 19*c8dee2aaSAndroid Build Coastguard Worker #include <android/log.h> 20*c8dee2aaSAndroid Build Coastguard Worker 21*c8dee2aaSAndroid Build Coastguard Worker // Print debug output to stdout as well. This is useful for command line 22*c8dee2aaSAndroid Build Coastguard Worker // applications 23*c8dee2aaSAndroid Build Coastguard Worker bool gSkDebugToStdOut = false; 24*c8dee2aaSAndroid Build Coastguard Worker SkDebugf(const char format[],...)25*c8dee2aaSAndroid Build Coastguard Workervoid SkDebugf(const char format[], ...) { 26*c8dee2aaSAndroid Build Coastguard Worker va_list args1, args2; 27*c8dee2aaSAndroid Build Coastguard Worker va_start(args1, format); 28*c8dee2aaSAndroid Build Coastguard Worker 29*c8dee2aaSAndroid Build Coastguard Worker if (gSkDebugToStdOut) { 30*c8dee2aaSAndroid Build Coastguard Worker va_copy(args2, args1); 31*c8dee2aaSAndroid Build Coastguard Worker vprintf(format, args2); 32*c8dee2aaSAndroid Build Coastguard Worker va_end(args2); 33*c8dee2aaSAndroid Build Coastguard Worker fflush(stdout); 34*c8dee2aaSAndroid Build Coastguard Worker } 35*c8dee2aaSAndroid Build Coastguard Worker 36*c8dee2aaSAndroid Build Coastguard Worker __android_log_vprint(ANDROID_LOG_DEBUG, LOG_TAG, format, args1); 37*c8dee2aaSAndroid Build Coastguard Worker 38*c8dee2aaSAndroid Build Coastguard Worker va_end(args1); 39*c8dee2aaSAndroid Build Coastguard Worker } 40*c8dee2aaSAndroid Build Coastguard Worker 41*c8dee2aaSAndroid Build Coastguard Worker #endif // defined(SK_BUILD_FOR_ANDROID) 42