Merge branch 'master'
This commit is contained in:
commit
c460609d8a
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
i3-wrapper*
|
73
main.go
Normal file
73
main.go
Normal file
@ -0,0 +1,73 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"flag"
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"os/exec"
|
||||
"os/signal"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
"syscall"
|
||||
)
|
||||
|
||||
var (
|
||||
envFile = flag.String("env", "$HOME/.config/i3-wrapper/environment", "environment file with variable definitions")
|
||||
)
|
||||
|
||||
var (
|
||||
i3 *os.Process
|
||||
running bool
|
||||
)
|
||||
|
||||
func main() {
|
||||
logFile, err := os.Create(filepath.Join(os.Getenv("HOME"), ".i3.log"))
|
||||
if err != nil {
|
||||
fmt.Fprintln(os.Stderr, err)
|
||||
}
|
||||
defer logFile.Close()
|
||||
|
||||
os.Stdout = logFile
|
||||
os.Stderr = logFile
|
||||
|
||||
fmt.Println("environment file:", os.ExpandEnv(*envFile))
|
||||
|
||||
sigs := make(chan os.Signal, 1)
|
||||
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
|
||||
go func() {
|
||||
sig := <-sigs
|
||||
running = false
|
||||
i3.Signal(sig)
|
||||
}()
|
||||
|
||||
running = true
|
||||
for running {
|
||||
cmd := exec.Command("i3")
|
||||
cmd.Stdin = os.Stdin
|
||||
cmd.Stdout = os.Stdout
|
||||
cmd.Stderr = os.Stderr
|
||||
|
||||
cmd.Env = os.Environ()
|
||||
if envData, err := ioutil.ReadFile(os.ExpandEnv(*envFile)); err == nil {
|
||||
cmd.Env = append(cmd.Env, strings.Split(string(envData), "\n")...)
|
||||
} else {
|
||||
fmt.Println(err)
|
||||
}
|
||||
|
||||
err = cmd.Start()
|
||||
if err != nil {
|
||||
fmt.Fprintln(os.Stderr, err)
|
||||
}
|
||||
i3 = cmd.Process
|
||||
|
||||
err = cmd.Wait()
|
||||
if err != nil {
|
||||
fmt.Fprintln(os.Stderr, err)
|
||||
}
|
||||
|
||||
if _, ok := err.(*exec.ExitError); ok {
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user