4
go.mod
4
go.mod
@@ -14,6 +14,6 @@ require (
|
|||||||
require (
|
require (
|
||||||
github.com/joshuarubin/lifecycle v1.1.4 // indirect
|
github.com/joshuarubin/lifecycle v1.1.4 // indirect
|
||||||
go.uber.org/multierr v1.11.0 // indirect
|
go.uber.org/multierr v1.11.0 // indirect
|
||||||
golang.org/x/sync v0.7.0 // indirect
|
golang.org/x/sync v0.8.0 // indirect
|
||||||
golang.org/x/sys v0.21.0 // indirect
|
golang.org/x/sys v0.25.0 // indirect
|
||||||
)
|
)
|
||||||
|
|||||||
4
go.sum
4
go.sum
@@ -30,9 +30,13 @@ go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN8
|
|||||||
golang.org/x/sync v0.0.0-20190412183630-56d357773e84/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20190412183630-56d357773e84/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M=
|
golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M=
|
||||||
golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
|
golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
|
||||||
|
golang.org/x/sync v0.8.0 h1:3NFvSEYkUoMifnESzZl15y791HH1qU2xm6eCJU5ZPXQ=
|
||||||
|
golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
|
||||||
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.21.0 h1:rF+pYz3DAGSQAxAu1CbC7catZg4ebC4UIeIhKxBZvws=
|
golang.org/x/sys v0.21.0 h1:rF+pYz3DAGSQAxAu1CbC7catZg4ebC4UIeIhKxBZvws=
|
||||||
golang.org/x/sys v0.21.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
golang.org/x/sys v0.21.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
||||||
|
golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34=
|
||||||
|
golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||||
|
|||||||
7
main.go
7
main.go
@@ -21,7 +21,7 @@ import (
|
|||||||
"github.com/gotk3/gotk3/gtk"
|
"github.com/gotk3/gotk3/gtk"
|
||||||
)
|
)
|
||||||
|
|
||||||
const version = "0.4.9"
|
const version = "0.5.0"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
appDirs []string
|
appDirs []string
|
||||||
@@ -171,7 +171,7 @@ var itemSpacing = flag.Uint("spacing", 20, "icon spacing")
|
|||||||
var lang = flag.String("lang", "", "force lang, e.g. \"en\", \"pl\"")
|
var lang = flag.String("lang", "", "force lang, e.g. \"en\", \"pl\"")
|
||||||
var fileManager = flag.String("fm", "thunar", "File Manager")
|
var fileManager = flag.String("fm", "thunar", "File Manager")
|
||||||
var term = flag.String("term", defaultTermIfBlank(os.Getenv("TERM"), "foot"), "Terminal emulator")
|
var term = flag.String("term", defaultTermIfBlank(os.Getenv("TERM"), "foot"), "Terminal emulator")
|
||||||
var wm = flag.String("wm", "", "use swaymsg exec (with 'sway' argument) or hyprctl dispatch exec (with 'hyprland') to launch programs")
|
var wm = flag.String("wm", "", "use swaymsg exec (with 'sway' argument) or hyprctl dispatch exec (with 'hyprland') or riverctl spawn (with 'river') to launch programs")
|
||||||
var nameLimit = flag.Int("fslen", 80, "File Search name LENgth Limit")
|
var nameLimit = flag.Int("fslen", 80, "File Search name LENgth Limit")
|
||||||
var noCats = flag.Bool("nocats", false, "Disable filtering by category")
|
var noCats = flag.Bool("nocats", false, "Disable filtering by category")
|
||||||
var noFS = flag.Bool("nofs", false, "Disable file search")
|
var noFS = flag.Bool("nofs", false, "Disable file search")
|
||||||
@@ -419,7 +419,6 @@ func main() {
|
|||||||
err = cssProvider.LoadFromPath(*cssFileName)
|
err = cssProvider.LoadFromPath(*cssFileName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("ERROR: %s css file not found or erroneous. Using GTK styling.", *cssFileName)
|
log.Errorf("ERROR: %s css file not found or erroneous. Using GTK styling.", *cssFileName)
|
||||||
log.Errorf("%s", err)
|
|
||||||
} else {
|
} else {
|
||||||
log.Info(fmt.Sprintf("Using style from %s", *cssFileName))
|
log.Info(fmt.Sprintf("Using style from %s", *cssFileName))
|
||||||
screen, _ := gdk.ScreenGetDefault()
|
screen, _ := gdk.ScreenGetDefault()
|
||||||
@@ -438,7 +437,7 @@ func main() {
|
|||||||
if *targetOutput != "" {
|
if *targetOutput != "" {
|
||||||
// We want to assign layershell to a monitor, but we only know the output name!
|
// We want to assign layershell to a monitor, but we only know the output name!
|
||||||
output2mon, err = mapOutputs()
|
output2mon, err = mapOutputs()
|
||||||
fmt.Println(">>>", output2mon)
|
log.Debugf("output2mon: %s", output2mon)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
monitor := output2mon[*targetOutput]
|
monitor := output2mon[*targetOutput]
|
||||||
layershell.SetMonitor(win, monitor)
|
layershell.SetMonitor(win, monitor)
|
||||||
|
|||||||
26
tools.go
26
tools.go
@@ -611,6 +611,8 @@ func launch(command string, terminal bool) {
|
|||||||
cmd = exec.Command("swaymsg", "exec", strings.Join(elements, " "))
|
cmd = exec.Command("swaymsg", "exec", strings.Join(elements, " "))
|
||||||
} else if *wm == "hyprland" || *wm == "Hyprland" {
|
} else if *wm == "hyprland" || *wm == "Hyprland" {
|
||||||
cmd = exec.Command("hyprctl", "dispatch", "exec", strings.Join(elements, " "))
|
cmd = exec.Command("hyprctl", "dispatch", "exec", strings.Join(elements, " "))
|
||||||
|
} else if *wm == "river" {
|
||||||
|
cmd = exec.Command("riverctl", "spawn", strings.Join(elements, " "))
|
||||||
}
|
}
|
||||||
|
|
||||||
msg := fmt.Sprintf("command: %q; args: %q\n", cmd.Args[0], cmd.Args[1:])
|
msg := fmt.Sprintf("command: %q; args: %q\n", cmd.Args[0], cmd.Args[1:])
|
||||||
@@ -687,14 +689,9 @@ func mapOutputs() (map[string]*gdk.Monitor, error) {
|
|||||||
num := display.GetNMonitors()
|
num := display.GetNMonitors()
|
||||||
for i := 0; i < num; i++ {
|
for i := 0; i < num; i++ {
|
||||||
mon, _ := display.GetMonitor(i)
|
mon, _ := display.GetMonitor(i)
|
||||||
geometry := mon.GetGeometry()
|
output := hyprlandMonitors[i]
|
||||||
// assign output to monitor on the basis of the same x, y coordinates
|
|
||||||
for _, output := range hyprlandMonitors {
|
|
||||||
if int(output.X) == geometry.GetX() && int(output.Y) == geometry.GetY() {
|
|
||||||
result[output.Name] = mon
|
result[output.Name] = mon
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -721,14 +718,9 @@ func mapOutputs() (map[string]*gdk.Monitor, error) {
|
|||||||
num := display.GetNMonitors()
|
num := display.GetNMonitors()
|
||||||
for i := 0; i < num; i++ {
|
for i := 0; i < num; i++ {
|
||||||
mon, _ := display.GetMonitor(i)
|
mon, _ := display.GetMonitor(i)
|
||||||
geometry := mon.GetGeometry()
|
output := outputs[i]
|
||||||
// assign output to monitor on the basis of the same x, y coordinates
|
|
||||||
for _, output := range outputs {
|
|
||||||
if int(output.Rect.X) == geometry.GetX() && int(output.Rect.Y) == geometry.GetY() {
|
|
||||||
result[output.Name] = mon
|
result[output.Name] = mon
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
return nil, errors.New("output assignment only supported on sway and Hyprland")
|
return nil, errors.New("output assignment only supported on sway and Hyprland")
|
||||||
}
|
}
|
||||||
@@ -754,7 +746,15 @@ func substring(s string, start int, end int) string {
|
|||||||
|
|
||||||
func hyprctl(cmd string) ([]byte, error) {
|
func hyprctl(cmd string) ([]byte, error) {
|
||||||
his := os.Getenv("HYPRLAND_INSTANCE_SIGNATURE")
|
his := os.Getenv("HYPRLAND_INSTANCE_SIGNATURE")
|
||||||
socketFile := fmt.Sprintf("/tmp/hypr/%s/.socket.sock", his)
|
xdgRuntimeDir := os.Getenv("XDG_RUNTIME_DIR")
|
||||||
|
hyprDir := ""
|
||||||
|
if xdgRuntimeDir != "" {
|
||||||
|
hyprDir = fmt.Sprintf("%s/hypr", xdgRuntimeDir)
|
||||||
|
} else {
|
||||||
|
hyprDir = "/tmp/hypr"
|
||||||
|
}
|
||||||
|
|
||||||
|
socketFile := fmt.Sprintf("%s/%s/.socket.sock", hyprDir, his)
|
||||||
conn, err := net.Dial("unix", socketFile)
|
conn, err := net.Dial("unix", socketFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|||||||
Reference in New Issue
Block a user