All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.android.server.utils.Slogf Maven / Gradle / Ivy

Go to download

A library jar that provides APIs for Applications written for the Google Android Platform.

There is a newer version: 15-robolectric-12650502
Show newest version
/*
 * Copyright (C) 2021 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.
 */

package com.android.server.utils;

import android.annotation.Nullable;
import android.os.Trace;
import android.util.Log;
import android.util.Slog;
import android.util.TimingsTraceLog;

import com.android.internal.annotations.GuardedBy;

import java.util.Formatter;
import java.util.Locale;

/**
 * Extends {@link Slog} by providing overloaded methods that take string formatting.
 *
 * 

Note: the overloaded methods won't create the formatted message if the * respective logging level is disabled for the tag, but the compiler will still create an * intermediate array of the objects for the {@code vargars}, which could affect garbage collection. * So, if you're calling these method in a critical path, make sure to explicitly check for the * level before calling them. */ public final class Slogf { @GuardedBy("sMessageBuilder") private static final StringBuilder sMessageBuilder; @GuardedBy("sMessageBuilder") private static final Formatter sFormatter; static { TimingsTraceLog t = new TimingsTraceLog("SLog", Trace.TRACE_TAG_SYSTEM_SERVER); t.traceBegin("static_init"); sMessageBuilder = new StringBuilder(); sFormatter = new Formatter(sMessageBuilder, Locale.ENGLISH); t.traceEnd(); } private Slogf() { throw new UnsupportedOperationException("provides only static methods"); } /** Same as {@link Log#isLoggable(String, int)}. */ public static boolean isLoggable(String tag, int level) { return Log.isLoggable(tag, level); } /** Same as {@link Slog#v(String, String)}. */ public static int v(String tag, String msg) { return Slog.v(tag, msg); } /** Same as {@link Slog#v(String, String, Throwable)}. */ public static int v(String tag, String msg, Throwable tr) { return Slog.v(tag, msg, tr); } /** Same as {@link Slog#d(String, String)}. */ public static int d(String tag, String msg) { return Slog.d(tag, msg); } /** Same as {@link Slog#d(String, String, Throwable)}. */ public static int d(String tag, String msg, Throwable tr) { return Slog.d(tag, msg, tr); } /** Same as {@link Slog#i(String, String)}. */ public static int i(String tag, String msg) { return Slog.i(tag, msg); } /** Same as {@link Slog#i(String, String, Throwable)}. */ public static int i(String tag, String msg, Throwable tr) { return Slog.i(tag, msg, tr); } /** Same as {@link Slog#w(String, String)}. */ public static int w(String tag, String msg) { return Slog.w(tag, msg); } /** Same as {@link Slog#w(String, String, Throwable)}. */ public static int w(String tag, String msg, Throwable tr) { return Slog.w(tag, msg, tr); } /** Same as {@link Slog#w(String, String)}. */ public static int w(String tag, Throwable tr) { return Slog.w(tag, tr); } /** Same as {@link Slog#e(String, String)}. */ public static int e(String tag, String msg) { return Slog.e(tag, msg); } /** Same as {@link Slog#e(String, String, Throwable)}. */ public static int e(String tag, String msg, Throwable tr) { return Slog.e(tag, msg, tr); } /** Same as {@link Slog#wtf(String, String)}. */ public static int wtf(String tag, String msg) { return Slog.wtf(tag, msg); } /** Same as {@link Slog#wtfQuiet(String, String)}. */ public static void wtfQuiet(String tag, String msg) { Slog.wtfQuiet(tag, msg); } /** Same as {@link Slog#wtfStack(String, String). */ public static int wtfStack(String tag, String msg) { return Slog.wtfStack(tag, msg); } /** Same as {@link Slog#wtf(String, Throwable). */ public static int wtf(String tag, Throwable tr) { return Slog.wtf(tag, tr); } /** Same as {@link Slog#wtf(String, String, Throwable)}. */ public static int wtf(String tag, String msg, Throwable tr) { return Slog.wtf(tag, msg, tr); } /** Same as {@link Slog#println(int, String, String)}. */ public static int println(int priority, String tag, String msg) { return Slog.println(priority, tag, msg); } /** * Logs a {@link Log.VERBOSE} message. * *

Note: the message will only be formatted if {@link Log#VERBOSE} logging * is enabled for the given {@code tag}, but the compiler will still create an intermediate * array of the objects for the {@code vargars}, which could affect garbage collection. So, if * you're calling this method in a critical path, make sure to explicitly do the check before * calling it. */ public static void v(String tag, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.VERBOSE)) return; v(tag, getMessage(format, args)); } /** * Logs a {@link Log.DEBUG} message. * *

Note: the message will only be formatted if {@link Log#DEBUG} logging is * enabled for the given {@code tag}, but the compiler will still create an intermediate array * of the objects for the {@code vargars}, which could affect garbage collection. So, if you're * calling this method in a critical path, make sure to explicitly do the check before calling * it. */ public static void d(String tag, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.DEBUG)) return; d(tag, getMessage(format, args)); } /** * Logs a {@link Log.INFO} message. * *

Note: the message will only be formatted if {@link Log#INFO} logging is * enabled for the given {@code tag}, but the compiler will still create an intermediate array * of the objects for the {@code vargars}, which could affect garbage collection. So, if you're * calling this method in a critical path, make sure to explicitly do the check before calling * it. */ public static void i(String tag, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.INFO)) return; i(tag, getMessage(format, args)); } /** * Logs a {@link Log.WARN} message. * *

Note: the message will only be formatted if {@link Log#WARN} logging is * enabled for the given {@code tag}, but the compiler will still create an intermediate array * of the objects for the {@code vargars}, which could affect garbage collection. So, if you're * calling this method in a critical path, make sure to explicitly do the check before calling * it. */ public static void w(String tag, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.WARN)) return; w(tag, getMessage(format, args)); } /** * Logs a {@link Log.WARN} message with an exception * *

Note: the message will only be formatted if {@link Log#WARN} logging is * enabled for the given {@code tag}, but the compiler will still create an intermediate array * of the objects for the {@code vargars}, which could affect garbage collection. So, if you're * calling this method in a critical path, make sure to explicitly do the check before calling * it. */ public static void w(String tag, Exception exception, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.WARN)) return; w(tag, getMessage(format, args), exception); } /** * Logs a {@link Log.ERROR} message. * *

Note: the message will only be formatted if {@link Log#ERROR} logging is * enabled for the given {@code tag}, but the compiler will still create an intermediate array * of the objects for the {@code vargars}, which could affect garbage collection. So, if you're * calling this method in a critical path, make sure to explicitly do the check before calling * it. */ public static void e(String tag, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.ERROR)) return; e(tag, getMessage(format, args)); } /** * Logs a {@link Log.ERROR} message with an exception * *

Note: the message will only be formatted if {@link Log#ERROR} logging is * enabled for the given {@code tag}, but the compiler will still create an intermediate array * of the objects for the {@code vargars}, which could affect garbage collection. So, if you're * calling this method in a critical path, make sure to explicitly do the check before calling * it. */ public static void e(String tag, Exception exception, String format, @Nullable Object... args) { if (!isLoggable(tag, Log.ERROR)) return; e(tag, getMessage(format, args), exception); } /** * Logs a {@code wtf} message. */ public static void wtf(String tag, String format, @Nullable Object... args) { wtf(tag, getMessage(format, args)); } /** * Logs a {@code wtf} message with an exception. */ public static void wtf(String tag, Exception exception, String format, @Nullable Object... args) { wtf(tag, getMessage(format, args), exception); } private static String getMessage(String format, @Nullable Object... args) { synchronized (sMessageBuilder) { sFormatter.format(format, args); String message = sMessageBuilder.toString(); sMessageBuilder.setLength(0); return message; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy