Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Mic92/nix-update
Swiss-knife for updating nix packages.
https://github.com/Mic92/nix-update
hacktoberfest
Last synced: 2 months ago
JSON representation
Swiss-knife for updating nix packages.
- Host: GitHub
- URL: https://github.com/Mic92/nix-update
- Owner: Mic92
- License: mit
- Created: 2020-03-05T11:31:09.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-30T21:09:04.000Z (9 months ago)
- Last Synced: 2024-05-02T00:17:14.448Z (9 months ago)
- Topics: hacktoberfest
- Language: Python
- Homepage:
- Size: 439 KB
- Stars: 390
- Watchers: 7
- Forks: 35
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- License: LICENSE.rst
Awesome Lists containing this project
- awesome-nix - nix-update - Update versions/source hashes of nix packages. (Development / Discovery)
- awesome-starred - Mic92/nix-update - Swiss-knife for updating nix packages. (Python)
- awesome-starred - Mic92/nix-update - Swiss-knife for updating nix packages. (Python)
README
# nix-update
Nix-update updates versions/source hashes of nix packages. It is
designed to work with nixpkgs but also other package sets.## Features
- automatically figure out the latest version of packages from:
- BitBucket
- Codeberg
- crates.io
- Gitea
- GitHub
- GitLab
- PyPi
- RubyGems.org
- Sourcehut
- Savannah
- update buildRustPackage's cargoHash/cargoSha256/cargoLock and cargoSetupHook's cargoDeps
- update buildGoModule's vendorHash/vendorSha256
- update buildNpmPackage's npmDepsHash and npmConfigHook's npmDeps
- update buildComposerProject's vendorHash
- update buildMavenPackage's mvnHash
- update mixRelease's mixFodDeps
- update fetchYarnDeps offlineCache output hash
- update flake outputs (see `--flake`)
- build and run the resulting package (see `--build`,
`--run` or `--shell`
- commit updated files (see `--commit` flag)
- run update scripts (`passthru.updateScript`, see `--use-update-script` flag)
- run package tests (see `--test` flag)
- specify the system to use (see `--system` flag)## Installation
`nix-update` is included in nixpkgs.
To run without installing it, use:
```console
$ nix-shell -p nix-update
```To install it:
```console
$ nix-env -f '' -iA nix-update
```To run it from the git repository:
```console
$ nix-build
$ ./result/bin/nix-update
```If you have nix flakes enabled you can also do:
```console
$ nix run github:Mic92/nix-update
```## USAGE
First change to your directory containing the nix expression (Could be a
nixpkgs or your own repository). Than run `nix-update` as follows```console
$ nix-update attribute [--version version]
```If your package is defined in a flake use the `--flake` flag instead:
```console
$ nix-update attribute --flake [--version version]
````nix-update` will than try to update either the
`packages.{currentSystem}.{attribute}` or `{attribute}` output attribute of the
given flake. To update a package in `legacyPackages`, pass the full path to that
package including the platform: `legacyPackages.{platform}.{attribute}`.This example will fetch the latest github release:
```console
$ nix-update nixpkgs-review
```It is also possible to specify the version manually
```console
$ nix-update --version=2.1.1 nixpkgs-review
```To update an unstable package to the latest commit of the default branch:
```console
$ nix-update --version=branch nixpkgs-review
```To update an unstable package the latest commit from a certain branch:
```console
$ nix-update --version=branch=develop nixpkgs-review
```To only update sources hashes without updating the version:
```console
$ nix-update --version=skip nixpkgs-review
```To extract version information from versions with prefixes or suffixes,
a regex can be used```console
$ nix-update jq --version-regex 'jq-(.*)'
```By default `nix-update` will locate the file that needs to be patched using the `src` attribute of a derivation.
In some cases this heurestic is wrong. One can override the behavior like that:```console
$ nix-update hello --override-filename pkgs/applications/misc/hello/default.nix
```The `nix-update` command checks for new releases of a package using the `src`
attribute. However, in some cases a package may use a non-standard release URL
that is not supported by `nix-update`, but still has a repository with release
information. For example, the Signal Desktop package in Nixpkgs fetches updates
from https://updates.signal.org/, but also publishes release information on its
GitHub page. In such cases, use the `--url` parameter to direct nix-update to
the correct repository:```console
nix-update --url https://github.com/signalapp/Signal-Desktop --override-filename pkgs/applications/networking/instant-messengers/signal-desktop/default.nix signal-desktop
```With the `--shell`, `--build`, `--test` and `--run` flags the update can be
tested. Additionally, the `--review` flag can be used to
initiate a run of [nixpkgs-review](https://github.com/Mic92/nixpkgs-review), which will ensure all
dependent packages can be built.In order to ensure consistent formatting, the `--format` flag will invoke [nixfmt](https://github.com/NixOS/nixfmt) (`nixfmt-rfc-style` in nixpkgs).
```console
# Also runs nix-build
$ nix-update --build nixpkgs-review
# Also runs nix-build nixpkgs-review.tests
$ nix-update --test nixpkgs-review
# Also runs nix-shell
$ nix-update --shell nixpkgs-review
# Also runs nix run
$ nix-update --run nixpkgs-review
# Run `nixpkgs-review wip` to validate dependent packages
$ nix-update --review nixpkgs-review
# Format file
$ nix-update --format nixpkgs-review
```Nix-update also can optionally generate a commit message in the form
`attribute: old_version -> new_version` with the applied
version update:```console
$ nix-update --commit bitcoin-abc
...
[master 53d68a6a5a9] bitcoin-abc: 0.21.1 -> 0.21.2
1 file changed, 2 insertions(+), 2 deletions(-)
```By default, nix-update will attempt to update to the next stable version
of a package. Alphas, betas, release candidates and similar unstable
releases will be ignored. This can be affected by changing the parameter
`version` from its default value `stable` to `unstable`.```console
$ nix-update sbt
Not updating version, already 1.4.6$ nix-update sbt --version=unstable
Update 1.4.6 -> 1.5.0-M1 in sbt
```## Development setup
First clone the repo to your preferred location (in the following, we assume `~/` - your home):
```console
$ git clone https://github.com/Mic92/nix-update/ ~/nix-update
```Than enter the dev shell:
```console
$ cd ~/nix-update
$ nix develop
```Change to the repository that contains the nix files you want to update, i.e. nixpkgs:
```console
$ cd nixpkgs
```Now you can run `nix-update` just by specifying the full path to its executable wrapper:
```console
$ ~/git/nix-update/bin/nix-update --commit hello
```## TODO
- create pull requests
## Known Bugs
nix-update might not work correctly if a file contain multiple packages
as it performs naive search and replace to update version numbers. This
might be a problem if:- A file contains the same version string for multiple packages.
- `name` is used instead of `pname` and/or `${version}` is injected into `name`.Related discussions:
-
-## Related projects:
- [nixpkgs-update](https://github.com/ryantm/nixpkgs-update) is
optimized for mass-updates in nixpkgs while nix-update is better
suited for interactive usage that might require user-intervention
i.e. fixing the build and testing the result. nix-update is also not
limited to nixpkgs.