[pbs-devel] applied: [PATCH proxmox-backup] build: use cargo wrapper when building package
Wolfgang Bumiller
w.bumiller at proxmox.com
Thu Jun 20 09:29:36 CEST 2024
applied, thanks
On Wed, Jun 19, 2024 at 04:38:05PM GMT, Fabian Grünbichler wrote:
> else we don't pick up the options set by the wrapper, which include generation
> of debug symbols. until rustc 1.77, this was not needed because compiled
> binaries always included a non-stripped libstd. now, without this change, the
> binaries built with `cargo build --release` have no debug symbols at all
> trigger a warning. fix this and include debug symbols when building a package,
> like was originally intended for release package builds.
>
> Signed-off-by: Fabian Grünbichler <f.gruenbichler at proxmox.com>
> ---
> no obvious fallout I could find, but more eyes probably don't hurt. 1.77 is not
> in the repository yet, I'll upload it tomorrow..
>
> Makefile | 4 ++--
> debian/rules | 2 +-
> docs/Makefile | 4 ++--
> pxar-bin/tests/pxar.rs | 18 +++++++++++-------
> 4 files changed, 16 insertions(+), 12 deletions(-)
>
> diff --git a/Makefile b/Makefile
> index 49575ea45..0b971f9c6 100644
> --- a/Makefile
> +++ b/Makefile
> @@ -38,9 +38,9 @@ SUBCRATES != cargo metadata --no-deps --format-version=1 \
>
> ifeq ($(BUILD_MODE), release)
> CARGO_BUILD_ARGS += --release
> -COMPILEDIR := target/release
> +COMPILEDIR := target/$(DEB_HOST_RUST_TYPE)/release
> else
> -COMPILEDIR := target/debug
> +COMPILEDIR := target/$(DEB_HOST_RUST_TYPE)/debug
> endif
>
> ifeq ($(valgrind), yes)
> diff --git a/debian/rules b/debian/rules
> index 54a3c22bf..a82c3e12f 100755
> --- a/debian/rules
> +++ b/debian/rules
> @@ -8,7 +8,7 @@ include /usr/share/rustc/architecture.mk
>
> export BUILD_MODE=release
>
> -CARGO=/usr/share/cargo/bin/cargo
> +export CARGO=/usr/share/cargo/bin/cargo
>
> export CFLAGS CXXFLAGS CPPFLAGS LDFLAGS
> export DEB_HOST_RUST_TYPE DEB_HOST_GNU_TYPE
> diff --git a/docs/Makefile b/docs/Makefile
> index d6c61c86e..d23796b7c 100644
> --- a/docs/Makefile
> +++ b/docs/Makefile
> @@ -90,10 +90,10 @@ SPHINXBUILD = sphinx-build
> BUILDDIR = output
>
> ifeq ($(BUILD_MODE), release)
> -COMPILEDIR := ../target/release
> +COMPILEDIR := ../target/$(DEB_HOST_RUST_TYPE)/release
> SPHINXOPTS += -t release
> else
> -COMPILEDIR := ../target/debug
> +COMPILEDIR := ../target/$(DEB_HOST_RUST_TYPE)/debug
> SPHINXOPTS += -t devbuild
> endif
>
> diff --git a/pxar-bin/tests/pxar.rs b/pxar-bin/tests/pxar.rs
> index 321f24c31..0a4fbcad5 100644
> --- a/pxar-bin/tests/pxar.rs
> +++ b/pxar-bin/tests/pxar.rs
> @@ -7,15 +7,17 @@ fn pxar_create_and_extract() {
> let src_dir = "../tests/catar_data/test_xattrs_src/";
> let dest_dir = "../tests/catar_data/test_xattrs_dest/";
>
> + let target_subdir = std::env::var("DEB_HOST_RUST_TYPE").unwrap_or(String::new());
> +
> let exec_path = if cfg!(debug_assertions) {
> - "../target/debug/pxar"
> + format!("../target/{target_subdir}/debug/pxar")
> } else {
> - "../target/release/pxar"
> + format!("../target/{target_subdir}/release/pxar")
> };
>
> println!("run '{} create archive.pxar {}'", exec_path, src_dir);
>
> - Command::new(exec_path)
> + Command::new(&exec_path)
> .arg("create")
> .arg("./tests/archive.pxar")
> .arg(src_dir)
> @@ -24,7 +26,7 @@ fn pxar_create_and_extract() {
>
> println!("run '{} extract archive.pxar {}'", exec_path, dest_dir);
>
> - Command::new(exec_path)
> + Command::new(&exec_path)
> .arg("extract")
> .arg("./tests/archive.pxar")
> .arg("--target")
> @@ -81,13 +83,15 @@ fn pxar_create_and_extract() {
>
> #[test]
> fn pxar_list_with_payload_input() {
> + let target_subdir = std::env::var("DEB_HOST_RUST_TYPE").unwrap_or(String::new());
> +
> let exec_path = if cfg!(debug_assertions) {
> - "../target/debug/pxar"
> + format!("../target/{target_subdir}/debug/pxar")
> } else {
> - "../target/release/pxar"
> + format!("../target/{target_subdir}/release/pxar")
> };
>
> - let output = Command::new(exec_path)
> + let output = Command::new(&exec_path)
> .args([
> "list",
> "../tests/pxar/backup-client-pxar-expected.mpxar",
> --
> 2.39.2
More information about the pbs-devel
mailing list