aboutsummaryrefslogtreecommitdiff
path: root/bin
diff options
context:
space:
mode:
authorNikolai Saoukh <nikolai.saoukh@gmail.com>2010-02-22 16:53:37 -0800
committerRuss Cox <rsc@swtch.com>2010-02-22 16:53:37 -0800
commit0c6074b6920c8e115944c9c5e79b74e9faad84cb (patch)
tree8ca6595d085fa1eda220f3c6fbf122c908f020b3 /bin
parentc4da64274d01d25fe699f888ce7ad6311bf4ef8b (diff)
downloadplan9port-0c6074b6920c8e115944c9c5e79b74e9faad84cb.tar.gz
plan9port-0c6074b6920c8e115944c9c5e79b74e9faad84cb.tar.bz2
plan9port-0c6074b6920c8e115944c9c5e79b74e9faad84cb.zip
9c, 9l: allow CC9=clang
R=rsc CC=codebot http://codereview.appspot.com/217045
Diffstat (limited to 'bin')
-rwxr-xr-xbin/9c64
-rwxr-xr-xbin/9l12
2 files changed, 57 insertions, 19 deletions
diff --git a/bin/9c b/bin/9c
index adcee2a1..50ab9f05 100755
--- a/bin/9c
+++ b/bin/9c
@@ -3,7 +3,7 @@
test -f $PLAN9/config && . $PLAN9/config
usegcc()
{
- cc=gcc
+ cc=${CC9:-gcc}
ngflags=" \
-O2 \
-c \
@@ -21,12 +21,58 @@ usegcc()
cflags="$ngflags -ggdb"
}
+quiet()
+{
+ # The uniq at the end is for gcc's strcmp/etc. built-in nonsense,
+ # which multiplies single errors as a result of its expansion.
+ # The "Cursor. is deprecated" kills off warnings from Apple
+ # about using SetCursor/InitCursor. (Okay, they're deprecated,
+ # but you could at least tell us what to use instead, Apple!)
+
+ ignore=': error: .Each undeclared identifier'
+ ignore=$ignore'|: error: for each function it appears'
+ ignore=$ignore'|is dangerous, better use'
+ ignore=$ignore'|is almost always misused'
+ ignore=$ignore'|: In function '
+ ignore=$ignore'|: At top level:'
+ ignore=$ignore'|support .long long.'
+ ignore=$ignore'|In file included from'
+ ignore=$ignore'| from'
+ ignore=$ignore'|use of C99 long long'
+ ignore=$ignore'|ISO C forbids conversion'
+ ignore=$ignore'|is deprecated'
+ ignore=$ignore'|warn_unused_result'
+
+ grep -v '__p9l_autolib_' $1 |
+ egrep -v "$ignore" |
+ sed 's/ .first use in this function.$//; s/\"\([^\"][^\"]*\)\", line \([0-9][0-9]*\)/\1:\2/g' |
+ uniq 1>&2
+}
+
+useclang()
+{
+ cc=${CC9:-clang}
+ ngflags=" \
+ -O2 \
+ -c \
+ -Wall \
+ -Wno-comment \
+ -Wno-empty-body \
+ -Wno-parentheses \
+ -Wno-unknown-pragmas \
+ -Wno-unused-value \
+ "
+ cflags="$ngflags -g"
+}
+
tag="${SYSNAME:-`uname`}-${OBJTYPE:-`uname -m`}-${CC9:-cc}"
case "$tag" in
+*FreeBSD*gcc*) usegcc ;;
+*FreeBSD*clang*) useclang ;;
*BSD*) usegcc ;;
*Darwin*) usegcc
cflags="$ngflags -g3 -no-cpp-precomp -m32" ;;
-*HP-UX*) cc=cc; cflags="-g -O -c -Ae" ;;
+*HP-UX*) cc=${CC9:-cc}; cflags="-g -O -c -Ae" ;;
*Linux*) usegcc
case "${CC9:-gcc}" in
tcc)
@@ -43,7 +89,7 @@ case "$tag" in
;;
esac
;;
-*OSF1*) cc=cc; cflags="-g -O -c" ;;
+*OSF1*) cc=${CC9:-cc}; cflags="-g -O -c" ;;
*SunOS*-cc) cc=cc;
cflags="-mt -g -O -c -xCC -D__sun__"
u=`uname`
@@ -67,17 +113,9 @@ case "$tag" in
esac
# N.B. Must use temp file to avoid pipe; pipe loses status.
-# The uniq at the end is for gcc's strcmp/etc. built-in nonsense,
-# which multiplies single errors as a result of its expansion.
-# The "Cursor. is deprecated" kills off warnings from Apple
-# about using SetCursor/InitCursor. (Okay, they're deprecated,
-# but you could at least tell us what to use instead, Apple!)
xtmp=/tmp/9c.$$.$USER.out
$cc -DPLAN9PORT -I$PLAN9/include $cflags "$@" 2>$xtmp
status=$?
-grep -v '__p9l_autolib_' $xtmp |
-egrep -v ': error: .Each undeclared identifier|: error: for each function it appears|is dangerous, better use|is almost always misused|: In function |: At top level:|support .long long.|In file included from| from|use of C99 long long|ISO C forbids conversion|is deprecated|warn_unused_result' |
-sed 's/ .first use in this function.$//; s/\"\([^\"][^\"]*\)\", line \([0-9][0-9]*\)/\1:\2/g' |
-uniq 1>&2
-rm -f $xtmp $xtmp.status
+quiet $xtmp
+rm -f $xtmp
exit $status
diff --git a/bin/9l b/bin/9l
index 2659db50..e3fa3091 100755
--- a/bin/9l
+++ b/bin/9l
@@ -12,7 +12,7 @@ extralibs="-lm"
tag="${SYSNAME:-`uname`}-${OBJTYPE:-`uname -m`}"
case "$tag" in
*FreeBSD*)
- ld=gcc
+ ld=${CC9:-gcc}
userpath=true
extralibs="$extralibs -lutil"
case "`uname -r`" in
@@ -25,18 +25,18 @@ case "$tag" in
esac
;;
*BSD*)
- ld=gcc
+ ld=${CC9:-gcc}
userpath=true
extralibs="$extralibs -lutil"
;;
*OSF1*)
- ld=cc
+ ld=${CC9:-cc}
userpath=true
extralibs="$extralibs -lutil"
nmflags="-B"
;;
*Linux*)
- ld=gcc
+ ld=${CC9:-gcc}
userpath=true
extralibs="$extralibs -lutil"
case "${SYSVERSION:-`uname -r`}" in
@@ -46,7 +46,7 @@ case "$tag" in
esac
;;
*Darwin*)
- ld="gcc -m32"
+ ld="${CC9:-gcc} -m32"
;;
*SunOS*)
ld="${CC9:-cc} -g"
@@ -76,7 +76,7 @@ case "$tag" in
esac
;;
*AIX*)
- ld=gcc
+ ld=${CC9:-gcc}
nmflags="-B"
;;
*)