Gentoo Archives: gentoo-commits

From: Sergei Trofimovich <slyfox@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-lang/nim/, dev-lang/nim/files/
Date: Wed, 26 Sep 2018 23:32:38
Message-Id: 1538004742.7617f03216587b94eec6c655202d27efdef238f4.slyfox@gentoo
1 commit: 7617f03216587b94eec6c655202d27efdef238f4
2 Author: Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
3 AuthorDate: Wed Sep 26 23:31:48 2018 +0000
4 Commit: Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
5 CommitDate: Wed Sep 26 23:32:22 2018 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7617f032
7
8 dev-lang/nim: bump up to 0.19.0, bug #635032
9
10 While at it move installation to /usr/ prefix.
11
12 Reported-by: Jonas Stein
13 Closes: https://bugs.gentoo.org/635032
14 Package-Manager: Portage-2.3.50, Repoman-2.3.11
15
16 dev-lang/nim/Manifest | 1 +
17 dev-lang/nim/files/nim-0.19.0-paths.patch | 36 ++++++++++++++
18 dev-lang/nim/nim-0.19.0.ebuild | 79 +++++++++++++++++++++++++++++++
19 3 files changed, 116 insertions(+)
20
21 diff --git a/dev-lang/nim/Manifest b/dev-lang/nim/Manifest
22 index dfd023bda12..60b6c77f4b8 100644
23 --- a/dev-lang/nim/Manifest
24 +++ b/dev-lang/nim/Manifest
25 @@ -2,3 +2,4 @@ DIST nim-0.16.0.tar.xz 2907076 BLAKE2B 5f14bb2634da32deb810381edf817e3885382ffce
26 DIST nim-0.17.0.tar.xz 25079320 BLAKE2B d01ade93ff299962aeea3dc9c90f0a8fe87acef8c2ee6d7d521d936c680aded0d8383221b7c11c3b2a8d6c28311c939456f271bbc90c1115acaae2c1987fa908 SHA512 90d709b39746fac5582b9df69d3eb9e3b7a39563a98f7a3002f00716b936e4e0d2be47d8b877878318692e6e2b85c08077dfcc20d9059573a1967402c244894b
27 DIST nim-0.17.2.tar.xz 4083084 BLAKE2B c1a4134592bb6a57bfaf6174becb409e40075c77042964c639b39fe7b30f094bfc8d404d6e1e4e527a95333a8ee4597477f1052da1af58c3216042bb2f85c826 SHA512 7b4ed1eb1e9067ce72b76b95c43ec74eb38f04611776c174ba6a697254a9253fed61258712fb938f15e662bb3b0d36138194fc8fa89bbcb4d22888263e5e2880
28 DIST nim-0.18.0.tar.xz 4412632 BLAKE2B f7286542daa4c3502f4edeb9d93e6a69169228a50248f1c5c02421cb8e70c0ab99bc84cc91b35a6227a4974345423eeb3b5ffecdb18e321b0a82eb8fd0879a16 SHA512 8f59cb4a8d44949cdd1154fb44df548005329da8255becf2f54083ce58323ff8d6cf7b2fdd86d4b1f446bd9f977e8eaf4b13c7ca6723da8a10c7b671954de772
29 +DIST nim-0.19.0.tar.xz 3321644 BLAKE2B e1de3b8a4c756315bcd110ddc62c03eb1a379403d8c102eb4d6d131cccabe3dccdfdac33d46037fd8b3b241d727acb42f5cb0b616a4079830ea3abf63089f90a SHA512 f7f3c8e0e9a6509b6404e21da4693ceb279112dd7a7c39edc7e717f21554442914c9cf7d811bb4034ff244e34d77dabf6e09b5e3e77c37314adf99cc0c3b2311
30
31 diff --git a/dev-lang/nim/files/nim-0.19.0-paths.patch b/dev-lang/nim/files/nim-0.19.0-paths.patch
32 new file mode 100644
33 index 00000000000..71ccb140d54
34 --- /dev/null
35 +++ b/dev-lang/nim/files/nim-0.19.0-paths.patch
36 @@ -0,0 +1,36 @@
37 +Default to <prefix>/usr/bin install.
38 +
39 +https://bugs.gentoo.org/635032
40 +--- a/tools/niminst/install.tmpl
41 ++++ b/tools/niminst/install.tmpl
42 +@@ -28,13 +28,13 @@ if [ $# -eq 1 ] ; then
43 + echo "sh deinstall.sh DIR"
44 + exit 1
45 + ;;
46 +- "/usr/bin")
47 +- bindir=/usr/bin
48 +- configdir=/etc/?proj
49 +- libdir=/usr/lib/?proj
50 +- docdir=/usr/share/?proj/doc
51 +- datadir=/usr/share/?proj/data
52 +- nimbleDir="/opt/nimble/pkgs/?c.nimblePkgName-?c.version"
53 ++ *)
54 ++ bindir=$1/usr/bin
55 ++ configdir=$1/etc/?proj
56 ++ libdir=$1/usr/lib/?proj
57 ++ docdir=$1/usr/share/?proj/doc
58 ++ datadir=$1/usr/share/?proj/data
59 ++ nimbleDir=$1"/opt/nimble/pkgs/?c.nimblePkgName-?c.version"
60 + ;;
61 + "/usr/local/bin")
62 + bindir=/usr/local/bin
63 +@@ -68,6 +68,9 @@ if [ $# -eq 1 ] ; then
64 + ;;
65 + esac
66 +
67 ++ mkdir -p $bindir
68 ++ mkdir -p $datadir
69 ++
70 + mkdir -p $libdir
71 + mkdir -p $docdir
72 + mkdir -p $configdir
73
74 diff --git a/dev-lang/nim/nim-0.19.0.ebuild b/dev-lang/nim/nim-0.19.0.ebuild
75 new file mode 100644
76 index 00000000000..c86fab3680e
77 --- /dev/null
78 +++ b/dev-lang/nim/nim-0.19.0.ebuild
79 @@ -0,0 +1,79 @@
80 +# Copyright 1999-2018 Gentoo Authors
81 +# Distributed under the terms of the GNU General Public License v2
82 +
83 +EAPI=6
84 +
85 +inherit bash-completion-r1 multiprocessing
86 +
87 +DESCRIPTION="compiled, garbage-collected systems programming language"
88 +HOMEPAGE="https://nim-lang.org/"
89 +SRC_URI="https://nim-lang.org/download/${P}.tar.xz"
90 +
91 +LICENSE="MIT"
92 +SLOT="0"
93 +KEYWORDS="~amd64 ~arm ~x86"
94 +IUSE="doc +readline test"
95 +
96 +RESTRICT=test # need to sort out depends and numerous failures
97 +
98 +RDEPEND="
99 + readline? ( sys-libs/readline:0= )
100 +"
101 +DEPEND="
102 + ${DEPEND}
103 + test? ( net-libs/nodejs )
104 +"
105 +
106 +PATCHES=(
107 + "${FILESDIR}"/${P}-paths.patch
108 +)
109 +
110 +_run() {
111 + echo "$@"
112 + "$@" || die "'$*' failed"
113 +}
114 +
115 +nim_use_enable() {
116 + [[ -z $2 ]] && die "usage: nim_use_enable <USE flag> <compiler flag>"
117 + use $1 && echo "-d:$2"
118 +}
119 +
120 +src_compile() {
121 + _run ./build.sh
122 +
123 + _run ./bin/nim --parallelBuild:$(makeopts_jobs) c koch
124 + _run ./koch boot --parallelBuild:$(makeopts_jobs) -d:release $(nim_use_enable readline useGnuReadline)
125 + # build nimble and friends
126 + # --stable to avoid pulling HEAD nimble
127 + PATH="./bin:$PATH" _run ./koch --stable tools
128 +
129 + if use doc; then
130 + PATH="./bin:$PATH" _run ./koch web
131 + fi
132 +}
133 +
134 +src_test() {
135 + PATH="./bin:$PATH" _run ./koch test
136 +}
137 +
138 +src_install() {
139 + PATH="./bin:$PATH" _run ./koch install "${ED%/}"
140 + rm -r "${ED%/}/usr/share/nim/doc" || die "failed to remove 'doc'"
141 +
142 + exeinto /usr/bin
143 +
144 + local bin_exe
145 + for bin_exe in bin/*; do
146 + # './koch install' installs only 'nim' binary
147 + # but not the rest
148 + [[ ${bin_exe} == bin/nim ]] && continue
149 + doexe "${bin_exe}"
150 + done
151 +
152 + if use doc; then
153 + insinto /usr/share/doc/${PF}
154 + dodoc doc/*.html
155 + fi
156 +
157 + newbashcomp tools/nim.bash-completion ${PN}
158 +}