Go to file
Érico Nogueira 55a3d3b326 Implement SelectProfile in kanshictl.
Rework how varlink_connection_call is called so the logic is used by all
methods. Uses method_name as a sign that argv[1] was matched by some
known method.
2021-07-26 11:55:31 -03:00
include Add IPC method to set a specific profile. 2021-07-26 11:49:07 -03:00
protocol Listen to output-management events 2019-06-01 13:25:09 +03:00
.build.yml Add CI step to test build without varlink. 2021-07-24 08:34:35 +02:00
.gitignore Add basic parser 2019-06-01 13:25:09 +03:00
LICENSE Add missing LICENSE 2019-08-12 11:45:55 +03:00
README.md Add optional varlink interface. 2021-07-24 08:34:35 +02:00
ctl.c Implement SelectProfile in kanshictl. 2021-07-26 11:55:31 -03:00
event-loop.c Add optional varlink interface. 2021-07-24 08:34:35 +02:00
ipc-addr.c Add optional varlink interface. 2021-07-24 08:34:35 +02:00
ipc.c Add IPC method to set a specific profile. 2021-07-26 11:49:07 -03:00
kanshi.1.scd Add kanshictl utility. 2021-07-24 08:34:35 +02:00
kanshi.5.scd Add 'include' directive to read additional configs 2020-10-13 14:42:03 +02:00
kanshictl.1.scd Implement SelectProfile in kanshictl. 2021-07-26 11:55:31 -03:00
main.c Add IPC method to set a specific profile. 2021-07-26 11:49:07 -03:00
meson.build Add kanshictl utility. 2021-07-24 08:34:35 +02:00
meson_options.txt Add optional varlink interface. 2021-07-24 08:34:35 +02:00
parser.c parser: support single quotation marks 2021-07-09 14:29:49 +02:00

README.md

kanshi

kanshi allows you to define output profiles that are automatically enabled and disabled on hotplug. For instance, this can be used to turn a laptop's internal screen off when docked.

This is a Wayland equivalent for tools like autorandr. kanshi can be used on Wayland compositors supporting the wlr-output-management protocol.

Join the IRC channel: #emersion on Libera Chat.

Building

Dependencies:

  • wayland-client
  • scdoc (optional, for man pages)
  • libvarlink (optional, for remote control functionality)
meson build
ninja -C build

Usage

mkdir -p ~/.config/kanshi && touch ~/.config/kanshi/config
kanshi

Configuration file

Each output profile is delimited by brackets. It contains several output directives (whose syntax is similar to sway-output(5)). A profile will be enabled if all of the listed outputs are connected.

profile {
	output LVDS-1 disable
	output "Some Company ASDF 4242" mode 1600x900 position 0,0
}

profile {
	output LVDS-1 enable scale 2
}

Contributing

The upstream repository can be found on SourceHut. Open tickets on the SourceHut tracker. Send patches on the mailing list or open pull requests on the GitHub mirror.

License

MIT