Refactor some parts of NewLaunch

This commit is contained in:
icelimetea
2022-04-24 14:45:01 +01:00
parent 5adcc26190
commit c968c1be78
3 changed files with 95 additions and 113 deletions

View File

@ -16,22 +16,24 @@ package org.multimc;/*
import org.multimc.onesix.OneSixLauncher;
import java.io.*;
import java.nio.charset.Charset;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
public class EntryPoint
{
private enum Action
{
Proceed,
Launch,
Abort
}
private final ParamBucket params = new ParamBucket();
private org.multimc.Launcher launcher;
public static void main(String[] args)
{
EntryPoint listener = new EntryPoint();
int retCode = listener.listen();
if (retCode != 0)
{
System.out.println("Exiting with " + retCode);
@ -41,111 +43,92 @@ public class EntryPoint
private Action parseLine(String inData) throws ParseException
{
String[] pair = inData.split(" ", 2);
String[] pair = inData.split("\\s+", 2);
if(pair.length == 1)
{
String command = pair[0];
if (pair[0].equals("launch"))
if (pair.length == 0)
throw new ParseException("Unexpected empty string!");
switch (pair[0]) {
case "launch": {
return Action.Launch;
}
else if (pair[0].equals("abort"))
case "abort": {
return Action.Abort;
}
else throw new ParseException("Error while parsing:" + pair[0]);
}
case "launcher": {
if (pair.length != 2)
throw new ParseException("Expected 2 tokens, got 1!");
if(pair.length != 2)
throw new ParseException("Pair length is not 2.");
if (pair[1].equals("onesix")) {
launcher = new OneSixLauncher();
String command = pair[0];
String param = pair[1];
Utils.log("Using onesix launcher.");
return Action.Proceed;
} else {
throw new ParseException("Invalid launcher type: " + pair[1]);
}
}
default: {
if (pair.length != 2)
throw new ParseException("Error while parsing:" + pair[0]);
params.add(pair[0], pair[1]);
if(command.equals("launcher"))
{
if(param.equals("onesix"))
{
m_launcher = new OneSixLauncher();
Utils.log("Using onesix launcher.");
Utils.log();
return Action.Proceed;
}
else
throw new ParseException("Invalid launcher type: " + param);
}
m_params.add(command, param);
//System.out.println(command + " : " + param);
return Action.Proceed;
}
public int listen()
{
BufferedReader buffer;
try
{
buffer = new BufferedReader(new InputStreamReader(System.in, "UTF-8"));
} catch (UnsupportedEncodingException e)
{
System.err.println("For some reason, your java does not support UTF-8. Consider living in the current century.");
Action action = Action.Proceed;
try (BufferedReader reader = new BufferedReader(new InputStreamReader(
System.in,
StandardCharsets.UTF_8
))) {
String line;
while (action == Action.Proceed) {
if ((line = reader.readLine()) != null) {
action = parseLine(line);
} else {
action = Action.Abort;
}
}
} catch (IOException | ParseException e) {
Utils.log("Launcher ABORT due to exception:");
e.printStackTrace();
return 1;
}
boolean isListening = true;
boolean isAborted = false;
// Main loop
while (isListening)
{
String inData;
try
{
// Read from the pipe one line at a time
inData = buffer.readLine();
if (inData != null)
{
Action a = parseLine(inData);
if(a == Action.Abort)
{
isListening = false;
isAborted = true;
}
if(a == Action.Launch)
{
isListening = false;
}
}
else
{
isListening = false;
isAborted = true;
}
}
catch (IOException e)
{
System.err.println("Launcher ABORT due to IO exception:");
e.printStackTrace();
return 1;
}
catch (ParseException e)
{
System.err.println("Launcher ABORT due to PARSE exception:");
e.printStackTrace();
return 1;
}
}
if(isAborted)
if (action == Action.Abort)
{
System.err.println("Launch aborted by the launcher.");
return 1;
}
if(m_launcher != null)
if (launcher != null)
{
return m_launcher.launch(m_params);
return launcher.launch(params);
}
System.err.println("No valid launcher implementation specified.");
return 1;
}
private ParamBucket m_params = new ParamBucket();
private org.multimc.Launcher m_launcher;
private enum Action {
Proceed,
Launch,
Abort
}
}