diff options
author | Jakub Jirutka <jakub@jirutka.cz> | 2017-05-17 18:36:14 +0200 |
---|---|---|
committer | Jakub Jirutka <jakub@jirutka.cz> | 2017-05-17 18:36:14 +0200 |
commit | 2282bb03f12bd9c0175feb9972cab2292df46f1e (patch) | |
tree | 08710bc3e7c2fad70de67bfb605545e0b71047eb /community/cargo | |
parent | 7560fbf3d64eb4a5eb63149359967766b078006a (diff) | |
download | aports-2282bb03f12bd9c0175feb9972cab2292df46f1e.tar.bz2 aports-2282bb03f12bd9c0175feb9972cab2292df46f1e.tar.xz |
community/cargo: move from testing
Diffstat (limited to 'community/cargo')
-rw-r--r-- | community/cargo/APKBUILD | 115 | ||||
-rw-r--r-- | community/cargo/fix-test-build-auth.patch | 46 |
2 files changed, 161 insertions, 0 deletions
diff --git a/community/cargo/APKBUILD b/community/cargo/APKBUILD new file mode 100644 index 0000000000..3089fecd36 --- /dev/null +++ b/community/cargo/APKBUILD @@ -0,0 +1,115 @@ +# Contributor: Jakub Jirutka <jakub@jirutka.cz> +# Maintainer: Jakub Jirutka <jakub@jirutka.cz> +pkgname=cargo +pkgver=0.18.0 +# Git revision of prebuilt Cargo to use for bootstrapping. +_bootstrap_gitrev=6e0c18cccc8b0c06fba8a8d76486f81a792fb420 # 0.16.0 +# Git revision of rust-installer (submodule in cargo repo). +_installer_gitrev=4f994850808a572e2cc8d43f968893c8e942e9bf +pkgrel=0 +pkgdesc="The Rust package manager" +url="https://crates.io" +arch="x86_64" # limited by rust pkg +license="MIT ASL-2.0" +depends="rust" +makedepends="cmake curl-dev libgit2-dev libssh2-dev libressl-dev python2 zlib-dev" +subpackages="$pkgname-doc + $pkgname-bash-completion:bashcomp:noarch + $pkgname-zsh-completion:zshcomp:noarch" +# Note: Cargo is self-hosted, so you need cargo to build cargo (ugh). +# XXX: Cargo depends on many crates (Rust packages) and currently downloads +# them itself in the build phase. This quite violates our policy. However, +# unlike some other package managers, Cargo does not download arbitrary +# packages from the Internet without any verification. The source tarball +# includes file Cargo.lock that contains complete dependency tree with exact +# version and checksum for each crate . With --locked we force cargo to +# adhere to this file and verify checksums. So it provides the same +# guarantees as abuild. That said, for now it's exception only for cargo +# package and should not be applied to other rust packages! +_cbuild="$CARCH-unknown-linux-musl" +source="$pkgname-$pkgver.tar.gz::https://github.com/rust-lang/$pkgname/archive/$pkgver.tar.gz + https://github.com/rust-lang/rust-installer/archive/$_installer_gitrev/rust-installer-$_installer_gitrev.tar.gz + cargo-$_bootstrap_gitrev-$_cbuild.tar.gz::https://s3.amazonaws.com/rust-lang-ci/cargo-builds/$_bootstrap_gitrev/cargo-nightly-$_cbuild.tar.gz + fix-test-build-auth.patch" +builddir="$srcdir/$pkgname-$pkgver" + +_bootstrap_cargo="$srcdir/cargo-nightly-$_cbuild/cargo/bin/cargo" + +export CARGOFLAGS="--locked" +export CARGO_HOME="$srcdir/.cargo" + +prepare() { + default_prepare + cd "$builddir" + + rmdir src/rust-installer + ln -s "$srcdir"/rust-installer-$_installer_gitrev src/rust-installer +} + +build() { + cd "$builddir" + + ./configure \ + --prefix=/usr \ + --release-channel=stable \ + --cargo="$_bootstrap_cargo" + + # LIBGIT2... Convince libgit2-sys to use the distro libgit2. + make LIBGIT2_SYS_USE_PKG_CONFIG=1 \ + VERBOSE=1 +} + +check() { + cd "$builddir" + + ./target/$CTARGET/release/cargo --version + + # XXX: ignore test failures for now + CFG_DISABLE_CROSS_TESTS=1 \ + "$_bootstrap_cargo" test \ + --release \ + --target "$CTARGET" \ + --no-fail-fast \ + --verbose || true +} + +package() { + cd "$builddir" + + make install DESTDIR="$pkgdir" + + # Remove installer artifacts (manifests, uninstall scripts, etc.) + rm -rv "$pkgdir"/usr/lib +} + +bashcomp() { + pkgdesc="Bash completions for $pkgname" + depends="" + install_if="$pkgname=$pkgver-r$pkgrel bash" + + _mv "$pkgdir"/usr/etc/bash_completion.d/* \ + "$subpkgdir"/usr/share/bash-completion/completions/ + + # Clean directories which are supposed to be empty. + rmdir -p "$pkgdir"/usr/etc/bash_completion.d 2>/dev/null || true +} + +zshcomp() { + pkgdesc="ZSH completions for $pkgname" + depends="" + install_if="$pkgname=$pkgver-r$pkgrel zsh" + + _mv "$pkgdir"/usr/share/zsh "$subpkgdir"/usr/share/ + rmdir "$pkgdir"/usr/share +} + +_mv() { + local dest; for dest; do true; done # get last argument + mkdir -p "$dest" + mv $@ +} + +sha512sums="561d6817555da802e99964daa74550cc47a285903301da12a245bb62e5857c18069d87a520c5cefb62aecfe5561666352d57dca8f75758f81ea82709565577d2 cargo-0.18.0.tar.gz +9ceb4755890ad3ae68ce141231c5114077261e0279d3a9a6208053f8d3386c9198e6b94d6321b456648dd5baa86dfc3ae81df44b67d41b428d11afd6763f0cff rust-installer-4f994850808a572e2cc8d43f968893c8e942e9bf.tar.gz +4df33353b6be1af822220ca03f9ec5a3b6421c9b10ec17b864be586ba495c6210bac70d904b0e0b35eff62ef2c9a681ded526e5cbd37e326dc3146742aa659de cargo-6e0c18cccc8b0c06fba8a8d76486f81a792fb420-x86_64-unknown-linux-musl.tar.gz +6a789fc1bf0eb19dde9267a10f7506787d6a4bb8316b09f4dee5da083c0fb0bad87630b238d92ef3aaf114d9a337a87797c8ac427f71c53ac06106925d459ee0 fix-test-build-auth.patch" diff --git a/community/cargo/fix-test-build-auth.patch b/community/cargo/fix-test-build-auth.patch new file mode 100644 index 0000000000..2fdb50c1c6 --- /dev/null +++ b/community/cargo/fix-test-build-auth.patch @@ -0,0 +1,46 @@ +From: Jakub Jirutka <jakub@jirutka.cz> +Date: Thu, 13 Aug 2016 14:47:00 +0200 +Subject: [PATCH] Fix test build-auth:http_auth_offered + +The test fails because of hard-coded libgit2 version, that may not be +the same as actually used libgit2... + +--- a/tests/build-auth.rs ++++ b/tests/build-auth.rs +@@ -20,7 +20,7 @@ + let addr = server.local_addr().unwrap(); + + fn headers(rdr: &mut BufRead) -> HashSet<String> { +- let valid = ["GET", "Authorization", "Accept", "User-Agent"]; ++ let valid = ["GET", "Authorization", "Accept"]; + rdr.lines().map(|s| s.unwrap()) + .take_while(|s| s.len() > 2) + .map(|s| s.trim().to_string()) +@@ -33,11 +33,6 @@ + let t = thread::spawn(move|| { + let mut conn = BufStream::new(server.accept().unwrap().0); + let req = headers(&mut conn); +- let user_agent = if cfg!(windows) { +- "User-Agent: git/1.0 (libgit2 0.25.1)" +- } else { +- "User-Agent: git/2.0 (libgit2 0.25.1)" +- }; + conn.write_all(b"\ + HTTP/1.1 401 Unauthorized\r\n\ + WWW-Authenticate: Basic realm=\"wheee\"\r\n +@@ -46,7 +41,6 @@ + assert_eq!(req, vec![ + "GET /foo/bar/info/refs?service=git-upload-pack HTTP/1.1", + "Accept: */*", +- user_agent, + ].into_iter().map(|s| s.to_string()).collect()); + drop(conn); + +@@ -61,7 +55,6 @@ + "GET /foo/bar/info/refs?service=git-upload-pack HTTP/1.1", + "Authorization: Basic Zm9vOmJhcg==", + "Accept: */*", +- user_agent, + ].into_iter().map(|s| s.to_string()).collect()); + }); + |