/[gentoo-x86]/eclass/elisp.eclass
Gentoo

Diff of /eclass/elisp.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.51 Revision 1.54
1# Copyright 1999-2011 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.51 2011/08/22 06:56:26 ulm Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/elisp.eclass,v 1.54 2011/12/03 08:54:46 ulm Exp $
4# 4#
5# @ECLASS: elisp.eclass 5# @ECLASS: elisp.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Gentoo Emacs team <emacs@gentoo.org> 7# Gentoo Emacs team <emacs@gentoo.org>
8# @AUTHOR: 8# @AUTHOR:
34# your package uses and the dependency will be adjusted. 34# your package uses and the dependency will be adjusted.
35 35
36# @ECLASS-VARIABLE: ELISP_PATCHES 36# @ECLASS-VARIABLE: ELISP_PATCHES
37# @DEFAULT_UNSET 37# @DEFAULT_UNSET
38# @DESCRIPTION: 38# @DESCRIPTION:
39# Any patches to apply after unpacking the sources. Patch files are 39# Space separated list of patches to apply after unpacking the sources.
40# 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.
41 47
42# @ECLASS-VARIABLE: SITEFILE 48# @ECLASS-VARIABLE: SITEFILE
43# @DEFAULT_UNSET 49# @DEFAULT_UNSET
44# @DESCRIPTION: 50# @DESCRIPTION:
45# 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
86# 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
87# WORKDIR for packages distributed that way. For EAPIs without 93# WORKDIR for packages distributed that way. For EAPIs without
88# src_prepare, call elisp_src_prepare. 94# src_prepare, call elisp_src_prepare.
89 95
90elisp_src_unpack() { 96elisp_src_unpack() {
91 [ -n "${A}" ] && unpack ${A} 97 [[ -n ${A} ]] && unpack ${A}
92 if [ -f ${P}.el ]; then 98 if [[ -f ${P}.el ]]; then
93 # the "simple elisp" case with a single *.el file in WORKDIR 99 # the "simple elisp" case with a single *.el file in WORKDIR
94 mv ${P}.el ${PN}.el || die 100 mv ${P}.el ${PN}.el || die
95 [ -d "${S}" ] || S=${WORKDIR} 101 [[ -d ${S} ]] || S=${WORKDIR}
96 fi 102 fi
97 103
98 case "${EAPI:-0}" in 104 case "${EAPI:-0}" in
99 0|1) [ -d "${S}" ] && cd "${S}" 105 0|1) [[ -d ${S} ]] && cd "${S}"
100 elisp_src_prepare ;; 106 elisp_src_prepare ;;
101 esac 107 esac
102} 108}
103 109
104# @FUNCTION: elisp_src_prepare 110# @FUNCTION: elisp_src_prepare
107# for in the current working dir, WORKDIR, and FILESDIR. 113# for in the current working dir, WORKDIR, and FILESDIR.
108 114
109elisp_src_prepare() { 115elisp_src_prepare() {
110 local patch 116 local patch
111 for patch in ${ELISP_PATCHES}; do 117 for patch in ${ELISP_PATCHES}; do
112 if [ -f "${patch}" ]; then 118 if [[ -f ${patch} ]]; then
113 epatch "${patch}" 119 epatch "${patch}"
114 elif [ -f "${WORKDIR}/${patch}" ]; then 120 elif [[ -f ${WORKDIR}/${patch} ]]; then
115 epatch "${WORKDIR}/${patch}" 121 epatch "${WORKDIR}/${patch}"
116 elif [ -f "${FILESDIR}/${patch}" ]; then 122 elif [[ -f ${FILESDIR}/${patch} ]]; then
117 epatch "${FILESDIR}/${patch}" 123 epatch "${FILESDIR}/${patch}"
118 else 124 else
119 die "Cannot find ${patch}" 125 die "Cannot find ${patch}"
120 fi 126 fi
121 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
122} 135}
123 136
124# @FUNCTION: elisp_src_configure 137# @FUNCTION: elisp_src_configure
125# @DESCRIPTION: 138# @DESCRIPTION:
126# Do nothing, because Emacs packages seldomly bring a full build system. 139# Do nothing, because Emacs packages seldomly bring a full build system.
133# If ELISP_TEXINFO lists any Texinfo sources, call makeinfo to generate 146# If ELISP_TEXINFO lists any Texinfo sources, call makeinfo to generate
134# GNU Info files from them. 147# GNU Info files from them.
135 148
136elisp_src_compile() { 149elisp_src_compile() {
137 elisp-compile *.el || die 150 elisp-compile *.el || die
138 if [ -n "${ELISP_TEXINFO}" ]; then 151 if [[ -n ${ELISP_TEXINFO} ]]; then
139 makeinfo ${ELISP_TEXINFO} || die 152 makeinfo ${ELISP_TEXINFO} || die
140 fi 153 fi
141} 154}
142 155
143# @FUNCTION: elisp_src_install 156# @FUNCTION: elisp_src_install
147# 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
148# ELISP_TEXINFO and documentation listed in the DOCS variable. 161# ELISP_TEXINFO and documentation listed in the DOCS variable.
149 162
150elisp_src_install() { 163elisp_src_install() {
151 elisp-install ${PN} *.el *.elc || die 164 elisp-install ${PN} *.el *.elc || die
152 if [ -n "${SITEFILE}" ]; then 165 if [[ -n ${SITEFILE} ]]; then
153 elisp-site-file-install "${FILESDIR}/${SITEFILE}" || die 166 elisp-site-file-install "${FILESDIR}/${SITEFILE}" || die
154 fi 167 fi
155 if [ -n "${ELISP_TEXINFO}" ]; then 168 if [[ -n ${ELISP_TEXINFO} ]]; then
156 set -- ${ELISP_TEXINFO} 169 set -- ${ELISP_TEXINFO}
157 set -- ${@##*/} 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

Legend:
Removed from v.1.51  
changed lines
  Added in v.1.54

  ViewVC Help
Powered by ViewVC 1.1.20