Skip to main content

Configure Windows using dotbot

Project description

Configure Windows using dotbot.


Table of contents

What you can do with it

The dotbot-windows plugin is able to configure Windows in the following ways:

  • Configure the desktop background color

  • Import registry files (*.reg) from a specified directory

Sample configuration:

windows:
  personalization:
    background-color: "#2A4661"

  registry:
    import: "my-registry-tweaks/"

  fonts:
    path: "my-standard-fonts/"

Installation

There are two ways to install and use the plugin:

  1. Install it as a Python package.

  2. Add it as a git submodule in your dotfiles repository.

  3. Copy dotbot_windows.py into your dotfiles directory.

Python package

If you want to install dotbot-windows as a Python package (for example, if you’re using a virtual environment), then you can install the plugin using pip:

pip install dotbot-windows

Then, when running dotbot, use the -p or --plugin option to tell dotbot to load the plugin:

dotbot [...] --plugin dotbot_windows [...]

If you’re using one of dotbot’s install scripts, you’ll need to edit that file to add the --plugin option.

Git submodule

If you want to track dotbot-windows as a git submodule (for example, if you manage your dotfiles using git) then you can add the plugin repository as a submodule using git:

git submodule add https://github.com/kurtmckee/dotbot-windows.git

This will clone the repository to a directory named dotbot-windows. Then, when running dotbot, use the -p or --plugin option to tell dotbot to load the plugin:

dotbot [...] --plugin dotbot-windows/dotbot_windows.py [...]

Note that you may need to initialize the plugin’s git submodule when you clone your dotfiles repository or pull new changes to another computer. The command for this will look something like:

git submodule update --init dotbot-windows

Copy dotbot_windows.py

If desired, you can copy dotbot_windows.py to your dotfiles directory. You might choose to do this if you already use other plugins and have configured dotbot to load all plugins from a plugin directory.

If you copy dotbot_windows.py to the root of your dotfiles directory then, when running dotbot, use the -p or --plugin option to tell dotbot to load the plugin:

dotbot [...] --plugin dotbot_windows.py [...]

If you copy dotbot_windows.py to a directory containing other plugins, you can use dotbot’s --plugin-dir option to load all plugins in the directory. In the example below, the plugin directory is named dotbot-plugins:

dotbot [...] --plugin-dir dotbot-plugins [...]

Configuration

Personalization

You can configure the desktop background color using a hexadecimal color (like "#2A4661") or a triplet of decimal RGB values (like "0 153 255").

Here are examples demonstrating the two formats:

windows:
    personalization:
        background-color: "#2A4661"
windows:
    personalization:
        background-color: "42 70 97"

Registry

You can import registry files by specifying a directory containing *.reg files. The directory will be recursively searched for *.reg files, and each of them will be imported.

Note that registry imports may fail if the changes require administrator privileges.

Here’s a dotbot configuration file example:

windows:
    registry:
        import: "registry-export-files"

Fonts

Starting with Windows 10 build 17704, users can install fonts without admin permissions. The fonts can be copied into "%LOCALAPPDATA%/Microsoft/Windows/Fonts", so this plugin replaces that directory with a symlink to a directory of your choosing.

Here’s a dotbot configuration file example:

windows:
  fonts:
    path: "my-standard-fonts/"

Development

To set up a development environment, clone the dotbot-windows plugin’s git repository. Then, follow these steps to create a virtual environment and run the unit tests locally:

# Create the virtual environment
$ python -m venv .venv

# Activate the virtual environment (Windows-only)
$ & .venv/Scripts/Activate.ps1

# Update pip and setuptools, and install wheel
(.venv) $ pip install -U pip setuptools wheel

# Install poetry, tox, and scriv
(.venv) $ pip install poetry tox scriv

# Install all dependencies
(.venv) $ poetry install

# Run the unit tests locally
(.venv) $ tox

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

dotbot_windows-1.1.0.tar.gz (7.5 kB view details)

Uploaded Source

Built Distribution

dotbot_windows-1.1.0-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file dotbot_windows-1.1.0.tar.gz.

File metadata

  • Download URL: dotbot_windows-1.1.0.tar.gz
  • Upload date:
  • Size: 7.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for dotbot_windows-1.1.0.tar.gz
Algorithm Hash digest
SHA256 3f275d9152c7b755cbdff1c127032e8579c6e4615aa264c0e364e2081f10a4bc
MD5 7fb3a42826bc0f5009cf3151755b2fbc
BLAKE2b-256 a188524c6aacdba227579858b8ed2cb1404d1e772a72c7d97a6ff0cdbc5d67a6

See more details on using hashes here.

File details

Details for the file dotbot_windows-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for dotbot_windows-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5bfe0e5e33c50977b66dcefca4188b659d7b657493e1c034ebf0357ec2f134a4
MD5 3091bff4272c0bc384bac3d61f9a5c98
BLAKE2b-256 db6f4392aad5ccd27f00d8efc2a960362a203cdc035b54115aaccefe17cb0081

See more details on using hashes here.

Supported by

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