All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning. Also I copied this intro verbatim from Keep a Changelog.
- Usage page in HTML docs
- Improved contrast of syntax-highlighted code blocks
thcon_linux_x86_86
binaries are now namedthcon_linux_amd64
gnome-shell
now respects the user themes included inconfig.toml
, instead of always using "Arc" and "Arc-Dark-solid".
- Default dark-mode/light-mode config paths for kitty
- No longer reports errors when calling lookandfeeltool on systems without KDE installed.
- No longer reports errors when switching helix themes where a ~/.config/helix directory doesn't exist.
- Skipped apps now use a separate "reason" field when info-level logging (-v) is enabled, instead of listing the skip-reason in the message itself.
- Align version number with released version number
Maintenance release to improve CI infrastructure. No other changes beyond v0.15.1.
Maintenance release to improve CI infrastructure. No other changes beyond v0.15.1.
- When not already running, Terminal.app no longer stays running in the background after switching themes
Relicensed to BSD 3-clause (previous releases were Apache 2.0 / MIT dual-licensed).
- Updated third-party dependencies
Completely rewritten in Go. Configuration format is backwards-compatible with the rust version, but the CLI makes no claims of backwards compatibility.
- Helix Editor support
- Kitty support
- Custom application support
- FreeBSD support
- Rewrote docs site, now hosted on https://thcon.app
thcon listen
subcommand
- Sublime Text support
- ST4 has been out for long enough that maintaining support for ST3 is unnecessary
- Visual Studio Code support
- VSCode supports OS theme syncing on all major platforms since no later than March 2022
- Atom support
- Atom was sunset in December 2022
- The
thcon-listen
binary is no longer included during installation- Use the
thcon listen
subcommand instead
- Use the
- Sublime Text is now disabled by default, since ST4 is able to sync with system dark-mode
- Systems without a VSCode
settings.json
no longer report errors when switching themes
- Per-application timing is printed when run with
-vvv
(trace-level verbosity) - Web-based documentation hosted at https://thcon.vercel.app
- No longer requires
thcon.toml
to exist on-disk forthcon
to run
dark
andlight
are now positional arguments instead of subcommands, which better represents howthcon
should be used.- Verbose output (
-v
through-vvv
) is a bit more pretty
- Terminal.app profile switching
- Documented
disabled
property in app schemas (supported since v0.10.0) - Corrected documented KDE Konsole section name in
thcon.toml
.konsole
was always supported, but the documentation was wrong
- GTK theme switching
- GNOME Shell user theme switching
- Allow apps to be disabled with
disabled = true
in their config section - Establish default values for Atom, KDE Plasma, Sublime Text, and Visual Studio Code
- Support for Atom via an app-side plugin
- Writes vim/nvim rc file to disk so new instances use previously-applied settings. Requires thcon.vim v0.4.0 (at least commit 39b6d82 (v0.4.0, 2021-03-24))
- Build-time dependency on
indicatif
crate
- New
--no-replace
CLI arg tothcon-listen
, to exit cleanly when pre-existing sockets are detected
- Moved
src/main.rs
tosrc/bin/thcon.rs
to better align withthcon-listen
binary
- New
thcon-listen
binary for use with app-specific plugins
- vim: Use
thcon-listen
for IPC transport - iterm2: Use
thcon-listen
for IPC transport
- Support for changing Sublime Text 3 color schemes and themes
- Removed progress bar with and without
--verbose
.thcon
tends to run fast enough to not warrant a progress bar.
- No longer panics when
thcon.toml
doesn't exist or is invalid TOML - No longer panics when no or invalid subcommand provided at commandline
- Moved
help
subcommand to the bottom of subcommand list in--help
- Support for changing iTerm2 profiles
- Updated dependencies
- VSCode: preserve comma in settings.json if one is present
- Silence unused import during build on non-mac platforms
- macOS:
thcon
now reads its config file from ~/.config/thcon/thcon.toml instead of ~/Library/Application Support/thcon/thcon.toml - macOS: Support
thcon.vim
0.2.0 (named pipes are written to ~/.local/share/thcon/ instead of ~/Library/Application Support/thcon/)
thcon
can once again be successfully installed on macOS
--verbose
/-v
argument to enable verbose logging of re-themed and skipped (unconfigured) applications- Configuration documentation for KDE Plasma
- Configuration documentation for KDE Konsole
- Stop logging errors for unconfigured applications (silently skips unconfigured apps instead)
- Don't require apps to be listed individually on CLI (try all apps by default
with
thcon dark
/thcon light
) - Suppress spurious error messages when switching
plasma
themes - Explicitly listed
thcon.toml
section to use forvim
/nvim
- Lots of lint failures
- The
plasma
app (KDE Plasma) is now only available on non-macOS, non-Windows platforms
Themeable::toggle()
, which was previously used to implicitly switch from light to dark (or vice-versa, depending on the current state) has been removed. It may return in a future release, but improving app support is more important right now.
vim
&neovim
theme switching via thcon.vim- This changelog
- Started documenting per-app configuration direction in crates to enable serving via https://docs.rs
- macOS global theme switching
- alacritty color switching
- First set of per-app documentation (may not be the correct place for those to live long-term though?)
- Allow installation on systems that don't support DBus
- Don't crash if ~/.config/thcon/thcon.toml doesn't exist (helpful on macOS, where there's no configuration required to switch between light and dark modes)