X-Git-Url: http://git.pld-linux.org/gitweb.cgi?p=packages%2Frust.git;a=blobdiff_plain;f=rust.spec;h=1d495f1fe377cfa46fe04127d73f4b909ccdebbf;hp=d9b270d7a7e349748946aed2240742a58652ceed;hb=62473c9552f86f55f6f591df14ca1755ecdb5cd6;hpb=2983f51986d36f1926f866ec4a3b6f7c5bb93bb2 diff --git a/rust.spec b/rust.spec index d9b270d..1d495f1 100644 --- a/rust.spec +++ b/rust.spec @@ -1,5 +1,4 @@ # TODO -# - unpackaged %{rustlibdir}/%{rust_triple}/bin/rust-llvm-dwp # - consider a rust-std package containing .../rustlib/$target # This might allow multilib cross-compilation to work naturally. # - package additional tools @@ -19,12 +18,12 @@ %define rustc_package rustc-%{channel}-src %endif -# To bootstrap from scratch, set the channel and date from src/stage0.txt +# To bootstrap from scratch, set the channel and date from src/stage0.json # e.g. 1.10.0 wants rustc: 1.9.0-2016-05-24 # or nightly wants some beta-YYYY-MM-DD -%define bootstrap_rust 1.55.0 -%define bootstrap_cargo 1.55.0 -%define bootstrap_date 2021-09-09 +%define bootstrap_rust 1.56.1 +%define bootstrap_cargo 1.56.1 +%define bootstrap_date 2021-11-01 %ifarch x32 %define with_cross 1 @@ -37,30 +36,32 @@ Summary: The Rust Programming Language Summary(pl.UTF-8): Język programowania Rust Name: rust -Version: 1.56.0 -Release: 2 +Version: 1.57.0 +Release: 1 # Licenses: (rust itself) and (bundled libraries) License: (Apache v2.0 or MIT) and (BSD and ISC and MIT) Group: Development/Languages Source0: https://static.rust-lang.org/dist/%{rustc_package}.tar.xz -# Source0-md5: 3ad94ba9f05779800a5da6c02e00c444 +# Source0-md5: 0c7d63d9c456c4ec0f95bb6bb729c13e Source1: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-x86_64-unknown-linux-gnu.tar.xz -# Source1-md5: 59b0a04436f96250a307086b6fc2ce34 +# Source1-md5: 9c12561dff9debea38e4b93f881ae2bb Source2: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-i686-unknown-linux-gnu.tar.xz -# Source2-md5: 693c87cf2fc1a41169f55fdbf8426a2e +# Source2-md5: 947bd95b9c8a9943d43af1bbabf1a8e1 Source3: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-aarch64-unknown-linux-gnu.tar.xz -# Source3-md5: 475f762804d4ad8695029a70f8b93a6d +# Source3-md5: 64d78bc0747c975fe0451e4fd5b8ac4b Source4: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-arm-unknown-linux-gnueabihf.tar.xz -# Source4-md5: 56a568e97e7a5c3cb80569ab84f4657b +# Source4-md5: a13652efd627b5e5f8bd278f378acea4 Source5: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-armv7-unknown-linux-gnueabihf.tar.xz -# Source5-md5: 991a439bcdcbcf1b2bbe55ce9e90404f +# Source5-md5: 3fb69008b1b0141d464a4a48317709b3 URL: https://www.rust-lang.org/ # for src/compiler-rt BuildRequires: cmake >= 3.4.3 BuildRequires: curl # make check needs "ps" for src/test/run-pass/wait-forked-but-failed-child.rs BuildRequires: procps -BuildRequires: python >= 1:2.7 +BuildRequires: python3 +BuildRequires: python3-modules +BuildRequires: rpm-build >= 4.6 BuildRequires: rpmbuild(macros) >= 1.752 %if %{without cross} BuildRequires: curl-devel @@ -150,6 +151,8 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %endif %endif +%define rust_targets %rust_triple %{?rust_suppl_targets} + %if %{without bootstrap} %define local_rust_root %{_prefix} %else @@ -175,7 +178,7 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) x_py() { \ local cmd="$1"; \ shift; \ - %{?__jobs:CARGO_BUILD_JOBS=%__jobs }./x.py "$cmd" %{?__jobs:-j %__jobs} "$@"; \ + %{?__jobs:CARGO_BUILD_JOBS=%__jobs }%{__python3} ./x.py "$cmd" %{?__jobs:-j %__jobs} "$@"; \ }; x_py } @@ -383,10 +386,13 @@ find vendor -name .cargo-checksum.json \ -exec sed -i.uncheck -e 's/"files":{[^}]*}/"files":{ }/' '{}' '+' %build +export CC="%{__cc}" +export CXX="%{__cxx}" +export AR="%{__ar}" %configure \ --build=%{rust_bootstrap_triple} \ --host=%{rust_host_triple} \ - --target=%{rust_triple} \ + --target="%(echo %rust_targets | tr ' ' ,)" \ --libdir=%{common_libdir} \ --disable-codegen-tests \ --disable-debuginfo-lines \ @@ -431,12 +437,14 @@ find $RPM_BUILD_ROOT%{_libdir}/ -type f -name '*.so' -exec chmod -v +x '{}' '+' # The libdir libraries are identical to those under rustlib/. It's easier on # library loading if we keep them in libdir, but we do need them in rustlib/ # to support dynamic linking for compiler plugins, so we'll symlink. -for l in libstd libtest ; do - liblib=$RPM_BUILD_ROOT%{_libdir}/${l}-*.so - libstd=$RPM_BUILD_ROOT%{rustlibdir}/%{rust_triple}/lib/${l}-*.so - if [ "$(basename ${liblib})" = "$(basename ${libstd})" ]; then - ln -vfsr ${libstd} $RPM_BUILD_ROOT%{_libdir}/ - fi +for rust_target in %rust_targets; do + for l in libstd libtest ; do + liblib=$RPM_BUILD_ROOT%{_libdir}/${l}-*.so + libstd=$RPM_BUILD_ROOT%{rustlibdir}/${rust_target}/lib/${l}-*.so + if [ "$(basename ${liblib})" = "$(basename ${libstd})" ]; then + ln -vfsr ${libstd} $RPM_BUILD_ROOT%{_libdir}/ + fi + done done # Remove installer artifacts (manifests, uninstall scripts, etc.) @@ -474,6 +482,7 @@ rm -rf $RPM_BUILD_ROOT %files %defattr(644,root,root,755) %doc COPYRIGHT LICENSE-APACHE LICENSE-MIT README.md +%attr(755,root,root) %{_bindir}/rust-demangler %attr(755,root,root) %{_bindir}/rustc %attr(755,root,root) %{_bindir}/rustdoc %attr(755,root,root) %{_bindir}/rustfmt @@ -486,14 +495,24 @@ rm -rf $RPM_BUILD_ROOT %files analysis %defattr(644,root,root,755) -%{rustlibdir}/%{rust_triple}/analysis +%(for rust_target in %rust_targets; do +echo "%{rustlibdir}/$rust_target/analysis" +done +) %files std %defattr(644,root,root,755) -%dir %{rustlibdir}/%{rust_triple} -%dir %{rustlibdir}/%{rust_triple}/lib -%attr(755,root,root) %{rustlibdir}/%{rust_triple}/lib/*.so -%{rustlibdir}/%{rust_triple}/lib/*.rlib +%(for rust_target in %rust_targets; do +cat <