1*90c8c64dSAndroid Build Coastguard Worker /* 2*90c8c64dSAndroid Build Coastguard Worker * Copyright (C) 2012 The Android Open Source Project 3*90c8c64dSAndroid Build Coastguard Worker * 4*90c8c64dSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*90c8c64dSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*90c8c64dSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*90c8c64dSAndroid Build Coastguard Worker * 8*90c8c64dSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*90c8c64dSAndroid Build Coastguard Worker * 10*90c8c64dSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*90c8c64dSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*90c8c64dSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*90c8c64dSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*90c8c64dSAndroid Build Coastguard Worker * limitations under the License. 15*90c8c64dSAndroid Build Coastguard Worker */ 16*90c8c64dSAndroid Build Coastguard Worker package com.example.android.common.logger; 17*90c8c64dSAndroid Build Coastguard Worker 18*90c8c64dSAndroid Build Coastguard Worker import android.util.Log; 19*90c8c64dSAndroid Build Coastguard Worker 20*90c8c64dSAndroid Build Coastguard Worker /** 21*90c8c64dSAndroid Build Coastguard Worker * Helper class which wraps Android's native Log utility in the Logger interface. This way 22*90c8c64dSAndroid Build Coastguard Worker * normal DDMS output can be one of the many targets receiving and outputting logs simultaneously. 23*90c8c64dSAndroid Build Coastguard Worker */ 24*90c8c64dSAndroid Build Coastguard Worker public class LogWrapper implements LogNode { 25*90c8c64dSAndroid Build Coastguard Worker 26*90c8c64dSAndroid Build Coastguard Worker // For piping: The next node to receive Log data after this one has done its work. 27*90c8c64dSAndroid Build Coastguard Worker private LogNode mNext; 28*90c8c64dSAndroid Build Coastguard Worker 29*90c8c64dSAndroid Build Coastguard Worker /** 30*90c8c64dSAndroid Build Coastguard Worker * Returns the next LogNode in the linked list. 31*90c8c64dSAndroid Build Coastguard Worker */ getNext()32*90c8c64dSAndroid Build Coastguard Worker public LogNode getNext() { 33*90c8c64dSAndroid Build Coastguard Worker return mNext; 34*90c8c64dSAndroid Build Coastguard Worker } 35*90c8c64dSAndroid Build Coastguard Worker 36*90c8c64dSAndroid Build Coastguard Worker /** 37*90c8c64dSAndroid Build Coastguard Worker * Sets the LogNode data will be sent to.. 38*90c8c64dSAndroid Build Coastguard Worker */ setNext(LogNode node)39*90c8c64dSAndroid Build Coastguard Worker public void setNext(LogNode node) { 40*90c8c64dSAndroid Build Coastguard Worker mNext = node; 41*90c8c64dSAndroid Build Coastguard Worker } 42*90c8c64dSAndroid Build Coastguard Worker 43*90c8c64dSAndroid Build Coastguard Worker /** 44*90c8c64dSAndroid Build Coastguard Worker * Prints data out to the console using Android's native log mechanism. 45*90c8c64dSAndroid Build Coastguard Worker * @param priority Log level of the data being logged. Verbose, Error, etc. 46*90c8c64dSAndroid Build Coastguard Worker * @param tag Tag for for the log data. Can be used to organize log statements. 47*90c8c64dSAndroid Build Coastguard Worker * @param msg The actual message to be logged. The actual message to be logged. 48*90c8c64dSAndroid Build Coastguard Worker * @param tr If an exception was thrown, this can be sent along for the logging facilities 49*90c8c64dSAndroid Build Coastguard Worker * to extract and print useful information. 50*90c8c64dSAndroid Build Coastguard Worker */ 51*90c8c64dSAndroid Build Coastguard Worker @Override println(int priority, String tag, String msg, Throwable tr)52*90c8c64dSAndroid Build Coastguard Worker public void println(int priority, String tag, String msg, Throwable tr) { 53*90c8c64dSAndroid Build Coastguard Worker // There actually are log methods that don't take a msg parameter. For now, 54*90c8c64dSAndroid Build Coastguard Worker // if that's the case, just convert null to the empty string and move on. 55*90c8c64dSAndroid Build Coastguard Worker String useMsg = msg; 56*90c8c64dSAndroid Build Coastguard Worker if (useMsg == null) { 57*90c8c64dSAndroid Build Coastguard Worker useMsg = ""; 58*90c8c64dSAndroid Build Coastguard Worker } 59*90c8c64dSAndroid Build Coastguard Worker 60*90c8c64dSAndroid Build Coastguard Worker // If an exeption was provided, convert that exception to a usable string and attach 61*90c8c64dSAndroid Build Coastguard Worker // it to the end of the msg method. 62*90c8c64dSAndroid Build Coastguard Worker if (tr != null) { 63*90c8c64dSAndroid Build Coastguard Worker msg += "\n" + Log.getStackTraceString(tr); 64*90c8c64dSAndroid Build Coastguard Worker } 65*90c8c64dSAndroid Build Coastguard Worker 66*90c8c64dSAndroid Build Coastguard Worker // This is functionally identical to Log.x(tag, useMsg); 67*90c8c64dSAndroid Build Coastguard Worker // For instance, if priority were Log.VERBOSE, this would be the same as Log.v(tag, useMsg) 68*90c8c64dSAndroid Build Coastguard Worker Log.println(priority, tag, useMsg); 69*90c8c64dSAndroid Build Coastguard Worker 70*90c8c64dSAndroid Build Coastguard Worker // If this isn't the last node in the chain, move things along. 71*90c8c64dSAndroid Build Coastguard Worker if (mNext != null) { 72*90c8c64dSAndroid Build Coastguard Worker mNext.println(priority, tag, msg, tr); 73*90c8c64dSAndroid Build Coastguard Worker } 74*90c8c64dSAndroid Build Coastguard Worker } 75*90c8c64dSAndroid Build Coastguard Worker } 76