| 1 | # Copyright 1999-2010 Gentoo Foundation |
1 | # Copyright 1999-2011 Gentoo Foundation |
| 2 | # Distributed under the terms of the GNU General Public License v2 |
2 | # Distributed under the terms of the GNU General Public License v2 |
| 3 | # $Header: /var/cvsroot/gentoo-x86/eclass/elisp.eclass,v 1.47 2010/11/23 20:56:08 ulm Exp $ |
3 | # $Header: /var/cvsroot/gentoo-x86/eclass/elisp.eclass,v 1.54 2011/12/03 08:54:46 ulm Exp $ |
| 4 | # |
|
|
| 5 | # Copyright 2002-2003 Matthew Kennedy <mkennedy@gentoo.org> |
|
|
| 6 | # Copyright 2003 Jeremy Maitin-Shepard <jbms@attbi.com> |
|
|
| 7 | # Copyright 2007-2010 Christian Faulhammer <fauli@gentoo.org> |
|
|
| 8 | # Copyright 2007-2010 Ulrich Müller <ulm@gentoo.org> |
|
|
| 9 | # |
4 | # |
| 10 | # @ECLASS: elisp.eclass |
5 | # @ECLASS: elisp.eclass |
| 11 | # @MAINTAINER: |
6 | # @MAINTAINER: |
| 12 | # Feel free to contact the Emacs team through <emacs@gentoo.org> if you |
7 | # Gentoo Emacs team <emacs@gentoo.org> |
| 13 | # have problems, suggestions or questions. |
8 | # @AUTHOR: |
|
|
9 | # Matthew Kennedy <mkennedy@gentoo.org> |
|
|
10 | # Jeremy Maitin-Shepard <jbms@attbi.com> |
|
|
11 | # Christian Faulhammer <fauli@gentoo.org> |
|
|
12 | # Ulrich Müller <ulm@gentoo.org> |
| 14 | # @BLURB: Eclass for Emacs Lisp packages |
13 | # @BLURB: Eclass for Emacs Lisp packages |
| 15 | # @DESCRIPTION: |
14 | # @DESCRIPTION: |
| 16 | # |
15 | # |
| 17 | # This eclass is designed to install elisp files of Emacs related |
16 | # This eclass is designed to install elisp files of Emacs related |
| 18 | # packages into the site-lisp directory. The majority of elisp packages |
17 | # packages into the site-lisp directory. The majority of elisp packages |
| … | |
… | |
| 35 | # your package uses and the dependency will be adjusted. |
34 | # your package uses and the dependency will be adjusted. |
| 36 | |
35 | |
| 37 | # @ECLASS-VARIABLE: ELISP_PATCHES |
36 | # @ECLASS-VARIABLE: ELISP_PATCHES |
| 38 | # @DEFAULT_UNSET |
37 | # @DEFAULT_UNSET |
| 39 | # @DESCRIPTION: |
38 | # @DESCRIPTION: |
| 40 | # Any patches to apply after unpacking the sources. Patch files are |
39 | # Space separated list of patches to apply after unpacking the sources. |
| 41 | # searched for in the current working dir, WORKDIR, and FILESDIR. |
40 | # Patch files are searched for in the current working dir, WORKDIR, and |
|
|
41 | # FILESDIR. |
|
|
42 | |
|
|
43 | # @ECLASS-VARIABLE: ELISP_REMOVE |
|
|
44 | # @DEFAULT_UNSET |
|
|
45 | # @DESCRIPTION: |
|
|
46 | # Space separated list of files to remove after unpacking the sources. |
| 42 | |
47 | |
| 43 | # @ECLASS-VARIABLE: SITEFILE |
48 | # @ECLASS-VARIABLE: SITEFILE |
| 44 | # @DEFAULT_UNSET |
49 | # @DEFAULT_UNSET |
| 45 | # @DESCRIPTION: |
50 | # @DESCRIPTION: |
| 46 | # Name of package's site-init file. The filename must match the shell |
51 | # Name of package's site-init file. The filename must match the shell |
| … | |
… | |
| 87 | # Unpack the sources; also handle the case of a single *.el file in |
92 | # Unpack the sources; also handle the case of a single *.el file in |
| 88 | # WORKDIR for packages distributed that way. For EAPIs without |
93 | # WORKDIR for packages distributed that way. For EAPIs without |
| 89 | # src_prepare, call elisp_src_prepare. |
94 | # src_prepare, call elisp_src_prepare. |
| 90 | |
95 | |
| 91 | elisp_src_unpack() { |
96 | elisp_src_unpack() { |
| 92 | [ -n "${A}" ] && unpack ${A} |
97 | [[ -n ${A} ]] && unpack ${A} |
| 93 | if [ -f ${P}.el ]; then |
98 | if [[ -f ${P}.el ]]; then |
| 94 | # the "simple elisp" case with a single *.el file in WORKDIR |
99 | # the "simple elisp" case with a single *.el file in WORKDIR |
| 95 | mv ${P}.el ${PN}.el || die |
100 | mv ${P}.el ${PN}.el || die |
| 96 | [ -d "${S}" ] || S=${WORKDIR} |
101 | [[ -d ${S} ]] || S=${WORKDIR} |
| 97 | fi |
102 | fi |
| 98 | |
103 | |
| 99 | case "${EAPI:-0}" in |
104 | case "${EAPI:-0}" in |
| 100 | 0|1) [ -d "${S}" ] && cd "${S}" |
105 | 0|1) [[ -d ${S} ]] && cd "${S}" |
| 101 | elisp_src_prepare ;; |
106 | elisp_src_prepare ;; |
| 102 | esac |
107 | esac |
| 103 | } |
108 | } |
| 104 | |
109 | |
| 105 | # @FUNCTION: elisp_src_prepare |
110 | # @FUNCTION: elisp_src_prepare |
| … | |
… | |
| 108 | # for in the current working dir, WORKDIR, and FILESDIR. |
113 | # for in the current working dir, WORKDIR, and FILESDIR. |
| 109 | |
114 | |
| 110 | elisp_src_prepare() { |
115 | elisp_src_prepare() { |
| 111 | local patch |
116 | local patch |
| 112 | for patch in ${ELISP_PATCHES}; do |
117 | for patch in ${ELISP_PATCHES}; do |
| 113 | if [ -f "${patch}" ]; then |
118 | if [[ -f ${patch} ]]; then |
| 114 | epatch "${patch}" |
119 | epatch "${patch}" |
| 115 | elif [ -f "${WORKDIR}/${patch}" ]; then |
120 | elif [[ -f ${WORKDIR}/${patch} ]]; then |
| 116 | epatch "${WORKDIR}/${patch}" |
121 | epatch "${WORKDIR}/${patch}" |
| 117 | elif [ -f "${FILESDIR}/${patch}" ]; then |
122 | elif [[ -f ${FILESDIR}/${patch} ]]; then |
| 118 | epatch "${FILESDIR}/${patch}" |
123 | epatch "${FILESDIR}/${patch}" |
| 119 | else |
124 | else |
| 120 | die "Cannot find ${patch}" |
125 | die "Cannot find ${patch}" |
| 121 | fi |
126 | fi |
| 122 | done |
127 | done |
|
|
128 | |
|
|
129 | # apply any user patches |
|
|
130 | epatch_user |
|
|
131 | |
|
|
132 | if [[ -n ${ELISP_REMOVE} ]]; then |
|
|
133 | rm ${ELISP_REMOVE} || die |
|
|
134 | fi |
| 123 | } |
135 | } |
| 124 | |
136 | |
| 125 | # @FUNCTION: elisp_src_configure |
137 | # @FUNCTION: elisp_src_configure |
| 126 | # @DESCRIPTION: |
138 | # @DESCRIPTION: |
| 127 | # Do nothing, because Emacs packages seldomly bring a full build system. |
139 | # Do nothing, because Emacs packages seldomly bring a full build system. |
| … | |
… | |
| 130 | |
142 | |
| 131 | # @FUNCTION: elisp_src_compile |
143 | # @FUNCTION: elisp_src_compile |
| 132 | # @DESCRIPTION: |
144 | # @DESCRIPTION: |
| 133 | # Call elisp-compile to byte-compile all Emacs Lisp (*.el) files. |
145 | # Call elisp-compile to byte-compile all Emacs Lisp (*.el) files. |
| 134 | # If ELISP_TEXINFO lists any Texinfo sources, call makeinfo to generate |
146 | # If ELISP_TEXINFO lists any Texinfo sources, call makeinfo to generate |
| 135 | # GNU Info files from then. |
147 | # GNU Info files from them. |
| 136 | |
148 | |
| 137 | elisp_src_compile() { |
149 | elisp_src_compile() { |
| 138 | elisp-compile *.el || die |
150 | elisp-compile *.el || die |
| 139 | if [ -n "${ELISP_TEXINFO}" ]; then |
151 | if [[ -n ${ELISP_TEXINFO} ]]; then |
| 140 | makeinfo ${ELISP_TEXINFO} || die |
152 | makeinfo ${ELISP_TEXINFO} || die |
| 141 | fi |
153 | fi |
| 142 | } |
154 | } |
| 143 | |
155 | |
| 144 | # @FUNCTION: elisp_src_install |
156 | # @FUNCTION: elisp_src_install |
| … | |
… | |
| 148 | # elisp-site-file-install. Also install any GNU Info files listed in |
160 | # elisp-site-file-install. Also install any GNU Info files listed in |
| 149 | # ELISP_TEXINFO and documentation listed in the DOCS variable. |
161 | # ELISP_TEXINFO and documentation listed in the DOCS variable. |
| 150 | |
162 | |
| 151 | elisp_src_install() { |
163 | elisp_src_install() { |
| 152 | elisp-install ${PN} *.el *.elc || die |
164 | elisp-install ${PN} *.el *.elc || die |
| 153 | if [ -n "${SITEFILE}" ]; then |
165 | if [[ -n ${SITEFILE} ]]; then |
| 154 | elisp-site-file-install "${FILESDIR}/${SITEFILE}" || die |
166 | elisp-site-file-install "${FILESDIR}/${SITEFILE}" || die |
| 155 | fi |
167 | fi |
| 156 | if [ -n "${ELISP_TEXINFO}" ]; then |
168 | if [[ -n ${ELISP_TEXINFO} ]]; then |
| 157 | set -- ${ELISP_TEXINFO} |
169 | set -- ${ELISP_TEXINFO} |
|
|
170 | set -- ${@##*/} |
| 158 | doinfo ${@/%.*/.info*} || die |
171 | doinfo ${@/%.*/.info*} || die |
| 159 | fi |
172 | fi |
| 160 | if [ -n "${DOCS}" ]; then |
173 | if [[ -n ${DOCS} ]]; then |
| 161 | dodoc ${DOCS} || die |
174 | dodoc ${DOCS} || die |
| 162 | fi |
175 | fi |
| 163 | } |
176 | } |
| 164 | |
177 | |
| 165 | # @FUNCTION: elisp_pkg_postinst |
178 | # @FUNCTION: elisp_pkg_postinst |