SteamWar/BauSystem
Archiviert
13
0

gradle #252

Manuell gemergt
SteamWar hat 35 Commits von gradle nach master 2021-05-22 21:04:38 +02:00 zusammengeführt
Nur Änderungen aus Commit af2585a3cd werden angezeigt - Alle Commits anzeigen

Datei anzeigen

@ -18,6 +18,7 @@
*/ */
import org.apache.tools.ant.taskdefs.condition.Os import org.apache.tools.ant.taskdefs.condition.Os
import org.codehaus.groovy.runtime.ProcessGroovyMethods
plugins { plugins {
// Adding the base plugin fixes the following gradle warnings in IntelliJ: // Adding the base plugin fixes the following gradle warnings in IntelliJ:
@ -97,15 +98,21 @@ if (project.hasProperty("hostname")) {
group "Steamwar" group "Steamwar"
doLast { doLast {
shell("scp ${libs}/${jarName} ${hostname}:~/Dev1.15/plugins") await(shell("scp ${libs}/${jarName} ${hostname}:~/Dev1.15/plugins"))
if (!answer("Start DEV server?")) { if (!answer("Start DEV server?")) {
return return
} }
shell("ssh ${hostname} \"./mc Dev1.15\"") serverStart()
} }
} }
} }
def await(Process proc) {
def out = new StringBuilder()
def err = new StringBuilder()
proc.waitForProcessOutput(out, err)
}
/** /**
* Executes a shell command and returns the stdout result. * Executes a shell command and returns the stdout result.
* *
@ -119,13 +126,39 @@ def shell(String command) {
} else { } else {
proc = ["cmd", "/c", command].execute() proc = ["cmd", "/c", command].execute()
} }
def out = new StringBuilder() return proc
def err = new StringBuilder()
proc.waitForProcessOutput(out, err)
return [out.toString().trim(), err.toString().trim(), proc.exitValue()]
} }
def serverStart() {
def proc = shell("ssh ${hostname} \"./mc Dev1.15\"")
Thread outputThread = proc.consumeProcessOutputStream(System.out)
outputThread.setName("OutputThread")
Thread inputThread = new Thread(new Runnable() {
@Override
void run() {
// Reader reader = System.in.newReader()
Writer writer = proc.getOutputStream().newWriter()
while (true) {
//String s = reader.readLine()
Thread.sleep(10000)
writer.write("stop\n")
writer.flush()
}
}
})
inputThread.setName("InputThread")
inputThread.start()
while (proc.alive) {
Thread.sleep(10)
}
outputThread.interrupt()
inputThread.interrupt()
};
def answer(String question) { def answer(String question) {
while (System.in.available() > 0) System.in.read() while (System.in.available() > 0) System.in.read()
println(question) println(question)