X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rust.spec;h=bea4753b9a8dce3b5e92ce409044503677be58d9;hb=830375b8a3887f890a98b105b437420b436b8bcb;hp=7e7d09a54844ef5ce1f7e9e256849e95c08e3458;hpb=c9b8e3ee8bf06832117739d699fcfd7c2409a698;p=packages%2Frust.git diff --git a/rust.spec b/rust.spec index 7e7d09a..bea4753 100644 --- a/rust.spec +++ b/rust.spec @@ -3,7 +3,7 @@ # This might allow multilib cross-compilation to work naturally. # # Conditional build: -%bcond_with bootstrap +%bcond_with bootstrap # bootstrap using precompiled binaries %bcond_with tests # build without tests # The channel can be stable, beta, or nightly @@ -18,33 +18,32 @@ # To bootstrap from scratch, set the channel and date from src/stage0.txt # 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.17.0 -%define bootstrap_cargo 0.18.0 -%define bootstrap_date 2017-04-27 +%define bootstrap_rust 1.24.0 +%define bootstrap_cargo 0.25.0 +%define bootstrap_date 2018-02-15 Summary: The Rust Programming Language +Summary(pl.UTF-8): Język programowania Rust Name: rust -Version: 1.18.0 -Release: 2 +Version: 1.25.0 +Release: 1 # Licenses: (rust itself) and (bundled libraries) -License: (ASL 2.0 or MIT) and (BSD and ISC and MIT) +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.gz -# Source0-md5: c37c0cd9d500f6a9d1f2f44401351f88 +# Source0-md5: d8d4d30c8d0b905f978bee3fdd618db5 Source1: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-x86_64-unknown-linux-gnu.tar.gz -# Source1-md5: 98e8f479515969123b4c203191104a54 +# Source1-md5: 61be17f80e1811211450e5b733624232 Source2: https://static.rust-lang.org/dist/%{bootstrap_date}/rust-%{bootstrap_rust}-i686-unknown-linux-gnu.tar.gz -# Source2-md5: 2d5de850c32aa8d40c8c21abacf749f8 -Patch0: rust-1.16.0-configure-no-override.patch +# Source2-md5: 5568788cd5d96173a89bd0e82a2aa356 URL: https://www.rust-lang.org/ -BuildRequires: cmake +# for src/compiler-rt +BuildRequires: cmake >= 3.4.3 BuildRequires: curl -BuildRequires: gcc -BuildRequires: libstdc++-devel BuildRequires: libstdc++-devel BuildRequires: llvm-devel BuildRequires: ncurses-devel -BuildRequires: python +BuildRequires: python >= 1:2.7 BuildRequires: zlib-devel %if %{without bootstrap} BuildRequires: %{name} >= %{bootstrap_rust} @@ -92,17 +91,27 @@ prevents segfaults, and guarantees thread safety. This package includes the Rust compiler, standard library, and documentation generator. +%description -l pl.UTF-8 +Rust to systemowy język programowania działający bardzo szybko, +zapobiegający naruszeniom ochrony pamięci i gwarantujący +bezpieczną wielowątkowość. + %package debugger-common Summary: Common debugger pretty printers for Rust +Summary(pl.UTF-8): Narzędzia wypisujące struktury Rusa wspólne dla różnych debuggerów Group: Development/Debuggers BuildArch: noarch %description debugger-common -This package includes the common functionality for %{name}-gdb and -%{name}-lldb. +This package includes the common functionality for rust-gdb and +rust-lldb. + +%description debugger-common -l pl.UTF-8 +Ten pakiet zawiera wspólny kod dla pakietów rust-gdb i rust-lldb. %package gdb Summary: GDB pretty printers for Rust +Summary(pl.UTF-8): Ładne wypisywanie struktur Rusta w GDB Group: Development/Debuggers Requires: %{name}-debugger-common = %{version}-%{release} Requires: gdb @@ -112,8 +121,13 @@ BuildArch: noarch This package includes the rust-gdb script, which allows easier debugging of Rust programs. +%description gdb -l pl.UTF-8 +Ten pakiet zawiera skrypt rust-gdb, pozwalający na łatwiejsze +odpluskwianie programów w języku Rust. + %package lldb Summary: LLDB pretty printers for Rust +Summary(pl.UTF-8): Ładne wypisywanie struktur Rusta w LLDB Group: Development/Debuggers Requires: %{name}-debugger-common = %{version}-%{release} Requires: lldb @@ -123,8 +137,13 @@ BuildArch: noarch This package includes the rust-lldb script, which allows easier debugging of Rust programs. +%description lldb -l pl.UTF-8 +Ten pakiet zawiera skrypt rust-lldb, pozwalający na łatwiejsze +odpluskwianie programów w języku Rust. + %package doc Summary: Documentation for Rust +Summary(pl.UTF-8): Dokumentacja do Rusta Group: Documentation BuildArch: noarch @@ -132,9 +151,12 @@ BuildArch: noarch This package includes HTML documentation for the Rust programming language and its standard library. +%description doc -l pl.UTF-8 +Ten pakiet zawiera dokumentację w formacie HTML do języka +programowania Rust i jego biblioteki standardowej. + %prep %setup -q -n %{rustc_package} -%patch0 -p1 %if %{with bootstrap} %ifarch %{x8664} @@ -153,8 +175,9 @@ test -f %{local_rust_root}/bin/rustc %endif # unbundle -rm -r src/jemalloc/ -rm -r src/llvm/ +# We're disabling jemalloc, but rust-src still wants it. +#%{__rm} -r src/jemalloc/ +%{__rm} -r src/llvm/ # extract bundled licenses for packaging cp -p src/rt/hoedown/LICENSE src/rt/hoedown/LICENSE-hoedown @@ -165,24 +188,29 @@ sed -e '/*\//q' src/libbacktrace/backtrace.h \ sed -i -e 's#DIRECTORY=".*"#DIRECTORY="%{_datadir}/%{name}/etc"#' \ src/etc/rust-gdb -# These tests assume that alloc_jemalloc is present -sed -i -e '1i // ignore-test jemalloc is disabled' \ - src/test/compile-fail/allocator-dylib-is-system.rs \ - src/test/compile-fail/allocator-rust-dylib-is-jemalloc.rs \ - src/test/run-pass/allocator-default.rs +# The configure macro will modify some autoconf-related files, which upsets +# cargo when it tries to verify checksums in those files. If we just truncate +# that file list, cargo won't have anything to complain about. +find src/vendor -name .cargo-checksum.json \ + -exec sed -i.uncheck -e 's/"files":{[^}]*}/"files":{ }/' '{}' '+' %build %configure \ + --build=%{rust_triple} \ + --host=%{rust_triple} \ + --target=%{rust_triple} \ --libdir=%{common_libdir} \ - --disable-option-checking \ - --build=%{rust_triple} --host=%{rust_triple} --target=%{rust_triple} \ - --enable-local-rust --local-rust-root=%{local_rust_root} \ - --llvm-root=%{_prefix} --disable-codegen-tests \ - --enable-llvm-link-shared \ + --disable-codegen-tests \ --disable-jemalloc \ + --disable-option-checking \ --disable-rpath \ + --disable-debuginfo-lines \ + --disable-debuginfo-only-std \ --enable-debuginfo \ + --enable-llvm-link-shared \ + --local-rust-root=%{local_rust_root} \ --enable-vendor \ + --llvm-root=%{_prefix} \ --release-channel=%{channel} ./x.py dist @@ -192,7 +220,8 @@ sed -i -e '1i // ignore-test jemalloc is disabled' \ %install rm -rf $RPM_BUILD_ROOT -DESTDIR=$RPM_BUILD_ROOT ./x.py dist --install +DESTDIR=$RPM_BUILD_ROOT ./x.py install +DESTDIR=$RPM_BUILD_ROOT ./x.py install src # Make sure the shared libraries are in the proper libdir %if "%{_libdir}" != "%{common_libdir}" @@ -218,10 +247,10 @@ find $RPM_BUILD_ROOT%{rustlibdir}/ -maxdepth 1 -type f -exec rm -v '{}' '+' # -- should we find a way to preserve debuginfo? # Remove unwanted documentation files (we already package them) -rm $RPM_BUILD_ROOT%{_docdir}/%{name}/README.md -rm $RPM_BUILD_ROOT%{_docdir}/%{name}/COPYRIGHT -rm $RPM_BUILD_ROOT%{_docdir}/%{name}/LICENSE-APACHE -rm $RPM_BUILD_ROOT%{_docdir}/%{name}/LICENSE-MIT +%{__rm} $RPM_BUILD_ROOT%{_docdir}/%{name}/README.md +%{__rm} $RPM_BUILD_ROOT%{_docdir}/%{name}/COPYRIGHT +%{__rm} $RPM_BUILD_ROOT%{_docdir}/%{name}/LICENSE-APACHE +%{__rm} $RPM_BUILD_ROOT%{_docdir}/%{name}/LICENSE-MIT # Sanitize the HTML documentation find $RPM_BUILD_ROOT%{_docdir}/%{name}/html -empty -delete @@ -229,7 +258,10 @@ find $RPM_BUILD_ROOT%{_docdir}/%{name}/html -type f -exec chmod -x '{}' '+' # Move rust-gdb's python scripts so they're noarch install -d $RPM_BUILD_ROOT%{_datadir}/%{name} -mv -v $RPM_BUILD_ROOT%{rustlibdir}/%{_sysconfdir} $RPM_BUILD_ROOT%{_datadir}/%{name}/ +%{__mv} $RPM_BUILD_ROOT%{rustlibdir}/etc $RPM_BUILD_ROOT%{_datadir}/%{name} + +# We don't need stdlib source +%{__rm} -r $RPM_BUILD_ROOT%{rustlibdir}/src %clean rm -rf $RPM_BUILD_ROOT @@ -239,17 +271,27 @@ rm -rf $RPM_BUILD_ROOT %files %defattr(644,root,root,755) -%doc COPYRIGHT LICENSE-APACHE LICENSE-MIT -%doc src/libbacktrace/LICENSE-libbacktrace -%doc src/rt/hoedown/LICENSE-hoedown -%doc README.md +%doc COPYRIGHT LICENSE-APACHE LICENSE-MIT README.md src/libbacktrace/LICENSE-libbacktrace src/rt/hoedown/LICENSE-hoedown %attr(755,root,root) %{_bindir}/rustc %attr(755,root,root) %{_bindir}/rustdoc -%attr(755,root,root) %{_libdir}/lib*.so +%attr(755,root,root) %{_libdir}/libarena-*.so +%attr(755,root,root) %{_libdir}/libfmt_macros-*.so +%attr(755,root,root) %{_libdir}/libgraphviz-*.so +%attr(755,root,root) %{_libdir}/libproc_macro-*.so +%attr(755,root,root) %{_libdir}/librustc*-*.so +%attr(755,root,root) %{_libdir}/libserialize-*.so +%attr(755,root,root) %{_libdir}/libstd-*.so +%attr(755,root,root) %{_libdir}/libsyntax-*.so +%attr(755,root,root) %{_libdir}/libsyntax_ext-*.so +%attr(755,root,root) %{_libdir}/libsyntax_pos-*.so +%attr(755,root,root) %{_libdir}/libterm-*.so +%attr(755,root,root) %{_libdir}/libtest-*.so %{_mandir}/man1/rustc.1* %{_mandir}/man1/rustdoc.1* %dir %{rustlibdir} %dir %{rustlibdir}/%{rust_triple} +%dir %{rustlibdir}/%{rust_triple}/codegen-backends +%attr(755,root,root) %{rustlibdir}/%{rust_triple}/codegen-backends/*.so %dir %{rustlibdir}/%{rust_triple}/lib %attr(755,root,root) %{rustlibdir}/%{rust_triple}/lib/*.so %{rustlibdir}/%{rust_triple}/lib/*.rlib