diff options
| author | Jeff Carr <[email protected]> | 2025-09-04 14:44:14 -0500 |
|---|---|---|
| committer | Jeff Carr <[email protected]> | 2025-09-04 14:44:14 -0500 |
| commit | 8ab6e8fcdcbb6060ff4870b41c64aa7de68925ef (patch) | |
| tree | 5dc0d3b51178250c5c448766f2e8fd70c61e631c /init.go | |
| parent | 709094a80f9bf51485df9dc215688b9a4c9dbe54 (diff) | |
fixes to make the GUI plugins more reliablev0.22.51
Diffstat (limited to 'init.go')
| -rw-r--r-- | init.go | 28 |
1 files changed, 16 insertions, 12 deletions
@@ -341,7 +341,7 @@ func NoGui() bool { } // try to load andlabs, if that doesn't work, fall back to the console -func (n *Node) Default() *Node { +func (n *Node) Default() (string, error) { var err error // used to check if plugins load or not if argGui.GuiPluginHack != "" { @@ -352,19 +352,21 @@ func (n *Node) Default() *Node { if argGui.NoGui { log.Log(WARN, "--no-gui chill Winston. I don't need no gui") - return n + return "", nil } if argGui.GuiPlugin != "" { log.Log(WARN, "New.Default() try toolkit =", argGui.GuiPlugin) if n, err = n.LoadToolkit(argGui.GuiPlugin); err == nil { - return n + return argGui.GuiPlugin, nil } - log.Log(WARN, "LoadToolkit() failed for =", argGui.GuiPlugin) - return nil + log.Log(WARN, "") + log.Log(WARN, "The GUI golang plugins did not load for the", argGui.GuiPlugin) + log.Log(WARN, "GO Plugin error:", err) + return argGui.GuiPlugin, err } if me.appPlugin != "" { if n, err = n.LoadToolkit(me.appPlugin); err == nil { - return n + return me.appPlugin, nil } } @@ -374,17 +376,18 @@ func (n *Node) Default() *Node { log.Log(WARN, "gui.Default() DISPLAY not set") log.Log(WARN, "gui.Default() attempting ncurses gui") if n, err = n.LoadToolkit("gocui"); err == nil { - return n + return "gocui", nil } - return nil + log.Log(WARN, "DISPLAY is not set so GTK GUI plugin can not run and gocui also failed") + return "gocui", log.Errorf("no plugins worked. You will have to build them") } if n, err = n.LoadToolkit("andlabs"); err == nil { - return n + return "andlabs", nil } log.Log(WARN, "LoadToolkit() failed to load andlabs") if n, err = n.LoadToolkit("gocui"); err == nil { - return n + return "gocui", nil } log.Log(WARN, "LoadToolkit() failed to load gocui") @@ -401,10 +404,11 @@ func (n *Node) Default() *Node { log.Sleep(2) if n, err = n.LoadToolkit("nocui"); err == nil { - return n + return "nocui", nil } log.Log(WARN, "LoadToolkit() failed to load nocui") - return n + // if everything fails to load, try "gocui" and "nocui" since they are easy to build + return "gocui", log.Errorf("no plugins worked. You will have to build them") } // The window is destroyed but the application does not quit |
