summarylogtreecommitdiffstats
path: root/PKGBUILD
diff options
context:
space:
mode:
Diffstat (limited to 'PKGBUILD')
-rw-r--r--PKGBUILD52
1 files changed, 45 insertions, 7 deletions
diff --git a/PKGBUILD b/PKGBUILD
index 4ed0a136ea7f..9e619942d989 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -3,7 +3,7 @@
pkgname=julia-zmq
_pkgname=ZMQ
pkgver=1.0.0
-pkgrel=2
+pkgrel=3
pkgdesc='Julia binding to the native API of ØMQ project'
arch=(any)
url=https://github.com/JuliaInterop/ZMQ.jl
@@ -12,11 +12,48 @@ depends=(julia julia-compat julia-loadpath zeromq)
_commit=ffed2d514d4e73cf0f8c700d5d33cd5f9dec9ee0
source=($pkgname-$pkgver.tar.gz::https://github.com/JuliaInterop/$_pkgname.jl/archive/v$pkgver.tar.gz
- $pkgname-Package.toml::https://raw.githubusercontent.com/JuliaRegistries/General/$_commit/${_pkgname:0:1}/$_pkgname/Package.toml)
+ $pkgname-Deps.toml::https://raw.githubusercontent.com/JuliaRegistries/General/$_commit/${_pkgname:0:1}/$_pkgname/Deps.toml
+ $pkgname-Package.toml::https://raw.githubusercontent.com/JuliaRegistries/General/$_commit/${_pkgname:0:1}/$_pkgname/Package.toml
+ $pkgname-Versions.toml::https://raw.githubusercontent.com/JuliaRegistries/General/$_commit/${_pkgname:0:1}/$_pkgname/Versions.toml)
sha256sums=('f8c3cc104b3e8dc7ae09da9787427fb2ca45f3e4b46c98a6c8eace78216b1333'
- '6b51aedfcda4ecddeed07880756db0791b33bb158237fdb714ff695f1902f417')
+ 'd27c36dfdb33f4cfb29f85c57509fa0874bd0f92e8c3d88ef87fcc93f3e32bcc'
+ '6b51aedfcda4ecddeed07880756db0791b33bb158237fdb714ff695f1902f417'
+ 'f2fc26069146b5cfebee4e243023d3793f843eccba6e48c02fa92d5124599da2')
+
+_slug() {
+ local uuid=$(grep uuid $pkgname-Package.toml | cut -f3 -d' ')
+ local sha1=$(grep \"$pkgver\" -a1 $pkgname-Versions.toml | tail -n1 | cut -f3 -d' ')
+ julia -e "u = Base.UUID($uuid);
+ s = Base.SHA1(hex2bytes($sha1));
+ println(Base.version_slug(u,s));"
+}
+
+_deps() {
+ julia -e "using Pkg
+
+ alldeps = Pkg.TOML.parsefile(\"$srcdir/$pkgname-Deps.toml\")
+ version = join(split(\"$pkgver\", \".\")[1:2],\".\")
+ deps = Dict{String,Any}()
+
+ for (key, value) in alldeps
+ vers = split(key, \"-\")
+
+ if version == vers[1] || (version > vers[1] && length(vers) == 2 && version <= vers[2])
+ merge!(deps, value)
+ end
+ end
+
+ Pkg.TOML.print(deps)"
+}
prepare() {
+ # Generate a Project.toml from Registry metadata
+ rm -f Project.toml && touch Project.toml
+ cat $pkgname-Package.toml >> Project.toml
+ echo -e "version = \"$pkgver\"" >> Project.toml
+ echo -e "\n[deps]" >> Project.toml
+ echo -e "$(_deps)" | sort >> Project.toml
+
cd $_pkgname.jl-$pkgver
cat >deps/deps.jl <<'EOF'
if isdefined((@static VERSION < v"0.7.0-DEV.484" ? current_module() : @__MODULE__), :Compat)
@@ -40,15 +77,16 @@ EOF
}
package() {
- install -d "$pkgdir"/usr/share/julia/vendor
+ install -d "$pkgdir"/usr/share/julia/{vendor,packages/$_pkgname}
- cp -r $_pkgname.jl-$pkgver "$pkgdir"/usr/share/julia/vendor/$_pkgname
- install -m644 $pkgname-Package.toml "$pkgdir"/usr/share/julia/vendor/$_pkgname/Project.toml
+ cp -r $_pkgname.jl-$pkgver "$pkgdir"/usr/share/julia/vendor/$_pkgname
+ install -m644 Project.toml "$pkgdir"/usr/share/julia/vendor/$_pkgname/Project.toml
+ ln -s ../../vendor/$_pkgname "$pkgdir"/usr/share/julia/packages/$_pkgname/$(_slug)
install -Dm644 $_pkgname.jl-$pkgver/LICENSE.md "$pkgdir"/usr/share/licenses/$pkgname/LICENSE
}
check() {
cd $_pkgname.jl-$pkgver
- HOME=$srcdir JULIA_LOAD_PATH=src: julia test/runtests.jl
+ HOME="$srcdir" JULIA_LOAD_PATH=src:$JULIA_LOAD_PATH julia test/runtests.jl
}