gradle #252
47
build.gradle
47
build.gradle
@ -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)
|
||||||
|
In neuem Issue referenzieren
Einen Benutzer sperren