mirror of
https://github.com/digital-asset/daml.git
synced 2024-09-20 09:17:43 +03:00
f4d0eb636e
* Unmangled libz.so and libbz2.so * Use stack_snapshot instead of Hazel * Remove Hazel * Define stack_snapshot * Update rules_haskell * Document stack_snapshot * Clean stack's lock file from aborted builds
30 lines
1.2 KiB
Markdown
30 lines
1.2 KiB
Markdown
# How to upgrade packages in this repo
|
|
|
|
## Stackage
|
|
|
|
The daml repository uses a custom stack snapshot defined in
|
|
`stack-snapshot.yaml`. Modify the `resolver` entry in that file to update the
|
|
base Stackage snapshot. Update the package overrides defined in that file as
|
|
appropriate.
|
|
|
|
A few Stackage packages require custom patches or custom build rules. These are
|
|
defined in the `WORKSPACE` file and referenced in the `vendored_packages`
|
|
attribute to `stack_snapshot` in the same file.
|
|
|
|
|
|
## Nixpkgs
|
|
|
|
To update the nixpkgs revision, find a commit in nixkgs-unstable from
|
|
https://github.com/NixOS/nixpkgs-channels/commits/nixpkgs-unstable and
|
|
use it in the `rev` field in `nix/nixpkgs/default.src.json`. Set the
|
|
`sha256` to a dummy hash, e.g., 64 zeros and run `nix-build -A tools
|
|
-A cached nix` and nix will tell you the correct hash.
|
|
|
|
After upgrading the revision, the easiest solution is usually to open
|
|
a PR and see what fails on CI (running the builds locally can take
|
|
quite some time). The most common reason for failures is usually that
|
|
we have overriden a specific package with certain patches that no
|
|
longer work. In that case, a good first step is to check if these
|
|
patches are still necessary and if not try to switch to the unpatched
|
|
package from nixpkgs.
|