diff options
Diffstat (limited to 'src/core/SkDebug_stdio.cpp')
-rw-r--r-- | src/core/SkDebug_stdio.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/core/SkDebug_stdio.cpp b/src/core/SkDebug_stdio.cpp new file mode 100644 index 0000000..c8a0d81 --- /dev/null +++ b/src/core/SkDebug_stdio.cpp @@ -0,0 +1,61 @@ +/* libs/corecg/SkDebug_stdio.cpp +** +** Copyright 2006, The Android Open Source Project +** +** 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. +*/ + +#include "SkTypes.h" + +static const size_t kBufferSize = 256; + +#ifdef ANDROID + +#define LOG_TAG "skia" +#include <utils/Log.h> + +void Android_SkDebugf(const char* file, int line, const char* function, + const char* format, ...) +{ + if (format[0] == '\n' && format[1] == '\0') + return; + va_list args; + va_start(args, format); +#ifdef HAVE_ANDROID_OS + char buffer[kBufferSize + 1]; + vsnprintf(buffer, kBufferSize, format, args); + if (buffer[0] != 0) + __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, "%s", buffer); +#else + android_vprintLog(ANDROID_LOG_DEBUG, NULL, LOG_TAG, format, args); +#endif + va_end(args); +} + +#else + +#include <stdarg.h> +#include <stdio.h> + +void SkDebugf(const char format[], ...) +{ + char buffer[kBufferSize + 1]; + va_list args; + va_start(args, format); + vsnprintf(buffer, kBufferSize, format, args); + va_end(args); + fprintf(stderr, buffer); +} + +#endif + |