455 lines
18 KiB
Text
455 lines
18 KiB
Text
rust2rpm
|
|
|
|
Version 24.3.3
|
|
==============
|
|
|
|
This release is a hotfix for v24.3.2 to address an undefined variable issue in
|
|
the changed logic for storing `.crate` files that was introduced in v24.3.2.
|
|
|
|
Version 24.3.2
|
|
==============
|
|
|
|
This release contains only two small fixes:
|
|
|
|
- Fixed a subtle bug in the logic for parsing `rust2rpm.conf` files. The
|
|
"default" feature was always accepted as a feature name since v24.3.1,
|
|
but reading the `lib+default.requires` setting failed and always returned
|
|
an empty list instead of the actual value.
|
|
- Store downloaded `.crate` files *before* attempting to parse `Cargo.toml`.
|
|
Previously, storing the `.crate` file in the current directory was cancelled
|
|
if `Cargo.toml` could not be parsed.
|
|
|
|
Version 24.3.1
|
|
==============
|
|
|
|
This release contains only two small fixes:
|
|
|
|
- Fixed a subtle bug in `rust2rpm.conf` file validation. The "default" feature
|
|
was only accepted as a feature name if it was explicitly listed in the crate
|
|
metadata, but the "default" feature is always implicitly defined and is always
|
|
a valid feature name.
|
|
- Added `riscv64` to the list of `target_arch` values that are considered
|
|
"supported" when auto-generating `Cargo.toml` patches to remove "foreign"
|
|
dependencies.
|
|
|
|
Version 24.3.0
|
|
==============
|
|
|
|
This version adds new settings to `rust2rpm.conf`:
|
|
|
|
- `summary`: override the RPM package's `Summary` with a specific string
|
|
if the heuristics for generating a summary from the crate's description
|
|
produces nonsense
|
|
- `supported-arches`: build library crates and run their tests only on
|
|
architectures where they are supported
|
|
|
|
The second setting allows generating spec files for Rust crates that only
|
|
have limited cross-platform compatibility that can still be included in
|
|
repositories for all architectures. This provides a workaround for limitations
|
|
of RPM (subpackages do not inherit `ExcludeArch` / `ExclusiveArch` tags) and
|
|
Fedora build infrastructure (`noarch` packages are included in repositories for
|
|
all architectures), and should make it possible to enable more features in more
|
|
crates without introducing broken dependencies on architectures where some
|
|
crates do not work.
|
|
|
|
Version 24.2.0
|
|
==============
|
|
|
|
This version adds a new `--compat` CLI flag to rust2rpm. It automatically
|
|
sets the package version suffix based on SemVer compatibility rules.
|
|
rust2rpm knows which suffix compat packages need based on the version that
|
|
is passed, so there is no need for the user to guess and pass it manually.
|
|
The old `--suffix [SUFFIX]` CLI argument is now deprecated in favor of using
|
|
`--compat`.
|
|
|
|
Version 24.1.0
|
|
==============
|
|
|
|
Added:
|
|
|
|
- Added an `enabled-features` setting to `rust2rpm.conf` files. This
|
|
setting accepts a list of features which will be explicitly enabled, i.e.
|
|
passed as flags to `%cargo_*` macros. This is useful when building
|
|
binaries with additional non-default features, or when running tests
|
|
requires enabling additional features.
|
|
- Added warnings when the currently processed spec file uses version
|
|
restrictions that are more strict than SemVer. Strong restrictions like
|
|
these are almost always in place for reasons that don't apply to
|
|
distribution packages (for example, MSRV compatibility policy).
|
|
- Added "interactive" mode for generating spec files for projects that use a
|
|
cargo workspace. This mode is required when the heuristics for determining
|
|
the "main" crate (i.e. for determining the package name and version) fail.
|
|
|
|
Changed:
|
|
|
|
- Feature flags for required features of binary targets are automatically added
|
|
to `%cargo_*` macro calls in generated spec files. The detection of "binary"
|
|
targets does not take `required-features` into account, so these features
|
|
need to be explicitly enabled for the expected binaries to be built by
|
|
`cargo install` (which skips targets with missing `required-features`).
|
|
- Attempting to generate spec files for crates that have SemVer "build metadata"
|
|
in their version string now prints an error and fails. This was previously
|
|
accepted, but could result in broken packages.
|
|
- Parsing of `rust2rpm.conf` files now fails if the file content is considered
|
|
"invalid" (for example, because of unrecognized or inconsistent settings).
|
|
|
|
Fixed:
|
|
|
|
- Tests no longer start to fail every January 1st. The current year is now
|
|
correctly stripped from test fixtures.
|
|
|
|
Version 24.0.2
|
|
==============
|
|
|
|
Changed:
|
|
|
|
- Rendered spec files now include a "FIXME" in the `%install` section for crates
|
|
that build shared libraries with a C ABI (i.e. crates with a `cdylib` binary
|
|
target).
|
|
|
|
Fixed:
|
|
|
|
- Crates that manually specify their crate type as "rlib" (which is equivalent
|
|
to the default "lib" crate type) are now detected as libraries correctly. This
|
|
fix requires bumping the dependency on cargo2rpm to >= 0.1.2.
|
|
|
|
Version 24.0.1
|
|
==============
|
|
|
|
Fixed:
|
|
|
|
- Additional Requires for feature subpackages specified in rust2rpm.conf
|
|
settings are respected again (fixes regression from 24.0.0).
|
|
|
|
Version 24.0.0
|
|
==============
|
|
|
|
This release contains large internal changes to support more use cases and
|
|
Rust projects that use new syntax for feature dependencies in their Cargo.toml
|
|
metadata. The functionality for translating between cargo and RPM metadata
|
|
and the RPM macros and dependency generators were moved to separate projects.
|
|
|
|
Additionally, the versioning scheme of rust2rpm has changed to allow for minor
|
|
or bugfix-only releases that do not change spec file rendering and which don't
|
|
require bumping the version number in the "# Generated by rust2rpm XX" header.
|
|
|
|
Added:
|
|
|
|
- Support for building non-crate projects that use cargo workspaces was added.
|
|
- The default Rust compiler flags now support conditionally building Rust code
|
|
with frame pointers (only enabled on Fedora 38+ on x86_64 and aarch64).
|
|
- New syntax for cargo feature dependencies (`dep:foo`) is now supported when
|
|
creating "remove foreign dependencies" patches.
|
|
- Rust crates that exclusively build shared libraries (`cdylib` targets) are now
|
|
(partially) supported by rust2rpm and no longer cause crashes.
|
|
|
|
Changed:
|
|
|
|
- Large parts of the project were refactored, modernized, reorganized into
|
|
smaller files, and updated with type annotations.
|
|
- The deprecated `requests.compat` module is no longer used, as all methods
|
|
used by rust2rpm have been part of the Python standard library for years.
|
|
|
|
Fixed:
|
|
|
|
- Logic for determining the list of feature subpackages was fixed. The
|
|
assumptions in the previous implementation were broken for crates that use
|
|
Rust 1.60+ syntax for feature dependencies.
|
|
- Logic for sorting binaries in %files lists was fixed to not cause crashes if
|
|
there are two or more binaries.
|
|
- Logic in the cfg-expression evaluation was fixed and no longer produces
|
|
architecture-specific patches.
|
|
- Logic for checking for the existence of a dist-git repo for the current
|
|
package was fixed to account for URL formatting issues.
|
|
- Files that are read when trying to detect the "host linux distribution" are
|
|
now closed correctly.
|
|
- Test fixtures were added for the year 2023.
|
|
|
|
Removed:
|
|
|
|
- The cargo-inspector executable was removed. It is no longer used by Rust RPM
|
|
macros.
|
|
- Files for RPM macros and dependency generators were moved into a separate
|
|
project (rust-packaging).
|
|
|
|
Version 23
|
|
==========
|
|
|
|
Added:
|
|
|
|
- New macros for collecting license information for all crates that are
|
|
statically linked into a Rust binary (`%cargo_license` and
|
|
`%cargo_license_summary`).
|
|
- Add support for specifying "testrequires" in rust2rpm.conf. These work similar
|
|
to "buildrequires", but the specified dependencies will be wrapped in an
|
|
`%if %{with check}` conditional in the generated spec file. This can be used
|
|
to specify BuildRequires that are only needed when running a crate's test
|
|
suite, but which are not necessary to build the crate itself.
|
|
|
|
Changed:
|
|
|
|
- The list of binaries in %files is now consistently sorted in generated spec
|
|
files (this only affects crates that build more than one binary, of course).
|
|
- Fall back to the latest pre-release if there are no stable releases (or if
|
|
all previously published stable released have been yanked).
|
|
- Dropped `ExclusiveArch: %{rust_arches}` when generating spec files for Fedora.
|
|
RPM itself will start to depend on Rust components, so Rust will by definition
|
|
need to be available on all architectures that are supported by Fedora.
|
|
- Replaced `i686` with the `%{ix86}` macro in `%{rust_arches}`.
|
|
|
|
Fixed:
|
|
|
|
- Ensure that rust2rpm doesn't auto-generate architecture-dependent patches.
|
|
- Ensure both automatically generated and manually written patches affect spec
|
|
file generation (i.e. feature subpackages).
|
|
- Fix evaluation of cfg-expressions that contain the new "wasm64" target.
|
|
- Only remove target-specific dependencies from feature dependencies if they
|
|
are optional.
|
|
- The logic for replacing the current version of rust2rpm when comparing spec
|
|
output in tests has been fixed for OpenSUSE spec templates.
|
|
|
|
Version 22
|
|
==========
|
|
|
|
This release comes with lots of improvements, bug fixes, and new features, but
|
|
also drops support for Python versions older than 3.10.
|
|
|
|
Added:
|
|
|
|
- Add macros to allow overriding default Rust compiler flags without needing to
|
|
manually invoke sed: %rustflags_opt_level, %rustflags_debuginfo,
|
|
%rustflags_codegen_units (PR#182 / @zbyszek)
|
|
- Add a new rust2rpm.conf setting that mirrors the "--all-features" CLI
|
|
argument of rust2rpm (PR#191 / @decathorpe)
|
|
- Add support for running rust2rpm without an explicit crate name argument, and
|
|
use heuristics (value of the %crate macro in an existing spec file, or the
|
|
name of the current directory) as fallback values (PR#197 / @zbyszek)
|
|
- Add a parser and evaluation logic for "cfg"-expressions and automatically
|
|
generate a Cargo.toml patch that removes "foreign" dependencies
|
|
(PR#183 / @zbyszek)
|
|
- Add CC-PDDC ("Creative Commons Public Domain Dedication and Certification")
|
|
to the list of accepted licenses (PR#203 / @yizhengxie)
|
|
- Added simple logger functionality and print messages to stderr to ensure the
|
|
"--stdout" mode of rust2rpm continues to work (@decathorpe).
|
|
|
|
Changed:
|
|
|
|
- Change the default name of the rust2rpm configuration file to "rust2rpm.conf",
|
|
and migrate existing ".rust2rpm.conf" and "_rust2rpm.conf" files
|
|
(PR#189 / @decathorpe)
|
|
- Dropped unnecessary numbering of patches in spec files generated by rust2rpm
|
|
(PR#196 / @gotmax23)
|
|
- Dropped translation from SPDX license expressions to Fedora / Callaway
|
|
notation when targeting Fedora or EPEL (PR#195 / @zbyszek)
|
|
- Apply consistent formatting for %license and %doc files for binary packages
|
|
and -devel packages (PR#197 / @zbyszek)
|
|
- Skip pre-release versions when running rust2rpm without an explicit version
|
|
argument (PR#197 / @zbyszek)
|
|
- Change the warning messages that are printed after the "existence check" of
|
|
rust2rpm succeeds to take compat packages into account (PR#199 / @decathorpe)
|
|
- Split rust2rpm package into "core" functionality without third-party python
|
|
dependencies, which can be used by cargo-inspector and RPM macros
|
|
(PR#204 / @decathorpe)
|
|
- Ported rust2rpm packaging to declarative configuration with setup.cfg and
|
|
pyproject.toml (PR#207 / @decathorpe)
|
|
- Enforced a consistent code formatting standard with black (@decathorpe).
|
|
|
|
Fixed:
|
|
|
|
- Various fixes for the automatic detection of rpmautospec usage in existing
|
|
spec files and the "--rpmautospec" and "--no-rpmautospec" CLI arguments
|
|
(PR#190, PR#195 / @zbyszek, @andersblomdell)
|
|
- Fix building with Rust 1.62+, which now fails when re-packaging sources from
|
|
crates.io (PR#194 / @decathorpe)
|
|
- Fixed the "existence check" when running rust2rpm by requesting the correct
|
|
URL (PR#199 / @decathorpe)
|
|
- Fixed tox settings for refactored tests and updated list of supported Python
|
|
versions (PR#208 / @decathorpe)
|
|
|
|
|
|
Version 21
|
|
==========
|
|
|
|
- new %crate_instdir convenience macro with the path to the
|
|
installation directory
|
|
- license and documentation files are now installed just once under
|
|
%crate_instdir and are marked with %license and %doc there
|
|
- link flags are now passed using the RUSTFLAGS envvar and include
|
|
package note linker script (when %_package_note_file is defined)
|
|
- CFLAGS/CXXFLAGS are passed to the processes started by cargo
|
|
- rpmautospec can be disabled with --no-rpmautospec
|
|
- minor tweaks to existence checks, documentation file detection, license tags,
|
|
version handling and spec file naming
|
|
|
|
Version 20
|
|
==========
|
|
|
|
- fix autodetection of rpmspec if it was already used in the existing spec file
|
|
- fix parsing of ID_LIKE in os-release files
|
|
- drop unused __cargo_skip_build logic
|
|
- improve handling of the upper bound in dependencies with ~ in version
|
|
- minor improvements to grammar and whitespace in generated output
|
|
|
|
Version 19
|
|
==========
|
|
|
|
- use rpmautospec by default for Fedora
|
|
- check if a package already exists in Fedora (use --no-existence-check to opt-out)
|
|
- replace hyphens by underscores in Version (issue #124)
|
|
- suppress tracebacks for network errors and similar (issue #125)
|
|
- add bundled() provider for vendoring to be used with 'cargo vendor'
|
|
and a new --provides-vendor parameter
|
|
- test with Python 3.10 and mark it as supported
|
|
- licensing: add CDDL-1.1, LGPL-2.0-or-later
|
|
|
|
Version 18
|
|
==========
|
|
|
|
- Add simple %license and %doc file auto-detection
|
|
- Add optional support for rpmautospec (%autorelease, %autochangelog)
|
|
- Use changelog timestamp format with time and timezone only on OpenSUSE
|
|
- Fix parsing of features with "+" in their name
|
|
- Use Fedora 35 for Fedora license helper script
|
|
- licensing: add Python-2.0
|
|
|
|
Version 17
|
|
==========
|
|
|
|
- revert the change to specify all BuildRequires directly, not in
|
|
%generate_buildrequires
|
|
|
|
Version 16
|
|
==========
|
|
|
|
- new 'fedora-helper' tool for Fedora
|
|
- specify all BuildRequires directly, not in %generate_buildrequires
|
|
- introduce new unwanted-features setting in .rust2rpm.conf files to
|
|
prevent subpackages for specific "unwanted" features from being
|
|
generated
|
|
- licensing: add LGPL-3.0-or-later, LGPL-2.1-or-later, EUPL-1.2
|
|
- add riscv64 to %rust_arches
|
|
|
|
Version 14/15
|
|
=============
|
|
|
|
- Use '--no-track' for 'cargo install'
|
|
- Support versions with multiple wildcards (e.g. '1.*.*')
|
|
- Ignore 'Cargo.toml.orig' which causes issues with build of many crates
|
|
|
|
Version 13
|
|
==========
|
|
|
|
- Generate %files entries with '%{version_no_tilde}'
|
|
- Add support for using multiple features at a time in cargo-inspector
|
|
- Implement support for "renamed" dependencies
|
|
|
|
Version 12
|
|
==========
|
|
|
|
- Set proper Version field for pre-release versions of crates
|
|
|
|
Version 11
|
|
==========
|
|
|
|
- When dynamic BuildRequires are turned on, propagate arguments to %cargo_*
|
|
- Few improvements in algorithm of description splitting into a summary
|
|
- Ignore Cargo.lock for installation (publish lockfile feature in Cargo 1.37+)
|
|
- Replace semantic_version dependency by custom parser
|
|
- Add MPL-2.0-or-later and 0BSD into a Fedora SPDX mapping
|
|
- Pass --cap-lints=warn into the RUSTFLAGS to prevent FTBFS after
|
|
dependency and/or compiler updates
|
|
- Enable dynamic BuildRequires by default for Fedora target
|
|
|
|
Version 10
|
|
==========
|
|
|
|
- Translate '-or-later' and '+' license suffixes properly
|
|
- Check /usr/lib/os-release in addition to /etc/os-release
|
|
- Prettify summary and description automatically
|
|
- Use %{expand:…} for %description to avoid escaping of newlines
|
|
- Add '--suffix' option for "compat" packages
|
|
- Implement option to skip building of crates (aka fast/bootstrap build)
|
|
|
|
Version 9
|
|
=========
|
|
|
|
- Always put upstream license in spec
|
|
- Fix version in egg-info
|
|
- Remove accidentally left Cargo.toml.deps
|
|
- Fix packager detection fallback
|
|
|
|
Version 8
|
|
=========
|
|
|
|
- Pass '-Ccodegen-units=1' in RUSTFLAGS
|
|
- Switch to '%{build_rustflags}'
|
|
|
|
Version 7
|
|
=========
|
|
|
|
- Generate %doc statements for readme from Cargo.toml
|
|
- Split features into subpackages ('rust-$crate+$feature-devel')
|
|
- Add support for dependencies with same name
|
|
- Add support for user configuration ('.rust2rpm.conf', '_rust2rpm.conf')
|
|
- Option to not generate default changelog entry ('--no-auto-changelog-entry')
|
|
- Set 'CARGO_HOME' to the local '.cargo' (required by new Rust)
|
|
- Improvements for crates with pre-release versions
|
|
- Fix '%cargo_install' with crates which use whitespace in files
|
|
- Do not put unneeded optional dependencies in BuildRequires ('-Z avoid-dev-deps')
|
|
- Option to use all crate features when generating spec file
|
|
- Use new-style changelog format (with TZ info) on Fedora
|
|
- Option to use dynamic BuildRequires (requires RPM 4.15+)
|
|
- Environment variables to control packager identity
|
|
|
|
Version 6
|
|
=========
|
|
|
|
- Improvements in RPM macros
|
|
- Add support for handling local crates
|
|
- Add option to copy crate into current working directory
|
|
- Filter non-linux dependencies automatically
|
|
- Translate SPDX licenses into Fedora ones (for Fedora and Mageia)
|
|
|
|
Version 5
|
|
=========
|
|
|
|
- Add cargo dependency for runtime (devel subpackages)
|
|
- Use cp instead of install in macros in order to keep original permissions
|
|
- Ignore yanked versions when no version is specified
|
|
- Pass --no-fail-fast for cargo-test
|
|
- Treat optional dependencies as "features" as well
|
|
- Add support for "rlib" crate-type
|
|
- Add support for Mageia and (open)SUSE in template
|
|
|
|
Version 4
|
|
=========
|
|
|
|
- Switch to /usr/share/cargo/registry for storing crates
|
|
- Explicitly set rustdoc in macro so it won't collide with the one used by user
|
|
- Add initial support for pre-release versions
|
|
- Add support for versions with multiple wildcards (like 1.*.*)
|
|
|
|
Version 3
|
|
=========
|
|
|
|
- Use rich dependencies to fulfil requirements
|
|
- Automagically strip [dev-dependencies] when building without tests
|
|
- Add support for wildcard in version
|
|
- Generate initial changelog
|
|
- Use rust-packaging for BuildRequires to break loop
|
|
- Other cleanups and fixes
|
|
|
|
Version 2
|
|
=========
|
|
|
|
- Automatic generation of summary and description
|
|
- Initial patching of metadata
|
|
- Save generated spec/patch as files instead of printing to stdout
|
|
- Support for proc-macro kind of library
|
|
- %cargo_build and %cargo_test now accept any parameters
|
|
- Automatically strip [dev-dependencies] when %check is disabled
|
|
|
|
Version 1
|
|
=========
|
|
|
|
- initial version with setuptools metadata
|