Note This is a fork of topgrade by r-darwish to keep it maintained.
Keeping your system up to date usually involves invoking multiple package managers. This results in big, non-portable shell one-liners saved in your shell. To remedy this, topgrade detects which tools you use and runs the appropriate commands to update them.
Other systems users can either use cargo install
or use the compiled binaries from the release page.
The compiled binaries contain a self-upgrading feature.
Topgrade requires Rust 1.51 or above.
Warning Work in Progress
You can visit the documentation at topgrade-rs.github.io .
Just run topgrade
.
See the wiki for the list of things Topgrade supports.
See config.example.toml
for an example configuration file.
The configuration should be placed in the following paths depending by the operating system:
- Windows -
%APPDATA%/topgrade.toml
- macOS and other Unix systems -
${XDG_CONFIG_HOME:-~/.config}/topgrade.toml
Open a new Issue describing your problem and if possible with a possible solution.
Just let us now what you are missing by opening an issue. For tools please open an Issue describing the tool, which platforms it supports and if possible, give us an example of its usage.
Just fork the repository and start coding.
You can specify a key called remote_topgrades
in the configuration file.
This key should contain a list of hostnames that have topgrade installed on them.
Topgrade will use ssh
to run topgrade
on remote hosts before acting locally.
To limit the execution only to specific hosts use the --remote-host-limit
parameter.
- Add a proper testing framework to the code base.
- Add unit tests for package managers.
- Split up code into more maintainable parts, eg. putting every linux package manager in a own submodule of linux.rs.