mirror of
https://codeberg.org/scip/swayipc.git
synced 2025-12-16 12:10:57 +01:00
110 lines
3.1 KiB
Markdown
110 lines
3.1 KiB
Markdown
|
|
[](https://goreportcard.com/report/github.com/tlinden/i3ipc)
|
||
|
|
[](https://github.com/tlinden/i3ipc/actions)
|
||
|
|

|
||
|
|
[](https://godoc.org/github.com/tlinden/i3ipc)
|
||
|
|
|
||
|
|
# i3ipc - go bindings to control sway (and possibly i3)
|
||
|
|
|
||
|
|
This is a go module which you can use to control [sway](https://swaywm.org/),
|
||
|
|
[swayfx](https://github.com/WillPower3309/swayfx) and possibly [i3wm](http://i3wm.org/).
|
||
|
|
|
||
|
|
## About
|
||
|
|
i3ipc's interprocess communication (or ipc) is the interface i3wm and
|
||
|
|
sway use to receive commands from client applications such as
|
||
|
|
i3-msg. It also features a publish/subscribe mechanism for notifying
|
||
|
|
interested parties of window manager events.
|
||
|
|
|
||
|
|
i3ipc is a go module for controlling the window manager. This project
|
||
|
|
is intended to be useful for general scripting, and for applications
|
||
|
|
that interact with the window manager like status line generators,
|
||
|
|
notification daemons, and window pagers.
|
||
|
|
|
||
|
|
For details on how to use the library, see the
|
||
|
|
[reference documentation](https://godoc.org/github.com/tlinden/i3ipc).
|
||
|
|
|
||
|
|
## Example usage
|
||
|
|
|
||
|
|
In this example we retrieve the current focused window:
|
||
|
|
|
||
|
|
```go
|
||
|
|
package main
|
||
|
|
|
||
|
|
import (
|
||
|
|
"fmt"
|
||
|
|
"log"
|
||
|
|
|
||
|
|
"github.com/tlinden/i3ipc"
|
||
|
|
)
|
||
|
|
|
||
|
|
func main() {
|
||
|
|
ipc := i3ipc.NewI3ipc()
|
||
|
|
|
||
|
|
err := ipc.Connect()
|
||
|
|
if err != nil {
|
||
|
|
log.Fatal(err)
|
||
|
|
}
|
||
|
|
defer ipc.Close()
|
||
|
|
|
||
|
|
tree, err := ipc.GetTree()
|
||
|
|
if err != nil {
|
||
|
|
log.Fatal(err)
|
||
|
|
}
|
||
|
|
|
||
|
|
focused := tree.FindFocused()
|
||
|
|
|
||
|
|
if focused != nil {
|
||
|
|
fmt.Printf("focused node: %s\n id: %d\n Geometry: %dx%d\n",
|
||
|
|
focused.Name, focused.Id, focused.Geometry.Width,
|
||
|
|
focused.Geometry.Height)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
|
||
|
|
Also take a look into the **_examples** folder for more examples.
|
||
|
|
|
||
|
|
You may take a look at the [tool swaycycle](https://github.com/tlinden/swaycycle)
|
||
|
|
which is using this module.
|
||
|
|
|
||
|
|
## Installation
|
||
|
|
|
||
|
|
Execute this to add the module to your project:
|
||
|
|
```sh
|
||
|
|
go get github.com/tlinden/i3ipc
|
||
|
|
```
|
||
|
|
|
||
|
|
## Acknowledgements
|
||
|
|
|
||
|
|
A couple of ideas have been taken from the [i3ipc python
|
||
|
|
module](https://github.com/altdesktop/i3ipc-python/), although this
|
||
|
|
one is not just a port of it and has been written from scratch.
|
||
|
|
|
||
|
|
## Getting help
|
||
|
|
|
||
|
|
Although I'm happy to hear from i3ipc users in private email, that's the
|
||
|
|
best way for me to forget to do something.
|
||
|
|
|
||
|
|
In order to report a bug, unexpected behavior, feature requests or to
|
||
|
|
submit a patch, please open an issue on github:
|
||
|
|
https://github.com/TLINDEN/i3ipc/issues.
|
||
|
|
|
||
|
|
## Copyright and license
|
||
|
|
|
||
|
|
This software is licensed under the GNU GENERAL PUBLIC LICENSE version 3.
|
||
|
|
|
||
|
|
## Authors
|
||
|
|
|
||
|
|
T.v.Dein <tom AT vondein DOT org>
|
||
|
|
|
||
|
|
## Project homepage
|
||
|
|
|
||
|
|
https://github.com/TLINDEN/i3ipc
|
||
|
|
|
||
|
|
## Copyright and License
|
||
|
|
|
||
|
|
Licensed under the GNU GENERAL PUBLIC LICENSE version 3.
|
||
|
|
|
||
|
|
## Author
|
||
|
|
|
||
|
|
T.v.Dein <tom AT vondein DOT org>
|
||
|
|
|