Skip to content
/ loose Public

A tool to apply vaguely-defined XrandR configurations

License

Notifications You must be signed in to change notification settings

seqizz/loose

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Loose 🫠

dall-e is stupid as hell

This is a helper tool to apply vague Xrandr configurations.

Use case (or why I wrote this)

(Warning: Includes rant)

I wrote this as a reaction to all other xrandr automation tools which requires you to exactly define your setup (e.g. which monitor has which damn fingerprint, what input name it has etc.) and then failing to set up, since you plugged a cable on a different port.

Come on, I just want to define some non-specific settings. Something like:

  • If I plug 1 extra monitor, my preference list:
    1. Switch off the laptop's monitor and only use plugged monitor
    2. Put the new monitor to right of my laptop's screen
    3. Put the new monitor to left of my laptop's screen and rotate it 90 degrees
  • If I plug 2 monitors:
    1. Switch off the laptop's monitor and use monitor 1 on the left, 2 on the right
    2. Switch off the laptop's monitor and use monitor 2 on the left, 1 on the right

Features

  • Configured with a yaml file (I know, I know..)
  • Accepts both explicit monitor names and aliases to define purposefully vague configurations
  • Supports setting the resolution, rotation, (relative) position, refresh rate and primary monitor
  • If you don't define a setting (e.g. resolution or refresh rate), it will apply the "preferred" one from Xrandr
  • Supports multiple pre/post commands to run before/after applying the configuration (e.g. to set the DPI)
  • Supports multiple configurations for multiple screen counts so you can "rotate" if you don't like the first applied one
  • It will try to detect the suitable devices for given aliases consistently (thus you can declare self-correcting preferences like "2 monitors" example above)
  • Something failed bad? Then it will try the global failback option defined in the config

I highly recommend checking the example config for examples and explanations.

Installation (What installation?)

Since I am using NixOS, I am using this with dark magic (systemd service, udev rules). Instructions for other distros are welcome, since I don't have enough incentive to write them (plus this tool is only really useful if it's integrated with udev).

For the testing/development purposes, you can use poetry:

  • Clone this repo
  • Install poetry
  • Run poetry install in the repo

TODO

Todo is tracked on my issues page. Although I am a happy user of my own solution, this is more like a wishlist :)

About

A tool to apply vaguely-defined XrandR configurations

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published