mirror of
https://github.com/sparrowwallet/sparrow.git
synced 2025-01-27 18:51:11 +00:00
separate application from main
This commit is contained in:
parent
22408103ea
commit
1e4c8c3837
4 changed files with 158 additions and 137 deletions
|
@ -28,6 +28,7 @@ import com.sparrowwallet.sparrow.net.*;
|
||||||
import com.sparrowwallet.sparrow.paynym.PayNymService;
|
import com.sparrowwallet.sparrow.paynym.PayNymService;
|
||||||
import com.sparrowwallet.sparrow.soroban.SorobanServices;
|
import com.sparrowwallet.sparrow.soroban.SorobanServices;
|
||||||
import com.sparrowwallet.sparrow.whirlpool.WhirlpoolServices;
|
import com.sparrowwallet.sparrow.whirlpool.WhirlpoolServices;
|
||||||
|
import javafx.application.Application;
|
||||||
import javafx.application.Platform;
|
import javafx.application.Platform;
|
||||||
import javafx.beans.property.BooleanProperty;
|
import javafx.beans.property.BooleanProperty;
|
||||||
import javafx.beans.property.SimpleBooleanProperty;
|
import javafx.beans.property.SimpleBooleanProperty;
|
||||||
|
@ -101,7 +102,7 @@ public class AppServices {
|
||||||
|
|
||||||
private static PayNymService payNymService;
|
private static PayNymService payNymService;
|
||||||
|
|
||||||
private final MainApp application;
|
private final Application application;
|
||||||
|
|
||||||
private final Map<Window, List<WalletTabData>> walletWindows = new LinkedHashMap<>();
|
private final Map<Window, List<WalletTabData>> walletWindows = new LinkedHashMap<>();
|
||||||
|
|
||||||
|
@ -175,7 +176,7 @@ public class AppServices {
|
||||||
openFiles(event.getFiles(), null);
|
openFiles(event.getFiles(), null);
|
||||||
};
|
};
|
||||||
|
|
||||||
private AppServices(MainApp application, InteractionServices interactionServices) {
|
private AppServices(Application application, InteractionServices interactionServices) {
|
||||||
this.application = application;
|
this.application = application;
|
||||||
this.interactionServices = interactionServices;
|
this.interactionServices = interactionServices;
|
||||||
EventManager.get().register(this);
|
EventManager.get().register(this);
|
||||||
|
@ -502,11 +503,11 @@ public class AppServices {
|
||||||
return proxy;
|
return proxy;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void initialize(MainApp application) {
|
public static void initialize(Application application) {
|
||||||
INSTANCE = new AppServices(application, new DefaultInteractionServices());
|
INSTANCE = new AppServices(application, new DefaultInteractionServices());
|
||||||
}
|
}
|
||||||
|
|
||||||
static void initialize(MainApp application, InteractionServices interactionServices) {
|
public static void initialize(Application application, InteractionServices interactionServices) {
|
||||||
INSTANCE = new AppServices(application, interactionServices);
|
INSTANCE = new AppServices(application, interactionServices);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -582,7 +583,7 @@ public class AppServices {
|
||||||
return (node.getScene() != null && node.getScene().getWindow().getHeight() < 768);
|
return (node.getScene() != null && node.getScene().getWindow().getHeight() < 768);
|
||||||
}
|
}
|
||||||
|
|
||||||
public MainApp getApplication() {
|
public Application getApplication() {
|
||||||
return application;
|
return application;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,33 +3,21 @@ package com.sparrowwallet.sparrow;
|
||||||
import com.beust.jcommander.JCommander;
|
import com.beust.jcommander.JCommander;
|
||||||
import com.sparrowwallet.drongo.Drongo;
|
import com.sparrowwallet.drongo.Drongo;
|
||||||
import com.sparrowwallet.drongo.Network;
|
import com.sparrowwallet.drongo.Network;
|
||||||
import com.sparrowwallet.drongo.wallet.Wallet;
|
|
||||||
import com.sparrowwallet.sparrow.glyphfont.FontAwesome5;
|
|
||||||
import com.sparrowwallet.sparrow.glyphfont.FontAwesome5Brands;
|
|
||||||
import com.sparrowwallet.sparrow.io.Config;
|
|
||||||
import com.sparrowwallet.sparrow.io.Storage;
|
import com.sparrowwallet.sparrow.io.Storage;
|
||||||
import com.sparrowwallet.sparrow.net.PublicElectrumServer;
|
|
||||||
import com.sparrowwallet.sparrow.net.ServerType;
|
|
||||||
import com.sparrowwallet.sparrow.preferences.PreferenceGroup;
|
|
||||||
import com.sparrowwallet.sparrow.preferences.PreferencesDialog;
|
|
||||||
import com.sparrowwallet.sparrow.instance.InstanceException;
|
import com.sparrowwallet.sparrow.instance.InstanceException;
|
||||||
import com.sparrowwallet.sparrow.instance.InstanceList;
|
import com.sparrowwallet.sparrow.instance.InstanceList;
|
||||||
import com.sparrowwallet.sparrow.terminal.SparrowTerminal;
|
import com.sparrowwallet.sparrow.terminal.SparrowTerminal;
|
||||||
import com.sparrowwallet.sparrow.terminal.TerminalInteractionServices;
|
import com.sparrowwallet.sparrow.terminal.TerminalInteractionServices;
|
||||||
|
import com.sun.javafx.application.PlatformImpl;
|
||||||
import javafx.application.Application;
|
import javafx.application.Application;
|
||||||
import javafx.scene.text.Font;
|
|
||||||
import javafx.stage.Stage;
|
|
||||||
import org.controlsfx.glyphfont.GlyphFontRegistry;
|
|
||||||
import org.controlsfx.tools.Platform;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.slf4j.bridge.SLF4JBridgeHandler;
|
import org.slf4j.bridge.SLF4JBridgeHandler;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
public class MainApp extends Application {
|
public class MainApp {
|
||||||
public static final String APP_ID = "com.sparrowwallet.sparrow";
|
public static final String APP_ID = "com.sparrowwallet.sparrow";
|
||||||
public static final String APP_NAME = "Sparrow";
|
public static final String APP_NAME = "Sparrow";
|
||||||
public static final String APP_VERSION = "1.6.6";
|
public static final String APP_VERSION = "1.6.6";
|
||||||
|
@ -37,105 +25,8 @@ public class MainApp extends Application {
|
||||||
public static final String APP_HOME_PROPERTY = "sparrow.home";
|
public static final String APP_HOME_PROPERTY = "sparrow.home";
|
||||||
public static final String NETWORK_ENV_PROPERTY = "SPARROW_NETWORK";
|
public static final String NETWORK_ENV_PROPERTY = "SPARROW_NETWORK";
|
||||||
|
|
||||||
private Stage mainStage;
|
|
||||||
|
|
||||||
private static SparrowInstance sparrowInstance;
|
private static SparrowInstance sparrowInstance;
|
||||||
|
|
||||||
@Override
|
|
||||||
public void init() throws Exception {
|
|
||||||
Thread.setDefaultUncaughtExceptionHandler((t, e) -> {
|
|
||||||
if(e instanceof IndexOutOfBoundsException && Arrays.stream(e.getStackTrace()).anyMatch(element -> element.getClassName().equals("javafx.scene.chart.BarChart"))) {
|
|
||||||
LoggerFactory.getLogger(MainApp.class).debug("Exception in thread \"" + t.getName() + "\"", e);;
|
|
||||||
} else {
|
|
||||||
LoggerFactory.getLogger(MainApp.class).error("Exception in thread \"" + t.getName() + "\"", e);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
super.init();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void start(Stage stage) throws Exception {
|
|
||||||
this.mainStage = stage;
|
|
||||||
|
|
||||||
GlyphFontRegistry.register(new FontAwesome5());
|
|
||||||
GlyphFontRegistry.register(new FontAwesome5Brands());
|
|
||||||
Font.loadFont(AppServices.class.getResourceAsStream("/font/RobotoMono-Regular.ttf"), 13);
|
|
||||||
|
|
||||||
AppServices.initialize(this);
|
|
||||||
|
|
||||||
boolean createNewWallet = false;
|
|
||||||
Mode mode = Config.get().getMode();
|
|
||||||
if(mode == null) {
|
|
||||||
WelcomeDialog welcomeDialog = new WelcomeDialog();
|
|
||||||
Optional<Mode> optionalMode = welcomeDialog.showAndWait();
|
|
||||||
if(optionalMode.isPresent()) {
|
|
||||||
mode = optionalMode.get();
|
|
||||||
Config.get().setMode(mode);
|
|
||||||
|
|
||||||
if(mode.equals(Mode.ONLINE)) {
|
|
||||||
PreferencesDialog preferencesDialog = new PreferencesDialog(PreferenceGroup.SERVER, true);
|
|
||||||
Optional<Boolean> optNewWallet = preferencesDialog.showAndWait();
|
|
||||||
createNewWallet = optNewWallet.isPresent() && optNewWallet.get();
|
|
||||||
} else if(Network.get() == Network.MAINNET) {
|
|
||||||
Config.get().setServerType(ServerType.PUBLIC_ELECTRUM_SERVER);
|
|
||||||
List<PublicElectrumServer> servers = PublicElectrumServer.getServers();
|
|
||||||
Config.get().setPublicElectrumServer(servers.get(new Random().nextInt(servers.size())).getServer());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(Config.get().getServerType() == null && Config.get().getCoreServer() == null && Config.get().getElectrumServer() != null) {
|
|
||||||
Config.get().setServerType(ServerType.ELECTRUM_SERVER);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(Config.get().getHdCapture() == null && Platform.getCurrent() == Platform.OSX) {
|
|
||||||
Config.get().setHdCapture(Boolean.TRUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
System.setProperty(Wallet.ALLOW_DERIVATIONS_MATCHING_OTHER_SCRIPT_TYPES_PROPERTY, Boolean.toString(!Config.get().isValidateDerivationPaths()));
|
|
||||||
|
|
||||||
if(Config.get().getAppHeight() != null && Config.get().getAppWidth() != null) {
|
|
||||||
mainStage.setWidth(Config.get().getAppWidth());
|
|
||||||
mainStage.setHeight(Config.get().getAppHeight());
|
|
||||||
}
|
|
||||||
|
|
||||||
AppController appController = AppServices.newAppWindow(stage);
|
|
||||||
|
|
||||||
if(createNewWallet) {
|
|
||||||
appController.newWallet(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
List<File> recentWalletFiles = Config.get().getRecentWalletFiles();
|
|
||||||
if(recentWalletFiles != null) {
|
|
||||||
//Preserve wallet order as far as possible. Unencrypted wallets will still be opened first.
|
|
||||||
List<File> encryptedWalletFiles = recentWalletFiles.stream().filter(Storage::isEncrypted).collect(Collectors.toList());
|
|
||||||
List<File> sortedWalletFiles = new ArrayList<>(recentWalletFiles);
|
|
||||||
sortedWalletFiles.removeAll(encryptedWalletFiles);
|
|
||||||
sortedWalletFiles.addAll(encryptedWalletFiles);
|
|
||||||
|
|
||||||
for(File walletFile : sortedWalletFiles) {
|
|
||||||
if(walletFile.exists()) {
|
|
||||||
appController.openWalletFile(walletFile, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
AppServices.openFileUriArguments(stage);
|
|
||||||
|
|
||||||
AppServices.get().start();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void stop() throws Exception {
|
|
||||||
AppServices.get().stop();
|
|
||||||
Config.get().setAppWidth(mainStage.getWidth());
|
|
||||||
Config.get().setAppHeight(mainStage.getHeight());
|
|
||||||
mainStage.close();
|
|
||||||
if(sparrowInstance != null) {
|
|
||||||
sparrowInstance.freeLock();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void main(String[] argv) {
|
public static void main(String[] argv) {
|
||||||
Args args = new Args();
|
Args args = new Args();
|
||||||
JCommander jCommander = JCommander.newBuilder().addObject(args).programName(APP_NAME.toLowerCase(Locale.ROOT)).acceptUnknownOptions(true).build();
|
JCommander jCommander = JCommander.newBuilder().addObject(args).programName(APP_NAME.toLowerCase(Locale.ROOT)).acceptUnknownOptions(true).build();
|
||||||
|
@ -182,9 +73,8 @@ public class MainApp extends Application {
|
||||||
}
|
}
|
||||||
|
|
||||||
if(args.terminal) {
|
if(args.terminal) {
|
||||||
MainApp mainApp = new MainApp();
|
PlatformImpl.setTaskbarApplication(false);
|
||||||
AppServices.initialize(mainApp, new TerminalInteractionServices());
|
Application.launch(SparrowTerminal.class, argv);
|
||||||
SparrowTerminal.startTerminal();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,14 +93,18 @@ public class MainApp extends Application {
|
||||||
|
|
||||||
SLF4JBridgeHandler.removeHandlersForRootLogger();
|
SLF4JBridgeHandler.removeHandlersForRootLogger();
|
||||||
SLF4JBridgeHandler.install();
|
SLF4JBridgeHandler.install();
|
||||||
com.sun.javafx.application.LauncherImpl.launchApplication(MainApp.class, MainAppPreloader.class, argv);
|
com.sun.javafx.application.LauncherImpl.launchApplication(Sparrow.class, MainAppPreloader.class, argv);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static SparrowInstance getSparrowInstance() {
|
||||||
|
return sparrowInstance;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Logger getLogger() {
|
private static Logger getLogger() {
|
||||||
return LoggerFactory.getLogger(MainApp.class);
|
return LoggerFactory.getLogger(MainApp.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class SparrowInstance extends InstanceList {
|
public static class SparrowInstance extends InstanceList {
|
||||||
private final List<String> fileUriArguments;
|
private final List<String> fileUriArguments;
|
||||||
|
|
||||||
public SparrowInstance(List<String> fileUriArguments) {
|
public SparrowInstance(List<String> fileUriArguments) {
|
||||||
|
|
122
src/main/java/com/sparrowwallet/sparrow/Sparrow.java
Normal file
122
src/main/java/com/sparrowwallet/sparrow/Sparrow.java
Normal file
|
@ -0,0 +1,122 @@
|
||||||
|
package com.sparrowwallet.sparrow;
|
||||||
|
|
||||||
|
import com.sparrowwallet.drongo.Network;
|
||||||
|
import com.sparrowwallet.drongo.wallet.Wallet;
|
||||||
|
import com.sparrowwallet.sparrow.glyphfont.FontAwesome5;
|
||||||
|
import com.sparrowwallet.sparrow.glyphfont.FontAwesome5Brands;
|
||||||
|
import com.sparrowwallet.sparrow.io.Config;
|
||||||
|
import com.sparrowwallet.sparrow.io.Storage;
|
||||||
|
import com.sparrowwallet.sparrow.net.PublicElectrumServer;
|
||||||
|
import com.sparrowwallet.sparrow.net.ServerType;
|
||||||
|
import com.sparrowwallet.sparrow.preferences.PreferenceGroup;
|
||||||
|
import com.sparrowwallet.sparrow.preferences.PreferencesDialog;
|
||||||
|
import javafx.application.Application;
|
||||||
|
import javafx.scene.text.Font;
|
||||||
|
import javafx.stage.Stage;
|
||||||
|
import org.controlsfx.glyphfont.GlyphFontRegistry;
|
||||||
|
import org.controlsfx.tools.Platform;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public class Sparrow extends Application {
|
||||||
|
private Stage mainStage;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws Exception {
|
||||||
|
Thread.setDefaultUncaughtExceptionHandler((t, e) -> {
|
||||||
|
if(e instanceof IndexOutOfBoundsException && Arrays.stream(e.getStackTrace()).anyMatch(element -> element.getClassName().equals("javafx.scene.chart.BarChart"))) {
|
||||||
|
LoggerFactory.getLogger(MainApp.class).debug("Exception in thread \"" + t.getName() + "\"", e);;
|
||||||
|
} else {
|
||||||
|
LoggerFactory.getLogger(MainApp.class).error("Exception in thread \"" + t.getName() + "\"", e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
super.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void start(Stage stage) throws Exception {
|
||||||
|
this.mainStage = stage;
|
||||||
|
|
||||||
|
GlyphFontRegistry.register(new FontAwesome5());
|
||||||
|
GlyphFontRegistry.register(new FontAwesome5Brands());
|
||||||
|
Font.loadFont(AppServices.class.getResourceAsStream("/font/RobotoMono-Regular.ttf"), 13);
|
||||||
|
|
||||||
|
AppServices.initialize(this);
|
||||||
|
|
||||||
|
boolean createNewWallet = false;
|
||||||
|
Mode mode = Config.get().getMode();
|
||||||
|
if(mode == null) {
|
||||||
|
WelcomeDialog welcomeDialog = new WelcomeDialog();
|
||||||
|
Optional<Mode> optionalMode = welcomeDialog.showAndWait();
|
||||||
|
if(optionalMode.isPresent()) {
|
||||||
|
mode = optionalMode.get();
|
||||||
|
Config.get().setMode(mode);
|
||||||
|
|
||||||
|
if(mode.equals(Mode.ONLINE)) {
|
||||||
|
PreferencesDialog preferencesDialog = new PreferencesDialog(PreferenceGroup.SERVER, true);
|
||||||
|
Optional<Boolean> optNewWallet = preferencesDialog.showAndWait();
|
||||||
|
createNewWallet = optNewWallet.isPresent() && optNewWallet.get();
|
||||||
|
} else if(Network.get() == Network.MAINNET) {
|
||||||
|
Config.get().setServerType(ServerType.PUBLIC_ELECTRUM_SERVER);
|
||||||
|
List<PublicElectrumServer> servers = PublicElectrumServer.getServers();
|
||||||
|
Config.get().setPublicElectrumServer(servers.get(new Random().nextInt(servers.size())).getServer());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(Config.get().getServerType() == null && Config.get().getCoreServer() == null && Config.get().getElectrumServer() != null) {
|
||||||
|
Config.get().setServerType(ServerType.ELECTRUM_SERVER);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(Config.get().getHdCapture() == null && Platform.getCurrent() == Platform.OSX) {
|
||||||
|
Config.get().setHdCapture(Boolean.TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
System.setProperty(Wallet.ALLOW_DERIVATIONS_MATCHING_OTHER_SCRIPT_TYPES_PROPERTY, Boolean.toString(!Config.get().isValidateDerivationPaths()));
|
||||||
|
|
||||||
|
if(Config.get().getAppHeight() != null && Config.get().getAppWidth() != null) {
|
||||||
|
mainStage.setWidth(Config.get().getAppWidth());
|
||||||
|
mainStage.setHeight(Config.get().getAppHeight());
|
||||||
|
}
|
||||||
|
|
||||||
|
AppController appController = AppServices.newAppWindow(stage);
|
||||||
|
|
||||||
|
if(createNewWallet) {
|
||||||
|
appController.newWallet(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
List<File> recentWalletFiles = Config.get().getRecentWalletFiles();
|
||||||
|
if(recentWalletFiles != null) {
|
||||||
|
//Preserve wallet order as far as possible. Unencrypted wallets will still be opened first.
|
||||||
|
List<File> encryptedWalletFiles = recentWalletFiles.stream().filter(Storage::isEncrypted).collect(Collectors.toList());
|
||||||
|
List<File> sortedWalletFiles = new ArrayList<>(recentWalletFiles);
|
||||||
|
sortedWalletFiles.removeAll(encryptedWalletFiles);
|
||||||
|
sortedWalletFiles.addAll(encryptedWalletFiles);
|
||||||
|
|
||||||
|
for(File walletFile : sortedWalletFiles) {
|
||||||
|
if(walletFile.exists()) {
|
||||||
|
appController.openWalletFile(walletFile, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AppServices.openFileUriArguments(stage);
|
||||||
|
|
||||||
|
AppServices.get().start();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void stop() throws Exception {
|
||||||
|
AppServices.get().stop();
|
||||||
|
Config.get().setAppWidth(mainStage.getWidth());
|
||||||
|
Config.get().setAppHeight(mainStage.getHeight());
|
||||||
|
mainStage.close();
|
||||||
|
MainApp.SparrowInstance sparrowInstance = MainApp.getSparrowInstance();
|
||||||
|
if(sparrowInstance != null) {
|
||||||
|
sparrowInstance.freeLock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -11,7 +11,9 @@ import com.sparrowwallet.drongo.wallet.Wallet;
|
||||||
import com.sparrowwallet.sparrow.AppServices;
|
import com.sparrowwallet.sparrow.AppServices;
|
||||||
import com.sparrowwallet.sparrow.EventManager;
|
import com.sparrowwallet.sparrow.EventManager;
|
||||||
import com.sparrowwallet.sparrow.terminal.wallet.WalletData;
|
import com.sparrowwallet.sparrow.terminal.wallet.WalletData;
|
||||||
|
import javafx.application.Application;
|
||||||
import javafx.application.Platform;
|
import javafx.application.Platform;
|
||||||
|
import javafx.stage.Stage;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
@ -19,22 +21,35 @@ import java.io.IOException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
public class SparrowTerminal {
|
public class SparrowTerminal extends Application {
|
||||||
private static final Logger log = LoggerFactory.getLogger(SparrowTerminal.class);
|
private static final Logger log = LoggerFactory.getLogger(SparrowTerminal.class);
|
||||||
|
|
||||||
private static SparrowTerminal sparrowTerminal;
|
private static SparrowTerminal sparrowTerminal;
|
||||||
|
|
||||||
private final Terminal terminal;
|
private Terminal terminal;
|
||||||
private final Screen screen;
|
private Screen screen;
|
||||||
private final SparrowTextGui gui;
|
private SparrowTextGui gui;
|
||||||
|
|
||||||
private final Map<Wallet, WalletData> walletData = new HashMap<>();
|
private final Map<Wallet, WalletData> walletData = new HashMap<>();
|
||||||
|
|
||||||
private SparrowTerminal() throws IOException {
|
@Override
|
||||||
|
public void init() throws Exception {
|
||||||
|
AppServices.initialize(this, new TerminalInteractionServices());
|
||||||
|
|
||||||
this.terminal = new DefaultTerminalFactory().createTerminal();
|
this.terminal = new DefaultTerminalFactory().createTerminal();
|
||||||
this.screen = new TerminalScreen(terminal);
|
this.screen = new TerminalScreen(terminal);
|
||||||
this.gui = new SparrowTextGui(this, screen, new DefaultWindowManager(), new EmptySpace(TextColor.ANSI.BLUE));
|
this.gui = new SparrowTextGui(this, screen, new DefaultWindowManager(), new EmptySpace(TextColor.ANSI.BLUE));
|
||||||
EventManager.get().register(gui);
|
EventManager.get().register(gui);
|
||||||
|
|
||||||
|
sparrowTerminal = this;
|
||||||
|
|
||||||
|
getScreen().startScreen();
|
||||||
|
getGui().getMainWindow().waitUntilClosed();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void start(Stage primaryStage) throws Exception {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Screen getScreen() {
|
public Screen getScreen() {
|
||||||
|
@ -62,17 +77,6 @@ public class SparrowTerminal {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void startTerminal() {
|
|
||||||
try {
|
|
||||||
sparrowTerminal = new SparrowTerminal();
|
|
||||||
sparrowTerminal.getScreen().startScreen();
|
|
||||||
sparrowTerminal.getGui().getMainWindow().waitUntilClosed();
|
|
||||||
} catch(Exception e) {
|
|
||||||
log.error("Could not start terminal", e);
|
|
||||||
System.err.println("Could not start terminal: " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static SparrowTerminal get() {
|
public static SparrowTerminal get() {
|
||||||
return sparrowTerminal;
|
return sparrowTerminal;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue