feat(run-pkg): added start-command-pipe listener

This commit is contained in:
Paul Fey 2025-03-05 13:50:06 +01:00
parent 486280fdf3
commit df56747d6d

View file

@ -19,7 +19,7 @@ func main() {
var arguments string
var program string
var workdir string
var exit_code int = 0
var exit_code int = 1
fallback_instance_path, ins_err := get_instance_path()
@ -70,11 +70,37 @@ func main() {
}
ln.Write(cmd)
pipe_running := false
for !pipe_running {
buffer := make([]byte, 1024)
n, err := ln.Read(buffer)
objmap := make(map[string]interface{})
if err == io.EOF {
break
} else if err != nil {
log.Fatal(err)
}
err = json.Unmarshal(buffer[:n], &objmap)
if err != nil {
os.Stdout.Write(buffer[:n])
} else {
command, has := objmap["command"]
if has && command == "start-command-pipe" {
pipe_running = true
break
} else {
os.Stdout.Write(buffer[:n])
}
}
}
go func() {
for {
for pipe_running {
buffer := make([]byte, 1024)
n, err := os.Stdin.Read(buffer)
if err == io.EOF {
pipe_running = false
break
} else if err != nil {
log.Fatal(err)
@ -83,11 +109,12 @@ func main() {
}
}()
func() {
for {
for pipe_running {
buffer := make([]byte, 1024)
n, err := ln.Read(buffer)
objmap := make(map[string]interface{})
if err == io.EOF {
pipe_running = false
break
} else if err != nil {
log.Fatal(err)
@ -101,6 +128,7 @@ func main() {
status_code, has := objmap["status_code"]
if has {
exit_code = int(status_code.(float64))
pipe_running = false
break
} else {
os.Stdout.Write(buffer[:n])