[logback-dev] [JIRA] (LOGBACK-1392) Improve support for the JANSI library in ConsoleAppender
QOS.CH (JIRA)
noreply-jira at qos.ch
Sat Mar 24 13:00:00 CET 2018
Alexandre Dutra created LOGBACK-1392:
----------------------------------------
Summary: Improve support for the JANSI library in ConsoleAppender
Key: LOGBACK-1392
URL: https://jira.qos.ch/browse/LOGBACK-1392
Project: logback
Issue Type: Improvement
Components: logback-core
Affects Versions: 1.2.3
Reporter: Alexandre Dutra
Assignee: Logback dev list
Priority: Minor
The JANSI library provides an {{AnsiPrintStream}} that intercepts ANSI sequences and allows the application to react to them accordingly. Jansi is compatible with a variety of terminals, including xterm-like terminals for Windows like Mintty and MinGW.
Jansi has a good algorithm to detect whether or not ANSI sequences will be correctly interpreted or not, and if not, its default behavior is to filter out such sequences.
Logback's {{ConsoleAppender}} has a {{withJansi}} option. Unfortunately, Logback bypasses Jansi's detection algorithm and boldly assumes that if the OS is Windows, then the terminal is a DOS prompt. So while DOS prompts get colored, terminals like Mintty or MinGW not only lose their coloring but are sent DOS escape sequences that they can't interpret.
We could improve support for JANSI with the following ideas:
* Amend {{ConsoleAppender}} so that when {{withJansi}} is {{true}}, then all {{OutputStream}}s are wrapped in an {{AnsiPrintStream}}, effectively delegating to the JANSI library the decision to filter out ANSI escape sequences or not, depending on the terminal capability. This also allows users to disable or customize the coloring behavior by using system properties recognized by JANSI, such as {{jansi.skip}}.
* Amend the documentation and stress that the JANSI library is the recommended solution for Windows systems, as well as for cross-platform deployments that include a mix of Windows and non-Windows systems.
--
This message was sent by Atlassian JIRA
(v7.3.1#73012)
More information about the logback-dev
mailing list