try to make --restore work
This commit is contained in:
parent
6dd0052dcf
commit
75c89281eb
4
Makefile
4
Makefile
|
@ -3,7 +3,7 @@
|
||||||
VERSION = $(shell git describe --tags)
|
VERSION = $(shell git describe --tags)
|
||||||
BUILDTIME = $(shell date +%Y.%m.%d)
|
BUILDTIME = $(shell date +%Y.%m.%d)
|
||||||
|
|
||||||
default: goimports verbose
|
default: install
|
||||||
|
|
||||||
build:
|
build:
|
||||||
GO111MODULE=off go build \
|
GO111MODULE=off go build \
|
||||||
|
@ -14,7 +14,7 @@ verbose:
|
||||||
GO111MODULE=off go install -v -x \
|
GO111MODULE=off go install -v -x \
|
||||||
-ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}"
|
-ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}"
|
||||||
|
|
||||||
install:
|
install: goimports
|
||||||
GO111MODULE=off go install \
|
GO111MODULE=off go install \
|
||||||
-ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}"
|
-ldflags "-X main.VERSION=${VERSION} -X main.BUILDTIME=${BUILDTIME} -X gui.GUIVERSION=${VERSION}"
|
||||||
|
|
||||||
|
|
1
argv.go
1
argv.go
|
@ -12,6 +12,7 @@ var argv args
|
||||||
type args struct {
|
type args struct {
|
||||||
Restore string `arg:"--restore" help:"restore terminal windows from a config file"`
|
Restore string `arg:"--restore" help:"restore terminal windows from a config file"`
|
||||||
Save *EmptyCmd `arg:"subcommand:save" help:"save current window geometries to the your config file"`
|
Save *EmptyCmd `arg:"subcommand:save" help:"save current window geometries to the your config file"`
|
||||||
|
DumpX *EmptyCmd `arg:"subcommand:dumpx" help:"show your current window geometries"`
|
||||||
Dump *EmptyCmd `arg:"subcommand:dump" help:"show your current window geometries"`
|
Dump *EmptyCmd `arg:"subcommand:dump" help:"show your current window geometries"`
|
||||||
Force bool `arg:"--force" help:"try to strong arm things"`
|
Force bool `arg:"--force" help:"try to strong arm things"`
|
||||||
Verbose bool `arg:"--verbose" help:"show more output"`
|
Verbose bool `arg:"--verbose" help:"show more output"`
|
||||||
|
|
|
@ -6,6 +6,9 @@ package main
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"go.wit.com/lib/gui/shell"
|
||||||
)
|
)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -28,7 +31,7 @@ func (args) doBashAuto() {
|
||||||
default:
|
default:
|
||||||
if argv.BashAuto[0] == ARGNAME {
|
if argv.BashAuto[0] == ARGNAME {
|
||||||
// list the subcommands here
|
// list the subcommands here
|
||||||
fmt.Println("--restore save dump")
|
fmt.Println("--restore save dump dumpx")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
|
@ -36,6 +39,10 @@ func (args) doBashAuto() {
|
||||||
|
|
||||||
// prints help to STDERR // TODO: move everything below this to go-args
|
// prints help to STDERR // TODO: move everything below this to go-args
|
||||||
func (args) doBashHelp() {
|
func (args) doBashHelp() {
|
||||||
|
if len(argv.BashAuto) < 2 {
|
||||||
|
fmt.Fprintf(os.Stderr, "something went wrong with the GO args autocomplete in %s\n", ARGNAME)
|
||||||
|
return
|
||||||
|
}
|
||||||
if argv.BashAuto[1] != "''" {
|
if argv.BashAuto[1] != "''" {
|
||||||
// if this is not blank, then the user has typed something
|
// if this is not blank, then the user has typed something
|
||||||
return
|
return
|
||||||
|
@ -55,33 +62,48 @@ func (args) doBashHelp() {
|
||||||
|
|
||||||
// complete -F forge --bash forge
|
// complete -F forge --bash forge
|
||||||
func (args) doBash() {
|
func (args) doBash() {
|
||||||
fmt.Println("# add this in your bashrc:")
|
if homeDir, err := os.UserHomeDir(); err == nil {
|
||||||
fmt.Println("")
|
filename := filepath.Join(homeDir, ".local/share/bash-completion/completions", ARGNAME)
|
||||||
fmt.Println("# todo: add this to go-arg as a 'hidden' go-arg option --bash")
|
if !shell.Exists(filename) {
|
||||||
fmt.Println("#")
|
if f, err := os.OpenFile(filename, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644); err == nil {
|
||||||
fmt.Println("# Put the below in the file: ~/.local/share/bash-completion/completions/" + ARGNAME)
|
f.Write([]byte(makeBashCompletionText(ARGNAME)))
|
||||||
fmt.Println("#")
|
f.Close()
|
||||||
fmt.Println("# todo: make this output work/parse with:")
|
}
|
||||||
fmt.Println("# complete -C " + ARGNAME + " --bash go")
|
}
|
||||||
fmt.Println("")
|
}
|
||||||
fmt.Println("_" + ARGNAME + "_complete()")
|
fmt.Println(makeBashCompletionText(ARGNAME))
|
||||||
fmt.Println("{")
|
}
|
||||||
fmt.Println(" # sets local to this func vars")
|
|
||||||
fmt.Println(" local cur prev all")
|
func makeBashCompletionText(argname string) string {
|
||||||
fmt.Println(" cur=${COMP_WORDS[COMP_CWORD]}")
|
var out string
|
||||||
fmt.Println(" prev=${COMP_WORDS[COMP_CWORD-1]}")
|
|
||||||
fmt.Println(" all=${COMP_WORDS[@]}")
|
out += fmt.Sprintf("# add this in your bashrc:\n")
|
||||||
fmt.Println("")
|
out += fmt.Sprintf("\n")
|
||||||
fmt.Println(" # this is where we generate the go-arg output")
|
out += fmt.Sprintf("# todo: add this to go-arg as a 'hidden' go-arg option --bash\n")
|
||||||
fmt.Println(" GOARGS=$(" + ARGNAME + " --auto-complete $prev \\'$cur\\' $all)")
|
out += fmt.Sprintf("#\n")
|
||||||
fmt.Println("")
|
out += fmt.Sprintf("# Put the below in the file: ~/.local/share/bash-completion/completions/%s\n", argname)
|
||||||
fmt.Println(" # this compares the command line input from the user")
|
out += fmt.Sprintf("#\n")
|
||||||
fmt.Println(" # to whatever strings we output")
|
out += fmt.Sprintf("# todo: make this output work/parse with:\n")
|
||||||
fmt.Println(" COMPREPLY=( $(compgen -W \"$GOARGS\" -- $cur) ) # THIS WORKS")
|
out += fmt.Sprintf("# complete -C " + argname + " --bash go\n")
|
||||||
fmt.Println(" return 0")
|
out += fmt.Sprintf("\n")
|
||||||
fmt.Println("}")
|
out += fmt.Sprintf("_" + argname + "_complete()\n")
|
||||||
fmt.Println("complete -F _" + ARGNAME + "_complete " + ARGNAME)
|
out += fmt.Sprintf("{\n")
|
||||||
fmt.Println("")
|
out += fmt.Sprintf(" # sets local to this func vars\n")
|
||||||
fmt.Println("# copy and paste the above into your bash shell should work")
|
out += fmt.Sprintf(" local cur prev all\n")
|
||||||
os.Exit(0)
|
out += fmt.Sprintf(" cur=${COMP_WORDS[COMP_CWORD]}\n")
|
||||||
|
out += fmt.Sprintf(" prev=${COMP_WORDS[COMP_CWORD-1]}\n")
|
||||||
|
out += fmt.Sprintf(" all=${COMP_WORDS[@]}\n")
|
||||||
|
out += fmt.Sprintf("\n")
|
||||||
|
out += fmt.Sprintf(" # this is where we generate the go-arg output\n")
|
||||||
|
out += fmt.Sprintf(" GOARGS=$(" + argname + " --auto-complete $prev \\'$cur\\' $all)\n")
|
||||||
|
out += fmt.Sprintf("\n")
|
||||||
|
out += fmt.Sprintf(" # this compares the command line input from the user\n")
|
||||||
|
out += fmt.Sprintf(" # to whatever strings we output\n")
|
||||||
|
out += fmt.Sprintf(" COMPREPLY=( $(compgen -W \"$GOARGS\" -- $cur) ) # THIS WORKS\n")
|
||||||
|
out += fmt.Sprintf(" return 0\n")
|
||||||
|
out += fmt.Sprintf("}\n")
|
||||||
|
out += fmt.Sprintf("complete -F _%s_complete %s\n", argname, argname)
|
||||||
|
out += fmt.Sprintf("\n")
|
||||||
|
out += fmt.Sprintf("# copy and paste the above into your bash shell should work\n")
|
||||||
|
return out
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ import (
|
||||||
"github.com/BurntSushi/xgb/xproto"
|
"github.com/BurntSushi/xgb/xproto"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func doDumpX() {
|
||||||
conn, err := xgb.NewConn()
|
conn, err := xgb.NewConn()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Failed to connect to X server:", err)
|
fmt.Println("Failed to connect to X server:", err)
|
16
main.go
16
main.go
|
@ -6,6 +6,7 @@ package main
|
||||||
// An app to submit patches for the 30 GO GUI repos
|
// An app to submit patches for the 30 GO GUI repos
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
"go.wit.com/dev/alexflint/arg"
|
"go.wit.com/dev/alexflint/arg"
|
||||||
|
@ -18,7 +19,7 @@ var VERSION string
|
||||||
var BUILDTIME string
|
var BUILDTIME string
|
||||||
|
|
||||||
// used for shell auto completion
|
// used for shell auto completion
|
||||||
var ARGNAME string = "startxplacment"
|
var ARGNAME string = "startxplacement"
|
||||||
|
|
||||||
// using this for now. triggers config save
|
// using this for now. triggers config save
|
||||||
var configSave bool
|
var configSave bool
|
||||||
|
@ -39,9 +40,18 @@ func main() {
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if argv.DumpX != nil {
|
||||||
|
doDumpX()
|
||||||
|
}
|
||||||
|
|
||||||
if argv.Dump != nil {
|
if argv.Dump != nil {
|
||||||
// doDump()
|
// 2. Get the current state of all terminal windows.
|
||||||
log.Info("dump here")
|
currentStates, err := getCurrentState()
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("Error getting current window state: %v\n", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Printf("%v\n", currentStates)
|
||||||
okExit("")
|
okExit("")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue