| /* |
| * Copyright (C) 2013 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. |
| */ |
| |
| #define LOG_TAG "Printer" |
| // #define LOG_NDEBUG 0 |
| |
| #include <utils/Printer.h> |
| #include <utils/String8.h> |
| #include <utils/Log.h> |
| |
| #include <string.h> |
| #include <stdio.h> |
| #include <stdlib.h> |
| |
| #ifndef __BIONIC__ |
| #define fdprintf dprintf |
| #endif |
| |
| namespace android { |
| |
| /* |
| * Implementation of Printer |
| */ |
| Printer::Printer() { |
| // Intentionally left empty |
| } |
| |
| Printer::~Printer() { |
| // Intentionally left empty |
| } |
| |
| void Printer::printFormatLine(const char* format, ...) { |
| va_list arglist; |
| va_start(arglist, format); |
| |
| char* formattedString; |
| |
| #ifndef USE_MINGW |
| if (vasprintf(&formattedString, format, arglist) < 0) { // returns -1 on error |
| ALOGE("%s: Failed to format string", __FUNCTION__); |
| return; |
| } |
| #else |
| return; |
| #endif |
| |
| va_end(arglist); |
| |
| printLine(formattedString); |
| free(formattedString); |
| } |
| |
| /* |
| * Implementation of LogPrinter |
| */ |
| LogPrinter::LogPrinter(const char* logtag, |
| android_LogPriority priority, |
| const char* prefix, |
| bool ignoreBlankLines) : |
| mLogTag(logtag), |
| mPriority(priority), |
| mPrefix(prefix ?: ""), |
| mIgnoreBlankLines(ignoreBlankLines) { |
| } |
| |
| void LogPrinter::printLine(const char* string) { |
| if (string == NULL) { |
| ALOGW("%s: NULL string passed in", __FUNCTION__); |
| return; |
| } |
| |
| if (mIgnoreBlankLines || (*string)) { |
| // Simple case: Line is not blank, or we don't care about printing blank lines |
| printRaw(string); |
| } else { |
| // Force logcat to print empty lines by adding prefixing with a space |
| printRaw(" "); |
| } |
| } |
| |
| void LogPrinter::printRaw(const char* string) { |
| __android_log_print(mPriority, mLogTag, "%s%s", mPrefix, string); |
| } |
| |
| |
| /* |
| * Implementation of FdPrinter |
| */ |
| FdPrinter::FdPrinter(int fd, unsigned int indent, const char* prefix) : |
| mFd(fd), mIndent(indent), mPrefix(prefix ?: "") { |
| |
| if (fd < 0) { |
| ALOGW("%s: File descriptor out of range (%d)", __FUNCTION__, fd); |
| } |
| |
| // <indent><prefix><line> -- e.g. '%-4s%s\n' for indent=4 |
| snprintf(mFormatString, sizeof(mFormatString), "%%-%us%%s\n", mIndent); |
| } |
| |
| void FdPrinter::printLine(const char* string) { |
| if (string == NULL) { |
| ALOGW("%s: NULL string passed in", __FUNCTION__); |
| return; |
| } else if (mFd < 0) { |
| ALOGW("%s: File descriptor out of range (%d)", __FUNCTION__, mFd); |
| return; |
| } |
| |
| #ifndef USE_MINGW |
| fdprintf(mFd, mFormatString, mPrefix, string); |
| #endif |
| } |
| |
| /* |
| * Implementation of String8Printer |
| */ |
| String8Printer::String8Printer(String8* target, const char* prefix) : |
| mTarget(target), |
| mPrefix(prefix ?: "") { |
| |
| if (target == NULL) { |
| ALOGW("%s: Target string was NULL", __FUNCTION__); |
| } |
| } |
| |
| void String8Printer::printLine(const char* string) { |
| if (string == NULL) { |
| ALOGW("%s: NULL string passed in", __FUNCTION__); |
| return; |
| } else if (mTarget == NULL) { |
| ALOGW("%s: Target string was NULL", __FUNCTION__); |
| return; |
| } |
| |
| mTarget->append(string); |
| mTarget->append("\n"); |
| } |
| |
| /* |
| * Implementation of PrefixPrinter |
| */ |
| PrefixPrinter::PrefixPrinter(Printer& printer, const char* prefix) : |
| mPrinter(printer), mPrefix(prefix ?: "") { |
| } |
| |
| void PrefixPrinter::printLine(const char* string) { |
| mPrinter.printFormatLine("%s%s", mPrefix, string); |
| } |
| |
| }; //namespace android |