/*
* 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