Umleiten des SLF4J-Protokolls an TextArea in JavaFX
Ich möchte Fehler anzeigen, die von SLF4J in @ protokolliert wurdTextArea
in JavaFX. Was ich bisher habe, ist einappender
im logback-test.xml:
<appender name="err" class="logtest.AppTA">
<filter class="logtest.ErrFilter" />
<encoder>
<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
</encoder>
</appender>
TextArea
bereit, Stream zu empfangen:
public class Output extends OutputStream{
private final TextArea ta;
public Output(TextArea ta) {
this.ta = ta;
}
@Override
public void write(int b) throws IOException {
if (ta!=null) {
ta.appendText(String.valueOf((char) b));
}
}
}
und eine Klasse, die angehängt werden soll:
public class AppTA extends AppenderBase<ILoggingEvent> {
PatternLayoutEncoder encoder;
OutputStream os;
@Override
protected void append(ILoggingEvent event) {
try {
if (isEncoderInitialized) {
this.encoder.doEncode(event);
}
} catch (IOException e) {
}
}
@Override
public void start() {
if (this.encoder == null) {
addError("No encoder set for the appender named [" + name + "].");
return;
}
try {
encoder.init(os);
} catch (IOException ex) {
Logger.getLogger(AppTA.class.getName()).log(Level.SEVERE, null, ex);
}
super.start();
}
public PatternLayoutEncoder getEncoder() {
return encoder;
}
public void setEncoder(PatternLayoutEncoder encoder) {
this.encoder = encoder;
}
}
Nun, das Problem, das ich habe, ist, dass meinTextArea
ist in der Controller-Klasse und ich weiß nicht, wie ich sie miteinander verknüpfen soll. Vor allem, wenn SLF4J @ erstelAppTA
Instanz für sich allein - Ich kann mein @ nicht wirklich übergebTextArea
zuAppTA
Wird vom Logger verwendet.
Wie kann ich das angehen?