nashorn/src/jdk/nashorn/internal/runtime/DebugLogger.java
author sundar
Mon, 11 Feb 2013 21:26:06 +0530
changeset 16226 0e4f37e6cc40
parent 16201 889ddb179cdf
child 16233 95d3e01c04c3
permissions -rw-r--r--
8007915: Nashorn IR, codegen, parser packages and Context instance should be inaccessible to user code Reviewed-by: lagergren, jlaskey, attila
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     1
/*
16151
97c1e756ae1e 8005663: Update copyright year to 2013
jlaskey
parents: 16147
diff changeset
     2
 * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     4
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    10
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    15
 * accompanied this code).
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    16
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    20
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    23
 * questions.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    24
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    25
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    26
package jdk.nashorn.internal.runtime;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    27
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    28
import java.io.PrintWriter;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    29
import java.util.logging.Level;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    30
import java.util.logging.Logger;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    31
import jdk.nashorn.internal.runtime.options.Options;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    32
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    33
/**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    34
 * Wrapper class for Logging system. This is how you are supposed to register a logger and use it
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    35
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    36
16226
0e4f37e6cc40 8007915: Nashorn IR, codegen, parser packages and Context instance should be inaccessible to user code
sundar
parents: 16201
diff changeset
    37
public final class DebugLogger {
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    38
    @SuppressWarnings("NonConstantLogger")
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    39
    private final Logger  logger;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    40
    private final boolean isEnabled;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    41
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    42
    private int indent;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    43
16201
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
    44
    private static final int INDENT_SPACE = 4;
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
    45
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    46
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    47
     * Constructor
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    48
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    49
     * @param loggerName name of logger - this is the unique key with which it can be identified
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    50
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    51
    public DebugLogger(final String loggerName) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    52
        this(loggerName, null);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    53
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    54
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    55
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    56
     * Constructor
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    57
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    58
     * A logger can be paired with a property, e.g. {@code --log:codegen:info} is equivalent to {@code -Dnashorn.codegen.log}
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    59
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    60
     * @param loggerName name of logger - this is the unique key with which it can be identified
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    61
     * @param property   system property activating the logger on {@code info} level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    62
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    63
    public DebugLogger(final String loggerName, final String property) {
16155
a8ab83cbaa49 8005788: Loggers and their corresponding system properties not working correctly
lagergren
parents: 16151
diff changeset
    64
        if (property != null && Options.getBooleanProperty(property)) {
a8ab83cbaa49 8005788: Loggers and their corresponding system properties not working correctly
lagergren
parents: 16151
diff changeset
    65
            this.logger = Logging.getOrCreateLogger(loggerName, Level.INFO);
a8ab83cbaa49 8005788: Loggers and their corresponding system properties not working correctly
lagergren
parents: 16151
diff changeset
    66
        } else {
a8ab83cbaa49 8005788: Loggers and their corresponding system properties not working correctly
lagergren
parents: 16151
diff changeset
    67
            this.logger = Logging.getLogger(loggerName);
a8ab83cbaa49 8005788: Loggers and their corresponding system properties not working correctly
lagergren
parents: 16151
diff changeset
    68
        }
a8ab83cbaa49 8005788: Loggers and their corresponding system properties not working correctly
lagergren
parents: 16151
diff changeset
    69
        this.isEnabled = logger.getLevel() != Level.OFF;
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    70
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    71
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    72
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    73
     * Get the output writer for the logger. Loggers always default to
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    74
     * stderr for output as they are used mainly to output debug info
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    75
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    76
     * @return print writer for log output.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    77
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    78
    public PrintWriter getOutputStream() {
16185
893aabe8c800 8006635: Reduce access levels as much as possible
sundar
parents: 16155
diff changeset
    79
        return Context.getCurrentErr();
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    80
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    81
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    82
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    83
     * Check if the logger is enabled
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    84
     * @return true if enabled
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    85
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    86
    public boolean isEnabled() {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    87
        return isEnabled;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    88
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    89
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    90
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    91
     * If you want to change the indent level of your logger, call indent with a new position.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    92
     * Positions start at 0 and are increased by one for a new "tab"
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    93
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    94
     * @param pos indent position
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    95
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    96
    public void indent(final int pos) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    97
        if (isEnabled) {
16201
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
    98
           indent += pos * INDENT_SPACE;
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
    99
        }
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   100
    }
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   101
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   102
    /**
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   103
     * Add an indent position
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   104
     */
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   105
    public void indent() {
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   106
        indent += INDENT_SPACE;
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   107
    }
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   108
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   109
    /**
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   110
     * Unindent a position
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   111
     */
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   112
    public void unindent() {
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   113
        indent -= INDENT_SPACE;
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   114
        if (indent < 0) {
889ddb179cdf 8007062: Split Lower up into Lower/Attr/FinalizeTypes. Integrate AccessSpecalizer into FinalizeTypes.
lagergren
parents: 16185
diff changeset
   115
            indent = 0;
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   116
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   117
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   118
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   119
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   120
     * Check if the logger is above of the level of detail given
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   121
     * @see java.util.logging.Level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   122
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   123
     * @param level logging level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   124
     * @return true if level is above the given one
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   125
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   126
    public boolean levelAbove(final Level level) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   127
        return logger.getLevel().intValue() > level.intValue();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   128
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   129
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   130
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   131
     * Shorthand for outputting a log string as log level {@link java.util.logging.Level#FINEST} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   132
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   133
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   134
    public void finest(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   135
        log(str, Level.FINEST);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   136
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   137
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   138
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   139
     * Shorthand for outputting a log string as log level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   140
     * {@link java.util.logging.Level#FINER} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   141
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   142
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   143
    public void finer(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   144
        log(str, Level.FINER);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   145
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   146
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   147
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   148
     * Shorthand for outputting a log string as log level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   149
     * {@link java.util.logging.Level#FINE} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   150
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   151
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   152
    public void fine(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   153
        log(str, Level.FINE);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   154
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   155
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   156
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   157
     * Shorthand for outputting a log string as log level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   158
     * {@link java.util.logging.Level#CONFIG} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   159
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   160
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   161
    public void config(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   162
        log(str, Level.CONFIG);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   163
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   164
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   165
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   166
     * Shorthand for outputting a log string as log level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   167
     * {@link java.util.logging.Level#INFO} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   168
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   169
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   170
    public void info(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   171
        log(str, Level.INFO);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   172
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   173
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   174
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   175
     * Shorthand for outputting a log string as log level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   176
     * {@link java.util.logging.Level#WARNING} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   177
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   178
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   179
    public void warning(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   180
        log(str, Level.WARNING);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   181
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   182
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   183
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   184
     * Shorthand for outputting a log string as log level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   185
     * {@link java.util.logging.Level#SEVERE} on this logger
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   186
     * @param str the string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   187
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   188
    public void severe(final String str) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   189
        log(str, Level.SEVERE);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   190
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   191
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   192
    /**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   193
     * Output log line on this logger at a given level of verbosity
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   194
     * @see java.util.logging.Level
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   195
     *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   196
     * @param str   string to log
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   197
     * @param level minimum log level required for logging to take place
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   198
     */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   199
    public void log(final String str, final Level level) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   200
        if (isEnabled) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   201
            final StringBuilder sb = new StringBuilder();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   202
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   203
            for (int i = 0 ; i < indent ; i++) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   204
                sb.append(' ');
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   205
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   206
            sb.append(str);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   207
            logger.log(level, sb.toString());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   208
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   209
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   210
}