73 lines
2.3 KiB
Java
73 lines
2.3 KiB
Java
/*
|
|
Copyright 2019-2022 Dmitry Isaenko
|
|
|
|
This file is part of Konogonka.
|
|
|
|
Konogonka 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, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
Konogonka 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.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with Konogonka. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
package konogonka.ModelControllers;
|
|
|
|
import java.util.concurrent.BlockingQueue;
|
|
import java.util.concurrent.LinkedBlockingQueue;
|
|
|
|
public class LogPrinter {
|
|
private MessagesConsumer msgConsumer;
|
|
private BlockingQueue<String> msgQueue;
|
|
private BlockingQueue<Double> progressQueue;
|
|
|
|
public LogPrinter(){
|
|
this.msgQueue = new LinkedBlockingQueue<>();
|
|
this.progressQueue = new LinkedBlockingQueue<>();
|
|
this.msgConsumer = new MessagesConsumer(this.msgQueue, this.progressQueue);
|
|
this.msgConsumer.start();
|
|
}
|
|
/**
|
|
* This is what will print to textArea of the application.
|
|
* */
|
|
public void print(String message, EMsgType type){
|
|
try {
|
|
switch (type){
|
|
case PASS:
|
|
msgQueue.put("[ PASS ] "+message+"\n");
|
|
break;
|
|
case FAIL:
|
|
msgQueue.put("[ FAIL ] "+message+"\n");
|
|
break;
|
|
case INFO:
|
|
msgQueue.put("[ INFO ] "+message+"\n");
|
|
break;
|
|
case WARNING:
|
|
msgQueue.put("[ WARN ] "+message+"\n");
|
|
break;
|
|
default:
|
|
msgQueue.put(message);
|
|
}
|
|
}catch (InterruptedException ie){
|
|
ie.printStackTrace();
|
|
}
|
|
}
|
|
/**
|
|
* Update progress for progress bar
|
|
* */
|
|
public void updateProgress(Double value) throws InterruptedException{
|
|
progressQueue.put(value);
|
|
}
|
|
/**
|
|
* When we're done - close it
|
|
* */
|
|
public void close(){
|
|
msgConsumer.interrupt();
|
|
}
|
|
}
|