symconf


Namesymconf JSON
Version 0.7.1 PyPI version JSON
download
home_pageNone
SummaryLocal app configuration manager
upload_time2024-08-18 21:15:21
maintainerNone
docs_urlNone
authorNone
requires_python>=3.12
licenseNone
keywords config
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 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](docs/_static/example.gif)

This GIF shows two `symconf` calls, the first of which applies a `gruvbox` dark theme and
the second a dark [`monobiome`][1] 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](docs/reference/matching.md).

# 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](docs/reference/configuring.md) 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 `pipx` on your system,
you can install with

```sh
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,

  ```sh
  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:

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

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

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

  ```sh
  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.



[1]: https://github.com/ologio/monobiome

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "symconf",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.12",
    "maintainer_email": null,
    "keywords": "config",
    "author": null,
    "author_email": "Sam Griesemer <samgriesemer+git@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/16/b4/47ee476fd712236c5af51e931086ef66cd1cea3e995b3607af66e4153567/symconf-0.7.1.tar.gz",
    "platform": null,
    "description": "# Symconf\n`symconf` is a CLI tool for managing local application configuration. It implements a\ngeneral model that supports dynamically switching/reloading themes for any application,\nand provides a basic means of templatizing your config files.\n\n## Simple example\nBelow is a simple example demonstrating two system-wide theme switches:\n\n![Simple example](docs/_static/example.gif)\n\nThis GIF shows two `symconf` calls, the first of which applies a `gruvbox` dark theme and\nthe second a dark [`monobiome`][1] variant. Each call (of the form `symconf config -m dark -s\nstyle`) indicates a dark mode preference and a particular color palette that should be\nused when populating config file templates. Specifically, in this example, invoking\n`symconf` results in the following app-specific config updates:\n\n- **GTK**: reacts to the mode setting and sets `prefer-dark` system-wide, changing general\n  GTK-responsive applications like Nautilus and Firefox (and subsequently websites that\n  are responsive to `prefers-color-scheme`)\n- **kitty**: theme template is re-generated using the specified palette, and `kitty`\n  processes are sent a message to live-reload the new config file\n- **neovim**: a `vim` theme file (along with a statusline theme) is generated from the\n  chosen palette, and running instances of `neovim` are sent a message to re-source this\n  theme (via `nvim --remote-send`)\n- **waybar**: bar styles are updated to match the mode setting\n- **sway**: the background color and window borders are dynamically set to base palette\n  colors, and `swaymsg reload` is called\n- **fzf**: a palette-dependent theme is re-generated and re-exported\n- **rofi**: launcher text and highlight colors are set according to the mode and palette,\n  applying on next invocation\n\nThis example highlights the generality of `symconf`, and so long as an app's config can be\nreloaded dynamically, you can use a single `symconf` call to apply themes for an arbitrary\nnumber of apps at once.\n\n# Behavior\n`symconf` uses a simple operational model that symlinks centralized config files to their\nexpected locations across the system. This central config directory can then be version\ncontrolled, and app config files can be updated in one place.\n\nApp config files can either be concrete (fully-specified) or templates (to be populated by\nvalues conditional on style, e.g., a palette). When `symconf` is executed with a\nparticular mode preference (dark or light) and a style (any other indicator of thematic\nelements, often simply in the form of a palette like `solarized` or `gruvbox`), it\nsearches for both concrete and template config files that match and symlinks them to\nregistered locations. When necessary, `symconf` will also match and execute scripts to\nreload apps after updating their configuration.\n\nYou can find more details on how `symconf`'s matching scheme works in\n[Matching](docs/reference/matching.md).\n\n# Configuring\nBefore using, you must first set up your config directory to house your config files and\ngive `symconf` something to act on. See [Configuring](docs/reference/configuring.md) for\ndetails.\n\n# Installation\nThe recommended way to install `symconf` is via `pipx`, which is particularly well-suited\nfor managing Python packages meant to be used as CLI programs. With `pipx` on your system,\nyou can install with\n\n```sh\npipx install symconf\n```\n\nYou can also install via `pip`, or clone and install locally.\n\n# Usage\n- `-h --help`: print help message\n- `-c --config-dir`: set the location of the `symconf` config directory\n- `symconf config` is the subcommand used to match and set available config files for\n  registered applications\n  * `-a --apps`: comma-separate list of registered apps, or `\"*\"` (default) to consider\n    all registered apps.\n  * `-m --mode`: preferred lightness mode/scheme, either `light`, `dark`, `any`, or\n    `none`.\n  * `-s --style`: style indicator, often the name of a color palette, capturing thematic\n    details in a config file to be matched. `any` or `none` are reserved keywords (see\n    below).\n  * `-T --template-vars`: additional groups to use when populating templates, in the form\n    `<group>=<value>`, where `<group>` is a template group with a folder\n    `$CONFIG_HOME/groups/<group>/` and `<value>` should correspond to a TOML file in this\n    folder (i.e., `<value>.toml`).\n- `symconf generate` is a subcommand that can be used for batch generation of config\n  files. It accepts the same arguments as `symconf config`, but rather than selecting the\n  best match to be used for the system setting, all matching templates are generated.\n  There is one additional required argument:\n  * `-o --output-dir`: the directory under which generated config files should be written.\n    App-specific subdirectories are created to house config files for each provided app.\n- `symconf install`: runs install scripts for matching apps that specify one\n  * `-a --apps`: comma-separate list of registered apps, or `\"*\"` (default) to consider\n    all registered apps.\n- `symconf update`: runs update scripts for matching apps that specify one\n  * `-a --apps`: comma-separate list of registered apps, or `\"*\"` (default) to consider\n    all registered apps.\n\nThe keywords `any` and `none` can be used when specifying `--mode`, `--style`, or as a\nvalue in `--template-vars` (and we refer to each of these variables as _factors_ that help\ndetermine a config match):\n\n- `any` will match config files with _any_ value for this factor, preferring config files\n  with a value `none`, indicating no dependence on the factor. This is the default value\n  when a factor is left unspecified.\n- `none` will match `\"none\"` directly for a given factor (so no special behavior), but\n  used to indicate that a config file is independent of the factor. For instance,\n\n  ```sh\n  symconf config -m light -s none\n  ```\n\n  will match config files that capture the notion of a light mode, but do not depend on or\n  provide further thematic components such as a color palette.\n\n## Examples\n- Set a dark mode for all registered apps, matching any available style/palette component:\n\n  ```sh\n  symconf config -m dark\n  ```\n- Set `solarized` theme for `kitty` and match any available mode (light or dark):\n\n  ```sh\n  symconf config -s solarized -a kitty\n  ```\n- Set a dark `gruvbox` theme for multiple apps (but not all):\n\n  ```sh\n  symconf config -m dark -s gruvbox -apps=\"kitty,nvim\"\n  ```\n- Set a dark `gruvbox` theme for all apps, and attempt to match other template elements:\n\n  ```sh\n  symconf config -m dark -s gruvbox -T font=mono window=sharp\n  ```\n\n  which would attempt to find and load key-value pairs in the files\n  `$CONFIG_HOME/groups/font/mono.toml` and `$CONFIG_HOME/groups/window/sharp.toml` to be\n  used as values when filling templatized config files.\n\n\n\n[1]: https://github.com/ologio/monobiome\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Local app configuration manager",
    "version": "0.7.1",
    "project_urls": {
        "Documentation": "https://doc.olog.io/symconf",
        "Homepage": "https://doc.olog.io/symconf",
        "Issues": "https://git.olog.io/olog/symconf/issues",
        "Repository": "https://git.olog.io/olog/symconf"
    },
    "split_keywords": [
        "config"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "409c0500f644e2bb50fc0711a8fe9f42c4d77bcc43bd7ca16ea69057a6b37c02",
                "md5": "fe719854c1294569ee774cb7d5db5b56",
                "sha256": "efcff01b7f0630ea1cf7cf6a9b3403934b991cdd634f1b7825828d7120c1d186"
            },
            "downloads": -1,
            "filename": "symconf-0.7.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "fe719854c1294569ee774cb7d5db5b56",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.12",
            "size": 24133,
            "upload_time": "2024-08-18T21:15:18",
            "upload_time_iso_8601": "2024-08-18T21:15:18.772994Z",
            "url": "https://files.pythonhosted.org/packages/40/9c/0500f644e2bb50fc0711a8fe9f42c4d77bcc43bd7ca16ea69057a6b37c02/symconf-0.7.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "16b447ee476fd712236c5af51e931086ef66cd1cea3e995b3607af66e4153567",
                "md5": "00b6f18195ba5a403d711ac1e02248e9",
                "sha256": "9037856f2edf1882fabb53c3a5dc1414019b8d0896968e946ec86662acb19c7d"
            },
            "downloads": -1,
            "filename": "symconf-0.7.1.tar.gz",
            "has_sig": false,
            "md5_digest": "00b6f18195ba5a403d711ac1e02248e9",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.12",
            "size": 25957,
            "upload_time": "2024-08-18T21:15:21",
            "upload_time_iso_8601": "2024-08-18T21:15:21.970981Z",
            "url": "https://files.pythonhosted.org/packages/16/b4/47ee476fd712236c5af51e931086ef66cd1cea3e995b3607af66e4153567/symconf-0.7.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-08-18 21:15:21",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "symconf"
}
        
Elapsed time: 0.28991s