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

Diff of /eclass/libtool.eclass

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

Revision 1.55 Revision 1.62
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2005 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/libtool.eclass,v 1.55 2005/09/04 18:40:48 flameeyes Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/libtool.eclass,v 1.62 2005/12/07 22:50:05 azarah Exp $
4# 4#
5# Author: Martin Schlemmer <azarah@gentoo.org> 5# Author: Martin Schlemmer <azarah@gentoo.org>
6# 6#
7# This eclass patches ltmain.sh distributed with libtoolized packages with the 7# This eclass patches ltmain.sh distributed with libtoolized packages with the
8# relink and portage patch among others 8# relink and portage patch among others
41# 41#
42# See if we can apply $2 on $1, and if so, do it 42# See if we can apply $2 on $1, and if so, do it
43# 43#
44ELT_try_and_apply_patch() { 44ELT_try_and_apply_patch() {
45 local ret=0 45 local ret=0
46 local file=$1
46 local patch="$2" 47 local patch=$2
47 48
48 # We only support patchlevel of 0 - why worry if its static patches? 49 # We only support patchlevel of 0 - why worry if its static patches?
49 if patch -p0 --dry-run $1 < ${patch} &> ${T}/elibtool.log ; then 50 if patch -p0 --dry-run "${file}" "${patch}" &> "${T}/elibtool.log" ; then
50 einfo " Applying $(basename "$(dirname "${patch}")")-${patch##*/}.patch ..." 51 einfo " Applying $(basename "$(dirname "${patch}")")-${patch##*/}.patch ..."
51 patch -p0 $1 < ${patch} &>${T}/elibtool.log 52 patch -p0 -g0 --no-backup-if-mismatch "${file}" "${patch}" \
53 &> "${T}/elibtool.log"
52 ret=$? 54 ret=$?
53 export ELT_APPLIED_PATCHES="${ELT_APPLIED_PATCHES} ${patch##*/}" 55 export ELT_APPLIED_PATCHES="${ELT_APPLIED_PATCHES} ${patch##*/}"
54 else 56 else
55 ret=1 57 ret=1
56 fi 58 fi
57 59
58 return ${ret} 60 return "${ret}"
61}
62
63#
64# Get string version of ltmain.sh or ltconfig (passed as $1)
65#
66ELT_libtool_version() {
67 local ltmain_sh=$1
68 local version=
69
70 version=$(eval $(grep -e '^[[:space:]]*VERSION=' "${ltmain_sh}"); \
71 echo "${VERSION}")
72 [[ -z ${version} ]] && version="0"
73
74 echo "${version}"
59} 75}
60 76
61# 77#
62# Run through the patches in $2 and see if any 78# Run through the patches in $2 and see if any
63# apply to $1 ... 79# apply to $1 ...
64# 80#
65ELT_walk_patches() { 81ELT_walk_patches() {
66 local x= 82 local x=
67 local y= 83 local y=
68 local ret=1 84 local ret=1
85 local file=$1
86 local patch_set=$2
69 local patch_dir= 87 local patch_dir=
88 local rem_int_dep=$3
70 local version= 89 local version=
71 local ltmain_sh=$1 90 local ltmain_sh=$1
72 91
73 [[ $1 == *"/configure" ]] && ltmain_sh=${ELT_LTMAIN_SH} 92 [[ ${file} == *"/configure" ]] && ltmain_sh=${ELT_LTMAIN_SH}
74 version=$(eval $(grep -e '^[[:space:]]*VERSION=' "${ltmain_sh}"); \ 93 version=$(ELT_libtool_version "${ltmain_sh}")
75 echo "${VERSION}")
76 94
77 if [[ -n $2 ]] ; then 95 if [[ -n ${patch_set} ]] ; then
78 if [[ -d ${ELT_PATCH_DIR}/$2 ]] ; then 96 if [[ -d ${ELT_PATCH_DIR}/${patch_set} ]] ; then
79 patch_dir="${ELT_PATCH_DIR}/$2" 97 patch_dir="${ELT_PATCH_DIR}/${patch_set}"
80 else 98 else
81 return ${ret} 99 return "${ret}"
82 fi 100 fi
83 101
84 if [[ -z ${version} ]] ; then 102 if [[ ${version} == "0" ]] ; then
85 eerror "Could not get VERSION for ${1##*/}!" 103 eerror "Could not get VERSION for ${file##*/}!"
86 die "Could not get VERSION for ${1##*/}!" 104 die "Could not get VERSION for ${file##*/}!"
87 fi 105 fi
88 106
89 # Go through the patches in reverse order (large to small) 107 # Go through the patches in reverse order (large to small)
90 for x in $(ls -d "${patch_dir}"/* 2> /dev/null | sort -r) ; do 108 for x in $(ls -d "${patch_dir}"/* 2> /dev/null | grep -v 'CVS' | sort -r) ; do
91 if [[ -n ${x} && -f ${x} ]] ; then 109 if [[ -n ${x} && -f ${x} ]] ; then
92 local ltver=$(VER_to_int "${version}") 110 local ltver=$(VER_to_int "${version}")
93 local ptver=$(VER_to_int "${x##*/}") 111 local ptver=$(VER_to_int "${x##*/}")
94 112
95 # If libtool version smaller than patch version, skip patch. 113 # If libtool version smaller than patch version, skip patch.
96 [[ ${ltver} -lt ${ptver} ]] && continue 114 [[ ${ltver} -lt ${ptver} ]] && continue
97 # For --remove-internal-dep ... 115 # For --remove-internal-dep ...
98 if [[ -n $3 ]] ; then 116 if [[ -n ${rem_int_dep} ]] ; then
99 # For replace @REM_INT_DEP@ with what was passed 117 # For replace @REM_INT_DEP@ with what was passed
100 # to --remove-internal-dep 118 # to --remove-internal-dep
101 sed -e "s|@REM_INT_DEP@|$3|g" ${x} > \ 119 sed -e "s|@REM_INT_DEP@|${rem_int_dep}|g" ${x} > \
102 ${T}/$$.rem_int_deps.patch 120 "${T}/$$.rem_int_deps.patch"
103 121
104 x="${T}/$$.rem_int_deps.patch" 122 x="${T}/$$.rem_int_deps.patch"
105 fi 123 fi
106 124
107 if ELT_try_and_apply_patch "$1" "${x}" ; then 125 if ELT_try_and_apply_patch "${file}" "${x}" ; then
108 ret=0 126 ret=0
109 break 127 break
110 fi 128 fi
111 fi 129 fi
112 done 130 done
113 fi 131 fi
114 132
115 return ${ret} 133 return "${ret}"
116} 134}
117 135
118elibtoolize() { 136elibtoolize() {
119 local x= 137 local x=
120 local y= 138 local y=
121 local do_portage="no" 139 local do_portage="no"
122 local do_reversedeps="no" 140 local do_reversedeps="no"
123 local do_only_patches="no" 141 local do_only_patches="no"
142 local do_uclibc="yes"
124 local deptoremove= 143 local deptoremove=
125 local my_dirlist= 144 local my_dirlist=
126 local elt_patches="portage relink max_cmd_len sed test tmp \ 145 local elt_patches="portage relink max_cmd_len sed test tmp"
127 uclibc-conf uclibc-ltconf"
128 local start_dir="${PWD}" 146 local start_dir=${PWD}
129 147
130 my_dirlist="$(ELT_find_ltmain_sh)" 148 my_dirlist=$(ELT_find_ltmain_sh)
131
132 [[ ${CHOST} == *"-freebsd"* ]] && \
133 elt_patches="${elt_patches} fbsd-conf"
134 149
135 for x in "$@" ; do 150 for x in "$@" ; do
136 case "${x}" in 151 case "${x}" in
137 "--portage") 152 "--portage")
138 # Only apply portage patch, and don't 153 # Only apply portage patch, and don't
150 do_only_patches="yes" 165 do_only_patches="yes"
151 ;; 166 ;;
152 "^--remove-internal-dep="*) 167 "^--remove-internal-dep="*)
153 # We will replace @REM_INT_DEP@ with what is needed 168 # We will replace @REM_INT_DEP@ with what is needed
154 # in ELT_walk_patches() ... 169 # in ELT_walk_patches() ...
155 deptoremove="$(echo "${x}" | sed -e 's|--remove-internal-dep=||')" 170 deptoremove=$(echo "${x}" | sed -e 's|--remove-internal-dep=||')
156 171
157 # Add the patch for this ... 172 # Add the patch for this ...
158 [ -n "${deptoremove}" ] && elt_patches="${elt_patches} rem-int-dep" 173 [[ -n ${deptoremove} ]] && elt_patches="${elt_patches} rem-int-dep"
159 ;; 174 ;;
160 "--shallow") 175 "--shallow")
161 # Only patch the ltmain.sh in ${S} 176 # Only patch the ltmain.sh in ${S}
162 if [ -f "${S}/ltmain.sh" ] 177 if [[ -f ${S}/ltmain.sh ]] ; then
163 then
164 my_dirlist="${S}" 178 my_dirlist=${S}
165 else 179 else
166 my_dirlist= 180 my_dirlist=
167 fi 181 fi
168 ;; 182 ;;
169 "--no-uclibc") 183 "--no-uclibc")
170 NO_UCLIBCTOOLIZE=1 184 do_uclibc="no"
171 ;; 185 ;;
172 *) 186 *)
173 eerror "Invalid elibtoolize option: $x" 187 eerror "Invalid elibtoolize option: ${x}"
174 die "elibtoolize called with $x ??" 188 die "elibtoolize called with ${x} ??"
175 esac 189 esac
176 done 190 done
177 191
192 [[ ${do_uclibc} == "yes" ]] && \
193 elt_patches="${elt_patches} uclibc-conf uclibc-ltconf"
194
195 [[ ${CHOST} == *"-freebsd"* ]] && \
196 elt_patches="${elt_patches} fbsd-conf"
197
178 if use ppc-macos ; then 198 if useq ppc-macos ; then
179 local opts 199 local opts
180 [[ -f Makefile.am ]] && opts="--automake" 200 [[ -f Makefile.am ]] && opts="--automake"
181 glibtoolize --copy --force ${opts} 201 glibtoolize --copy --force ${opts}
182 darwintoolize 202
203 elt_patches="${elt_patches} darwin-ltconf darwin-ltmain"
183 fi 204 fi
184 205
185 for x in ${my_dirlist} ; do 206 for x in ${my_dirlist} ; do
186 local tmp=$(echo "${x}" | sed -e "s|${WORKDIR}||") 207 local tmp=$(echo "${x}" | sed -e "s|${WORKDIR}||")
187 export ELT_APPLIED_PATCHES= 208 export ELT_APPLIED_PATCHES=
213 ELT_walk_patches "${x}/ltmain.sh" "${y}" 234 ELT_walk_patches "${x}/ltmain.sh" "${y}"
214 ret=$? 235 ret=$?
215 fi 236 fi
216 ;; 237 ;;
217 "uclibc-conf") 238 "uclibc-conf")
218 if [[ -e ${x}/configure ]] && \ 239 if [[ -e ${x}/configure && \
219 grep 'Transform linux' "${x}/configure" > /dev/null ; then 240 -n $(grep 'Transform linux' "${x}/configure") ]] ; then
220 ELT_walk_patches "${x}/configure" "${y}" 241 ELT_walk_patches "${x}/configure" "${y}"
221 ret=$? 242 ret=$?
222 # ltmain.sh and co might be in a subdirectory ... 243 # ltmain.sh and co might be in a subdirectory ...
223 elif [[ ! -e ${x}/configure && -e ${x}/../configure ]] && \ 244 elif [[ ! -e ${x}/configure && -e ${x}/../configure && \
224 grep 'Transform linux' "${x}/../configure" > /dev/null ; then 245 -n $(grep 'Transform linux' "${x}/../configure") ]] ; then
225 ELT_walk_patches "${x}/../configure" "${y}" 246 ELT_walk_patches "${x}/../configure" "${y}"
226 ret=$? 247 ret=$?
227 fi 248 fi
228 ;; 249 ;;
229 "uclibc-ltconf") 250 "uclibc-ltconf")
251 # Newer libtoolize clears ltconfig, as not used anymore
230 if [[ -e ${x}/ltconfig ]] ; then 252 if [[ -s ${x}/ltconfig ]] ; then
231 ELT_walk_patches "${x}/ltconfig" "${y}" 253 ELT_walk_patches "${x}/ltconfig" "${y}"
232 ret=$? 254 ret=$?
233 fi 255 fi
234 ;; 256 ;;
235 "fbsd-conf") 257 "fbsd-conf")
236 if [[ -e ${x}/configure ]] && \ 258 if [[ -e ${x}/configure && \
237 grep 'version_type=freebsd-' "${x}/configure" > /dev/null ; then 259 -n $(grep 'version_type=freebsd-' "${x}/configure") ]] ; then
238 ELT_walk_patches "${x}/configure" "${y}" 260 ELT_walk_patches "${x}/configure" "${y}"
239 ret=$? 261 ret=$?
240 # ltmain.sh and co might be in a subdirectory ... 262 # ltmain.sh and co might be in a subdirectory ...
241 elif [[ ! -e ${x}/configure && -e ${x}/../configure ]] && \ 263 elif [[ ! -e ${x}/configure && -e ${x}/../configure && \
242 grep 'version_type=freebsd-' "${x}/../configure" > /dev/null ; then 264 -n $(grep 'version_type=freebsd-' "${x}/../configure") ]] ; then
243 ELT_walk_patches "${x}/../configure" "${y}" 265 ELT_walk_patches "${x}/../configure" "${y}"
266 ret=$?
267 fi
268 ;;
269 "darwin-ltconf")
270 # Newer libtoolize clears ltconfig, as not used anymore
271 if [[ -s ${x}/ltconfig ]] ; then
272 ELT_walk_patches "${x}/ltconfig" "${y}"
244 ret=$? 273 ret=$?
245 fi 274 fi
246 ;; 275 ;;
247 *) 276 *)
248 ELT_walk_patches "${x}/ltmain.sh" "${y}" 277 ELT_walk_patches "${x}/ltmain.sh" "${y}"
251 esac 280 esac
252 281
253 if [[ ${ret} -ne 0 ]] ; then 282 if [[ ${ret} -ne 0 ]] ; then
254 case ${y} in 283 case ${y} in
255 "relink") 284 "relink")
285 local version=$(ELT_libtool_version "${x}/ltmain.sh")
256 # Critical patch, but could be applied ... 286 # Critical patch, but could be applied ...
287 # FIXME: Still need a patch for ltmain.sh > 1.4.0
257 if [[ -z $(grep 'inst_prefix_dir' "${x}/ltmain.sh") ]] ; then 288 if [[ -z $(grep 'inst_prefix_dir' "${x}/ltmain.sh") && \
289 $(VER_to_int "${version}") -ge $(VER_to_int "1.4.0") ]] ; then
258 ewarn " Could not apply relink.patch!" 290 ewarn " Could not apply relink.patch!"
259 fi 291 fi
260 ;; 292 ;;
261 "portage") 293 "portage")
262 # Critical patch - for this one we abort, as it can really 294 # Critical patch - for this one we abort, as it can really
289 "uclibc-"*) 321 "uclibc-"*)
290 [[ ${CHOST} == *"-uclibc" ]] && \ 322 [[ ${CHOST} == *"-uclibc" ]] && \
291 ewarn " uClibc patch set '${y}' failed to apply!" 323 ewarn " uClibc patch set '${y}' failed to apply!"
292 ;; 324 ;;
293 "fbsd-"*) 325 "fbsd-"*)
294 [[ ${CHOST} == *"-freebsd"* ]] && \ 326 if [[ ${CHOST} == *"-freebsd"* ]] ; then
327 if [[ -z $(grep 'Handle Gentoo/FreeBSD as it was Linux' "${x}/configure") ]]; then
295 eerror " FreeBSD patch set '${y}' failed to apply!" 328 eerror " FreeBSD patch set '${y}' failed to apply!"
296 die "FreeBSD patch set '${y}' failed to apply!" 329 die "FreeBSD patch set '${y}' failed to apply!"
330 fi
331 fi
332 ;;
333 "darwin-"*)
334 useq ppc-macos && \
335 ewarn " Darwin patch set '${y}' failed to apply!"
297 ;; 336 ;;
298 esac 337 esac
299 fi 338 fi
300 done 339 done
301 340
331 370
332 cd "${start_dir}" 371 cd "${start_dir}"
333} 372}
334 373
335uclibctoolize() { 374uclibctoolize() {
336 ewarn "uclibctoolize() is depreciated, please just use libtoolize()!" 375 ewarn "uclibctoolize() is depreciated, please just use elibtoolize()!"
337 elibtoolize 376 elibtoolize
338} 377}
339 378
340darwintoolize() { 379darwintoolize() {
341 local targets="" 380 ewarn "darwintoolize() is depreciated, please just use elibtoolize()!"
342 local x 381 elibtoolize
343
344 if [[ -z $* ]] ; then
345 targets=$(find ${S} -name ltmain.sh -o -name ltconfig)
346 fi
347
348 einfo "Applying Darwin/libtool patches ..."
349 for x in ${targets} ; do
350 [[ ! -s ${x} ]] && continue
351 case ${x##*/} in
352 ltmain.sh|ltconfig)
353 local ver=$(grep '^VERSION=' ${x})
354 ver=${ver/VERSION=}
355 if [[ ${ver:0:3} == "1.4" || ${ver:0:3} == "1.5" ]] ; then
356 ver="1.3" # 1.4, 1.5 and 1.3 are compat
357 fi
358
359 ebegin " Fixing \${S}${x/${S}}"
360 patch -p0 "${x}" "${ELT_PATCH_DIR}/darwin/${x##*/}-${ver:0:3}.patch" > /dev/null
361 eend $? "PLEASE CHECK ${x}"
362 ;;
363 esac
364 done
365} 382}
366 383
367# char *VER_major(string) 384# char *VER_major(string)
368# 385#
369# Return the Major (X of X.Y.Z) version 386# Return the Major (X of X.Y.Z) version
370# 387#
371VER_major() { 388VER_major() {
372 [[ -z $1 ]] && return 1 389 [[ -z $1 ]] && return 1
373 390
374 local VER=$@ 391 local VER=$@
375 echo ${VER%%[^[:digit:]]*} 392 echo "${VER%%[^[:digit:]]*}"
376} 393}
377 394
378# char *VER_minor(string) 395# char *VER_minor(string)
379# 396#
380# Return the Minor (Y of X.Y.Z) version 397# Return the Minor (Y of X.Y.Z) version
382VER_minor() { 399VER_minor() {
383 [[ -z $1 ]] && return 1 400 [[ -z $1 ]] && return 1
384 401
385 local VER=$@ 402 local VER=$@
386 VER=${VER#*.} 403 VER=${VER#*.}
387 echo ${VER%%[^[:digit:]]*} 404 echo "${VER%%[^[:digit:]]*}"
388} 405}
389 406
390# char *VER_micro(string) 407# char *VER_micro(string)
391# 408#
392# Return the Micro (Z of X.Y.Z) version. 409# Return the Micro (Z of X.Y.Z) version.
394VER_micro() { 411VER_micro() {
395 [[ -z $1 ]] && return 1 412 [[ -z $1 ]] && return 1
396 413
397 local VER=$@ 414 local VER=$@
398 VER=${VER#*.*.} 415 VER=${VER#*.*.}
399 echo ${VER%%[^[:digit:]]*} 416 echo "${VER%%[^[:digit:]]*}"
400} 417}
401 418
402# int VER_to_int(string) 419# int VER_to_int(string)
403# 420#
404# Convert a string type version (2.4.0) to an int (132096) 421# Convert a string type version (2.4.0) to an int (132096)

Legend:
Removed from v.1.55  
changed lines
  Added in v.1.62

  ViewVC Help
Powered by ViewVC 1.1.20