Egbert Eich
d29386cf99
OBS-URL: https://build.opensuse.org/package/show/network:cluster/spack?expand=0&rev=116
1371 lines
65 KiB
Plaintext
1371 lines
65 KiB
Plaintext
-------------------------------------------------------------------
|
|
Mon Jan 6 19:01:00 UTC 2025 - Egbert Eich <eich@suse.com>
|
|
|
|
- Work towards a reproducible doc build (boo#1235144):
|
|
When building documentation, hard code:
|
|
* year for license.
|
|
* cpu count dependent settings.
|
|
|
|
-------------------------------------------------------------------
|
|
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.
|