|
|
|
@ -17,6 +17,7 @@ import (
|
|
|
|
|
|
|
|
|
|
"github.com/creack/pty"
|
|
|
|
|
"github.com/gdamore/tcell"
|
|
|
|
|
"github.com/micmonay/keybd_event"
|
|
|
|
|
"github.com/rivo/tview"
|
|
|
|
|
"golang.org/x/crypto/ssh/terminal"
|
|
|
|
|
)
|
|
|
|
@ -25,6 +26,8 @@ var (
|
|
|
|
|
ErrEmptyJSON = errors.New("empty json")
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var kb keybd_event.KeyBonding
|
|
|
|
|
|
|
|
|
|
type Gui struct {
|
|
|
|
|
Tree *Tree
|
|
|
|
|
Navi *Navi
|
|
|
|
@ -43,6 +46,20 @@ func New() *Gui {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (g *Gui) Run(i interface{}) error {
|
|
|
|
|
var err error
|
|
|
|
|
kb, err = keybd_event.NewKeyBonding()
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// For linux, it is very important wait 2 seconds
|
|
|
|
|
//if runtime.GOOS == "linux" {
|
|
|
|
|
// time.Sleep(2 * time.Second)
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
//set keys
|
|
|
|
|
kb.SetKeys(keybd_event.VK_A, keybd_event.VK_B)
|
|
|
|
|
|
|
|
|
|
g.Tree.UpdateView(g, i)
|
|
|
|
|
g.Tree.SetKeybindings(g)
|
|
|
|
|
g.Navi.UpdateView()
|
|
|
|
@ -150,7 +167,6 @@ func (g *Gui) LoadJSON() {
|
|
|
|
|
log.Println(fmt.Sprintf("can't open file: %s", err))
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
defer file.Close()
|
|
|
|
|
|
|
|
|
|
i, err := UnMarshalJSON(file)
|
|
|
|
|
if err != nil {
|
|
|
|
@ -216,7 +232,7 @@ func (g *Gui) SaveJSONToFile(file string) error {
|
|
|
|
|
enc := json.NewEncoder(&buf)
|
|
|
|
|
enc.SetIndent("", " ")
|
|
|
|
|
|
|
|
|
|
if err := enc.Encode(g.MakeJSON(g.Tree.OriginRoot)); err != nil {
|
|
|
|
|
if err := enc.Encode(g.makeJSON(g.Tree.GetRoot())); err != nil {
|
|
|
|
|
log.Println(fmt.Sprintf("can't marshal json: %s", err))
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
@ -229,7 +245,7 @@ func (g *Gui) SaveJSONToFile(file string) error {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (g *Gui) MakeJSON(node *tview.TreeNode) interface{} {
|
|
|
|
|
func (g *Gui) makeJSON(node *tview.TreeNode) interface{} {
|
|
|
|
|
ref := node.GetReference().(Reference)
|
|
|
|
|
children := node.GetChildren()
|
|
|
|
|
|
|
|
|
@ -237,25 +253,22 @@ func (g *Gui) MakeJSON(node *tview.TreeNode) interface{} {
|
|
|
|
|
case Object:
|
|
|
|
|
i := make(map[string]interface{})
|
|
|
|
|
for _, n := range children {
|
|
|
|
|
i[n.GetText()] = g.MakeJSON(n)
|
|
|
|
|
i[n.GetText()] = g.makeJSON(n)
|
|
|
|
|
}
|
|
|
|
|
return i
|
|
|
|
|
case Array:
|
|
|
|
|
var i []interface{}
|
|
|
|
|
for _, n := range children {
|
|
|
|
|
i = append(i, g.MakeJSON(n))
|
|
|
|
|
i = append(i, g.makeJSON(n))
|
|
|
|
|
}
|
|
|
|
|
return i
|
|
|
|
|
case Key:
|
|
|
|
|
if len(node.GetChildren()) == 0 {
|
|
|
|
|
return ""
|
|
|
|
|
}
|
|
|
|
|
v := node.GetChildren()[0]
|
|
|
|
|
if v.GetReference().(Reference).JSONType == Value {
|
|
|
|
|
return g.parseValue(v)
|
|
|
|
|
}
|
|
|
|
|
return map[string]interface{}{
|
|
|
|
|
node.GetText(): g.MakeJSON(v),
|
|
|
|
|
node.GetText(): g.makeJSON(v),
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -351,6 +364,7 @@ func (g *Gui) EditWithEditor() {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
f.Close()
|
|
|
|
|
defer os.RemoveAll(f.Name())
|
|
|
|
|
|
|
|
|
|
if err := g.SaveJSONToFile(f.Name()); err != nil {
|
|
|
|
|
log.Println(fmt.Sprintf("can't write to temp file: %s", err))
|
|
|
|
@ -360,9 +374,8 @@ func (g *Gui) EditWithEditor() {
|
|
|
|
|
|
|
|
|
|
editor := os.Getenv("EDITOR")
|
|
|
|
|
if editor == "" {
|
|
|
|
|
msg := fmt.Sprint("$EDITOR is empty")
|
|
|
|
|
log.Println(msg)
|
|
|
|
|
g.Message(msg, "main", func() {})
|
|
|
|
|
log.Println(fmt.Sprintf("$EDITOR is empty: %s", err))
|
|
|
|
|
g.Message(err.Error(), "main", func() {})
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -422,7 +435,6 @@ func (g *Gui) EditWithEditor() {
|
|
|
|
|
g.Message(err.Error(), "main", func() {})
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
defer f.Close()
|
|
|
|
|
|
|
|
|
|
i, err := UnMarshalJSON(f)
|
|
|
|
|
if err != nil {
|
|
|
|
@ -431,9 +443,12 @@ func (g *Gui) EditWithEditor() {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
os.RemoveAll(f.Name())
|
|
|
|
|
g.Tree.UpdateView(g, i)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
if err := kb.Launching(); err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func UnMarshalJSON(in io.Reader) (interface{}, error) {
|
|
|
|
|