Add ignore line based on regex
This commit is contained in:
parent
1075fac43f
commit
88718390fa
27
src/main.go
27
src/main.go
|
@ -11,6 +11,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"syscall"
|
"syscall"
|
||||||
"log"
|
"log"
|
||||||
|
"regexp"
|
||||||
|
|
||||||
"github.com/creack/pty"
|
"github.com/creack/pty"
|
||||||
)
|
)
|
||||||
|
@ -20,7 +21,7 @@ func main() {
|
||||||
sigs := make(chan os.Signal, 1)
|
sigs := make(chan os.Signal, 1)
|
||||||
signal.Notify(sigs, syscall.SIGTERM)
|
signal.Notify(sigs, syscall.SIGTERM)
|
||||||
|
|
||||||
var minram, maxram, args, stop, jar string
|
var minram, maxram, args, stop, jar, regex string
|
||||||
for _, e := range os.Environ() {
|
for _, e := range os.Environ() {
|
||||||
pair := strings.SplitN(e, "=", 2)
|
pair := strings.SplitN(e, "=", 2)
|
||||||
switch pair[0] {
|
switch pair[0] {
|
||||||
|
@ -34,9 +35,12 @@ func main() {
|
||||||
stop = pair[1]
|
stop = pair[1]
|
||||||
case "JAR":
|
case "JAR":
|
||||||
jar = pair[1]
|
jar = pair[1]
|
||||||
|
case "REGEX":
|
||||||
|
regex = pair[1]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
log.Printf("Ram: Min: %s Max: %s Stop: %s Jar: %s\n\r", minram, maxram, stop, jar)
|
log.Printf("Ram: Min: %s Max: %s Stop: %s Jar: %s\n\r", minram, maxram, stop, jar)
|
||||||
|
|
||||||
|
|
||||||
|
@ -54,8 +58,8 @@ func main() {
|
||||||
log.Printf("Args: %s \n\r", args)
|
log.Printf("Args: %s \n\r", args)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
cmd.Dir = "/server"
|
cmd.Dir = "/server"
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
tty, err := pty.Start(cmd)
|
tty, err := pty.Start(cmd)
|
||||||
ln, _ := net.Listen("tcp", ":8081")
|
ln, _ := net.Listen("tcp", ":8081")
|
||||||
|
|
||||||
|
@ -71,6 +75,7 @@ func main() {
|
||||||
ln.Close()
|
ln.Close()
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
// capture sigterm
|
||||||
go func() {
|
go func() {
|
||||||
sig := <-sigs
|
sig := <-sigs
|
||||||
if sig == syscall.SIGTERM {
|
if sig == syscall.SIGTERM {
|
||||||
|
@ -90,6 +95,22 @@ func main() {
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
filter := regexp.MustCompile(regex)
|
||||||
|
if(regex != "") {
|
||||||
|
scanner := bufio.NewScanner(tty)
|
||||||
|
for scanner.Scan() {
|
||||||
|
text := scanner.Text()
|
||||||
|
if(!filter.MatchString(text)) {
|
||||||
|
fmt.Println(text)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
io.Copy(os.Stdout, tty)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
io.Copy(tty, os.Stdin)
|
io.Copy(tty, os.Stdin)
|
||||||
}()
|
}()
|
||||||
|
|
Loading…
Reference in New Issue