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

Diff of /eclass/eutils.eclass

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

Revision 1.5 Revision 1.8
1# Copyright 1999-2002 Gentoo Technologies, Inc. 1# Copyright 1999-2002 Gentoo Technologies, Inc.
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# Author: Martin Schlemmer <azarah@gentoo.org> 3# Author: Martin Schlemmer <azarah@gentoo.org>
4# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.5 2002/11/11 22:36:22 azarah Exp $ 4# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.8 2002/12/01 12:34:23 azarah Exp $
5# This eclass is for general purpose functions that most ebuilds 5# This eclass is for general purpose functions that most ebuilds
6# have to implement themselfs. 6# have to implement themselves.
7# 7#
8# NB: If you add anything, please comment it! 8# NB: If you add anything, please comment it!
9 9
10ECLASS=eutils 10ECLASS=eutils
11INHERITED="$INHERITED $ECLASS" 11INHERITED="$INHERITED $ECLASS"
87EPATCH_SOURCE="${WORKDIR}/patch" 87EPATCH_SOURCE="${WORKDIR}/patch"
88# Default extension for patches 88# Default extension for patches
89EPATCH_SUFFIX="patch.bz2" 89EPATCH_SUFFIX="patch.bz2"
90# Default options for patch 90# Default options for patch
91EPATCH_OPTS="" 91EPATCH_OPTS=""
92# List of patches not to apply. Not this is only file names,
93# and not the full path ..
94EPATCH_EXCLUDE=""
92 95
93# This function is for bulk patching, or in theory for just one 96# This function is for bulk patching, or in theory for just one
94# or two patches. 97# or two patches.
95# 98#
96# It should work with .bz2, .gz, .zip and plain text patches. 99# It should work with .bz2, .gz, .zip and plain text patches.
124# <azarah@gentoo.org> (10 Nov 2002) 127# <azarah@gentoo.org> (10 Nov 2002)
125# 128#
126epatch() { 129epatch() {
127 local PIPE_CMD="" 130 local PIPE_CMD=""
128 local STDERR_TARGET="${T}/$$.out" 131 local STDERR_TARGET="${T}/$$.out"
132 local PATCH_TARGET="${T}/$$.patch"
133 local PATCH_SUFFIX=""
129 local SINGLE_PATCH="no" 134 local SINGLE_PATCH="no"
130 local x="" 135 local x=""
131 136
132 if [ "$#" -gt 1 ] 137 if [ "$#" -gt 1 ]
133 then 138 then
144 149
145 elif [ -n "$1" -a -d "$1" ] 150 elif [ -n "$1" -a -d "$1" ]
146 then 151 then
147 local EPATCH_SOURCE="$1/*.${EPATCH_SUFFIX}" 152 local EPATCH_SOURCE="$1/*.${EPATCH_SUFFIX}"
148 else 153 else
154 if [ ! -d ${EPATCH_SOURCE} ]
155 then
156 echo
157 eerror "Cannot find \$EPATCH_SOURCE!"
158 echo
159 die "Cannot find \$EPATCH_SOURCE!"
160 fi
161
149 local EPATCH_SOURCE="${EPATCH_SOURCE}/*.${EPATCH_SUFFIX}" 162 local EPATCH_SOURCE="${EPATCH_SOURCE}/*.${EPATCH_SUFFIX}"
150 fi 163 fi
151 164
152 case ${EPATCH_SUFFIX##*\.} in 165 case ${EPATCH_SUFFIX##*\.} in
153 bz2) 166 bz2)
154 PIPE_CMD="bzip2 -dc" 167 PIPE_CMD="bzip2 -dc"
168 PATCH_SUFFIX="bz2"
155 ;; 169 ;;
156 gz) 170 gz|Z|z)
157 PIPE_CMD="gzip -dc" 171 PIPE_CMD="gzip -dc"
172 PATCH_SUFFIX="gz"
158 ;; 173 ;;
159 zip) 174 ZIP|zip)
160 PIPE_CMD="unzip -p" 175 PIPE_CMD="unzip -p"
176 PATCH_SUFFIX="zip"
161 ;; 177 ;;
162 *) 178 *)
163 PIPE_CMD="cat" 179 PIPE_CMD="cat"
180 PATCH_SUFFIX="patch"
164 ;; 181 ;;
165 esac 182 esac
166 183
167 if [ "${SINGLE_PATCH}" = "no" ] 184 if [ "${SINGLE_PATCH}" = "no" ]
168 then 185 then
177 if [ -f ${x} ] && \ 194 if [ -f ${x} ] && \
178 [ -n "$1" -o "${x/_all_}" != "${x}" -o "`eval echo \$\{x/_${ARCH}_\}`" != "${x}" ] 195 [ -n "$1" -o "${x/_all_}" != "${x}" -o "`eval echo \$\{x/_${ARCH}_\}`" != "${x}" ]
179 then 196 then
180 local count=0 197 local count=0
181 local popts="${EPATCH_OPTS}" 198 local popts="${EPATCH_OPTS}"
199
200 if [ -n "${EPATCH_EXCLUDE}" ]
201 then
202 if [ "${EPATCH_EXCLUDE/${x##*/}}" != "${EPATCH_EXCLUDE}" ]
203 then
204 continue
205 fi
206 fi
182 207
183 if [ "${SINGLE_PATCH}" = "yes" ] 208 if [ "${SINGLE_PATCH}" = "yes" ]
184 then 209 then
185 einfo "Applying ${x##*/}..." 210 einfo "Applying ${x##*/}..."
186 else 211 else
187 einfo " ${x##*/}..." 212 einfo " ${x##*/}..."
188 fi 213 fi
189 214
190 echo "***** ${x##*/} *****" > ${STDERR_TARGET} 215 echo "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
191 echo >> ${STDERR_TARGET} 216 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
192 217
193 # Allow for prefix to differ ... im lazy, so shoot me :/ 218 # Allow for prefix to differ ... im lazy, so shoot me :/
194 while [ "${count}" -lt 5 ] 219 while [ "${count}" -lt 5 ]
195 do 220 do
196 # Generate some useful debug info ... 221 # Generate some useful debug info ...
197 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET} 222 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
198 echo >> ${STDERR_TARGET} 223 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
224
225 if [ "${PATCH_SUFFIX}" != "patch" ]
226 then
227 echo -n "PIPE_COMMAND: " >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
228 echo "${PIPE_CMD} ${x} > ${PATCH_TARGET}" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
229 else
230 PATCH_TARGET="${x}"
231 fi
199 232
200 echo -n "PATCH COMMAND: " >> ${STDERR_TARGET} 233 echo -n "PATCH COMMAND: " >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
201 echo "${PIPE_CMD} ${x} | patch ${popts} -p${count}" >> ${STDERR_TARGET} 234 echo "patch ${popts} -p${count} < ${PATCH_TARGET}" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
202 235
203 echo >> ${STDERR_TARGET} 236 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
204 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET} 237 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
238
239 if [ "${PATCH_SUFFIX}" != "patch" ]
240 then
241 if ! (${PIPE_CMD} ${x} > ${PATCH_TARGET}) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1
242 then
243 echo
244 eerror "Could not extract patch!"
245 #die "Could not extract patch!"
246 count=5
247 break
248 fi
249 fi
205 250
206 if eval ${PIPE_CMD} ${x} | patch ${popts} --dry-run -f -p${count} 2>&1 >> ${STDERR_TARGET} 251 if patch ${popts} --dry-run -f -p${count} < ${PATCH_TARGET} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1
207 then 252 then
208 eval ${PIPE_CMD} ${x} | patch ${popts} -p${count} 2>&1 >> ${STDERR_TARGET} 253 draw_line "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
254 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
255 echo "ACTUALLY APPLYING ${x##*/}..." >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
256 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
257 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
258
259 patch ${popts} -p${count} < ${PATCH_TARGET} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 2>&1
260
261 if [ "$?" -ne 0 ]
262 then
263 cat ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
264 echo
265 eerror "A dry-run of patch command succeeded, but actually"
266 eerror "applying the patch failed!"
267 #die "Real world sux compared to the dreamworld!"
268 count=5
269 fi
270
271 rm -f ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
272
209 break 273 break
210 fi 274 fi
211 275
212 count=$((count + 1)) 276 count=$((count + 1))
213 done 277 done
214 278
279 if [ "${PATCH_SUFFIX}" != "patch" ]
280 then
281 rm -f ${PATCH_TARGET}
282 fi
283
215 if [ "${count}" -eq 5 ] 284 if [ "${count}" -eq 5 ]
216 then 285 then
286 echo
217 eerror "Failed Patch: ${x##*/}!" 287 eerror "Failed Patch: ${x##*/}!"
218 eerror 288 eerror
219 eerror "Include in your bugreport the contents of:" 289 eerror "Include in your bugreport the contents of:"
220 eerror 290 eerror
221 eerror " ${STDERR_TARGET}" 291 eerror " ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}"
222 eerror 292 echo
223 die "Failed Patch: ${x##*/}!" 293 die "Failed Patch: ${x##*/}!"
224 fi 294 fi
295
296 rm -f ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
225 297
226 eend 0 298 eend 0
227 fi 299 fi
228 done 300 done
229 if [ "${SINGLE_PATCH}" = "no" ] 301 if [ "${SINGLE_PATCH}" = "no" ]

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.8

  ViewVC Help
Powered by ViewVC 1.1.20