mirror of
https://github.com/archlinuxarm/PKGBUILDs.git
synced 2025-03-19 00:21:40 +00:00
extra/rust to 1.56.1-3
This commit is contained in:
parent
6cf959bf0f
commit
877f3c2297
2 changed files with 113 additions and 73 deletions
24
extra/rust/0003-compiler-Use-wasm-ld-for-wasm-targets.patch
Normal file
24
extra/rust/0003-compiler-Use-wasm-ld-for-wasm-targets.patch
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Jan Alexander Steffens (heftig)" <jan.steffens@gmail.com>
|
||||||
|
Date: Sat, 6 Nov 2021 22:42:06 +0100
|
||||||
|
Subject: [PATCH] compiler: Use wasm-ld for wasm targets
|
||||||
|
|
||||||
|
We don't ship rust-lld.
|
||||||
|
---
|
||||||
|
compiler/rustc_target/src/spec/wasm_base.rs | 3 +--
|
||||||
|
1 file changed, 1 insertion(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/compiler/rustc_target/src/spec/wasm_base.rs b/compiler/rustc_target/src/spec/wasm_base.rs
|
||||||
|
index 4c954a1e567c..f1d5fbf83748 100644
|
||||||
|
--- a/compiler/rustc_target/src/spec/wasm_base.rs
|
||||||
|
+++ b/compiler/rustc_target/src/spec/wasm_base.rs
|
||||||
|
@@ -99,8 +99,7 @@ pub fn options() -> TargetOptions {
|
||||||
|
// arguments just yet
|
||||||
|
limit_rdylib_exports: false,
|
||||||
|
|
||||||
|
- // we use the LLD shipped with the Rust toolchain by default
|
||||||
|
- linker: Some("rust-lld".to_owned()),
|
||||||
|
+ linker: Some("wasm-ld".to_owned()),
|
||||||
|
lld_flavor: LldFlavor::Wasm,
|
||||||
|
linker_is_gnu: false,
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
# Contributor: userwithuid <userwithuid@gmail.com>
|
# Contributor: userwithuid <userwithuid@gmail.com>
|
||||||
|
|
||||||
# ALARM: Kevin Mihelich <kevin@archlinuxarm.org>
|
# ALARM: Kevin Mihelich <kevin@archlinuxarm.org>
|
||||||
# - remove lib32 package and related bits
|
# - remove lib32, musl, and wasm packages and related bits
|
||||||
# - add a link to g++ to compensate for broken cross-compiler decisions
|
# - add a link to g++ to compensate for broken cross-compiler decisions
|
||||||
# - build v6/v7 with -j2 - RAM constraints
|
# - build v6/v7 with -j2 - RAM constraints
|
||||||
# - set llvm-config in config.toml for ARM architectures
|
# - set llvm-config in config.toml for ARM architectures
|
||||||
|
@ -14,53 +14,55 @@
|
||||||
buildarch=28
|
buildarch=28
|
||||||
highmem=1
|
highmem=1
|
||||||
|
|
||||||
pkgname=('rust' 'rust-docs')
|
pkgbase=rust
|
||||||
|
pkgname=(rust rust-src)
|
||||||
epoch=1
|
epoch=1
|
||||||
pkgver=1.56.0
|
pkgver=1.56.1
|
||||||
pkgrel=1
|
pkgrel=3
|
||||||
|
pkgdesc="Systems programming language focused on safety, speed and concurrency"
|
||||||
_llvm_ver=12.0.1
|
url=https://www.rust-lang.org/
|
||||||
|
arch=(x86_64)
|
||||||
pkgdesc='Systems programming language focused on safety, speed and concurrency'
|
license=(MIT Apache)
|
||||||
url='https://www.rust-lang.org/'
|
options=(!emptydirs !strip)
|
||||||
arch=('x86_64')
|
_llvm_ver=13.0.0
|
||||||
license=('MIT' 'Apache')
|
depends=(gcc-libs llvm-libs curl libssh2 gcc)
|
||||||
|
makedepends=(rust "llvm=$_llvm_ver" libffi perl python cmake
|
||||||
makedepends=('rust' "llvm=$_llvm_ver" 'libffi' 'perl' 'python'
|
ninja lld)
|
||||||
'curl' 'cmake' 'ninja')
|
checkdepends=(procps-ng gdb)
|
||||||
checkdepends=('procps-ng' 'gdb')
|
|
||||||
|
|
||||||
options=('!emptydirs' '!strip')
|
|
||||||
|
|
||||||
source=(
|
source=(
|
||||||
"https://static.rust-lang.org/dist/rustc-$pkgver-src.tar.gz"{,.asc}
|
"https://static.rust-lang.org/dist/rustc-$pkgver-src.tar.gz"{,.asc}
|
||||||
"https://github.com/llvm/llvm-project/releases/download/llvmorg-$_llvm_ver/compiler-rt-$_llvm_ver.src.tar.xz"{,.sig}
|
"https://github.com/llvm/llvm-project/releases/download/llvmorg-$_llvm_ver/compiler-rt-$_llvm_ver.src.tar.xz"{,.sig}
|
||||||
0001-bootstrap-Change-libexec-dir.patch
|
|
||||||
0001-cargo-Change-libexec-dir.patch
|
0001-cargo-Change-libexec-dir.patch
|
||||||
|
0001-bootstrap-Change-libexec-dir.patch
|
||||||
0002-compiler-Change-LLVM-targets.patch
|
0002-compiler-Change-LLVM-targets.patch
|
||||||
|
0003-compiler-Use-wasm-ld-for-wasm-targets.patch
|
||||||
)
|
)
|
||||||
sha256sums=('cd0fd72d698deb3001c18e0f4bf8261d8f86420097eef94ca3a1fe047f2df43f'
|
sha256sums=('c3898dfaadaa193dc88ddbc5345946a163211b58621df1cfff70186b4fc79511'
|
||||||
'SKIP'
|
'SKIP'
|
||||||
'b4c8d5f2a802332987c1c0a95b5afb35b1a66a96fe44add4e4ed4792c4cba0a4'
|
'4c3602d76c7868a96b30c36165c4b7643e2a20173fced7e071b4baeb2d74db3f'
|
||||||
'SKIP'
|
'SKIP'
|
||||||
'a2a8a7c6a5732f79cc92f81d3c8380589c4e2b9a996fb565bbefe42f66b62597'
|
|
||||||
'0f8cfbe0387dd62909fe9cb9523223ae1c2319494e2caf5fa4d0592198631b3e'
|
'0f8cfbe0387dd62909fe9cb9523223ae1c2319494e2caf5fa4d0592198631b3e'
|
||||||
'977da945985dce4484ace8794cbc91241b1f3c27311c1a8b201231db6e1d19e5')
|
'a2a8a7c6a5732f79cc92f81d3c8380589c4e2b9a996fb565bbefe42f66b62597'
|
||||||
validpgpkeys=('108F66205EAEB0AAA8DD5E1C85AB96E6FA1BE5FE' # Rust Language (Tag and Release Signing Key) <rust-key@rust-lang.org>
|
'977da945985dce4484ace8794cbc91241b1f3c27311c1a8b201231db6e1d19e5'
|
||||||
'474E22316ABF4785A88C6E8EA2C794A986419D8A' # Tom Stellard <tstellar@redhat.com>
|
'fcf3c4442ba6a9e59415652ce8514428b2e37b80c5fe7d07fb44259ad37abafb')
|
||||||
'B6C8F98282B944E3B0D5C2530FC3042E345AD05D') # Hans Wennborg <hans@chromium.org>
|
validpgpkeys=(108F66205EAEB0AAA8DD5E1C85AB96E6FA1BE5FE # Rust Language (Tag and Release Signing Key) <rust-key@rust-lang.org>
|
||||||
|
474E22316ABF4785A88C6E8EA2C794A986419D8A # Tom Stellard <tstellar@redhat.com>
|
||||||
|
B6C8F98282B944E3B0D5C2530FC3042E345AD05D) # Hans Wennborg <hans@chromium.org>
|
||||||
|
|
||||||
prepare() {
|
prepare() {
|
||||||
cd "rustc-$pkgver-src"
|
cd rustc-$pkgver-src
|
||||||
|
|
||||||
# Patch bootstrap and cargo so credential helpers
|
# Patch bootstrap and cargo so credential helpers
|
||||||
# are in /usr/lib instead of /usr/libexec
|
# are in /usr/lib instead of /usr/libexec
|
||||||
patch -Np1 -i ../0001-bootstrap-Change-libexec-dir.patch
|
|
||||||
patch -d src/tools/cargo -Np1 < ../0001-cargo-Change-libexec-dir.patch
|
patch -d src/tools/cargo -Np1 < ../0001-cargo-Change-libexec-dir.patch
|
||||||
|
patch -Np1 -i ../0001-bootstrap-Change-libexec-dir.patch
|
||||||
|
|
||||||
# Use our *-pc-linux-gnu targets, making LTO with clang simpler
|
# Use our *-pc-linux-gnu targets, making LTO with clang simpler
|
||||||
patch -Np1 -i ../0002-compiler-Change-LLVM-targets.patch
|
patch -Np1 -i ../0002-compiler-Change-LLVM-targets.patch
|
||||||
|
|
||||||
|
# Use our wasm-ld
|
||||||
|
patch -Np1 -i ../0003-compiler-Use-wasm-ld-for-wasm-targets.patch
|
||||||
|
|
||||||
cat >config.toml <<END
|
cat >config.toml <<END
|
||||||
changelog-seen = 2
|
changelog-seen = 2
|
||||||
profile = "user"
|
profile = "user"
|
||||||
|
@ -72,24 +74,35 @@ link-shared = true
|
||||||
cargo = "/usr/bin/cargo"
|
cargo = "/usr/bin/cargo"
|
||||||
rustc = "/usr/bin/rustc"
|
rustc = "/usr/bin/rustc"
|
||||||
rustfmt = "/usr/bin/rustfmt"
|
rustfmt = "/usr/bin/rustfmt"
|
||||||
|
locked-deps = true
|
||||||
vendor = true
|
vendor = true
|
||||||
tools = ["cargo", "rls", "clippy", "rustfmt", "analysis", "src", "rust-demangler"]
|
tools = ["cargo", "rls", "clippy", "rustfmt", "analysis", "src", "rust-demangler"]
|
||||||
sanitizers = false
|
sanitizers = false
|
||||||
profiler = true
|
profiler = true
|
||||||
|
|
||||||
|
# Generating docs fails with the wasm32-* targets
|
||||||
|
docs = false
|
||||||
|
|
||||||
[install]
|
[install]
|
||||||
prefix = "/usr"
|
prefix = "/usr"
|
||||||
|
|
||||||
[rust]
|
[rust]
|
||||||
|
debuginfo-level-std = 0
|
||||||
|
channel = "stable"
|
||||||
|
description = "Arch Linux $pkgbase $epoch:$pkgver-$pkgrel"
|
||||||
|
rpath = false
|
||||||
|
backtrace-on-ice = true
|
||||||
|
remap-debuginfo = true
|
||||||
|
jemalloc = true
|
||||||
|
|
||||||
# LLVM crashes when passing an object through ThinLTO twice. This is triggered
|
# LLVM crashes when passing an object through ThinLTO twice. This is triggered
|
||||||
# when using rust code in cross-language LTO if libstd was built using ThinLTO.
|
# when using rust code in cross-language LTO if libstd was built using ThinLTO.
|
||||||
# http://blog.llvm.org/2019/09/closing-gap-cross-language-lto-between.html
|
# http://blog.llvm.org/2019/09/closing-gap-cross-language-lto-between.html
|
||||||
# https://github.com/rust-lang/rust/issues/54872
|
# https://github.com/rust-lang/rust/issues/54872
|
||||||
codegen-units-std = 1
|
codegen-units-std = 1
|
||||||
|
|
||||||
debuginfo-level-std = 0
|
[dist]
|
||||||
channel = "stable"
|
compression-formats = ["gz"]
|
||||||
rpath = false
|
|
||||||
|
|
||||||
[target.x86_64-unknown-linux-gnu]
|
[target.x86_64-unknown-linux-gnu]
|
||||||
llvm-config = "/usr/bin/llvm-config"
|
llvm-config = "/usr/bin/llvm-config"
|
||||||
|
@ -114,64 +127,67 @@ END
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_pick() {
|
||||||
|
local p="$1" f d; shift
|
||||||
|
for f; do
|
||||||
|
d="$srcdir/$p/$f"
|
||||||
|
mkdir -p "$(dirname "$d")"
|
||||||
|
mv "$f" "$d"
|
||||||
|
rmdir -p --ignore-fail-on-non-empty "$(dirname "$f")"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
build() {
|
build() {
|
||||||
cd "rustc-$pkgver-src"
|
cd rustc-$pkgver-src
|
||||||
|
|
||||||
export RUST_BACKTRACE=1
|
export RUST_BACKTRACE=1
|
||||||
export RUST_COMPILER_RT_ROOT="$srcdir/compiler-rt-$_llvm_ver.src"
|
export RUST_COMPILER_RT_ROOT="$srcdir/compiler-rt-$_llvm_ver.src"
|
||||||
[[ -d $RUST_COMPILER_RT_ROOT ]]
|
[[ -d $RUST_COMPILER_RT_ROOT ]]
|
||||||
|
|
||||||
DESTDIR="$PWD"/dest-rust python ./x.py install -j "$(nproc)"
|
DESTDIR="$srcdir/dest-rust" python ./x.py install -j "$(nproc)"
|
||||||
|
|
||||||
# Remove analysis data for libs that weren't installed
|
cd ../dest-rust
|
||||||
# TODO: Find out where these come from
|
|
||||||
local file lib
|
|
||||||
while read -rd '' file; do
|
|
||||||
lib="${file%.json}.rlib"
|
|
||||||
lib="${lib/\/analysis\///lib/}"
|
|
||||||
if [[ ! -e $lib ]]; then
|
|
||||||
echo "missing '$lib'"
|
|
||||||
rm -v "$file"
|
|
||||||
fi
|
|
||||||
done < <(find "dest-rust/usr/lib/rustlib" -path '*/analysis/*.json' -print0)
|
|
||||||
|
|
||||||
# move docs and cross targets out of the way for splitting
|
# delete unnecessary files, e.g. files only used for the uninstall script
|
||||||
mv dest-rust/usr/share/doc dest-doc
|
rm usr/lib/rustlib/{components,install.log,rust-installer-version,uninstall.sh}
|
||||||
}
|
rm usr/lib/rustlib/manifest-*
|
||||||
|
|
||||||
package_rust() {
|
|
||||||
depends=('gcc-libs' 'llvm-libs' 'curl' 'libssh2')
|
|
||||||
optdepends=('lldb: rust-lldb script'
|
|
||||||
'gdb: rust-gdb script')
|
|
||||||
provides=('cargo' 'rustfmt')
|
|
||||||
conflicts=('cargo' 'rustfmt')
|
|
||||||
replaces=('cargo' 'rustfmt' 'cargo-tree')
|
|
||||||
|
|
||||||
cd "rustc-$pkgver-src"
|
|
||||||
|
|
||||||
cp -a dest-rust/* "$pkgdir"
|
|
||||||
install -Dm644 -t "$pkgdir/usr/share/licenses/$pkgname" LICENSE*
|
|
||||||
|
|
||||||
# delete unnecesary files, e.g. components and manifest files only used for the uninstall script
|
|
||||||
cd "$pkgdir"/usr/lib/rustlib
|
|
||||||
rm components install.log manifest-* rust-installer-version uninstall.sh
|
|
||||||
|
|
||||||
# rustbuild always installs copies of the shared libraries to /usr/lib,
|
# rustbuild always installs copies of the shared libraries to /usr/lib,
|
||||||
# overwrite them with symlinks to the per-architecture versions
|
# overwrite them with symlinks to the per-architecture versions
|
||||||
ln -srft "$pkgdir"/usr/lib x86_64-unknown-linux-gnu/lib/*.so
|
#mkdir -p usr/lib32
|
||||||
|
#ln -srft usr/lib usr/lib/rustlib/x86_64-unknown-linux-gnu/lib/*.so
|
||||||
|
#ln -srft usr/lib32 usr/lib/rustlib/i686-unknown-linux-gnu/lib/*.so
|
||||||
|
|
||||||
install -d "$pkgdir"/usr/share/bash-completion/
|
mkdir -p usr/share/bash-completion
|
||||||
mv "$pkgdir"/etc/bash_completion.d "$pkgdir"/usr/share/bash-completion/completions
|
mv etc/bash_completion.d usr/share/bash-completion/completions
|
||||||
|
|
||||||
|
mkdir -p usr/share/licenses/rust
|
||||||
|
mv -t usr/share/licenses/rust usr/share/doc/rust/{COPYRIGHT,LICENSE*}
|
||||||
|
|
||||||
|
#_pick dest-i686 usr/lib/rustlib/i686-unknown-linux-gnu usr/lib32
|
||||||
|
#_pick dest-musl usr/lib/rustlib/x86_64-unknown-linux-musl
|
||||||
|
#_pick dest-wasm usr/lib/rustlib/wasm32-*
|
||||||
|
_pick dest-src usr/lib/rustlib/src
|
||||||
}
|
}
|
||||||
|
|
||||||
package_rust-docs() {
|
package_rust() {
|
||||||
pkgdesc='Documentation for the Rust programming language'
|
optdepends=('lldb: rust-lldb script'
|
||||||
|
'gdb: rust-gdb script')
|
||||||
|
provides=(cargo rustfmt)
|
||||||
|
conflicts=(cargo rustfmt 'rust-docs<1:1.56.1-3')
|
||||||
|
replaces=(cargo rustfmt cargo-tree 'rust-docs<1:1.56.1-3')
|
||||||
|
|
||||||
cd "rustc-$pkgver-src"
|
cp -a dest-rust/* "$pkgdir"
|
||||||
install -Dm644 -t "$pkgdir/usr/share/licenses/$pkgname" LICENSE*
|
}
|
||||||
|
|
||||||
install -d "$pkgdir"/usr/share/
|
package_rust-src() {
|
||||||
cp -a dest-doc "$pkgdir"/usr/share/doc
|
pkgdesc="Source code for the Rust standard library"
|
||||||
|
depends=(rust)
|
||||||
|
|
||||||
|
cp -a dest-src/* "$pkgdir"
|
||||||
|
|
||||||
|
mkdir -p "$pkgdir/usr/share/licenses"
|
||||||
|
ln -s rust "$pkgdir/usr/share/licenses/$pkgname"
|
||||||
}
|
}
|
||||||
|
|
||||||
# vim:set ts=2 sw=2 et:
|
# vim:set ts=2 sw=2 et:
|
||||||
|
|
Loading…
Reference in a new issue