Code cleanup, startup bugfixes and method result caching
This commit is contained in:
parent
094b2df460
commit
35fc49768c
BIN
math-rules-cache.zip618
Normal file
BIN
math-rules-cache.zip618
Normal file
Binary file not shown.
BIN
math-rules-cache.zip648
Normal file
BIN
math-rules-cache.zip648
Normal file
Binary file not shown.
BIN
math-rules-cache.zip72
Normal file
BIN
math-rules-cache.zip72
Normal file
Binary file not shown.
BIN
math-rules-cache.zip868
Normal file
BIN
math-rules-cache.zip868
Normal file
Binary file not shown.
150
pom.xml
150
pom.xml
@ -14,14 +14,16 @@
|
|||||||
<src.dir>src/main/java</src.dir>
|
<src.dir>src/main/java</src.dir>
|
||||||
<src.dir2>src/main/java</src.dir2>
|
<src.dir2>src/main/java</src.dir2>
|
||||||
<src.resdir>src/main/resources</src.resdir>
|
<src.resdir>src/main/resources</src.resdir>
|
||||||
<buildprops.exclude1>veryverylongandparticularpath/abcd</buildprops.exclude1>
|
<buildprops.exclude1>veryverylongandparticularpath/abcd</buildprops.exclude1>
|
||||||
</properties>
|
</properties>
|
||||||
<repositories>
|
<repositories>
|
||||||
<repository>
|
<repository>
|
||||||
<id>teavm-dev</id>
|
<id>teavm-dev</id>
|
||||||
<url>https://dl.bintray.com/konsoletyper/teavm</url>
|
<url>https://dl.bintray.com/konsoletyper/teavm</url>
|
||||||
<snapshots> <enabled>true</enabled> </snapshots>
|
<snapshots>
|
||||||
<layout>default</layout>
|
<enabled>true</enabled>
|
||||||
|
</snapshots>
|
||||||
|
<layout>default</layout>
|
||||||
</repository>
|
</repository>
|
||||||
<repository>
|
<repository>
|
||||||
<id>oss-snapshots-repo</id>
|
<id>oss-snapshots-repo</id>
|
||||||
@ -32,43 +34,42 @@
|
|||||||
<updatePolicy>always</updatePolicy>
|
<updatePolicy>always</updatePolicy>
|
||||||
</snapshots>
|
</snapshots>
|
||||||
</repository>
|
</repository>
|
||||||
<repository>
|
<repository>
|
||||||
<id>jitpack.io</id> <!-- JitPack allows github repo to be used as a maven repo -->
|
<id>jitpack.io</id> <!-- JitPack allows github repo to be used as a maven repo -->
|
||||||
<url>https://jitpack.io</url> <!-- For documentation: http://jitpack.io/ -->
|
<url>https://jitpack.io</url> <!-- For documentation: http://jitpack.io/ -->
|
||||||
</repository>
|
</repository>
|
||||||
</repositories>
|
</repositories>
|
||||||
<pluginRepositories>
|
<pluginRepositories>
|
||||||
<pluginRepository>
|
<pluginRepository>
|
||||||
<id>1_teavm-dev</id>
|
<id>1_teavm-dev</id>
|
||||||
<url>https://dl.bintray.com/konsoletyper/teavm</url>
|
<url>https://dl.bintray.com/konsoletyper/teavm</url>
|
||||||
<snapshots> <enabled>true</enabled> </snapshots>
|
<snapshots>
|
||||||
<layout>default</layout>
|
<enabled>true</enabled>
|
||||||
</pluginRepository>
|
</snapshots>
|
||||||
|
<layout>default</layout>
|
||||||
|
</pluginRepository>
|
||||||
</pluginRepositories>
|
</pluginRepositories>
|
||||||
<profiles>
|
<profiles>
|
||||||
<profile>
|
<profile>
|
||||||
<id>aarch64</id>
|
<id>aarch64</id>
|
||||||
<activation>
|
<activation>
|
||||||
<!--<os>
|
<!--<os> <family>Linux</family> <arch>aarch64</arch> </os> -->
|
||||||
<family>Linux</family>
|
<activeByDefault>false</activeByDefault>
|
||||||
<arch>aarch64</arch>
|
</activation>
|
||||||
</os>-->
|
<properties>
|
||||||
<activeByDefault>false</activeByDefault>
|
<buildprops.exclude1>org/warp/picalculator/gui/graphicengine/gpu/*</buildprops.exclude1>
|
||||||
</activation>
|
</properties>
|
||||||
<properties>
|
</profile>
|
||||||
<buildprops.exclude1>org/warp/picalculator/gui/graphicengine/gpu/*</buildprops.exclude1>
|
<profile>
|
||||||
</properties>
|
<id>jarprofile</id>
|
||||||
</profile>
|
<properties>
|
||||||
<profile>
|
<src.dir>jar-specific</src.dir>
|
||||||
<id>jarprofile</id>
|
<src.resdir>src/main/rules</src.resdir>
|
||||||
<properties>
|
</properties>
|
||||||
<src.dir>jar-specific</src.dir>
|
<activation>
|
||||||
<src.resdir>src/main/rules</src.resdir>
|
<activeByDefault>true</activeByDefault>
|
||||||
</properties>
|
</activation>
|
||||||
<activation>
|
<dependencies>
|
||||||
<activeByDefault>true</activeByDefault>
|
|
||||||
</activation>
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.jogamp.jogl</groupId>
|
<groupId>org.jogamp.jogl</groupId>
|
||||||
<artifactId>jogl-all-main</artifactId>
|
<artifactId>jogl-all-main</artifactId>
|
||||||
@ -79,27 +80,27 @@
|
|||||||
<artifactId>gluegen-rt-main</artifactId>
|
<artifactId>gluegen-rt-main</artifactId>
|
||||||
<version>2.3.2</version>
|
<version>2.3.2</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.pi4j</groupId>
|
<groupId>com.pi4j</groupId>
|
||||||
<artifactId>pi4j-core</artifactId>
|
<artifactId>pi4j-core</artifactId>
|
||||||
<version>1.2-SNAPSHOT</version>
|
<version>1.2-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.fusesource.jansi</groupId>
|
<groupId>org.fusesource.jansi</groupId>
|
||||||
<artifactId>jansi</artifactId>
|
<artifactId>jansi</artifactId>
|
||||||
<version>1.15</version>
|
<version>1.15</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>net.lingala.zip4j</groupId>
|
<groupId>net.lingala.zip4j</groupId>
|
||||||
<artifactId>zip4j</artifactId>
|
<artifactId>zip4j</artifactId>
|
||||||
<version>1.3.2</version>
|
<version>1.3.2</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.eclipse.jdt.core.compiler</groupId>
|
<groupId>org.eclipse.jdt.core.compiler</groupId>
|
||||||
<artifactId>ecj</artifactId>
|
<artifactId>ecj</artifactId>
|
||||||
<version>4.6.1</version>
|
<version>4.6.1</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<build>
|
<build>
|
||||||
<plugins>
|
<plugins>
|
||||||
<!-- Set a compiler level -->
|
<!-- Set a compiler level -->
|
||||||
@ -111,19 +112,19 @@
|
|||||||
<source>1.8</source>
|
<source>1.8</source>
|
||||||
<target>1.8</target>
|
<target>1.8</target>
|
||||||
<encoding>UTF-8</encoding>
|
<encoding>UTF-8</encoding>
|
||||||
<excludes>
|
<excludes>
|
||||||
<exclude>${buildprops.exclude1}</exclude>
|
<exclude>${buildprops.exclude1}</exclude>
|
||||||
</excludes>
|
</excludes>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
</profile>
|
</profile>
|
||||||
<profile>
|
<profile>
|
||||||
<id>jsprofile</id>
|
<id>jsprofile</id>
|
||||||
<properties>
|
<properties>
|
||||||
<src.dir>js-specific</src.dir>
|
<src.dir>js-specific</src.dir>
|
||||||
<src.dir2>src/main/rules</src.dir2>
|
<src.dir2>src/main/rules</src.dir2>
|
||||||
</properties>
|
</properties>
|
||||||
<activation>
|
<activation>
|
||||||
<activeByDefault>false</activeByDefault>
|
<activeByDefault>false</activeByDefault>
|
||||||
@ -132,7 +133,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.teavm</groupId>
|
<groupId>org.teavm</groupId>
|
||||||
<artifactId>teavm-classlib</artifactId>
|
<artifactId>teavm-classlib</artifactId>
|
||||||
<version>0.6.0-dev-529</version>
|
<version>0.6.0-dev-559</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<build>
|
<build>
|
||||||
@ -177,7 +178,7 @@
|
|||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.teavm</groupId>
|
<groupId>org.teavm</groupId>
|
||||||
<artifactId>teavm-maven-plugin</artifactId>
|
<artifactId>teavm-maven-plugin</artifactId>
|
||||||
<version>0.6.0-dev-529</version>
|
<version>0.6.0-dev-559</version>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
<goals>
|
<goals>
|
||||||
@ -202,6 +203,12 @@
|
|||||||
<dependencies>
|
<dependencies>
|
||||||
<!--<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId>
|
<!--<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId>
|
||||||
<version>4.12</version> <scope>test</scope> </dependency> -->
|
<version>4.12</version> <scope>test</scope> </dependency> -->
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.infinispan</groupId>
|
||||||
|
<artifactId>infinispan-jcache</artifactId>
|
||||||
|
<version>8.2.4.Final</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>it.unimi.dsi</groupId>
|
<groupId>it.unimi.dsi</groupId>
|
||||||
<artifactId>fastutil</artifactId>
|
<artifactId>fastutil</artifactId>
|
||||||
@ -214,15 +221,12 @@
|
|||||||
</dependency>
|
</dependency>
|
||||||
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
|
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>commons-io</groupId>
|
<groupId>commons-io</groupId>
|
||||||
<artifactId>commons-io</artifactId>
|
<artifactId>commons-io</artifactId>
|
||||||
<version>2.6</version>
|
<version>2.6</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!-- <dependency>
|
<!-- <dependency> <groupId>ar.com.hjg</groupId> <artifactId>pngj</artifactId>
|
||||||
<groupId>ar.com.hjg</groupId>
|
<version>2.1.0</version> </dependency> -->
|
||||||
<artifactId>pngj</artifactId>
|
|
||||||
<version>2.1.0</version>
|
|
||||||
</dependency>-->
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<build>
|
<build>
|
||||||
<resources>
|
<resources>
|
||||||
|
@ -27,7 +27,7 @@ import java.util.stream.Stream;
|
|||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.warp.picalculator.ClassUtils;
|
import org.warp.picalculator.ClassUtils;
|
||||||
import org.warp.picalculator.Main;
|
import org.warp.picalculator.boot.Main;
|
||||||
|
|
||||||
public class StorageUtils {
|
public class StorageUtils {
|
||||||
public static final boolean exists(Path f) {
|
public static final boolean exists(Path f) {
|
||||||
|
@ -0,0 +1,29 @@
|
|||||||
|
package org.warp.picalculator.deps.nio;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.warp.picalculator.math.Function;
|
||||||
|
|
||||||
|
public class DFiles {
|
||||||
|
|
||||||
|
public static boolean deleteIfExists(DPath path) throws IOException {
|
||||||
|
return Files.deleteIfExists(path.toPath());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean exists(DPath f) {
|
||||||
|
return Files.exists(f.toPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static DPath createTempFile(String prefix, String suffix) throws IOException {
|
||||||
|
return new DPath(Files.createTempFile(prefix, suffix));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static List<String> readAllLines(DPath p) throws IOException {
|
||||||
|
return Files.readAllLines(p.toPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,20 @@
|
|||||||
|
package org.warp.picalculator.deps.nio;
|
||||||
|
|
||||||
|
import java.nio.file.Path;
|
||||||
|
|
||||||
|
public class DPath {
|
||||||
|
|
||||||
|
private final Path p;
|
||||||
|
|
||||||
|
public DPath(Path p) {
|
||||||
|
this.p = p;
|
||||||
|
}
|
||||||
|
|
||||||
|
Path toPath() {
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DPath toAbsolutePath() {
|
||||||
|
return new DPath(p.toAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,11 @@
|
|||||||
|
package org.warp.picalculator.deps.nio;
|
||||||
|
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
|
||||||
|
public class DPaths {
|
||||||
|
|
||||||
|
public static DPath get(String first, String... more) {
|
||||||
|
return new DPath(Paths.get(first, more));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -17,7 +17,6 @@ import java.nio.file.FileSystemAlreadyExistsException;
|
|||||||
import java.nio.file.FileSystems;
|
import java.nio.file.FileSystems;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.nio.file.StandardOpenOption;
|
import java.nio.file.StandardOpenOption;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
@ -0,0 +1,31 @@
|
|||||||
|
package org.warp.picalculator.deps.nio;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.warp.picalculator.deps.nio.DPaths.DPathImpl;
|
||||||
|
|
||||||
|
public class DFiles {
|
||||||
|
|
||||||
|
public static List<String> readAllLines(DPath osRelease) throws IOException {
|
||||||
|
return FileUtils.readLines(osRelease.toFile(), Charset.defaultCharset());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean exists(DPath f) {
|
||||||
|
return f.toFile().exists();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static DPath createTempFile(String prefix, String suffix) throws IOException {
|
||||||
|
return new DPathImpl(File.createTempFile(prefix, suffix));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void deleteIfExists(DPath f) throws IOException {
|
||||||
|
if (f.toFile().exists()) {
|
||||||
|
f.toFile().delete();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,12 @@
|
|||||||
|
package org.warp.picalculator.deps.nio;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
|
||||||
|
public interface DPath {
|
||||||
|
|
||||||
|
DPath toAbsolutePath();
|
||||||
|
|
||||||
|
File toFile();
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,32 @@
|
|||||||
|
package org.warp.picalculator.deps.nio;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
public class DPaths {
|
||||||
|
public static DPath get(String first, String... more) {
|
||||||
|
return new DPathImpl("/etc", "os-release");
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static class DPathImpl implements DPath {
|
||||||
|
protected final File realFile;
|
||||||
|
|
||||||
|
private DPathImpl(String main, String... more) {
|
||||||
|
realFile = new File(String.join(File.separator, main));
|
||||||
|
}
|
||||||
|
|
||||||
|
DPathImpl(File f) {
|
||||||
|
realFile = f;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public File toFile() {
|
||||||
|
return realFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DPath toAbsolutePath() {
|
||||||
|
return new DPathImpl(realFile.getAbsoluteFile());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
41
src/main/java/org/warp/picalculator/CacheUtils.java
Normal file
41
src/main/java/org/warp/picalculator/CacheUtils.java
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
package org.warp.picalculator;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.Callable;
|
||||||
|
import java.util.function.Function;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
public class CacheUtils {
|
||||||
|
|
||||||
|
private static final Map<String, Object> cache = Collections.synchronizedMap(new HashMap<>());
|
||||||
|
private static final Map<String, Long> time = Collections.synchronizedMap(new HashMap<>());
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
public static <T> T get(String entryName, long expireDelta, Supplier<T> function) {
|
||||||
|
refreshEntry(entryName);
|
||||||
|
synchronized(cache) {
|
||||||
|
if (cache.containsKey(entryName)) {
|
||||||
|
return (T) cache.get(entryName);
|
||||||
|
} else {
|
||||||
|
time.put(entryName, System.currentTimeMillis() + expireDelta);
|
||||||
|
T result = function.get();
|
||||||
|
cache.put(entryName, result);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void refreshEntry(String entryName) {
|
||||||
|
synchronized(time) {
|
||||||
|
synchronized(cache) {
|
||||||
|
if (time.getOrDefault(entryName, 0L) <= System.currentTimeMillis()) {
|
||||||
|
time.remove(entryName);
|
||||||
|
cache.remove(entryName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -2,6 +2,7 @@ package org.warp.picalculator;
|
|||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.warp.picalculator.boot.Main;
|
||||||
import org.warp.picalculator.device.PIHardwareDisplay;
|
import org.warp.picalculator.device.PIHardwareDisplay;
|
||||||
import org.warp.picalculator.gui.CalculatorHUD;
|
import org.warp.picalculator.gui.CalculatorHUD;
|
||||||
import org.warp.picalculator.gui.screens.KeyboardDebugScreen;
|
import org.warp.picalculator.gui.screens.KeyboardDebugScreen;
|
||||||
@ -9,6 +10,6 @@ import org.warp.picalculator.gui.screens.KeyboardDebugScreen;
|
|||||||
public class KeyboardTest {
|
public class KeyboardTest {
|
||||||
|
|
||||||
public static void main(String[] args) throws InterruptedException, Error, IOException {
|
public static void main(String[] args) throws InterruptedException, Error, IOException {
|
||||||
new Main(new KeyboardDebugScreen(), new PIHardwareDisplay(), new CalculatorHUD(), args);
|
new PICalculator(new KeyboardDebugScreen(), new PIHardwareDisplay(), new CalculatorHUD(), Main.parseStartupArguments(args));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,192 +0,0 @@
|
|||||||
package org.warp.picalculator;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import org.warp.picalculator.deps.DGpio;
|
|
||||||
import org.warp.picalculator.deps.DSystem;
|
|
||||||
import org.warp.picalculator.device.HardwareDevice;
|
|
||||||
import org.warp.picalculator.device.HardwareTouchDevice;
|
|
||||||
import org.warp.picalculator.device.InputManager;
|
|
||||||
import org.warp.picalculator.device.Keyboard;
|
|
||||||
import org.warp.picalculator.device.PIHardwareDisplay;
|
|
||||||
import org.warp.picalculator.device.PIHardwareTouchDevice;
|
|
||||||
import org.warp.picalculator.gui.CalculatorHUD;
|
|
||||||
import org.warp.picalculator.gui.DisplayManager;
|
|
||||||
import org.warp.picalculator.gui.HUD;
|
|
||||||
import org.warp.picalculator.gui.HardwareDisplay;
|
|
||||||
import org.warp.picalculator.gui.screens.LoadingScreen;
|
|
||||||
import org.warp.picalculator.gui.screens.Screen;
|
|
||||||
import org.warp.picalculator.math.rules.RulesManager;
|
|
||||||
|
|
||||||
public class Main {
|
|
||||||
public static Main instance;
|
|
||||||
public static String[] args;
|
|
||||||
|
|
||||||
public Main(String[] args) throws InterruptedException, Error, IOException {
|
|
||||||
this(new LoadingScreen(), new PIHardwareDisplay(), new CalculatorHUD(), args);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Main(Screen screen, HardwareDisplay disp, HUD hud, String[] args) throws InterruptedException, Error, IOException {
|
|
||||||
System.out.println("WarpPI Calculator");
|
|
||||||
instance = this;
|
|
||||||
Main.args = args;
|
|
||||||
// ClassUtils.classLoader = this.getClass();
|
|
||||||
beforeStart();
|
|
||||||
Thread.currentThread().setPriority(Thread.MAX_PRIORITY);
|
|
||||||
PlatformUtils.setThreadName(Thread.currentThread(), "Main thread");
|
|
||||||
DisplayManager dm = new DisplayManager(disp, hud, screen, "WarpPI Calculator by Andrea Cavalli (@Cavallium)");
|
|
||||||
Keyboard k = new Keyboard();
|
|
||||||
HardwareTouchDevice touch = new PIHardwareTouchDevice(false,false,false);
|
|
||||||
InputManager im = new InputManager(k, touch);
|
|
||||||
HardwareDevice hardwareDevice = new HardwareDevice(dm, im);
|
|
||||||
hardwareDevice.setup(() -> {
|
|
||||||
try {
|
|
||||||
HardwareDevice.INSTANCE.getDisplayManager().setBrightness(0.2f);
|
|
||||||
RulesManager.initialize();
|
|
||||||
RulesManager.warmUp();
|
|
||||||
if (screen instanceof LoadingScreen) {
|
|
||||||
((LoadingScreen) screen).loaded = true;
|
|
||||||
}
|
|
||||||
HardwareDevice.INSTANCE.getDisplayManager().waitForExit();
|
|
||||||
} catch (InterruptedException | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
ConsoleUtils.out.println(1, "Shutdown...");
|
|
||||||
beforeShutdown();
|
|
||||||
ConsoleUtils.out.println(1, "");
|
|
||||||
ConsoleUtils.out.println(1, "Closed.");
|
|
||||||
DSystem.exit(0);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public void beforeStart() throws IOException {
|
|
||||||
boolean isRaspi = false;
|
|
||||||
try {
|
|
||||||
isRaspi = DGpio.getBoardType() != DGpio.UnknownBoardType;
|
|
||||||
} catch (final Exception e) {}
|
|
||||||
if (Utils.isRunningOnRaspberry() && !Utils.isInArray("-noraspi", args) && isRaspi) {
|
|
||||||
DGpio.wiringPiSetupPhys();
|
|
||||||
DGpio.pinMode(12, DGpio.PWM_OUTPUT);
|
|
||||||
} else {
|
|
||||||
StaticVars.screenPos = new int[] { 0, 0 };
|
|
||||||
StaticVars.debugOn = true;
|
|
||||||
}
|
|
||||||
Utils.debugThirdScreen = StaticVars.debugOn & false;
|
|
||||||
for (final String arg : args) {
|
|
||||||
if (arg.equalsIgnoreCase("2x")) {
|
|
||||||
StaticVars.debugWindow2x = true;
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("headless")) {
|
|
||||||
Utils.headlessOverride = true;
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("headless-8")) {
|
|
||||||
Utils.headlessOverride = true;
|
|
||||||
Utils.forceEngine = "console-8";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("headless-256")) {
|
|
||||||
Utils.headlessOverride = true;
|
|
||||||
Utils.forceEngine = "console-256";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("headless-24bit")) {
|
|
||||||
Utils.headlessOverride = true;
|
|
||||||
Utils.forceEngine = "console-24bit";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("cpu")) {
|
|
||||||
Utils.forceEngine = "cpu";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("gpu")) {
|
|
||||||
Utils.forceEngine = "gpu";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("fb")) {
|
|
||||||
Utils.forceEngine = "fb";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("nogui")) {
|
|
||||||
Utils.forceEngine = "nogui";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("html")) {
|
|
||||||
Utils.forceEngine = "html";
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("verbose") || arg.equalsIgnoreCase("debug")) {
|
|
||||||
StaticVars.outputLevel = ConsoleUtils.OUTPUTLEVEL_DEBUG_VERBOSE;
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("uncached")) {
|
|
||||||
Utils.debugCache = true;
|
|
||||||
}
|
|
||||||
if (arg.equalsIgnoreCase("ms-dos")) {
|
|
||||||
Utils.headlessOverride = true;
|
|
||||||
Utils.msDosMode = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void beforeShutdown() {
|
|
||||||
Keyboard.stopKeyboard();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void main(String[] args) throws InterruptedException, Error, IOException {
|
|
||||||
/*
|
|
||||||
* TEST: Comparing BigIntegerMath.divisors() vs programmingpraxis' Number.getFactors() function
|
|
||||||
*
|
|
||||||
long time1;
|
|
||||||
long time2;
|
|
||||||
final int max = 10000;
|
|
||||||
final long HCN = 720720L;
|
|
||||||
final long LCN = 104911L;
|
|
||||||
final BigInteger[] bigintegers = new BigInteger[max];
|
|
||||||
bigintegers[0] = BigInteger.valueOf(HCN);
|
|
||||||
for (int i = 0; i < max; i++) {
|
|
||||||
bigintegers[i] = bigintegers[0];
|
|
||||||
}
|
|
||||||
final Number[] numbers = new Number[max];
|
|
||||||
final MathContext mc = new MathContext();
|
|
||||||
numbers[0] = new Number(mc, HCN);
|
|
||||||
for (int i = 0; i < max; i++) {
|
|
||||||
numbers[i] = numbers[0];
|
|
||||||
}
|
|
||||||
Vector<BigInteger> empty = null;
|
|
||||||
LinkedList<BigInteger> empty2 = null;
|
|
||||||
|
|
||||||
time1 = System.currentTimeMillis();
|
|
||||||
for(int i = 0; i < max; i++) {
|
|
||||||
empty = BigIntegerMath.divisors(bigintegers[i]);
|
|
||||||
}
|
|
||||||
time2 = System.currentTimeMillis();
|
|
||||||
System.out.println("BigIntegerMath HCN: "+(time2-time1)+" ("+empty.toString()+")");
|
|
||||||
|
|
||||||
|
|
||||||
bigintegers[0] = BigInteger.valueOf(LCN);
|
|
||||||
for (int i = 0; i < max; i++) {
|
|
||||||
bigintegers[i] = bigintegers[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
time1 = System.currentTimeMillis();
|
|
||||||
for(int i = 0; i < max; i++) {
|
|
||||||
empty = BigIntegerMath.divisors(bigintegers[i]);
|
|
||||||
}
|
|
||||||
time2 = System.currentTimeMillis();
|
|
||||||
System.out.println("BigIntegerMath LCN: "+(time2-time1)+" ("+empty.toString()+")");
|
|
||||||
|
|
||||||
time1 = System.currentTimeMillis();
|
|
||||||
for(int i = 0; i < max; i++) {
|
|
||||||
empty2 = numbers[i].getFactors();
|
|
||||||
}
|
|
||||||
time2 = System.currentTimeMillis();
|
|
||||||
System.out.println("BigIntegerMath HCN: "+(time2-time1)+" ("+empty2.toString()+")");
|
|
||||||
|
|
||||||
numbers[0] = new Number(mc, LCN);
|
|
||||||
for (int i = 0; i < max; i++) {
|
|
||||||
numbers[i] = numbers[0];
|
|
||||||
}
|
|
||||||
time1 = System.currentTimeMillis();
|
|
||||||
for(int i = 0; i < max; i++) {
|
|
||||||
empty2 = numbers[i].getFactors();
|
|
||||||
}
|
|
||||||
time2 = System.currentTimeMillis();
|
|
||||||
System.out.println("BigIntegerMath LCN: "+(time2-time1)+" ("+empty2.toString()+")");
|
|
||||||
if(true) {
|
|
||||||
System.exit(0);;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
new Main(args);
|
|
||||||
}
|
|
||||||
}
|
|
86
src/main/java/org/warp/picalculator/PICalculator.java
Executable file
86
src/main/java/org/warp/picalculator/PICalculator.java
Executable file
@ -0,0 +1,86 @@
|
|||||||
|
package org.warp.picalculator;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.warp.picalculator.boot.StartupArguments;
|
||||||
|
import org.warp.picalculator.deps.DGpio;
|
||||||
|
import org.warp.picalculator.deps.DSystem;
|
||||||
|
import org.warp.picalculator.device.HardwareDevice;
|
||||||
|
import org.warp.picalculator.device.HardwareTouchDevice;
|
||||||
|
import org.warp.picalculator.device.InputManager;
|
||||||
|
import org.warp.picalculator.device.Keyboard;
|
||||||
|
import org.warp.picalculator.device.PIHardwareDisplay;
|
||||||
|
import org.warp.picalculator.device.PIHardwareTouchDevice;
|
||||||
|
import org.warp.picalculator.gui.CalculatorHUD;
|
||||||
|
import org.warp.picalculator.gui.DisplayManager;
|
||||||
|
import org.warp.picalculator.gui.HUD;
|
||||||
|
import org.warp.picalculator.gui.HardwareDisplay;
|
||||||
|
import org.warp.picalculator.gui.screens.LoadingScreen;
|
||||||
|
import org.warp.picalculator.gui.screens.Screen;
|
||||||
|
import org.warp.picalculator.math.rules.RulesManager;
|
||||||
|
|
||||||
|
public class PICalculator {
|
||||||
|
public static PICalculator instance;
|
||||||
|
|
||||||
|
public PICalculator(StartupArguments args) throws InterruptedException, IOException {
|
||||||
|
this(new LoadingScreen(), new PIHardwareDisplay(), new CalculatorHUD(), args);
|
||||||
|
}
|
||||||
|
|
||||||
|
public PICalculator(Screen screen, HardwareDisplay disp, HUD hud, StartupArguments args) throws InterruptedException, IOException {
|
||||||
|
ConsoleUtils.out.println("WarpPI Calculator");
|
||||||
|
initializeEnvironment(args);
|
||||||
|
Thread.currentThread().setPriority(Thread.MAX_PRIORITY);
|
||||||
|
PlatformUtils.setThreadName(Thread.currentThread(), "Main thread");
|
||||||
|
DisplayManager dm = new DisplayManager(disp, hud, screen, "WarpPI Calculator by Andrea Cavalli (@Cavallium)");
|
||||||
|
Keyboard k = new Keyboard();
|
||||||
|
HardwareTouchDevice touch = new PIHardwareTouchDevice(false,false,false);
|
||||||
|
InputManager im = new InputManager(k, touch);
|
||||||
|
HardwareDevice hardwareDevice = new HardwareDevice(dm, im);
|
||||||
|
hardwareDevice.setup(() -> {
|
||||||
|
try {
|
||||||
|
HardwareDevice.INSTANCE.getDisplayManager().setBrightness(0.2f);
|
||||||
|
RulesManager.initialize();
|
||||||
|
RulesManager.warmUp();
|
||||||
|
if (screen instanceof LoadingScreen) {
|
||||||
|
((LoadingScreen) screen).loaded = true;
|
||||||
|
}
|
||||||
|
HardwareDevice.INSTANCE.getDisplayManager().waitForExit();
|
||||||
|
} catch (InterruptedException | Error e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
ConsoleUtils.out.println(1, "Shutdown...");
|
||||||
|
beforeShutdown();
|
||||||
|
ConsoleUtils.out.println(1, "");
|
||||||
|
ConsoleUtils.out.println(1, "Closed.");
|
||||||
|
DSystem.exit(0);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void initializeEnvironment(StartupArguments args) throws IOException {
|
||||||
|
instance = this;
|
||||||
|
ClassUtils.classLoader = this.getClass();
|
||||||
|
StaticVars.startupArguments = args;
|
||||||
|
checkDeviceType();
|
||||||
|
if (Utils.isRunningOnRaspberry() && args.isRaspberryModeAllowed()) {
|
||||||
|
DGpio.wiringPiSetupPhys();
|
||||||
|
DGpio.pinMode(12, DGpio.PWM_OUTPUT);
|
||||||
|
} else {
|
||||||
|
StaticVars.screenPos = new int[] { 0, 0 };
|
||||||
|
StaticVars.debugOn = true;
|
||||||
|
}
|
||||||
|
Utils.debugThirdScreen = StaticVars.debugOn & false;
|
||||||
|
StaticVars.debugWindow2x = args.isZoomed();
|
||||||
|
if (args.isVerboseLoggingEnabled() || args.isDebugEnabled()) {
|
||||||
|
StaticVars.outputLevel = ConsoleUtils.OUTPUTLEVEL_DEBUG_VERBOSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkDeviceType() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void beforeShutdown() {
|
||||||
|
Keyboard.stopKeyboard();
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,7 @@
|
|||||||
package org.warp.picalculator;
|
package org.warp.picalculator;
|
||||||
|
|
||||||
|
import org.warp.picalculator.boot.StartupArguments;
|
||||||
|
|
||||||
public class StaticVars {
|
public class StaticVars {
|
||||||
public static final boolean enableVBO = true;
|
public static final boolean enableVBO = true;
|
||||||
public static final String calculatorName = "WarpPI";
|
public static final String calculatorName = "WarpPI";
|
||||||
@ -13,6 +15,7 @@ public class StaticVars {
|
|||||||
public static int outputLevel = 0;
|
public static int outputLevel = 0;
|
||||||
public static boolean debugWindow2x = false;
|
public static boolean debugWindow2x = false;
|
||||||
public static float windowZoom = 2;
|
public static float windowZoom = 2;
|
||||||
|
public static StartupArguments startupArguments;
|
||||||
|
|
||||||
private StaticVars() {
|
private StaticVars() {
|
||||||
|
|
||||||
|
@ -15,14 +15,20 @@ import java.math.BigDecimal;
|
|||||||
import java.math.BigInteger;
|
import java.math.BigInteger;
|
||||||
import java.math.RoundingMode;
|
import java.math.RoundingMode;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.nevec.rjm.BigDecimalMath;
|
import org.nevec.rjm.BigDecimalMath;
|
||||||
import org.nevec.rjm.Rational;
|
import org.nevec.rjm.Rational;
|
||||||
|
import org.warp.picalculator.deps.DGpio;
|
||||||
import org.warp.picalculator.deps.StorageUtils;
|
import org.warp.picalculator.deps.StorageUtils;
|
||||||
|
import org.warp.picalculator.deps.nio.DFiles;
|
||||||
|
import org.warp.picalculator.deps.nio.DPath;
|
||||||
|
import org.warp.picalculator.deps.nio.DPaths;
|
||||||
import org.warp.picalculator.device.HardwareDevice;
|
import org.warp.picalculator.device.HardwareDevice;
|
||||||
import org.warp.picalculator.gui.DisplayManager;
|
import org.warp.picalculator.gui.DisplayManager;
|
||||||
import org.warp.picalculator.gui.graphicengine.BinaryFont;
|
import org.warp.picalculator.gui.graphicengine.BinaryFont;
|
||||||
@ -53,32 +59,17 @@ public class Utils {
|
|||||||
public static final RoundingMode scaleMode2 = RoundingMode.HALF_UP;
|
public static final RoundingMode scaleMode2 = RoundingMode.HALF_UP;
|
||||||
|
|
||||||
public static boolean debugThirdScreen;
|
public static boolean debugThirdScreen;
|
||||||
public static boolean headlessOverride = false;
|
|
||||||
public static String forceEngine;
|
|
||||||
public static boolean msDosMode;
|
|
||||||
public static boolean debugCache;
|
|
||||||
public static boolean newtMode = true;
|
public static boolean newtMode = true;
|
||||||
|
|
||||||
public static boolean isInArray(String ch, String[] a) {
|
public static <T> boolean isInArray(T ch, T[] a) {
|
||||||
boolean contains = false;
|
return Arrays.stream(a).anyMatch(item -> ch.equals(item));
|
||||||
for (final String c : a) {
|
|
||||||
if (c.equals(ch)) {
|
|
||||||
contains = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return contains;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isInArray(char ch, char[] a) {
|
public static boolean isInArray(char ch, char[] a) {
|
||||||
boolean contains = false;
|
|
||||||
for (final char c : a) {
|
for (final char c : a) {
|
||||||
if (c == ch) {
|
if (c == ch) return true;
|
||||||
contains = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return contains;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final String[] regexNormalSymbols = new String[] { "\\", ".", "[", "]", "{", "}", "(", ")", "*", "+", "-", "?", "^", "$", "|" };
|
private static final String[] regexNormalSymbols = new String[] { "\\", ".", "[", "]", "{", "}", "(", ")", "*", "+", "-", "?", "^", "$", "|" };
|
||||||
@ -648,22 +639,28 @@ public class Utils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isRunningOnRaspberry() {
|
public static boolean isRunningOnRaspberry() {
|
||||||
if (PlatformUtils.osName.equals("Linux")) {
|
return CacheUtils.get("isRunningOnRaspberry", 24*60*60*1000, () -> {
|
||||||
final File file = new File("/etc", "os-release");
|
if (PlatformUtils.isJavascript) return false;
|
||||||
try (FileInputStream fis = new FileInputStream(file); BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(fis))) {
|
try {
|
||||||
String string;
|
// Check if it's a raspberry using pi4j
|
||||||
while ((string = bufferedReader.readLine()) != null) {
|
return DGpio.getBoardType() != DGpio.UnknownBoardType;
|
||||||
if (string.toLowerCase().contains("raspbian")) {
|
|
||||||
if (string.toLowerCase().contains("name")) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
e.printStackTrace();
|
// Check if it's a raspberry using other methods
|
||||||
|
if (PlatformUtils.osName.equals("Linux")) {
|
||||||
|
try {
|
||||||
|
final DPath osRelease = DPaths.get("/etc", "os-release");
|
||||||
|
return DFiles.readAllLines(osRelease).stream()
|
||||||
|
.map(String::toLowerCase)
|
||||||
|
.anyMatch(line -> line.contains("raspbian") && line.contains("name"));
|
||||||
|
} catch (IOException readException) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isWindows() {
|
public static boolean isWindows() {
|
||||||
@ -684,7 +681,7 @@ public class Utils {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Path getJarDirectory() {
|
public static DPath getJarDirectory() {
|
||||||
return Paths.get("").toAbsolutePath();
|
return DPaths.get("").toAbsolutePath();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
80
src/main/java/org/warp/picalculator/boot/Main.java
Normal file
80
src/main/java/org/warp/picalculator/boot/Main.java
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
package org.warp.picalculator.boot;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
import org.warp.picalculator.ConsoleUtils;
|
||||||
|
import org.warp.picalculator.PICalculator;
|
||||||
|
import org.warp.picalculator.Utils;
|
||||||
|
import org.warp.picalculator.device.PIHardwareDisplay;
|
||||||
|
import org.warp.picalculator.gui.CalculatorHUD;
|
||||||
|
import org.warp.picalculator.gui.screens.LoadingScreen;
|
||||||
|
|
||||||
|
public class Main {
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
new PICalculator(parseStartupArguments(args));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StartupArguments parseStartupArguments(final String[] a) {
|
||||||
|
final StartupArgumentsImpl args = new StartupArgumentsImpl();
|
||||||
|
Arrays.asList(a).stream().parallel().map(String::toLowerCase).forEach(arg -> {
|
||||||
|
switch(arg) {
|
||||||
|
case "2x":
|
||||||
|
args.setZoomed(true);
|
||||||
|
break;
|
||||||
|
case "verbose":
|
||||||
|
args.setVerboseLoggingEnabled(true);
|
||||||
|
break;
|
||||||
|
case "-noraspi":
|
||||||
|
args.setRaspberryModeAllowed(false);
|
||||||
|
break;
|
||||||
|
case "nogui":
|
||||||
|
args.setNoGUIEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "ms-dos":
|
||||||
|
args.setMSDOSModeEnabled(true);
|
||||||
|
break;
|
||||||
|
case "headless-8":
|
||||||
|
args.setHeadless8EngineForced(true);
|
||||||
|
break;
|
||||||
|
case "headless-256":
|
||||||
|
args.setHeadless256EngineForced(true);
|
||||||
|
break;
|
||||||
|
case "headless-24bit":
|
||||||
|
args.setHeadless24bitEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "headless":
|
||||||
|
args.setHeadlessEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "html":
|
||||||
|
args.setHTMLEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "gpu":
|
||||||
|
args.setGPUEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "cpu":
|
||||||
|
args.setCPUEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "framebuffer":
|
||||||
|
args.setFrameBufferEngineForced(true);
|
||||||
|
break;
|
||||||
|
case "debug":
|
||||||
|
args.setDebugEnabled(true);
|
||||||
|
break;
|
||||||
|
case "uncached":
|
||||||
|
args.setUncached(true);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
ConsoleUtils.out.print(ConsoleUtils.OUTPUTLEVEL_NODEBUG, "Unrecognized argument " + arg);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
args.setHeadlessEngineForced(args.isHeadlessEngineForced() ||
|
||||||
|
args.isHeadless8EngineForced() ||
|
||||||
|
args.isHeadless256EngineForced() ||
|
||||||
|
args.isHeadless24bitEngineForced()
|
||||||
|
);
|
||||||
|
return args;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
package org.warp.picalculator.boot;
|
||||||
|
|
||||||
|
public interface StartupArguments {
|
||||||
|
public boolean isRaspberryModeAllowed();
|
||||||
|
public boolean isZoomed();
|
||||||
|
public boolean isHeadlessEngineForced();
|
||||||
|
public boolean isHeadless8EngineForced();
|
||||||
|
public boolean isHeadless256EngineForced();
|
||||||
|
public boolean isHeadless24bitEngineForced();
|
||||||
|
public boolean isCPUEngineForced();
|
||||||
|
public boolean isGPUEngineForced();
|
||||||
|
public boolean isFrameBufferEngineForced();
|
||||||
|
public boolean isNoGUIEngineForced();
|
||||||
|
public boolean isHTMLEngineForced();
|
||||||
|
public boolean isMSDOSModeEnabled();
|
||||||
|
public boolean isVerboseLoggingEnabled();
|
||||||
|
public boolean isDebugEnabled();
|
||||||
|
public boolean isUncached();
|
||||||
|
public boolean isEngineForced();
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,175 @@
|
|||||||
|
package org.warp.picalculator.boot;
|
||||||
|
|
||||||
|
public class StartupArgumentsImpl implements StartupArguments {
|
||||||
|
|
||||||
|
StartupArgumentsImpl() {
|
||||||
|
isRaspberryModeAllowed = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isRaspberryModeAllowed;
|
||||||
|
private boolean isZoomed;
|
||||||
|
private boolean isHeadlessEngineForced;
|
||||||
|
private boolean isHeadless8EngineForced;
|
||||||
|
private boolean isHeadless256EngineForced;
|
||||||
|
private boolean isHeadless24bitEngineForced;
|
||||||
|
private boolean isCPUEngineForced;
|
||||||
|
private boolean isGPUEngineForced;
|
||||||
|
private boolean isFrameBufferEngineForced;
|
||||||
|
private boolean isNoGUIEngineForced;
|
||||||
|
private boolean isHTMLEngineForced;
|
||||||
|
private boolean isMSDOSModeEnabled;
|
||||||
|
private boolean isVerboseLoggingEnabled;
|
||||||
|
private boolean isDebugEnabled;
|
||||||
|
private boolean isUncached;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isRaspberryModeAllowed() {
|
||||||
|
return isRaspberryModeAllowed;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isZoomed() {
|
||||||
|
return isZoomed;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isHeadlessEngineForced() {
|
||||||
|
return isHeadlessEngineForced ||
|
||||||
|
isHeadless8EngineForced ||
|
||||||
|
isHeadless256EngineForced ||
|
||||||
|
isHeadless24bitEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isHeadless8EngineForced() {
|
||||||
|
return isHeadless8EngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isHeadless256EngineForced() {
|
||||||
|
return isHeadless256EngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isHeadless24bitEngineForced() {
|
||||||
|
return isHeadless24bitEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isCPUEngineForced() {
|
||||||
|
return isCPUEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isGPUEngineForced() {
|
||||||
|
return isGPUEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isFrameBufferEngineForced() {
|
||||||
|
return isFrameBufferEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isNoGUIEngineForced() {
|
||||||
|
return isNoGUIEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isHTMLEngineForced() {
|
||||||
|
return isHTMLEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isMSDOSModeEnabled() {
|
||||||
|
return isMSDOSModeEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isVerboseLoggingEnabled() {
|
||||||
|
return isVerboseLoggingEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isDebugEnabled() {
|
||||||
|
return isDebugEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isUncached() {
|
||||||
|
return isUncached;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isEngineForced() {
|
||||||
|
return isCPUEngineForced
|
||||||
|
|| isFrameBufferEngineForced
|
||||||
|
|| isGPUEngineForced
|
||||||
|
|| isHeadless24bitEngineForced
|
||||||
|
|| isHeadless256EngineForced
|
||||||
|
|| isHeadless8EngineForced
|
||||||
|
|| isHTMLEngineForced
|
||||||
|
|| isNoGUIEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setRaspberryModeAllowed(boolean isRaspberryModeAllowed) {
|
||||||
|
this.isRaspberryModeAllowed = isRaspberryModeAllowed;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setZoomed(boolean isZoomed) {
|
||||||
|
this.isZoomed = isZoomed;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setHeadlessEngineForced(boolean isHeadlessEngineForced) {
|
||||||
|
this.isHeadlessEngineForced = isHeadlessEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setHeadless8EngineForced(boolean isHeadless8EngineForced) {
|
||||||
|
this.isHeadless8EngineForced = isHeadless8EngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setHeadless256EngineForced(boolean isHeadless256EngineForced) {
|
||||||
|
this.isHeadless256EngineForced = isHeadless256EngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setHeadless24bitEngineForced(boolean isHeadless24bitEngineForced) {
|
||||||
|
this.isHeadless24bitEngineForced = isHeadless24bitEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setCPUEngineForced(boolean isCPUEngineForced) {
|
||||||
|
this.isCPUEngineForced = isCPUEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setGPUEngineForced(boolean isGPUEngineForced) {
|
||||||
|
this.isGPUEngineForced = isGPUEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setFrameBufferEngineForced(boolean isFrameBufferEngineForced) {
|
||||||
|
this.isFrameBufferEngineForced = isFrameBufferEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setNoGUIEngineForced(boolean isNoGUIEngineForced) {
|
||||||
|
this.isNoGUIEngineForced = isNoGUIEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setHTMLEngineForced(boolean isHTMLEngineForced) {
|
||||||
|
this.isHTMLEngineForced = isHTMLEngineForced;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setMSDOSModeEnabled(boolean isMSDOSModeEnabled) {
|
||||||
|
this.isMSDOSModeEnabled = isMSDOSModeEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setVerboseLoggingEnabled(boolean isVerboseLoggingEnabled) {
|
||||||
|
this.isVerboseLoggingEnabled = isVerboseLoggingEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setDebugEnabled(boolean isDebugEnabled) {
|
||||||
|
this.isDebugEnabled = isDebugEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setUncached(boolean isUncached) {
|
||||||
|
this.isUncached = isUncached;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -5,11 +5,11 @@ import java.io.FileOutputStream;
|
|||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.ObjectInputStream;
|
import java.io.ObjectInputStream;
|
||||||
import java.io.ObjectOutputStream;
|
import java.io.ObjectOutputStream;
|
||||||
import java.nio.file.Files;
|
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.warp.picalculator.StaticVars;
|
import org.warp.picalculator.StaticVars;
|
||||||
|
import org.warp.picalculator.deps.nio.DFiles;
|
||||||
|
import org.warp.picalculator.deps.nio.DPaths;
|
||||||
|
|
||||||
public class CacheFile {
|
public class CacheFile {
|
||||||
private String path;
|
private String path;
|
||||||
@ -21,9 +21,9 @@ public class CacheFile {
|
|||||||
public CacheFile() {
|
public CacheFile() {
|
||||||
do {
|
do {
|
||||||
path = UUID.randomUUID().toString() + ".ser";
|
path = UUID.randomUUID().toString() + ".ser";
|
||||||
} while (Files.exists(Paths.get(path)));
|
} while (DFiles.exists(DPaths.get(path)));
|
||||||
try {
|
try {
|
||||||
Files.createTempFile(StaticVars.calculatorNameLOWER, "");
|
DFiles.createTempFile(StaticVars.calculatorNameLOWER, "");
|
||||||
} catch (final IOException e) {
|
} catch (final IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@ -80,7 +80,7 @@ public class CacheFile {
|
|||||||
public void dispose() {
|
public void dispose() {
|
||||||
closeStreams();
|
closeStreams();
|
||||||
try {
|
try {
|
||||||
Files.deleteIfExists(Paths.get(path));
|
DFiles.deleteIfExists(DPaths.get(path));
|
||||||
} catch (final IOException e) {
|
} catch (final IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package org.warp.picalculator.device;
|
package org.warp.picalculator.device;
|
||||||
|
|
||||||
|
import org.warp.picalculator.PlatformUtils;
|
||||||
import org.warp.picalculator.gui.DisplayManager;
|
import org.warp.picalculator.gui.DisplayManager;
|
||||||
|
|
||||||
public class HardwareDevice {
|
public class HardwareDevice {
|
||||||
@ -25,8 +26,8 @@ public class HardwareDevice {
|
|||||||
displayManager.initialize();
|
displayManager.initialize();
|
||||||
inputManager.getKeyboard().startKeyboard();
|
inputManager.getKeyboard().startKeyboard();
|
||||||
Thread t = new Thread(r);
|
Thread t = new Thread(r);
|
||||||
t.setDaemon(false);
|
PlatformUtils.setDaemon(t, false);
|
||||||
t.setName("Main thread (after setup)");
|
PlatformUtils.setThreadName(t, "Main thread (after setup)");
|
||||||
t.start();
|
t.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ import java.util.logging.Logger;
|
|||||||
import javax.imageio.ImageIO;
|
import javax.imageio.ImageIO;
|
||||||
|
|
||||||
import org.warp.picalculator.ClassUtils;
|
import org.warp.picalculator.ClassUtils;
|
||||||
import org.warp.picalculator.Main;
|
import org.warp.picalculator.PICalculator;
|
||||||
import org.warp.picalculator.Utils;
|
import org.warp.picalculator.Utils;
|
||||||
import org.warp.picalculator.deps.DSystem;
|
import org.warp.picalculator.deps.DSystem;
|
||||||
|
|
||||||
|
@ -191,10 +191,10 @@ public class CPUEngine implements GraphicEngine {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isSupported() {
|
public boolean isSupported() {
|
||||||
if (Utils.forceEngine != null && Utils.forceEngine != "cpu") {
|
if (StaticVars.startupArguments.isEngineForced() && StaticVars.startupArguments.isCPUEngineForced() == false) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return (Utils.headlessOverride || GraphicsEnvironment.isHeadless()) == false;
|
return (StaticVars.startupArguments.isHeadlessEngineForced() || GraphicsEnvironment.isHeadless()) == false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -7,6 +7,7 @@ import java.nio.MappedByteBuffer;
|
|||||||
import java.util.concurrent.Semaphore;
|
import java.util.concurrent.Semaphore;
|
||||||
|
|
||||||
import org.warp.picalculator.MmapByteBuffer;
|
import org.warp.picalculator.MmapByteBuffer;
|
||||||
|
import org.warp.picalculator.StaticVars;
|
||||||
import org.warp.picalculator.TestJNI;
|
import org.warp.picalculator.TestJNI;
|
||||||
import org.warp.picalculator.Utils;
|
import org.warp.picalculator.Utils;
|
||||||
import org.warp.picalculator.gui.graphicengine.BinaryFont;
|
import org.warp.picalculator.gui.graphicengine.BinaryFont;
|
||||||
@ -174,10 +175,10 @@ public class FBEngine implements GraphicEngine {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isSupported() {
|
public boolean isSupported() {
|
||||||
if (Utils.forceEngine != null && Utils.forceEngine != "fb") {
|
if (StaticVars.startupArguments.isEngineForced() && StaticVars.startupArguments.isFrameBufferEngineForced() == false) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (Utils.headlessOverride) {
|
if (StaticVars.startupArguments.isHeadlessEngineForced()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
@ -162,10 +162,10 @@ public class GPUEngine implements GraphicEngine {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isSupported() {
|
public boolean isSupported() {
|
||||||
if (Utils.forceEngine != null && Utils.forceEngine != "gpu") {
|
if (StaticVars.startupArguments.isEngineForced() && StaticVars.startupArguments.isGPUEngineForced() == false) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (Utils.headlessOverride) {
|
if (StaticVars.startupArguments.isHeadlessEngineForced()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
boolean available = false;
|
boolean available = false;
|
||||||
|
@ -64,7 +64,7 @@ public class Headless24bitEngine implements org.warp.picalculator.gui.graphiceng
|
|||||||
public void create(Runnable onInitialized) {
|
public void create(Runnable onInitialized) {
|
||||||
StaticVars.outputLevel = -1;
|
StaticVars.outputLevel = -1;
|
||||||
AnsiConsole.systemInstall();
|
AnsiConsole.systemInstall();
|
||||||
if (Utils.isWindows() && !Utils.msDosMode) {
|
if (Utils.isWindows() && !StaticVars.startupArguments.isMSDOSModeEnabled()) {
|
||||||
win = true;
|
win = true;
|
||||||
WindowsSupport.setConsoleMode(0x0200);
|
WindowsSupport.setConsoleMode(0x0200);
|
||||||
final Thread t = new Thread(() -> {
|
final Thread t = new Thread(() -> {
|
||||||
@ -319,7 +319,13 @@ public class Headless24bitEngine implements org.warp.picalculator.gui.graphiceng
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isSupported() {
|
public boolean isSupported() {
|
||||||
if (Utils.msDosMode || (Utils.forceEngine != null && Utils.forceEngine != "console-24bit")) {
|
if (
|
||||||
|
StaticVars.startupArguments.isMSDOSModeEnabled()
|
||||||
|
|| (
|
||||||
|
StaticVars.startupArguments.isEngineForced()
|
||||||
|
&& StaticVars.startupArguments.isHeadless24bitEngineForced() == false
|
||||||
|
)
|
||||||
|
) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -63,7 +63,7 @@ public class Headless256Engine implements org.warp.picalculator.gui.graphicengin
|
|||||||
public void create(Runnable onInitialized) {
|
public void create(Runnable onInitialized) {
|
||||||
StaticVars.outputLevel = -1;
|
StaticVars.outputLevel = -1;
|
||||||
AnsiConsole.systemInstall();
|
AnsiConsole.systemInstall();
|
||||||
if (Utils.isWindows() && !Utils.msDosMode) {
|
if (Utils.isWindows() && !StaticVars.startupArguments.isMSDOSModeEnabled()) {
|
||||||
win = true;
|
win = true;
|
||||||
WindowsSupport.setConsoleMode(0x0200);
|
WindowsSupport.setConsoleMode(0x0200);
|
||||||
final Thread t = new Thread(() -> {
|
final Thread t = new Thread(() -> {
|
||||||
@ -276,7 +276,13 @@ public class Headless256Engine implements org.warp.picalculator.gui.graphicengin
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isSupported() {
|
public boolean isSupported() {
|
||||||
if (Utils.msDosMode || (Utils.forceEngine != null && Utils.forceEngine != "console-256")) {
|
if (
|
||||||
|
StaticVars.startupArguments.isMSDOSModeEnabled()
|
||||||
|
|| (
|
||||||
|
StaticVars.startupArguments.isEngineForced()
|
||||||
|
&& StaticVars.startupArguments.isHeadless256EngineForced() == false
|
||||||
|
)
|
||||||
|
) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -63,7 +63,7 @@ public class Headless8Engine implements org.warp.picalculator.gui.graphicengine.
|
|||||||
public void create(Runnable onInitialized) {
|
public void create(Runnable onInitialized) {
|
||||||
StaticVars.outputLevel = -1;
|
StaticVars.outputLevel = -1;
|
||||||
AnsiConsole.systemInstall();
|
AnsiConsole.systemInstall();
|
||||||
if (Utils.isWindows() && !Utils.msDosMode) {
|
if (Utils.isWindows() && !StaticVars.startupArguments.isMSDOSModeEnabled()) {
|
||||||
win = true;
|
win = true;
|
||||||
WindowsSupport.setConsoleMode(0x0200);
|
WindowsSupport.setConsoleMode(0x0200);
|
||||||
final Thread t = new Thread(() -> {
|
final Thread t = new Thread(() -> {
|
||||||
@ -276,7 +276,13 @@ public class Headless8Engine implements org.warp.picalculator.gui.graphicengine.
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isSupported() {
|
public boolean isSupported() {
|
||||||
if (Utils.forceEngine != null && Utils.forceEngine != "console-8") {
|
if (
|
||||||
|
StaticVars.startupArguments.isMSDOSModeEnabled()
|
||||||
|
|| (
|
||||||
|
StaticVars.startupArguments.isEngineForced()
|
||||||
|
&& StaticVars.startupArguments.isHeadless8EngineForced() == false
|
||||||
|
)
|
||||||
|
) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package org.warp.picalculator.gui.graphicengine.headless8;
|
package org.warp.picalculator.gui.graphicengine.headless8;
|
||||||
|
|
||||||
|
import org.warp.picalculator.StaticVars;
|
||||||
import org.warp.picalculator.Utils;
|
import org.warp.picalculator.Utils;
|
||||||
import org.warp.picalculator.gui.graphicengine.Renderer;
|
import org.warp.picalculator.gui.graphicengine.Renderer;
|
||||||
|
|
||||||
@ -19,7 +20,7 @@ public class Headless8Renderer implements Renderer {
|
|||||||
public static final String[] colorANSI = new String[] { "0", "1", "2", "3", "4", "5", "6", "7", "0;1", "1;1", "2;1", "3;1", "4;1", "5;1", "6;1", "7;1" };
|
public static final String[] colorANSI = new String[] { "0", "1", "2", "3", "4", "5", "6", "7", "0;1", "1;1", "2;1", "3;1", "4;1", "5;1", "6;1", "7;1" };
|
||||||
|
|
||||||
public static final String ANSI_RESET = "\u001B[0m";
|
public static final String ANSI_RESET = "\u001B[0m";
|
||||||
public static final char FILL = Utils.msDosMode ? 0xDB : '█';
|
public static final char FILL = StaticVars.startupArguments.isMSDOSModeEnabled() ? 0xDB : '█';
|
||||||
|
|
||||||
private int hexColor(int red, int green, int blue) {
|
private int hexColor(int red, int green, int blue) {
|
||||||
final int r1 = red;
|
final int r1 = red;
|
||||||
|
@ -11,7 +11,6 @@ import java.net.URL;
|
|||||||
import java.net.URLClassLoader;
|
import java.net.URLClassLoader;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.nio.file.StandardOpenOption;
|
import java.nio.file.StandardOpenOption;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -21,6 +20,7 @@ import org.apache.commons.io.IOUtils;
|
|||||||
import org.warp.picalculator.ConsoleUtils;
|
import org.warp.picalculator.ConsoleUtils;
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
import org.warp.picalculator.PlatformUtils;
|
import org.warp.picalculator.PlatformUtils;
|
||||||
|
import org.warp.picalculator.StaticVars;
|
||||||
import org.warp.picalculator.Utils;
|
import org.warp.picalculator.Utils;
|
||||||
import org.warp.picalculator.ZipUtils;
|
import org.warp.picalculator.ZipUtils;
|
||||||
import org.warp.picalculator.deps.StorageUtils;
|
import org.warp.picalculator.deps.StorageUtils;
|
||||||
@ -101,7 +101,7 @@ public class RulesManager {
|
|||||||
tDir.delete();
|
tDir.delete();
|
||||||
}
|
}
|
||||||
ZipUtils.unzip(cacheFilePath.toString(), tDir.getParent().toString(), "");
|
ZipUtils.unzip(cacheFilePath.toString(), tDir.getParent().toString(), "");
|
||||||
useCache = !Utils.debugCache;
|
useCache = !StaticVars.startupArguments.isUncached();
|
||||||
} catch (final Exception ex) {
|
} catch (final Exception ex) {
|
||||||
ex.printStackTrace();
|
ex.printStackTrace();
|
||||||
}
|
}
|
||||||
@ -189,7 +189,7 @@ public class RulesManager {
|
|||||||
}
|
}
|
||||||
StorageUtils.write(tFileJava, javaCode.getBytes("UTF-8"), DStandardOpenOption.WRITE, DStandardOpenOption.CREATE);
|
StorageUtils.write(tFileJava, javaCode.getBytes("UTF-8"), DStandardOpenOption.WRITE, DStandardOpenOption.CREATE);
|
||||||
final boolean compiled = DJDTCompiler.compile(new String[] { "-nowarn", "-1.8", tFileJava.toString() }, new PrintWriter(System.out), new PrintWriter(System.err));
|
final boolean compiled = DJDTCompiler.compile(new String[] { "-nowarn", "-1.8", tFileJava.toString() }, new PrintWriter(System.out), new PrintWriter(System.err));
|
||||||
if (Utils.debugCache) {
|
if (StaticVars.startupArguments.isUncached()) {
|
||||||
tFileJava.deleteOnExit();
|
tFileJava.deleteOnExit();
|
||||||
} else {
|
} else {
|
||||||
tFileJava.delete();
|
tFileJava.delete();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user