blob: f0d51228e05e41691686457f3fae822a2f60f689 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
# Copyright 1999-2023 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
inherit autotools bash-completion-r1 llvm
DESCRIPTION="NVC is a VHDL compiler and simulator"
HOMEPAGE="https://www.nickg.me.uk/nvc/
https://github.com/nickg/nvc/"
if [[ ${PV} == *9999* ]] ; then
inherit git-r3
EGIT_REPO_URI="https://github.com/nickg/nvc.git"
NVC_SOURCEDIR="${WORKDIR}"/${PN}-${PV}
else
SRC_URI="https://github.com/nickg/nvc/archive/r${PV}.tar.gz
-> ${P}.tar.gz"
KEYWORDS="~amd64 ~x86"
NVC_SOURCEDIR="${WORKDIR}"/${PN}-r${PV}
fi
LICENSE="GPL-3+"
SLOT="0"
IUSE="debug jit llvm"
REQUIRED_USE="jit? ( llvm )"
RESTRICT="test" # Some tests fail.
RDEPEND="
app-arch/bzip2:=
app-arch/zstd:=
dev-libs/capstone:=
dev-libs/elfutils
dev-libs/icu:=
dev-libs/libffi:=
dev-libs/libxml2:=
sys-libs/ncurses:=
sys-libs/zlib:=
llvm? ( sys-devel/llvm:= )
"
DEPEND="
${RDEPEND}
"
BDEPEND="
dev-libs/check
sys-devel/flex
"
NVC_BUILDDIR="${NVC_SOURCEDIR}_BuildDir"
S="${NVC_BUILDDIR}"
PATCHES=( "${FILESDIR}"/nvc-1.9.2-jit-code-capstone.patch )
# Special libraries for NVC.
QA_FLAGS_IGNORED="usr/lib[0-9]*/nvc/preload[0-9]*.so"
pkg_setup() {
use llvm && llvm_pkg_setup
}
src_unpack() {
default
mkdir -p "${S}" || die
}
src_prepare() {
pushd "${NVC_SOURCEDIR}" >/dev/null || die
default
eautoreconf
popd >/dev/null || die
}
src_configure() {
local ECONF_SOURCE="${NVC_SOURCEDIR}"
local -a myconf=(
--enable-verilog
--enable-vital
--with-bash-completion="$(get_bashcompdir)"
$(use_enable debug)
$(use_enable jit)
$(use_enable llvm)
)
econf "${myconf[@]}"
export V=1 # Verbose compilation and install.
}
src_test() {
emake check
}
src_install() {
default
mv "${ED}"/"$(get_bashcompdir)"/nvc{.bash,} || die
dostrip -x /usr/$(get_libdir)/nvc
}
|