aboutsummaryrefslogtreecommitdiff
path: root/libraries/launcher/org/prismlauncher/utils/logging/Log.java
blob: e3aa538b26f195a6f8e3db6ff19a402da5d4c2b6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// SPDX-License-Identifier: GPL-3.0-only
/*
 *  Prism Launcher - Minecraft Launcher
 *  Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
 *
 *  This program is free software: you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation, version 3.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  Linking this library statically or dynamically with other modules is
 *  making a combined work based on this library. Thus, the terms and
 *  conditions of the GNU General Public License cover the whole
 *  combination.
 *
 *  As a special exception, the copyright holders of this library give
 *  you permission to link this library with independent modules to
 *  produce an executable, regardless of the license terms of these
 *  independent modules, and to copy and distribute the resulting
 *  executable under terms of your choice, provided that you also meet,
 *  for each linked independent module, the terms and conditions of the
 *  license of that module. An independent module is a module which is
 *  not derived from or based on this library. If you modify this
 *  library, you may extend this exception to your version of the
 *  library, but you are not obliged to do so. If you do not wish to do
 *  so, delete this exception statement from your version.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program.  If not, see <https://www.gnu.org/licenses/>.
 */

package org.prismlauncher.utils.logging;

import java.io.PrintStream;

/**
 * Used to print messages with different levels used to colourise the output.
 * Used instead of a logging framework, as the launcher knows how to parse these
 * messages.
 */
public final class Log {

    // original before possibly overridden by MC
	private static final PrintStream OUT = new PrintStream(System.out), ERR = new PrintStream(System.err);
    private static final boolean DEBUG = Boolean.getBoolean("org.prismlauncher.debug");

    public static void launcher(String message) {
        log(message, Level.LAUNCHER);
    }

    public static void error(String message) {
        log(message, Level.ERROR);
    }

    public static void debug(String message) {
        log(message, Level.DEBUG);
    }

    public static void warning(String message) {
        log(message, Level.WARNING);
    }

    public static void error(String message, Throwable e) {
        error(message);
        e.printStackTrace(ERR);
    }

    public static void fatal(String message) {
        log(message, Level.FATAL);
    }

    public static void fatal(String message, Throwable e) {
        fatal(message);
        e.printStackTrace(ERR);
    }

    /**
     * Logs a message with the prefix <code>!![LEVEL]!</code>. This is picked up by
     * the log viewer to give it nice colours.
     *
     * @param message The message
     * @param level   The level
     */
    public static void log(String message, Level level) {
        if (!DEBUG && level == Level.DEBUG)
            return;

        String prefix = "!![" + level.name + "]!";
        // prefix first line
        message = prefix + message;
        // prefix subsequent lines
        message = message.replace("\n", "\n" + prefix);

        if (level.stderr)
            ERR.println(message);
        else
            OUT.println(message);
    }

}