Egbert Eich
56ffc9a15e
* Features in this Release + Spec splicing To make binary installation more seamless in Spack, `v0.23` introduces "splicing", which allows users to deploy binaries using local, optimized versions of a binary interface, even if they were not built with that interface. For example, this would allow you to build binaries in the cloud using `mpich` and install them on a system using a local, optimized version of `mvapich2` *without rebuilding*. Spack preserves full provenance for the installed packages and knows that they were built one way but deployed another. The intent is to leverage this across many key HPC binary packages, e.g. MPI, CUDA, ROCm, and libfabric. Fundamentally, splicing allows Spack to redeploy an existing spec with different dependencies than how it was built. There are two interfaces to splicing. a. Explicit Splicing In the concretizer config, you can specify a target spec and a replacement by hash. ```yaml concretizer: splice: explicit: - target: mpi replacement: mpich/abcdef ``` Here, every installation that would normally use the target spec will instead use its replacement. Above, any spec using *any* `mpi` will be spliced to depend on the specific `mpich` OBS-URL: https://build.opensuse.org/package/show/network:cluster/spack?expand=0&rev=111
1363 lines
65 KiB
Plaintext
1363 lines
65 KiB
Plaintext
-------------------------------------------------------------------
|
|
Fri Jan 3 13:40:08 UTC 2025 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update to version v0.23.0. This is a major release.
|
|
* Features in this Release
|
|
+ Spec splicing
|
|
To make binary installation more seamless in Spack, `v0.23`
|
|
introduces "splicing", which allows users to deploy binaries
|
|
using local, optimized versions of a binary interface, even
|
|
if they were not built with that interface. For example, this
|
|
would allow you to build binaries in the cloud using `mpich`
|
|
and install them on a system using a local, optimized version
|
|
of `mvapich2` *without rebuilding*. Spack preserves full
|
|
provenance for the installed packages and knows that they
|
|
were built one way but deployed another.
|
|
The intent is to leverage this across many key HPC binary
|
|
packages, e.g. MPI, CUDA, ROCm, and libfabric.
|
|
Fundamentally, splicing allows Spack to redeploy an existing
|
|
spec with different dependencies than how it was built. There
|
|
are two interfaces to splicing.
|
|
a. Explicit Splicing
|
|
In the concretizer config, you can specify a target spec
|
|
and a replacement by hash.
|
|
```yaml
|
|
concretizer:
|
|
splice:
|
|
explicit:
|
|
- target: mpi
|
|
replacement: mpich/abcdef
|
|
```
|
|
Here, every installation that would normally use the target
|
|
spec will instead use its replacement. Above, any spec using
|
|
*any* `mpi` will be spliced to depend on the specific `mpich`
|
|
installation requested. This *can* go wrong if you try to
|
|
replace something built with, e.g., `openmpi` with `mpich`,
|
|
and it is on the user to ensure ABI compatibility between
|
|
target and replacement specs. This currently requires some
|
|
expertise to use, but it will allow users to reuse the
|
|
binaries they create across more machines and environments.
|
|
b. Automatic Splicing (experimental)
|
|
In the concretizer config, enable automatic splicing:
|
|
```yaml
|
|
concretizer:
|
|
splice:
|
|
automatic: true
|
|
```
|
|
or run:
|
|
```console
|
|
spack config add concretizer:splice:automatic:true
|
|
```
|
|
The concretizer will select splices for ABI compatibility
|
|
to maximize package reuse. Packages can denote ABI
|
|
compatibility using the `can_splice` directive. No packages
|
|
in Spack yet use this directive, so if you want to use this
|
|
feature you will need to add `can_splice` annotations to
|
|
your packages. We are working on ways to add more ABI
|
|
compatibility information to the Spack package repository,
|
|
and this directive may change in the future.
|
|
Further documentation:
|
|
* https://spack.readthedocs.io/en/latest/build_settings.html#splicing
|
|
* https://spack.readthedocs.io/en/latest/packaging_guide.html#specifying-abi-compatibility
|
|
+ Broader variant propagation
|
|
You can specify propagated variants like
|
|
`hdf5 build_type==RelWithDebInfo` or `trilinos ++openmp` to
|
|
propagate a variant to all dependencies for which it is
|
|
relevant. This is valid *even* if the variant does not exist
|
|
on the package or its dependencies.
|
|
See https://spack.readthedocs.io/en/latest/basic_usage.html#variants.
|
|
+ Query specs by namespace
|
|
Allow a package's namespace (indicating the repository it came
|
|
from) to be treated like a variant. You can request packages
|
|
from particular repos like this:
|
|
```console
|
|
spack find zlib namespace=builtin
|
|
spack find zlib namespace=myrepo
|
|
```
|
|
Previously, the spec syntax only allowed namespaces to be prefixes of spec
|
|
names, e.g. `builtin.zlib`. The previous syntax still works.
|
|
+ `spack spec` respects environment settings and `unify:true`
|
|
`spack spec` did not previously respect environment lockfiles
|
|
or unification settings, which made it difficult to see
|
|
exactly how a spec would concretize within an environment.
|
|
Now it does, so the output you get with `spack spec` will
|
|
be *the same* as what your environment will concretize to
|
|
when you run `spack concretize`. Similarly, if you provide
|
|
multiple specs on the command line with `spack spec`, it will
|
|
concretize them together if `unify:true` is set.
|
|
+ Less noisy `spack spec` output
|
|
`spack spec` previously showed output like this:
|
|
```console
|
|
> spack spec /v5fn6xo
|
|
Input spec
|
|
--------------------------------
|
|
- /v5fn6xo
|
|
|
|
Concretized
|
|
--------------------------------
|
|
[+] openssl@3.3.1%apple-clang@16.0.0~docs+shared arch=darwin-sequoia-m1
|
|
...
|
|
```
|
|
But the input spec is redundant, and we know we run
|
|
`spack spec` to concretize the input spec. `spack spec` now
|
|
*only* shows the concretized spec. See #47574.
|
|
+ Better output for `spack find -c`
|
|
In an environment, `spack find -c` lets you search the
|
|
concretized, but not yet installed, specs, just as you would
|
|
the installed ones. As with `spack spec`, this should make
|
|
it easier for you to see what *will* be built before building
|
|
and installing it.
|
|
+ `spack -C <env>`: use an environment's configuration without activation
|
|
Spack environments allow you to associate:
|
|
1. a set of (possibly concretized) specs, and
|
|
2. configuration
|
|
When you activate an environment, you're using both of these.
|
|
Previously, we supported:
|
|
* `spack -e <env>` to run spack in the context of a specific
|
|
environment, and
|
|
* `spack -C <directory>` to run spack using a directory with
|
|
configuration files.
|
|
You can now also pass an environment to `spack -C` to use
|
|
*only* the environment's configuration, but not the specs or
|
|
lockfile.
|
|
* New commands, options, and directives
|
|
+ The new `spack env track` command (#41897) takes a non-managed
|
|
Spack environment and adds a symlink to Spack's
|
|
`$environments_root` directory, so that it will be included
|
|
for reference counting for commands like `spack uninstall`
|
|
and `spack gc`. If you use free-standing directory environments,
|
|
this is useful for preventing Spack from removing things
|
|
required by your environments. You can undo this tracking
|
|
with the `spack env untrack` command.
|
|
+ Add `-t` short option for `spack --backtrace`
|
|
`spack -d / --debug` enables backtraces on error, but it
|
|
can be very verbose, and sometimes you just want the
|
|
backtrace. `spack -t / --backtrace` provides that option.
|
|
+ `gc`: restrict to specific specs (#46790)
|
|
If you only want to garbage-collect specific packages, you can
|
|
now provide them on the command line. This gives users finer-grained
|
|
control over what is uninstalled.
|
|
+ oci buildcaches now support `--only=package`. You can now push
|
|
*just* a package and not its dependencies to an OCI registry.
|
|
This allows dependents of non-redistributable specs to be
|
|
stored in OCI registries without an error.
|
|
* Notable refactors
|
|
* Highlighted bugfixes
|
|
+ Externals no longer override the preferred provider.
|
|
External definitions could interfere with package preferences.
|
|
Now, if `openmpi` is the preferred `mpi`, and an external
|
|
`mpich` is defined, a new `openmpi` *will* be built if
|
|
building it is possible. Previously we would prefer `mpich`
|
|
despite the preference.
|
|
+ Composable `cflags`.
|
|
This release fixes a longstanding bug that concretization
|
|
would fail if there were different `cflags` specified in
|
|
`packages.yaml`, `compilers.yaml`, or on `the` CLI. Flags
|
|
and their ordering are now tracked in the concretizer and
|
|
flags from multiple sources will be merged.
|
|
+ Fix concretizer Unification for included environments.
|
|
* Deprecations, removals, and syntax changes
|
|
+ The old concretizer has been removed from Spack, along with
|
|
the `config:concretizer` config option. Spack will emit a
|
|
warning if the option is present in user configuration,
|
|
since it now has no effect. Spack now uses a simpler
|
|
bootstrapping mechanism, where a JSON prototype is tweaked
|
|
slightly to get an initial concrete spec to download.
|
|
+ Best-effort expansion of spec matrices has been removed.
|
|
This feature did not work with the "new" ASP-based concretizer,
|
|
and did not work with `unify: True` or `unify: when_possible`.
|
|
Use the
|
|
[exclude key](https://spack.readthedocs.io/en/latest/environments.html#spec-matrices)
|
|
for the environment to exclude invalid components, or use
|
|
multiple spec matrices to combine the list of specs for
|
|
which the constraint is valid and the list of specs for
|
|
which it is not.
|
|
+ The old Cray `platform` (based on Cray PE modules) has been
|
|
removed, and `platform=cray` is no longer supported. Since
|
|
`v0.19`, Spack has handled Cray machines like Linux clusters
|
|
with extra packages, and we have encouraged using this option
|
|
to support Cray. The new approach allows us to correctly handle
|
|
Cray machines with non-SLES operating systems, and it is much
|
|
more reliable than making assumptions about Cray modules. See
|
|
the `v0.19` release notes and #43796 for more details.
|
|
+ The `config:install_missing_compilers` config option has been
|
|
deprecated, and it is a no-op when set in `v0.23`. Our new
|
|
compiler dependency model will replace it with a much more
|
|
reliable and robust mechanism in `v1.0`.
|
|
+ Config options that deprecated in `v0.21` have been removed
|
|
in `v0.23`. You can now only specify preferences for
|
|
`compilers`, `targets`, and `providers` globally via the
|
|
`packages:all:` section. Similarly, you can only specify
|
|
`versions:` locally for a specific package.
|
|
+ Spack's old test interface has been removed (#45752), having
|
|
been deprecated in `v0.22.0` (#34236). All `builtin` packages
|
|
have been updated to use the new interface. See the
|
|
[stand-alone test documentation](
|
|
https://spack.readthedocs.io/en/latest/packaging_guide.html#stand-alone-tests)
|
|
+ The `spack versions --safe-only` option, deprecated since
|
|
`v0.21.0`, has been removed.
|
|
+ The `--dependencies` and `--optimize` arguments to `spack ci`
|
|
have been deprecated.
|
|
- Binary caches
|
|
+ Public binary caches now include an ML stack for Linux/aarch64.
|
|
We now build an ML stack for Linux/aarch64 for all pull
|
|
requests and on develop. The ML stack includes both CPU-only
|
|
and CUDA builds for Horovod, Hugging Face, JAX, Keras, PyTorch,
|
|
scikit-learn, TensorBoard, and TensorFlow, and related packages.
|
|
The CPU-only stack also includes XGBoost.
|
|
See https://cache.spack.io/tag/develop/?stack=ml-linux-aarch64-cuda.
|
|
- Architecture support
|
|
* archspec has been updated to `v0.2.5`, with support for
|
|
`zen5`.
|
|
* Spack's CUDA package now supports the Grace Hopper `9.0a`
|
|
compute capability.
|
|
- Other notable changes
|
|
+ Bugfix: `spack find -x` in environments.
|
|
+ Spec splices are now robust to duplicate nodes with the
|
|
same name in a spec.
|
|
+ Cache per-compiler libc calculations for performance.
|
|
+ Fixed a bug in external detection for openmpi.
|
|
+ Mirror configuration allows username/password as environment
|
|
variables.
|
|
+ Default library search caps maximum depth/
|
|
+ Unify interface for `spack spec` and `spack solve` commands.
|
|
+ Spack no longer RPATHs directories in the default library
|
|
search path.
|
|
+ Improved performance of Spack database.
|
|
+ Enable package reuse for packages with versions from git refs.
|
|
+ Improved tracking of task queueing/requeueing in the installer.
|
|
- Deleted: Fix-error-during-documentation-build-due-to-recursive-module-inclusion.patch
|
|
Patch no longer required for target versions.
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Nov 1 06:32:35 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update to version 0.22.2
|
|
* Bugfixes
|
|
- Forward compatibility with Spack 0.23 packages with language
|
|
dependencies.
|
|
- Forward compatibility with `urllib` from Python 3.12.6+.
|
|
- Bump vendored `archspec` for better aarch64 support.
|
|
- Fix regression in `{variants.X}` and `{variants.X.value}`
|
|
format strings.
|
|
- Ensure shell escaping of environment variable values in load
|
|
and activate commands.
|
|
- Fix an issue where `spec[pkg]` considers specs outside the
|
|
current DAG.
|
|
- Do not halt concretization on unknown variants in externals.
|
|
- Improve validation of `develop` config section/
|
|
- Explicitly disable `ccache` if turned off in config, to
|
|
avoid cache pollution.
|
|
- Improve backwards compatibility in `include_concrete`.
|
|
- Fix issue where package tags were sometimes repeated.
|
|
- Make `setup-env.sh` "sourced only" by dropping execution bits.
|
|
- Make certain source/binary fetch errors recoverable instead
|
|
of a hard error.
|
|
- Remove debug statements in package hash computation.
|
|
- Remove redundant clingo warnings.
|
|
- Remove hard-coded layout version.
|
|
- Do not initialize previous store state in `use_store`.
|
|
* Package updates
|
|
- `chapel` major update/
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Jul 10 06:54:31 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update to 0.22.1.
|
|
* Bug Fixes:
|
|
- Fix reuse of externals on Linux.
|
|
- Ensure parent gcc-runtime version >= child.
|
|
- Ensure the latest gcc-runtime is rpath'ed when multiple exist
|
|
among link deps.
|
|
- Improve version detection of glibc.
|
|
- Improve heuristics for solver.
|
|
- Make strong preferences override reuse.
|
|
- Reduce verbosity when C compiler is missing.
|
|
- Make missing ccache executable an error when required.
|
|
- Make every environment view containing `python` a `venv`.
|
|
- Fix external detection for compilers with os but no target.
|
|
- Fix version optimization for roots.
|
|
- Handle common implementations of pagination of tags in OCI
|
|
build caches.
|
|
- Apply fetched patches to develop specs.
|
|
- Avoid Windows wrappers for filesystem utilities on non-Windows.
|
|
- Fix formatting issue in `spack audit`.
|
|
* Package updates:
|
|
- Require libiconv for iconv.
|
|
Notice that glibc/musl also provide iconv, but are not
|
|
guaranteed to be complete. Set `packages:iconv:require:[glibc]`
|
|
to restore the old behavior.
|
|
- protobuf: fix 3.4:3.21 patch checksum.
|
|
- protobuf: update hash for patch needed when="@3.4:3.21".
|
|
- git: bump v2.39 to 2.45; deprecate unsafe versions.
|
|
- gcc: use `-rpath {rpath_dir}` not `-rpath={rpath dir}`.
|
|
- Remove mesa18 and libosmesa.
|
|
- Enforce consistency of `gl` providers.
|
|
- py-matplotlib: qualify when to do a post install.
|
|
- rust: fix v1.78.0 instructions.
|
|
- suite-sparse: improve setting of the libs property.
|
|
- netlib-lapack: provide blas and lapack together.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu May 16 17:03:50 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Move-site-config-scope-before-system-scope.patch:
|
|
Give 'site' scope a lower precedence than 'system' scope.
|
|
The 'site wide' config scope was meant to be per Spack
|
|
installation. A single system may have multiple Spack
|
|
installations, so was is meant for overriding the
|
|
'system' wide setting per installation.
|
|
The Spack package is OS-vendor provided. The vendor provides
|
|
pr generates a configuration which a local admin may want to
|
|
override. This can now be done from within the 'system' scope.
|
|
Previously the vendor-supplied configuration was mixed with
|
|
the 'system' scope - local modifications collided with
|
|
vendor autoconfiguration.
|
|
- Add a build-dependency package which will cause build tools
|
|
and libraries used frequently by Spack to be installed.
|
|
All these packages are recommended by the main Spack package
|
|
already. This package may be used in environments where the
|
|
installation of recommended packages is disabled by default.
|
|
|
|
-------------------------------------------------------------------
|
|
Mon May 13 13:12:22 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update Spack to version 0.22.0
|
|
* New features:
|
|
- Compiler dependencies:
|
|
Spack is in the process of making compilers proper dependencies.
|
|
For this, compiler dependencies are moving from `compilers.yaml`
|
|
to `packages.yaml` to make this consistent with other externals.
|
|
For this, dependency graphs will not show the compiler runtime
|
|
libraries like `gcc-runtime` or `libgfortran`.
|
|
To minimize disruption, an existing `compilers.yaml` file will
|
|
continue to work, however, users are encourage to migrate
|
|
before v0.23.
|
|
+ Packages compiled with `%gcc` now depend on a new package
|
|
`gcc-runtime`, which contains a copy of the shared compiler
|
|
runtime libraries. This enables gcc runtime libraries to be
|
|
installed and relocated when using a build cache.
|
|
When building minimal Spack-generated container images it
|
|
is no longer necessary to install libgfortran, libgomp
|
|
etc. using the system package manager.
|
|
+ Packages compiled with `%oneapi` now depend on a new package
|
|
`intel-oneapi-runtime`. This is similar to gcc-runtime.
|
|
This allows us to model library soname compatibility and
|
|
allows compilers like %oneapi to provide virtuals like sycl
|
|
(which can also be provided by standalone libraries).
|
|
+ Changes to the optimization criteria of the solver improve
|
|
the hit-rate of buildcaches by a fair amount. The solver has
|
|
more relaxed compatibility rules and will not try to strictly
|
|
match compilers or targets of reused specs. Users can still
|
|
enforce the previous strict behavior with require: sections
|
|
in packages.yaml.
|
|
Note that to enforce correct linking, Spack will not reuse
|
|
old %gcc and %oneapi specs that do not have the runtime
|
|
libraries as a dependency.
|
|
+ Spack will reuse specs built with compilers that are not
|
|
explicitly configured in `compilers.yaml`. Because we can
|
|
now keep runtime libraries in build cache, we do not require
|
|
you to also have a local configured compiler to use the
|
|
runtime libraries. This improves reuse in buildcaches and
|
|
avoids conflicts with OS updates that happen underneath
|
|
Spack.
|
|
+ Binary compatibility on `linux` is now based on the `libc`
|
|
version, instead of on the OS tag. Spack builds now detect
|
|
the host `libc` (`glibc`) and add it as an implicit external
|
|
node in the dependency graph. Binaries with a `libc` with
|
|
the same name and a version less than or equal to that of
|
|
the detected libc can be reused.
|
|
+ Each package that can provide a compiler is now detectable
|
|
using spack external find. External packages defining
|
|
compiler paths are effectively used as compilers, and spack
|
|
external find -t compiler` can be used as a substitute for
|
|
`spack compiler find. More details on this transition are
|
|
in [the docs](https://spack.readthedocs.io/en/latest/getting_started.html#manual-compiler-configuration).
|
|
- Improved spack find UI for Environments:
|
|
`spack find` in environments shows information about
|
|
* What are the roots
|
|
* Which ones are installed / not installed
|
|
* What's been added that still needs to be concretized
|
|
much more clearly. An option `--only-roots`/`-r` has been added
|
|
to `spack find` that will only show env roots, if you don't want
|
|
to look at all the installed specs.
|
|
- Improved command-line string quoting
|
|
Spack now parses specs in the CLI respecting shell quoting. Instead
|
|
of:
|
|
```
|
|
spack install zlib cflags=\"-O2 -g\"
|
|
```
|
|
you should use:
|
|
```
|
|
spack install zlib cflags="-O2 -g"
|
|
```
|
|
The old form will now result in an error.
|
|
This allows to include special characters, flags like
|
|
```
|
|
spack intall zlib ldflags='-Wl,-rpath=$ORIGIN/_libs'
|
|
```
|
|
may now be supplied. To reduce ambiguities during paring, quotes
|
|
are no longer allowed around `=` and `==`. Commands like:
|
|
```
|
|
spack install zlib cflags = "-O2 -g"
|
|
```
|
|
will result in an error.
|
|
- Revert default spack install behavior to `--reuse`
|
|
In v0.20 the default concretizer behavior was changed from
|
|
`--reuse` to `--reuse-deps`, which meant that *every* `spack
|
|
install` invocation would attempt to build a new version of
|
|
the requested package / any environment roots.
|
|
While this is a common ask for *upgrading* and for *developer
|
|
workflows*, it shouldn't be the default for a package manager.
|
|
- The `install` command now offers the three options:
|
|
* `--reuse` (default): reuse as many existing installations
|
|
as possible.
|
|
* `--reuse-deps` or `--fresh-roots`: upgrade (freshen) roots
|
|
but reuse dependencies if possible.
|
|
* --fresh: install fresh versions of requested packages
|
|
(roots) and their dependencies.
|
|
- More control over reused specs
|
|
Spack now provides better control over which packages to reuse
|
|
and how. There is a new `concretizer:reuse` config option,
|
|
which accepts the following properties:
|
|
* `roots`: true to reuse roots, false to reuse just dependencies
|
|
* `exclude`: list of constraints used to select which specs
|
|
not to reuse.
|
|
* `include`: list of constraints used to select which specs
|
|
to reuse.
|
|
* `from`: list of sources for reused specs (some combination
|
|
of `local`, `buildcache`, or `external`).
|
|
- New `conflict:` and `prefer:` syntax for package preferences
|
|
Instead of having to express conflicts and preferences just
|
|
using `require:`, these can now be expressed explicitly.
|
|
- `include_concrete` in environments
|
|
This directive allows to build on the *cncrete* contents of
|
|
another environment without changing this environment by
|
|
includeing the concrete specs from this environment's
|
|
`spack.lock`:
|
|
```
|
|
spack:
|
|
specs: []
|
|
concretizer:
|
|
unify: true
|
|
include_concrete:
|
|
- /path/to/environment1
|
|
- /path/to/environment2
|
|
```
|
|
When this environment is concretized, it will bring the
|
|
already concrete specs from `environment1` and `environment2`,
|
|
and build on top of them without changing them.
|
|
- `python-venv` isolation
|
|
Spack now insert a small `python-venv` package in between
|
|
`python` and packages that need to install Python code to
|
|
isolate Spack's build environment and shield Spack form
|
|
potential issues with an external python.
|
|
- Packages can now specify whether they may be distributed in
|
|
source or binary form.
|
|
* New commands, options and directives
|
|
- Allow packages to be pushed to build cache after install from
|
|
source.
|
|
_ `spack develop`: stage build artifacts in same root as non-dev
|
|
builds.
|
|
- Don't delete spack develop build artifacts after install.
|
|
- `spack find`: add options for local/upstream only.
|
|
- `spack logs`: print log files for packages (either partially
|
|
built or installed).
|
|
- `patch`: support reversing patches.
|
|
- `develop`: Add `-b`/`--build-directory` option to set
|
|
build_directory package attribute.
|
|
- `spack list`: add `--namesapce` / `--repo` option.
|
|
- spack gc: add options for environments and build dependencies.
|
|
- Add `--create` to `spack env activate`.
|
|
* Performance improvements
|
|
- environment.py: Fix excessive re-reads.
|
|
- ruamel yaml: Fix quadratic complexity bug.
|
|
- Refactor to improve `spec format` speed.
|
|
- Do not acquire a write lock on the env post install if no views.
|
|
- `asp.py`: fewer calls to `spec.copy()`
|
|
- `spec.py`: early return in `__str__`
|
|
- avoid `jinja2` import at startup unless needed.
|
|
* Other new features of note
|
|
- `archspec`: update to v0.2.4: bugfixes for `neoverse-v1` and
|
|
`neoverse-v2` detection.
|
|
- `spack config` get/blame: with no args, show entire config
|
|
- `spack env create <env>`: dir if dir-like
|
|
- Add handling of custom ssl certs in urllib ops.
|
|
- Add ability to rename environments.
|
|
- Add config option and compiler support to reuse across OS's.
|
|
- Support for prereleases.
|
|
- Only reuse externals when configured.
|
|
- Environments: Add support for including views.
|
|
* Binary caches
|
|
Build cache: make signed/unsigned a mirror property.
|
|
* Removals, deprecations, and syntax changes
|
|
- Remove `dpcpp` compiler and package.
|
|
- `spack load`: remove `--only` argument.
|
|
* Notable Bugfixes
|
|
- repo.py: drop deleted packages from provider cache.
|
|
- Allow `+` in module file names.
|
|
- `cmd/python`: use runpy to allow multiprocessing in scripts.
|
|
- Show extension commands with `spack -h`.
|
|
- Support environment variable expansion inside module
|
|
projections.
|
|
- Alert user to failed concretizations.
|
|
- `shell`: fix `zsh` color formatting for PS1 in environments.
|
|
- `spack mirror create --all`: include patches.
|
|
- Update `run-find-external.sh` script to address the deprecation
|
|
of `compilers.yaml`.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Apr 18 06:54:54 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add lsb-release and zstd as new requires to match upstream
|
|
prerequisites.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Apr 4 07:14:54 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Make `patchelf` a mandatory dependency on products where it
|
|
is always available.
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Mar 15 13:35:51 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update Spack to version 0.21.2
|
|
* Bugfixes
|
|
+ Containerize: accommodate nested or pre-existing `spack-env`
|
|
paths.
|
|
+ Fix `setup-env` script, when going back and forth between
|
|
instances.
|
|
+ Fix using fully-qualified namespaces from root specs.
|
|
+ Fix a bug when a required provider is requested for multiple
|
|
virtuals.
|
|
+ OCI buildcaches:
|
|
* only push in parallel when forking.
|
|
* use pickleable errors (#42160)
|
|
+ Fix using sticky variants in externals.
|
|
+ Fix a rare issue with conditional requirements and
|
|
multi-valued variants.
|
|
* Package updates
|
|
+ `rust`: add v1.75, rework a few variants.
|
|
+ `py-transformers`: add v4.35.2.
|
|
- Fix path to setup-env.sh in the Apptainer template (bsc#1221471).
|
|
- Add libgfortran, libfl2 and libzip5 to the Spack runtime
|
|
container as the Spack build container has the corresponding
|
|
devel packages but these libraries are not installed in a
|
|
BCI-style base container by default (bsc#1221503).
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Feb 2 14:41:14 UTC 2024 - Egbert Eich <eich@suse.com>
|
|
|
|
- Make python version used configurable.
|
|
- Filter out more rpmlint errors.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Jan 25 14:07:19 UTC 2024 - Christian Goll <cgoll@suse.com>
|
|
|
|
- Update Spack to version 0.21.1
|
|
* Add support for reading buildcaches created by Spack v0.22
|
|
* Bugfixes
|
|
+ `spack graph`: fix coloring with environments
|
|
+ `spack info`: sort variants in --variants-by-name
|
|
+ `Spec.format`: error on old style format strings
|
|
+ ASP-based solver:
|
|
- fix infinite recursion when computing concretization
|
|
errors,
|
|
- don't error for type mismatch on preferences,
|
|
- don't emit spurious debug output.
|
|
+ Improve the error message for deprecated preferences.
|
|
+ Fix multi-word aliases.
|
|
+ Add a warning for unconfigured compiler.
|
|
+ environment: fix an issue with deconcretization/reconcretization
|
|
of specs.
|
|
+ buildcache: don't error if a patch is missing, when
|
|
installing from binaries
|
|
- From version 0.21.0
|
|
* following new features:
|
|
+ Better error messages with condition chaining:
|
|
In v0.18, we added better error messages that could tell you
|
|
what problem happened, but they couldn't tell you why it
|
|
happened. 0.21 adds condition chaining to the solver, and
|
|
Spack can now trace back through the conditions that led to
|
|
an error and build a tree of causes potential causes and
|
|
where they came from.
|
|
+ OCI build caches:
|
|
You can now use an arbitrary OCI registry as a build cache:
|
|
- For Dockerhub:
|
|
`$ spack mirror add my_registry oci://user/image`
|
|
- For another registry (GHCR):
|
|
`$ spack mirror add my_registry oci://ghcr.io/haampie/spack-test`
|
|
Then set the login credentials:
|
|
`$ spack mirror set --push --oci-username ... --oci-password ... my_registry`
|
|
and push to it:
|
|
`$ spack buildcache push my_registry [specs...]`
|
|
You can optionally add a base image to get runnable images:
|
|
```
|
|
$ spack buildcache push --base-image leap:15.5 my_registry python`
|
|
Pushed ... as [image]:python-3.11.2-65txfcpqbmpawclvtasuog4yzmxwaoia.spack
|
|
$ docker run --rm -it [image]:python-3.11.2-65txfcpqbmpawclvtasuog4yzmxwaoia.spack
|
|
```
|
|
This creates a container image from the Spack installations
|
|
on the host system, without the need to run `spack install`
|
|
from a `Dockerfile` or `sif` file. It also addresses the
|
|
inconvenience of losing binaries of dependencies when
|
|
`RUN spack install` fails inside `docker build`. Further, the
|
|
container image layers and build cache tarballs are the same
|
|
files. This means that `spack install` and `docker pull` use the
|
|
exact same underlying binaries. If you previously used `spack
|
|
install` inside of docker build, this feature helps you save
|
|
storage by a factor two.
|
|
+ Multiple versions of build dependencies:
|
|
Increasingly, complex package builds require multiple
|
|
versions of some build dependencies. For example, Python
|
|
packages frequently require very specific versions of
|
|
`setuptools`, `cython`, while different physics packages
|
|
require different versions of Python to build. The concretizer
|
|
enforced that every solve was unified, i.e., so that there was
|
|
only one version of every package. The concretizer now supports
|
|
"duplicate" nodes for build dependencies, but enforces unification
|
|
through transitive link and run dependencies. This will allow it
|
|
to better resolve complex dependency graphs in ecosystems like
|
|
Python.
|
|
+ Cherry-picking virtual dependencies:
|
|
You can now select only a subset of virtual dependencies
|
|
from a spec that may provide more. For example, to make mpich
|
|
your mpi provider, you can be explicit by writing:
|
|
`hdf5 ^[virtuals=mpi] mpich`.
|
|
Or, to use, e.g., `intel-parallel-studio` for blas along with
|
|
an external `lapack` like `openblas`, you could write:
|
|
```
|
|
strumpack ^[virtuals=mpi] intel-parallel-studio+mkl ^[virtuals=lapack] openblas`
|
|
```
|
|
The `virtuals=mpi` is an edge attribute, and dependency edges
|
|
in Spack graphs now track which virtuals they satisfied.
|
|
+ The `spack deconcretize` command gives you control over what
|
|
you want to update in an already concrete environment.
|
|
As an example, with an environment built with meson, and you
|
|
want to update your meson version, you can run:
|
|
`$spack deconcretize meson`
|
|
and have everything that depends on meson rebuilt the next
|
|
time you run spack concretize. In the future, we'll handle
|
|
this in a single command, but for now you can use this to
|
|
drop bits of your lockfile and resolve your dependencies
|
|
again.
|
|
+ UI Improvements:
|
|
The `spack info` received a rework to make the output more
|
|
appealing. It is now on par with the rest of Spack's UI.
|
|
`spack info` now makes much better use of terminal space and
|
|
shows variants, their values, and their descriptions more
|
|
clearly. Conditional variants are grouped separately so you
|
|
can more easily understand how packages are structured.
|
|
`spack checksum` now allows you to filter versions from your
|
|
editor, or by version range. It also notifies you about
|
|
potential download URL changes.
|
|
+ Environments can include definitions:
|
|
Spack did not previously support using `include:` with The
|
|
definitions section of an environment, but now it does. You
|
|
can use this to curate lists of specs and more easily reuse
|
|
them across environments.
|
|
+ Aliases:
|
|
You can now add aliases to Spack commands in `config.yaml`,
|
|
e.g. this might enshrine your favorite args to `spack find`
|
|
as `spack f`:
|
|
```
|
|
config:
|
|
aliases:
|
|
f: find -lv
|
|
```
|
|
+ Improved autoloading of modules:
|
|
In this release, you can start using `hide_implicits: true`
|
|
instead, which exposes only explicitly installed packages to
|
|
the user, while still autoloading dependencies. On top of
|
|
that, you can safely use `hash_length: 0`, as this config now
|
|
only applies to the modules exposed to the user -- you don't
|
|
have to worry about file name clashes for hidden
|
|
dependencies.
|
|
Note: for Tcl this feature requires Modules 4.7 or higher.
|
|
* Other new commands and directives:
|
|
+ `spack env activate` without arguments now loads a default
|
|
environment that you do not have to create.
|
|
+ `spack find -H` / `--hashes`: a new shortcut for piping spack
|
|
find output to other commands.
|
|
+ Add `spack checksum --verify`, fix `--add`.
|
|
+ New `default_args` context manager factors out common args for
|
|
directives.
|
|
+ `spack compiler find --[no]-mixed-toolchain` lets you easily
|
|
mix clang and gfortran on Linux.
|
|
* Performance improvements:
|
|
+ `spack external find execution` is now much faster.
|
|
+ `spack location -i` is now much faster on success.
|
|
+ Drop redundant rpaths post install.
|
|
+ ASP-based solver: avoid cycles in clingo using hidden
|
|
directive.
|
|
+ Fix multiple quadratic complexity issues in environments.
|
|
* Other new features of note:
|
|
+ archspec: update to v0.2.2, support for Sapphire Rapids,
|
|
Power10, Neoverse V2.
|
|
+ Propagate variants across nodes that don't have that variant
|
|
+ Implement fish shell completion.
|
|
+ Can now distinguish between source/binary mirror; don't ping
|
|
mirror.spack.io as much.
|
|
+ Improve status reporting on `spack install`
|
|
(add [n/total] display...).
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Nov 6 08:04:55 UTC 2023 - Bernhard Wiedemann <bwiedemann@suse.com>
|
|
|
|
- Update to version 0.20.3 with the following changes:
|
|
* Bug fixes:
|
|
+ Fix a bug where `spack mirror set-url` would drop configured
|
|
connection info.
|
|
+ Fix a minor issue with package hash computation for Python 3.12.
|
|
+ Improve escaping in Tcl module files.
|
|
+ Make repo cache work on repositories with zero mtime.
|
|
+ Ignore errors for newer, incompatible buildcache version.
|
|
+ Print an error when git is required, but missing.
|
|
+ Ensure missing build dependencies get installed when using
|
|
`spack install --overwrite`.
|
|
+ Fix an issue where Spack freezes when the build process
|
|
unexpectedly exits.
|
|
+ Fix a bug where installation failures cause an unrelated
|
|
`NameError` to be thrown.
|
|
+ Fix an issue where Spack package versions would be incorrectly
|
|
derived from git tags.
|
|
+ Fix a bug triggered when file locking fails internally.
|
|
+ Prevent `spack external find` to error out when a directory
|
|
cannot be accessed.
|
|
+ Fix multiple performance regressions in environments.
|
|
+ Add more ignored modules to `pyproject.toml` for `mypy`.
|
|
* Features:
|
|
+ Spack now supports Python 3.12.
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Sep 12 05:32:46 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update to version 0.20.1 with the following changes:
|
|
* Bug fixes:
|
|
+ Fix spec removed from an environment where not actually
|
|
removed if `--force` was not given.
|
|
+ Hotfix for a few recipes that treat CMake as a link
|
|
dependency.
|
|
+ Fix re-running stand-alone test a second time, which was
|
|
getting a trailing spurious failure.
|
|
+ Fix reading JSON manifest on Cray, reporting non-concrete
|
|
specs.
|
|
+ Fix a few bugs when generating Dockerfiles from Spack.
|
|
+ Fix a few long-standing bugs when generating module files.
|
|
+ Fix issues with building Python extensions when using an
|
|
external Python.
|
|
+ Fix `spack compiler remove`: remove from command line even
|
|
if they appear in different scopes.
|
|
* Features:
|
|
+ Speed-up module file generation.
|
|
+ Show external status as `[e]`.
|
|
+ Backport `archspec` fixes.
|
|
+ Improve a few error messages.
|
|
|
|
-------------------------------------------------------------------
|
|
Sun Aug 13 12:21:57 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Fix SPACK_ROOT setting in /etc/profile.d/spack.[c]sh (bsc#1214222).
|
|
- Don't source /etc/os-release directly, use a subshell.
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Jun 26 12:26:10 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add hwloc-devel and sqlite3 to the packages that trigger a
|
|
`spack external find`.
|
|
- Change /usr/bin to %{_bindir}.
|
|
- Make sure, libhwloc and hwloc are installed together when
|
|
spack is installed.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Jun 1 11:32:36 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Do not attempt to build documentation for 32-bit, s390x and
|
|
ppc64*. There are build issues on some build targets.
|
|
|
|
-------------------------------------------------------------------
|
|
Mon May 22 14:40:17 UTC 2023 - Christian Goll <cgoll@suse.com>
|
|
|
|
- Update to version 0.20.0 with the following features:
|
|
* Exact versions: Spack did not previously have a way to distinguish a
|
|
version if it was a prefix of some other version. For example, @3.2 would
|
|
match 3.2, 3.2.1, 3.2.2, etc. You can now match exactly 3.2 with @=3.2.
|
|
This is useful, for example, if you need to patch only the 3.2 version of a
|
|
package
|
|
* More stable concretization: Now, spack concretize will only concretize the
|
|
new portions of the environment and will not change existing parts of an
|
|
environment unless you specify --force. This has always been true for
|
|
unify:false, but not for unify:true and unify:when_possible environments.
|
|
* The concretizer has a new --reuse-deps argument that only reuses dependencies.
|
|
That is, it will always treat the roots of your environment as it would with
|
|
--fresh. This allows you to upgrade just the roots of your environment while
|
|
keeping everything else stable
|
|
* Specs in buildcaches can be referenced by hash: Previously, you could run
|
|
spack buildcache list and see the hashes in buildcaches, but referring to
|
|
them by hash would fail. You can now run commands like spack spec and
|
|
spack install and refer to buildcache hashes directly, e.g. spack install
|
|
/abc123
|
|
* New package and buildcache index websites
|
|
Our public websites for searching packages have been completely revamped
|
|
and updated. You can check them out here:
|
|
Package Index: https://packages.spack.io
|
|
Buildcache Index: https://cache.spack.io
|
|
Both are searchable and more interactive than before. Currently major
|
|
releases are shown; UI for browsing develop snapshots is coming soon.
|
|
* Default CMake and Meson build types are now Release: Spack has historically
|
|
defaulted to building with optimization and debugging, but packages like
|
|
llvm can be enormous with debug turned on. Our default build type for all
|
|
Spack packages is now Release. This has a number of benefits:
|
|
much smaller binaries;
|
|
higher default optimization level; and
|
|
defining NDEBUG disables assertions, which may lead to further speedups.
|
|
You can still get the old behavior back through requirements and package
|
|
preferences
|
|
* spack checksum can automatically add new versions to package
|
|
* new command: spack pkg grep to easily search package files
|
|
* New maintainers directive
|
|
* Add spack buildcache push (alias to buildcache create)
|
|
* Allow using -j to control the parallelism of concretization
|
|
* Add --exclude option to 'spack external find'
|
|
requires() directive and enhanced package requirements We've added some
|
|
more enhancements to requirements in Spack. There is a new requires()
|
|
directive for packages. requires() is the opposite of conflicts()
|
|
|
|
- removed Add-zypper-to-the-valid-container.os_packages-commands.patch
|
|
as incoperated upstream
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Apr 17 06:59:15 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Update to version 0.19.2 with the following bug fixes:
|
|
* Ignore global variant requirement for packages that do not define it.
|
|
* Compiler wrapper: improved parsing of linker arguments.
|
|
* Views: fix support for optional Python extensions.
|
|
* Views: fix issue where Python executable gets symlinked instead of copied.
|
|
* Fix a bug where tests were not added when concretizing together.
|
|
* Increase db timeout from 3s to 60s to improve stability of parallel
|
|
installs.
|
|
* Buildcache: improve error handling in downloads.
|
|
* Module files for packages installed from buildcache have long placeholder
|
|
paths abbreviated in configure args section.
|
|
* Ensure file with build environment variables is truncated when writing
|
|
to it.
|
|
* spack config update now works on active environments;
|
|
- Add:
|
|
Add-zypper-to-the-valid-container.os_packages-commands.patch
|
|
This adds `zypper` to the valid OS package managers that can
|
|
be specified in a slack.yaml container description like:
|
|
spack:
|
|
...
|
|
container:
|
|
..
|
|
os_packages:
|
|
command: zypper
|
|
..
|
|
- Add: spack_get_libs.sh
|
|
This scripts obtains library and include paths for spack-build
|
|
libraries and outputs shell commands which set these as
|
|
environment variables.
|
|
Additionally, it generates a command line to prepend these lib
|
|
directories to LD_LIBRARY_PATH. Thus, the variables can be set
|
|
in the current shell by running `source $(spack_get_libs.sh foo)`.
|
|
When using `bash` this script may also be sourced directly.
|
|
The names of the environment variables are the upper-cased library
|
|
names with the strings 'LIB_' and 'INC_' prepended. Thus, for a
|
|
library 'foo', they would be 'INC_FOO' and 'LIB_FOO'.
|
|
These variables may be used at build time to point the compiler
|
|
to the include and library files (bsc#1208751).
|
|
- Drop:
|
|
Make-sure-spack-environment-is-set-up-in-Dockerfile-template.patch
|
|
This patch should not be needed. When building using `podman` use:
|
|
`podman build --format docker ...` to enable the non-OCI compliant
|
|
instructions in a Dockerfile.
|
|
- Add info, makeinfo, libcurl-devel, patchelf to the recommended
|
|
packages to add.
|
|
Fix: openssl-devel -> libopenssl-devel
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Apr 6 09:30:50 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add 'zypper' as valid command to container.os_packages. This
|
|
allows to build SUSE container using non-default registries.
|
|
- Add 'awk', 'git', 'gzip' and 'gunzip' to the requires.
|
|
- Add 'patchelf' to the recommended packages.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Mar 30 09:34:39 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Avoid running run-find-external.sh twice during installation/
|
|
update.
|
|
- Stop accidental inclusion of %%pre/post/triggerin/un scripts
|
|
in doc packages.
|
|
- Adpot new info file installation sceme for Factory.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Mar 23 09:59:40 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- run-find-external.sh: Extend the range of versions of MPI
|
|
flavors to be searched for when asking Spack to look
|
|
for external packages (bsc#1208751).
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Mar 8 19:54:55 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Improve run-find-external.sh:
|
|
* Extend to run 'spack compiler find'.
|
|
* Separate triggers for packages and compilers.
|
|
* Better handle when search patterns match multiple directories.
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Mar 1 13:13:34 UTC 2023 - Christian Goll <cgoll@suse.com>
|
|
|
|
- Udpate to 0.19.1 with following bug fixes:
|
|
* buildcache create: make "file exists" less verbose
|
|
* spack mirror create: don't change paths to urls
|
|
* Improve error message for requirements
|
|
* Fix libtool filter for Fujitsu compilers
|
|
* FileCache: delete the new cache file on exception
|
|
- using `--all` flag for `spack external find` in the %triggrin
|
|
section, as MPI packages were not recognized any more, fixing
|
|
(bsc#1208751)
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Jan 31 08:29:00 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Make sure the spack environment is set up correctly in
|
|
spack-generated Dockerfiles (boo#1207784):
|
|
Make-sure-spack-environment-is-set-up-in-Dockerfile-template.patch
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Jan 11 13:04:37 UTC 2023 - Egbert Eich <eich@suse.com>
|
|
|
|
- Fix var_path: this regression was introduced with the update
|
|
to the 0.19.0 release (boo#1207053).
|
|
- Move repos to /usr/share/spack: /var is strictly for local data.
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Nov 22 11:16:26 UTC 2022 - Christian Goll <cgoll@suse.com>
|
|
|
|
- updated to version 0.19.0 with the following changes:
|
|
* Spack's traditional package preferences are soft, but we've added hard
|
|
requriements to packages.yaml and spack.yaml
|
|
* spack install in an environment will no longer add to the specs: list; you'll
|
|
need to either use spack add <spec> or spack install --add <spec>.
|
|
* spack uninstall will not remove from your environment's specs:
|
|
list; you'll need to use spack remove or spack uninstall --remove.
|
|
* concretizer:unify:true is now the default mode for new environments
|
|
* include environment configuration from URLs
|
|
* An increasing number of packages in the ecosystem need the ability to
|
|
support multiple build systems
|
|
* package ++variant:
|
|
enabled variant that will be propagated to dependencies
|
|
* git. prefix to specify git tags or branches as versions. All of these are
|
|
valid git versions in
|
|
* spack ci generate --tests will generate a .gitlab-ci.yml file that not only
|
|
does builds but also runs tests for built packages
|
|
* spack test run --explicit will only run tests for packages that are
|
|
explicitly installed, instead of all packages.
|
|
* You can add a new shared_linking option to config.yaml to make Spack embed absolute paths
|
|
to needed shared libraries in ELF executables and shared libraries on Linux
|
|
* spack spec prints dependencies more legibly. Dependencies in the output now
|
|
appear at the earliest level of indentation possible (#33406)
|
|
* You can override package.py attributes like url, directly in packages.yaml
|
|
* There are a number of new architecture-related format strings you can use
|
|
in Spack configuration files to specify paths
|
|
- Improvements from v0.18.0
|
|
* spack install --reuse was introduced in v0.17.0, and --reuse is now the
|
|
default concretization mode. Spack will try hard to resolve dependencies
|
|
using installed packages or binaries
|
|
* Spack hashes now include link, run, and build dependencies, as well as a
|
|
canonical hash of package recipes. Previously, hashes only included link
|
|
and run dependencies (though build dependencies were stored by
|
|
environments). We coarsened the hash to reduce churn in user installations,
|
|
but the new default concretizer behavior mitigates this concern and gets us
|
|
reuse and provenance. You will be able to see the build dependencies of
|
|
new installations
|
|
* concretizer:unify:when_possible will try to resolve a fully unified
|
|
environment, but if it cannot, it will create multiple configurations of
|
|
some packages where it has to. with spack find.
|
|
* Spack now has an updated binary format, with improvements for security. The
|
|
new format has a detached signature file, and Spack verifies the signature
|
|
before untarring or decompressing the binary package. The previous format
|
|
embedded the signature in a tar file, which required the client to run tar
|
|
before verifying (#30750). Spack can still install from build caches using
|
|
the old format, but we encourage users to switch to the new format going
|
|
forward.
|
|
* The spack bootstrap mirror command can automatically create a mirror for
|
|
bootstrapping the concretizer and other needed dependencies in an
|
|
air-gapped environment.
|
|
* spack env depfile can be used to generate a Makefile from an environment,
|
|
which can be used to build packages the environment in parallel on a single
|
|
node
|
|
* In addition to being conditional themselves, variants can now have
|
|
conditional values that are only possible for certain configurations of a
|
|
package.
|
|
- removed following patches as incorporated upstream:
|
|
* fix-tumbleweed-naming.patch
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Aug 15 19:39:22 UTC 2022 - Dirk Müller <dmueller@suse.com>
|
|
|
|
- avoid bashism in post scripts (bsc#1195391)
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Apr 7 12:56:45 UTC 2022 - Egbert Eich <eich@suse.com>
|
|
|
|
- Fix: Fix-error-during-documentation-build-due-to-recursive-module-inclusion.patch
|
|
This is needed to prevent an AttributeError during
|
|
'import spack.environment as some_name'
|
|
when building Sphinx documentation - due to an outdated
|
|
Python on SLE.
|
|
The original version caused errors:
|
|
'NameError: name 'uenv' is not defined'
|
|
when using 'spack env activate' et.al. (bsc#1198212).
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Mar 2 12:41:12 UTC 2022 - Egbert Eich <eich@suse.com>
|
|
|
|
- Remove unneeded build dependency.
|
|
- Make dependencies of spack and spack-recipes symetrical.
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Feb 10 13:58:04 UTC 2022 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add openssl-devel, xz-devel and libzip-devel as recommends
|
|
bsc#1195789.
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Jan 12 09:50:56 UTC 2022 - Egbert Eich <eich@suse.com>
|
|
|
|
- Fix run-find-external.sh script: RPM macros are not expanded
|
|
in external scripts.
|
|
* Rename: run-find-external.sh to run-find-external.sh.in
|
|
- Fix list of recommended packages.
|
|
- Add support for container building using a SLE base container.
|
|
* Add-support-for-container-building-using-a-SLE-base-container.patch
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Jan 10 12:45:19 UTC 2022 - Christian Goll <cgoll@suse.com>
|
|
|
|
- updated to spack 0.17.1 with following chnages:
|
|
* Allow locks to work under high contention (#27846)
|
|
* Improve errors messages from clingo (#27707 #27970)
|
|
* Respect package permissions for sbang (#25764)
|
|
* Fix --enable-locks behavior (#24675)
|
|
* Fix log-format reporter ignoring install errors (#25961)
|
|
* Fix overloaded argparse keys (#27379)
|
|
* Allow style commands to run with targets other than "develop" (#27472)
|
|
* Log lock messages to debug level, instead of verbose level (#27408)
|
|
* Handle invalid unicode while logging (#21447)
|
|
* spack audit: fix API calls to variants (#27713)
|
|
* Provide meaningful message for empty environment installs (#28031)
|
|
* Added opensuse leap containers to spack containerize (#27837)
|
|
* Revert "patches: make re-applied patches idempotent" (#27625)
|
|
* MANPATH can use system defaults (#21682)
|
|
* Add "setdefault" subcommand to `spack module tcl` (#14686)
|
|
* Regenerate views when specs already installed (#28113)
|
|
- removed leap-container.patch as incoperated upstream
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Dec 14 11:13:37 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- fixed the configuration files /etc/skel/.spack/{config|modules}.yaml
|
|
so that spack writes to $HOME if started as user
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Dec 13 08:19:33 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- made objects.inv (Source5) to be static as the online version is changed
|
|
dynamically
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Dec 7 15:34:12 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added leap-container.patch which adds leap15 as os to the
|
|
spack containerize command.
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Nov 8 14:55:34 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- updated to version 0.17.0
|
|
(Upstream feature/bug references (<ID>) are relative to
|
|
https://github.com/spack/spack/issues/<ID>).
|
|
* New concretizer is now default
|
|
The new concretizer introduced as an experimental feature in v0.16.0
|
|
is now the default (#25502). The new concretizer is based on the
|
|
clingo logic programming system,
|
|
and it enables us to do much higher quality and faster dependency solving
|
|
The old concretizer is still available via the concretizer: original
|
|
setting, but it is deprecated and will be removed in v0.18.0.
|
|
* Binary Bootstrapping
|
|
To make it easier to use the new concretizer and binary packages,
|
|
Spack now bootstraps clingo and GnuPG from public binaries. If it
|
|
is not able to bootstrap them from binaries, it installs them from
|
|
source code. With these changes, you should still be able to clone Spack
|
|
and start using it almost immediately.
|
|
* Reuse existing packages (experimental)
|
|
The most wanted feature from our
|
|
2020 user survey and
|
|
the most wanted Spack feature of all time (#25310). spack install,
|
|
spack spec, and spack concretize now have a --reuse option, which
|
|
causes Spack to minimize the number of rebuilds it does. The --reuse
|
|
option will try to find existing installations and binary packages locally
|
|
and in registered mirrors, and will prefer to use them over building new
|
|
versions. This will allow users to build from source far less than in
|
|
prior versions of Spack. This feature will continue to be improved, with
|
|
configuration options and better CLI expected in v0.17.1. It will become
|
|
the default concretization mode in v0.18.0.
|
|
* Better error messages
|
|
We have improved the error messages generated by the new concretizer by
|
|
using unsatisfiable cores. Spack will now print a summary of the types
|
|
of constraints that were violated to make a spec unsatisfiable (#26719).
|
|
* Conditional variants
|
|
Variants can now have a when="<spec>" clause, allowing them to be
|
|
conditional based on the version or other attributes of a package (#24858).
|
|
* Git commit versions
|
|
In an environment and on the command-line, you can now provide a full,
|
|
40-character git commit as a version for any package with a top-level
|
|
git URL. e.g., spack install hdf5@45bb27f58240a8da7ebb4efc821a1a964d7712a8.
|
|
Spack will compare the commit to tags in the git repository to understand
|
|
what versions it is ahead of or behind.
|
|
* Override local config and cache directories
|
|
You can now set SPACK_DISABLE_LOCAL_CONFIG to disable the ~/.spack and
|
|
/etc/spack configuration scopes. SPACK_USER_CACHE_PATH allows you to
|
|
move caches out of ~/.spack, as well (#27022, #26735). This addresses
|
|
common problems where users could not isolate CI environments from local
|
|
configuration.
|
|
* Improvements to Spack Containerize
|
|
For added reproducibility, you can now pin the Spack version used by
|
|
spack containerize (#21910). The container build will only build
|
|
with the Spack version pinned at build recipe creation instead of the
|
|
latest Spack version.
|
|
* New commands for dealing with tags
|
|
The spack tags command allows you to list tags on packages (#26136), and you
|
|
can list tests and filter tags with spack test list (#26842).
|
|
* Copy and relocate environment views as stand-alone installations (#24832)
|
|
* spack diff command can diff two installed specs (#22283, #25169)
|
|
* spack -c <config> can set one-off config parameters on CLI (#22251)
|
|
* spack load --list is an alias for spack find --loaded (#27184)
|
|
* spack gpg can export private key with --secret (#22557)
|
|
* spack style automatically bootstraps dependencies (#24819)
|
|
* spack style --fix automatically invokes isort (#24071)
|
|
* build dependencies can be installed from build caches with --include-build-deps (#19955)
|
|
* spack audit command for checking package constraints (#23053)
|
|
* spack can now fetch from CVS repositories (yep, really) (#23212)
|
|
* spack monitor lets you upload analysis about installations to a
|
|
* spack monitor server (#23804, #24321, #23777, #25928))
|
|
* spack python --path shows which python Spack is using (#22006)
|
|
* spack env activate --temp can create temporary environments (#25388)
|
|
* --preferred and --latest options for spack checksum (#25830)
|
|
* SPACK_PYTHON environment variable sets which python spack uses (#21222)
|
|
* SPACK_SKIP_MODULES lets you source setup-env.sh faster if you don't need modules (#24545)
|
|
- removed following patches as incomperated upstream:
|
|
* added-dockerfile-for-opensuse-leap-15.patch
|
|
- removed as not needed any more:
|
|
* basic-exclude-pattern-for-external-find.patch
|
|
* Fix-documentation-so-that-parser-doesn-t-stumble.patch
|
|
- updated patches:
|
|
* Adapt-shell-scripts-that-set-up-the-environment-for-different-shells.patch
|
|
* added-target-and-os-calls-to-output-of-spack-spec-co.patch
|
|
* Fix-error-during-documentation-build-due-to-recursive-module-inclusion.patch
|
|
* fix-tumbleweed-naming.patch
|
|
* Make-spack-paths-compliant-to-distro-installation.patch
|
|
- added:
|
|
* Fix-Spinx-configuration-to-avoid-throwing-errors.patch
|
|
* Set-modules-default-to-lmod.patch
|
|
- updated requires to actual sphinx version, so that the documentation
|
|
builds
|
|
- Included source:
|
|
objects.inv
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Oct 15 17:00:57 UTC 2021 - Egbert Eich <eich@suse.com>
|
|
|
|
- Fix sysuser file name.
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Oct 1 05:55:10 UTC 2021 - Egbert Eich <eich@suse.com>
|
|
|
|
- Utilize sysuser infrastructure to set group spack.
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Sep 29 20:32:58 UTC 2021 - Antoine Ginies <aginies@suse.com>
|
|
|
|
- update to version 0.16.3 (JSC#SLE-22137):
|
|
* clang/llvm: fix version detection
|
|
* Fix use of quotes in Python build system
|
|
* Ensure all roots of an installed environment are marked explicit in db
|
|
* Fix fetching for Python 3.8 and 3.9
|
|
* locks: only open lockfiles once instead of for every lock held
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Aug 6 14:28:20 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added tar and make as requirement
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Jul 7 16:09:21 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added README-oo-wiki which is the raw version of the opensuse wiki
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Jul 6 21:45:21 UTC 2021 - Egbert Eich <eich@suse.com>
|
|
|
|
- Fix patch
|
|
Fix-error-during-documentation-build-due-to-recursive-module-inclusion.patch
|
|
to actually work correctly.
|
|
The updated version makes sure modules are not called recursively even
|
|
if modules are loaded in an out-of-order fashion from python-Sphinx.
|
|
- Remove duplicates in spec file.
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Jun 2 14:04:26 UTC 2021 - Antoine Ginies <aginies@suse.com>
|
|
|
|
- fix typo to export prefix in patch (bsc#1191395):
|
|
Adapt-shell-scripts-that-set-up-the-environment-for-different-shells.patch
|
|
|
|
-------------------------------------------------------------------
|
|
Tue May 25 08:55:42 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- update to version 0.16.1
|
|
* Major performance improvement for spack load and other commands.
|
|
* spack fetch is now environment-aware. (#19166)
|
|
* Numerous fixes for the new, clingo-based concretizer.
|
|
* Supoprt for automatically bootstrapping clingo from source.
|
|
* Python 3.10 support: collections.abc
|
|
* Fix import issues by using __import__ instead of Spack package import.
|
|
* Bugfixes and --source-dir argument for spack location.
|
|
* Better support for externals in shared prefixes.
|
|
* spack build-env now prefers specs defined in the active environment.
|
|
* Remove erroneous warnings about quotes in from_sourcing_files.
|
|
* Fix clearing cache of InternalConfigScope.
|
|
* Bugfix for active when pkg is already active error.
|
|
* Make SingleFileScope able to repopulate the cache after clearing it.
|
|
* Channelflow: Fix the package.
|
|
* More descriptive error message for bugs in package.py
|
|
* Use package-supplied autogen.sh
|
|
* Respect -k/verify-ssl-false in _existing_url method.
|
|
|
|
|
|
-------------------------------------------------------------------
|
|
Mon May 3 06:34:46 UTC 2021 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add gcc-c++ to the required packages (bsc#1185519).
|
|
- Add alternative c++ & fortran compilers to the triggers list.
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Mar 30 14:31:26 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added run-find-external.sh which calls the command in post
|
|
`spack external find` as nobody and not as root
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Mar 23 08:32:49 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added libbz2-devel as dependency as spack requires this, as soon
|
|
as the bzip2 binary is found and removed warning for this
|
|
corner case in rpmlinrc
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Mar 19 15:04:20 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- set the right MODULEPATH in /etc/profile.d/spack.[cs]h
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Feb 26 22:06:36 UTC 2021 - Egbert Eich <eich@suse.com>
|
|
|
|
- Remove BuildRequires for patterns-base-basesystem and
|
|
distribution-release.
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Feb 26 10:40:00 UTC 2021 - Christian Goll <cgoll@suse.com>
|
|
|
|
- update to version 0.16.1
|
|
* intel-oneapi support through new packages
|
|
* HIP/ROCm support (#19715, #20095)
|
|
* concretization enhancements
|
|
* environment install reporting fix (#20004)
|
|
* avoid import in ABI compatibility info (#20236)
|
|
* restore ability of dev-build to skip patches (#20351)
|
|
* spack find -d spec grouping (#20028)
|
|
* spack smoke test support (#19987, #20298)
|
|
* abstract spec comparisons (#20341)
|
|
* performance improvements for binary relocation (#19690, #20768)
|
|
* additional sanity checks for variants in builtin packages (#20373)
|
|
* do not pollute auto-generated configuration files with empty lists or
|
|
dicts
|
|
- added file: basic-exclude-pattern-for-external-find.patch
|
|
* adds the functionality to exclude binaries for external search
|
|
so that the call 'installdbgsymbols' can be prohibited as this
|
|
leads to an endless loop when drkonqui is installed
|
|
|
|
-------------------------------------------------------------------
|
|
Thu Feb 4 06:54:13 UTC 2021 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add
|
|
* Fix-documentation-so-that-parser-doesn-t-stumble.patch:
|
|
* Fix-error-during-documentation-build-due-to-recursive-module-inclusion.patch
|
|
Fix documentation building.
|
|
- Fix texinfo file installation.
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Dec 11 15:09:07 UTC 2020 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added patch for more reproduceable output for the doc package
|
|
* added file: added-target-and-os-calls-to-output-of-spack-spec-co.patch
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Dec 8 14:19:00 UTC 2020 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added test for /etc/spack/no_rpm_trigger
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Dec 2 12:33:44 UTC 2020 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added %triggerin and %triggerpostun for the packages which
|
|
can be detected by spack
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Nov 25 10:58:48 UTC 2020 - Christian Goll <cgoll@suse.com>
|
|
|
|
- updated to 0.16.0
|
|
- added find for external packages
|
|
- added dockerfile for leap
|
|
* added patchfile added-dockerfile-for-opensuse-leap-15.patch
|
|
|
|
-------------------------------------------------------------------
|
|
Tue Nov 24 13:45:24 UTC 2020 - Egbert Eich <eich@suse.com>
|
|
|
|
- Add documentation (man and info pages, pdf doesn't build
|
|
currently).
|
|
* Do not ship documentation sources.
|
|
- Do not distribute Dockerfiles and other container related
|
|
material, yet. This needs to be fixed so that the samples
|
|
work with SUSE.
|
|
- Fully integrate spack into SUSE directory structure, fix
|
|
paths where required.
|
|
* Fix setup scripts to work correctly in above environment.
|
|
|
|
-------------------------------------------------------------------
|
|
Mon Nov 16 14:42:32 UTC 2020 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added profile file for csh
|
|
- enabled projections
|
|
- updated README.SUSE
|
|
|
|
-------------------------------------------------------------------
|
|
Wed Nov 11 19:56:11 UTC 2020 - Christian Goll <cgoll@suse.com>
|
|
|
|
- added patches to be more on the traditional file system hierarchy
|
|
and avoid explicit version in tumbleweed.
|
|
* added file Make-spack-paths-compliant-to-distro-installation.patch
|
|
* added file fix-tumbleweed-naming.patch
|
|
|
|
|
|
-------------------------------------------------------------------
|
|
Fri Sep 11 07:50:30 UTC 2020 - Ana Guerrero Lopez <aguerrero@suse.com>
|
|
|
|
- Initial release. Version 0.15.4
|
|
* Make-spack-paths-compliant-to-distro-installation.patch
|
|
Make spack paths compliant to distro installation.
|