diff options
author | Tavis Ormandy <taviso@gentoo.org> | 2003-05-26 21:07:00 +0000 |
---|---|---|
committer | Tavis Ormandy <taviso@gentoo.org> | 2003-05-26 21:07:00 +0000 |
commit | d196a9c326038a0669e851efc59706e16ebd0e85 (patch) | |
tree | bd9d5d17cafef8d47b7ac3ca64a3a38f3df8f7ee /eclass | |
parent | Masked dev-python/bsddb3-4.1.3 as it depends on db-4 (diff) | |
download | gentoo-2-d196a9c326038a0669e851efc59706e16ebd0e85.tar.gz gentoo-2-d196a9c326038a0669e851efc59706e16ebd0e85.tar.bz2 gentoo-2-d196a9c326038a0669e851efc59706e16ebd0e85.zip |
fixing bug in hardcode functions where '/' was included in CC, changing fixup function to be able to handle arbitrarily long list of files to check, apparently sed dumps core if you give it a list of >~200 files.
Diffstat (limited to 'eclass')
-rw-r--r-- | eclass/ccc.eclass | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/eclass/ccc.eclass b/eclass/ccc.eclass index 712923c3dd1e..da6dba4d276c 100644 --- a/eclass/ccc.eclass +++ b/eclass/ccc.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2003 Gentoo Technologies, Inc. # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/ccc.eclass,v 1.4 2003/05/26 20:33:50 taviso Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/ccc.eclass,v 1.5 2003/05/26 21:07:00 taviso Exp $ # # Authors: Tavis Ormandy <taviso@gentoo.org> # Aron Griffis <agriffis@gentoo.org> @@ -98,17 +98,22 @@ ccc-fixup() # and show differences when debugging # # store the backup suffix. - local files="`cat`" suffix=ccc-fixup-${$} - sed --in-place=.${suffix} ${1} ${files} || return 1 + local files list suffix=ccc-fixup-${$} + + while read files + do + sed --in-place=.${suffix} ${1} ${files} || return 1 + list="${list} ${files}" + done + [ ! "$DEBUG_CCC_ECLASS" ] && return 0 - # if theres a backup, diff it. - for i in ${files} + for i in ${list} do einfo "Checking for changes to `basename ${i}`..." if [ -e "${i}.${suffix}" ]; then diff -u ${i}.${suffix} ${i} - sleep 1 +# sleep 1 fi done } @@ -123,7 +128,7 @@ hide-restrict-arr() # find ${WORKDIR} -iname '*.h' | \ - xargs | ccc-fixup 's/\(\[__restrict\)_arr\]/\1\]/g' + xargs | ccc-fixup 's#\(\[__restrict\)_arr\]#\1\]#g' } replace-cc-hardcode() @@ -132,7 +137,7 @@ replace-cc-hardcode() # Makefiles. Try and fix these. # find ${WORKDIR} -iname Makefile | \ - xargs | ccc-fixup "s/^\(CC.*=\).*g*cc/\1${CC:-gcc}/g" + xargs | ccc-fixup "s#^\(CC.*=\).*g*cc#\1${CC:-gcc}#g" } replace-cxx-hardcode() @@ -140,7 +145,7 @@ replace-cxx-hardcode() # lots of developers hardcode g++ into thier # Makefiles. Try and fix these. find ${WORKDIR} -iname Makefile | \ - xargs | ccc-fixup "s/^\(CXX.*=\).*[gc]*++/\1${CXX:-g++}/g" + xargs | ccc-fixup "s#^\(CXX.*=\).*[gc]*++#\1${CXX:-g++}#g" } is-ccc() @@ -160,7 +165,7 @@ replace-ccc-g() # -g will stop ccc/cxx performing optimisation # replacing it with -g3 will let them co-exist. find ${WORKDIR} -iname Makefile | \ - xargs | ccc-fixup "s/\(^\CX*FLAGS=.*[\'\" \t]\)-g\([\'\" \t]\)/\1-g3\2/g" + xargs | ccc-fixup "s#\(^\CX*FLAGS=.*[\'\" \t]\)-g\([\'\" \t]\)#\1-g3\2#g" } ccc-elf-check() |