summaryrefslogtreecommitdiff
blob: cbff03ed8fa7c106afb9d31541cf44c861103416 (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
119
120
121
122
123
124
125
126
# Copyright 1999-2009 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/eclass/elisp.eclass,v 1.41 2009/03/29 20:27:19 ulm Exp $
#
# Copyright 2002-2003 Matthew Kennedy <mkennedy@gentoo.org>
# Copyright 2003      Jeremy Maitin-Shepard <jbms@attbi.com>
# Copyright 2007-2009 Christian Faulhammer <fauli@gentoo.org>
# Copyright 2007-2009 Ulrich Müller <ulm@gentoo.org>
#
# @ECLASS: elisp.eclass
# @MAINTAINER:
# Feel free to contact the Emacs team through <emacs@gentoo.org> if you
# have problems, suggestions or questions.
# @BLURB: Eclass for Emacs Lisp packages
# @DESCRIPTION:
#
# This eclass is designed to install elisp files of Emacs related
# packages into the site-lisp directory. The majority of elisp packages
# will only need to define the standard ebuild variables (like SRC_URI)
# and optionally SITEFILE for successful installation.
#
# Emacs support for other than pure elisp packages is handled by
# elisp-common.eclass where you won't have a dependency on Emacs itself.
# All elisp-* functions are documented there.
#
# If the package's source is a single (in whatever way) compressed elisp
# file with the file name ${P}.el, then this eclass will move ${P}.el to
# ${PN}.el in src_unpack().

# @ECLASS-VARIABLE: NEED_EMACS
# @DESCRIPTION:
# If you need anything different from Emacs 21, use the NEED_EMACS
# variable before inheriting elisp.eclass.  Set it to the major version
# your package uses and the dependency will be adjusted.

# @ECLASS-VARIABLE: DOCS
# @DESCRIPTION:
# DOCS="blah.txt ChangeLog" is automatically used to install the given
# files by dodoc in src_install().

# @ECLASS-VARIABLE: ELISP_PATCHES
# @DESCRIPTION:
# Any patches to apply after unpacking the sources. Patches are searched
# both in ${PWD} and ${FILESDIR}.

# @ECLASS-VARIABLE: SITEFILE
# @DESCRIPTION:
# Name of package's site-init file.  The filename must match the shell
# pattern "[1-8][0-9]*-gentoo.el"; numbers below 10 and above 89 are
# reserved for internal use.  "50${PN}-gentoo.el" is a reasonable choice
# in most cases.

inherit elisp-common eutils versionator

case "${EAPI:-0}" in
	0|1) EXPORT_FUNCTIONS src_{unpack,compile,install} \
		pkg_{setup,postinst,postrm} ;;
	*) EXPORT_FUNCTIONS src_{unpack,prepare,configure,compile,install} \
		pkg_{setup,postinst,postrm} ;;
esac

DEPEND=">=virtual/emacs-${NEED_EMACS:-21}"
RDEPEND="${DEPEND}"
IUSE=""

elisp_pkg_setup() {
	local need_emacs=${NEED_EMACS:-21}
	local have_emacs=$(elisp-emacs-version)
	if ! version_is_at_least "${need_emacs}" "${have_emacs}"; then
		eerror "This package needs at least Emacs ${need_emacs}."
		eerror "Use \"eselect emacs\" to select the active version."
		die "Emacs version ${have_emacs} is too low."
	fi
	einfo "Emacs version: ${have_emacs}"
}

elisp_src_unpack() {
	[ -n "${A}" ] && unpack ${A}
	if [ -f ${P}.el ]; then
		# the "simple elisp" case with a single *.el file in WORKDIR
		mv ${P}.el ${PN}.el || die
		[ -d "${S}" ] || S=${WORKDIR}
	fi

	case "${EAPI:-0}" in
		0|1) [ -d "${S}" ] && cd "${S}"
			elisp_src_prepare ;;
	esac
}

elisp_src_prepare() {
	local patch
	for patch in ${ELISP_PATCHES}; do
		if [ -f "${patch}" ]; then
			epatch "${patch}"
		elif [ -f "${FILESDIR}/${patch}" ]; then
			epatch "${FILESDIR}/${patch}"
		else
			die "Cannot find ${patch}"
		fi
	done
}

elisp_src_configure() { :; }

elisp_src_compile() {
	elisp-compile *.el || die
}

elisp_src_install() {
	elisp-install ${PN} *.el *.elc || die
	if [ -n "${SITEFILE}" ]; then
		elisp-site-file-install "${FILESDIR}/${SITEFILE}" || die
	fi
	if [ -n "${DOCS}" ]; then
		dodoc ${DOCS} || die
	fi
}

elisp_pkg_postinst() {
	elisp-site-regen
}

elisp_pkg_postrm() {
	elisp-site-regen
}