WarpPI/desktop/src/main/java/it/cavallium/warppi/desktop/DesktopConsoleUtils.java

119 lines
3.8 KiB
Java

package it.cavallium.warppi.desktop;
import java.io.PrintStream;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import it.cavallium.warppi.StaticVars;
import it.cavallium.warppi.math.MathematicalSymbols;
public class DesktopConsoleUtils implements it.cavallium.warppi.Platform.ConsoleUtils {
private AdvancedOutputStream os;
public DesktopConsoleUtils() {
os = new AdvancedOutputStream() {
private void print(final PrintStream stream, final String str) {
stream.print(fixString(str));
}
private void println(final PrintStream stream, final String str) {
stream.println(fixString(str));
}
private void println(final PrintStream stream) {
stream.println();
}
private String fixString(final String str) {
return str.replace("" + MathematicalSymbols.NTH_ROOT, "root").replace("" + MathematicalSymbols.SQUARE_ROOT, "sqrt").replace("" + MathematicalSymbols.POWER, "powerOf").replace("" + MathematicalSymbols.POWER_OF_TWO, "powerOfTwo").replace("" + MathematicalSymbols.SINE, "sine").replace("" + MathematicalSymbols.COSINE, "cosine").replace("" + MathematicalSymbols.TANGENT, "tangent").replace("" + MathematicalSymbols.ARC_SINE, "asin").replace("" + MathematicalSymbols.ARC_COSINE, "acos").replace("" + MathematicalSymbols.ARC_TANGENT, "atan").replace("" + MathematicalSymbols.UNDEFINED, "undefined").replace("" + MathematicalSymbols.PI, "PI").replace("" + MathematicalSymbols.EULER_NUMBER, "EULER_NUMBER").replace("" + MathematicalSymbols.X, "X").replace("" + MathematicalSymbols.Y, "Y");
}
@Override
public void println(final Object str) {
println(0, str);
}
@Override
public void println(final int level) {
if (StaticVars.outputLevel >= level)
if (StaticVars.outputLevel == 0)
println(System.out);
else
println(System.out);
}
@Override
public void println(final int level, final Object str) {
if (StaticVars.outputLevel >= level) {
final String time = getTimeString();
if (StaticVars.outputLevel == 0)
println(System.out, "[" + time + "]" + str);
else
println(System.out, "[" + time + "]" + str);
}
}
@Override
public void print(final int level, final String str) {
if (StaticVars.outputLevel >= level)
if (StaticVars.outputLevel == 0)
print(System.out, str);
else
print(System.out, str);
}
@Override
public void println(final int level, final String prefix, final String str) {
if (StaticVars.outputLevel >= level) {
final String time = getTimeString();
if (StaticVars.outputLevel == 0)
println(System.out, "[" + time + "][" + prefix + "]" + str);
else
println(System.out, "[" + time + "][" + prefix + "]" + str);
}
}
@Override
public void println(final int level, final String... parts) {
if (StaticVars.outputLevel >= level) {
final String time = getTimeString();
final StringBuilder output = new StringBuilder();
for (int i = 0; i < parts.length; i++)
if (i + 1 == parts.length) {
output.append(' ');
output.append(parts[i]);
} else {
output.append('[');
output.append(parts[i]);
output.append(']');
}
output.insert(0, '[');
output.insert(1, time);
output.insert(time.length() + 1, ']');
if (StaticVars.outputLevel == 0)
println(System.out, output.toString());
else
println(System.out, output.toString());
}
}
private String getTimeString() {
return LocalDateTime.now().format(DateTimeFormatter.ofPattern("HH:mm:ss.SSS"));
}
};
}
@Override
public AdvancedOutputStream out() {
return os;
}
@Override
public int getOutputLevel() {
return StaticVars.outputLevel;
}
}