Skip to main content

Local app configuration manager

Project description

Symconf

symconf is a CLI tool for managing local application configuration. It implements a general model that supports dynamically switching/reloading themes for any application, and provides a basic means of templatizing your config files.

Simple example

Below is a simple example demonstrating two system-wide theme switches:

Simple example

This GIF shows two symconf calls, the first of which applies a gruvbox dark theme and the second a dark monobiome variant. Each call (of the form symconf config -m dark -s style) indicates a dark mode preference and a particular color palette that should be used when populating config file templates. Specifically, in this example, invoking symconf results in the following app-specific config updates:

  • GTK: reacts to the mode setting and sets prefer-dark system-wide, changing general GTK-responsive applications like Nautilus and Firefox (and subsequently websites that are responsive to prefers-color-scheme)
  • kitty: theme template is re-generated using the specified palette, and kitty processes are sent a message to live-reload the new config file
  • neovim: a vim theme file (along with a statusline theme) is generated from the chosen palette, and running instances of neovim are sent a message to re-source this theme (via nvim --remote-send)
  • waybar: bar styles are updated to match the mode setting
  • sway: the background color and window borders are dynamically set to base palette colors, and swaymsg reload is called
  • fzf: a palette-dependent theme is re-generated and re-exported
  • rofi: launcher text and highlight colors are set according to the mode and palette, applying on next invocation

This example highlights the generality of symconf, and so long as an app's config can be reloaded dynamically, you can use a single symconf call to apply themes for an arbitrary number of apps at once.

Behavior

symconf uses a simple operational model that symlinks centralized config files to their expected locations across the system. This central config directory can then be version controlled, and app config files can be updated in one place.

App config files can either be concrete (fully-specified) or templates (to be populated by values conditional on style, e.g., a palette). When symconf is executed with a particular mode preference (dark or light) and a style (any other indicator of thematic elements, often simply in the form of a palette like solarized or gruvbox), it searches for both concrete and template config files that match and symlinks them to registered locations. When necessary, symconf will also match and execute scripts to reload apps after updating their configuration.

You can find more details on how symconf's matching scheme works in Matching.

Configuring

Before using, you must first set up your config directory to house your config files and give symconf something to act on. See Configuring for details.

Installation

The recommended way to install symconf is via pipx, which is particularly well-suited for managing Python packages meant to be used as CLI programs. With uv on your system, you can install with

uv tool install symconf

Alternatively, you can use pipx to similar effect:

pipx install symconf

You can also install via pip, or clone and install locally.

Usage

  • -h --help: print help message
  • -c --config-dir: set the location of the symconf config directory
  • symconf config is the subcommand used to match and set available config files for registered applications
    • -a --apps: comma-separate list of registered apps, or "*" (default) to consider all registered apps.
    • -m --mode: preferred lightness mode/scheme, either light, dark, any, or none.
    • -s --style: style indicator, often the name of a color palette, capturing thematic details in a config file to be matched. any or none are reserved keywords (see below).
    • -T --template-vars: additional groups to use when populating templates, in the form <group>=<value>, where <group> is a template group with a folder $CONFIG_HOME/groups/<group>/ and <value> should correspond to a TOML file in this folder (i.e., <value>.toml).
  • symconf generate is a subcommand that can be used for batch generation of config files. It accepts the same arguments as symconf config, but rather than selecting the best match to be used for the system setting, all matching templates are generated. There is one additional required argument:
    • -o --output-dir: the directory under which generated config files should be written. App-specific subdirectories are created to house config files for each provided app.
  • symconf install: runs install scripts for matching apps that specify one
    • -a --apps: comma-separate list of registered apps, or "*" (default) to consider all registered apps.
  • symconf update: runs update scripts for matching apps that specify one
    • -a --apps: comma-separate list of registered apps, or "*" (default) to consider all registered apps.

The keywords any and none can be used when specifying --mode, --style, or as a value in --template-vars (and we refer to each of these variables as factors that help determine a config match):

  • any will match config files with any value for this factor, preferring config files with a value none, indicating no dependence on the factor. This is the default value when a factor is left unspecified.

  • none will match "none" directly for a given factor (so no special behavior), but used to indicate that a config file is independent of the factor. For instance,

    symconf config -m light -s none
    

    will match config files that capture the notion of a light mode, but do not depend on or provide further thematic components such as a color palette.

Examples

  • Set a dark mode for all registered apps, matching any available style/palette component:

    symconf config -m dark
    
  • Set solarized theme for kitty and match any available mode (light or dark):

    symconf config -s solarized -a kitty
    
  • Set a dark gruvbox theme for multiple apps (but not all):

    symconf config -m dark -s gruvbox -apps="kitty,nvim"
    
  • Set a dark gruvbox theme for all apps, and attempt to match other template elements:

    symconf config -m dark -s gruvbox -T font=mono window=sharp
    

    which would attempt to find and load key-value pairs in the files $CONFIG_HOME/groups/font/mono.toml and $CONFIG_HOME/groups/window/sharp.toml to be used as values when filling templatized config files.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

symconf-0.8.2.tar.gz (26.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

symconf-0.8.2-py3-none-any.whl (24.9 kB view details)

Uploaded Python 3

File details

Details for the file symconf-0.8.2.tar.gz.

File metadata

  • Download URL: symconf-0.8.2.tar.gz
  • Upload date:
  • Size: 26.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.22

File hashes

Hashes for symconf-0.8.2.tar.gz
Algorithm Hash digest
SHA256 041e06d5accc050a4a1729c9cdd0b2c0a06bdb0d087edd793e2b560e05221515
MD5 0e939b13d9956bab3589bb3bf58c2fc9
BLAKE2b-256 fdba05a9c36a93f97a2cd819d9af82cc3afad5b0af54f88701d877c5b46c7afb

See more details on using hashes here.

File details

Details for the file symconf-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: symconf-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 24.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.22

File hashes

Hashes for symconf-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e5e7f40fcb231320a6074543beec9e6cfc0892ac115a3a0ac74dbd538447e44b
MD5 4dd9fa2816428e4b9a7ff367ab10c22e
BLAKE2b-256 ea1af8d84a402907cb442c4c8aa47794ad1200f95a9f20b3c0552f90107112c5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page