aboutsummaryrefslogtreecommitdiff
blob: 3258cea48dcd64b67a1e32970fcc02f6ec34818e (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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# Copyright 2022 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2

# @ECLASS: shards.eclass
# @MAINTAINER:
# Anna <cyber+gentoo@sysrq.in>
# @AUTHOR:
# Anna <cyber+gentoo@sysrq.in>
# @SUPPORTED_EAPIS: 8
# @PROVIDES: crystal-utils
# @BLURB: eclass to build Crystal packages using Shards
# @DESCRIPTION:
# This eclass contains the default phase function for packages which use Crystal
# Shards as a build system.
#
# If the package has no shard.yml(5) file, use crystal-utils.eclass(5) instead.

case ${EAPI} in
	8) ;;
	*) die "${ECLASS}: EAPI ${EAPI} unsupported."
esac

if [[ ! ${_SHARDS_ECLASS} ]]; then
_SHARDS_ECLASS=1

inherit crystal-utils multiprocessing toolchain-funcs

BDEPEND="
	${CRYSTAL_DEPS}
	${SHARDS_DEPS}
	>=dev-util/gshards-0.2
"
IUSE="debug doc"

# Crystal packages do not use CFLAGS
QA_FLAGS_IGNORED='.*'

# @FUNCTION: shards_get_libdir
# @RETURN: the library path for Crystal packages
shards_get_libdir() {
	echo /usr/lib/shards
}

# @FUNCTION: shards_get_pkgname
# @RETURN: the package name as specified in shard.yml
shards_get_pkgname() {
	debug-print-function ${FUNCNAME} "${@}"

	gshards-get-pkgname || die "Parsing package name failed"
}

# @FUNCTION: shards_src_configure
# @DESCRIPTION:
# Function for configuring Crystal to match user settings.
shards_src_configure() {
	debug-print-function ${FUNCNAME} "${@}"

	crystal_configure
	debug-print "CRYSTAL_OPTS='${CRYSTAL_OPTS}'"

	export SHARDS_INSTALL_PATH="${BROOT}$(shards_get_libdir)"
	export CRYSTAL_PATH="${SHARDS_INSTALL_PATH}:$(crystal env CRYSTAL_PATH || die "'crystal env' failed")"
	debug-print "CRYSTAL_PATH='${CRYSTAL_PATH}'"

	tc-export CC
}

# @FUNCTION: shards_src_compile
# @DESCRIPTION:
# Function for building the package's executables and documentation.
shards_src_compile() {
	debug-print-function ${FUNCNAME} "${@}"

	local args
	gshards-print-targets | while read -r args; do
		crystal_build "${@}" ${args}
	done

	if use doc; then
		ecrystal docs "${CRYSTAL_DEFINES[@]}"
		HTML_DOCS=( docs/. )
	fi

	return 0
}

# @FUNCTION: shards_src_test
# @USAGE: [<args>...]
# @DESCRIPTION:
# Function for testing the package.
shards_src_test() {
	debug-print-function ${FUNCNAME} "${@}"

	if [[ -d "spec" ]]; then
		crystal_spec "${@}"
	fi

	return 0
}

# @FUNCTION: shards_src_install
# @DESCRIPTION:
# Function for installing the package's source.
shards_src_install() {
	debug-print-function ${FUNCNAME} "${@}"

	if [[ -d "src" ]]; then
		insinto $(shards_get_libdir)/$(shards_get_pkgname)
		doins -r src
		doins shard.yml
	fi

	einstalldocs
}

fi

EXPORT_FUNCTIONS src_configure src_compile src_test src_install