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

com.google.common.flogger.StackSize Maven / Gradle / Ivy

There is a newer version: 2.0.32
Show newest version
/*
 * Copyright (C) 2016 The Flogger Authors.
 *
 * 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.google.common.flogger;

/**
 * Enum values to be passed into {@link GoogleLoggingApi#withStackTrace} to control the maximum
 * number of stack trace elements created.
 *
 * 

Note that the precise value returned by {@link #getMaxDepth()} may change over time, but it * can be assumed that {@code SMALL <= MEDIUM <= LARGE <= FULL}. */ public enum StackSize { /** * Produces a small stack suitable for more fine grained debugging. For performance reasons, this * is the only stack size suitable for log statements at level {@code INFO} or finer, but is may * also be useful for {@code WARNING} level log statements in cases where context is not as * important. For {@code SEVERE} log statements, it is advised to use a stack size of * {@link #MEDIUM} or above. *

* Requesting a small stack trace for log statements which occur under normal circumstances is * acceptable, but may affect performance. Consider using * {@link GoogleLoggingApi#withStackTrace(StackSize)} in conjunction with rate limiting methods, * such as {@link LoggingApi#atMostEvery(int, TimeUnit)}, to mitigate performance issues. *

* The current maximum size of a {@code SMALL} stack trace is 10 elements, but this may change. */ SMALL(10), /** * Produces a medium sized stack suitable for providing contextual information for most log * statements at {@code WARNING} or above. There should be enough stack trace elements in a * {@code MEDIUM} stack to provide sufficient debugging context in most cases. *

* Requesting a medium stack trace for any log statements which can occur regularly under normal * circumstances is not recommended. *

* The current maximum size of a {@code MEDIUM} stack trace is 20 elements, but this may change. */ MEDIUM(20), /** * Produces a large stack suitable for providing highly detailed contextual information. * This is most useful for {@code SEVERE} log statements which might be processed by external * tools and subject to automated analysis. *

* Requesting a large stack trace for any log statement which can occur under normal circumstances * is not recommended. *

* The current maximum size of a {@code LARGE} stack trace is 50 elements, but this may change. */ LARGE(50), /** * Provides the complete stack trace. This is included for situations in which it is known that * the upper-most elements of the stack are definitely required for analysis. *

* Requesting a full stack trace for any log statement which can occur under normal circumstances * is not recommended. */ FULL(-1), /** * Provides no stack trace, making the {@code withStackTrace()} method an effective no-op. This is * useful when your stack size is conditional. For example: *

 {@code
   *   logger.atWarning()
   *       .withStackTrace(showTrace ? StackSize.MEDIUM : StackSize.NONE)
   *       .log("message");
   * }
*/ NONE(0); private final int maxDepth; StackSize(int value) { this.maxDepth = value; } /** * Returns the maximum stack depth to create when adding contextual stack information to a log * statement. *

* Note that the precise number of stack elements emitted for the enum values might change over * time, but it can be assumed that {@code NONE < SMALL <= MEDIUM <= LARGE <= FULL}. */ int getMaxDepth() { return maxDepth; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy