18103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn/*
28103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * Copyright (C) 2012 The Android Open Source Project
38103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn *
48103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * Licensed under the Apache License, Version 2.0 (the "License");
58103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * you may not use this file except in compliance with the License.
68103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * You may obtain a copy of the License at
78103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn *
88103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn *      http://www.apache.org/licenses/LICENSE-2.0
98103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn *
108103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * Unless required by applicable law or agreed to in writing, software
118103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * distributed under the License is distributed on an "AS IS" BASIS,
128103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
138103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * See the License for the specific language governing permissions and
148103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * limitations under the License.
158103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn */
168103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
178103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackbornpackage com.android.internal.util;
188103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
198103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackbornimport java.io.PrintWriter;
208103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackbornimport java.util.ArrayList;
218103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
228103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackbornimport android.util.Slog;
238103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
248103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn/**
258103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * Helper class for logging serious issues, which also keeps a small
268103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * snapshot of the logged events that can be printed later, such as part
278103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * of a system service's dumpsys output.
288103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn * @hide
298103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn */
308103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackbornpublic class LocalLog {
318103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    private final String mTag;
328103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    private final int mMaxLines = 20;
338103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    private final ArrayList<String> mLines = new ArrayList<String>(mMaxLines);
348103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
358103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    public LocalLog(String tag) {
368103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn        mTag = tag;
378103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    }
388103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
398103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    public void w(String msg) {
408103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn        synchronized (mLines) {
418103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            Slog.w(mTag, msg);
428103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            if (mLines.size() >= mMaxLines) {
438103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                mLines.remove(0);
448103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            }
458103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            mLines.add(msg);
468103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn        }
478103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    }
488103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn
498103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    public boolean dump(PrintWriter pw, String header, String prefix) {
508103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn        synchronized (mLines) {
518103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            if (mLines.size() <= 0) {
528103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                return false;
538103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            }
548103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            if (header != null) {
558103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                pw.println(header);
568103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            }
578103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            for (int i=0; i<mLines.size(); i++) {
588103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                if (prefix != null) {
598103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                    pw.print(prefix);
608103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                }
618103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn                pw.println(mLines.get(i));
628103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            }
638103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn            return true;
648103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn        }
658103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn    }
668103890a59de6ed4abaedaad80e66666ea59f9b5Dianne Hackborn}
67