aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoland McGrath <roland@hack.frob.com>2011-07-02 15:52:51 -0700
committerRoland McGrath <roland@hack.frob.com>2011-07-02 15:52:51 -0700
commitea5ee9f73d7b9d143d04e6b91020fe9dc7b18a40 (patch)
tree7f734582fe608af5316458e08258bb5ad9d2304b
parent1b74661a6b93a892ecb1c717dedeedba5c2a976c (diff)
downloadglibc-ea5ee9f73d7b9d143d04e6b91020fe9dc7b18a40.tar
glibc-ea5ee9f73d7b9d143d04e6b91020fe9dc7b18a40.tar.gz
glibc-ea5ee9f73d7b9d143d04e6b91020fe9dc7b18a40.tar.bz2
glibc-ea5ee9f73d7b9d143d04e6b91020fe9dc7b18a40.zip
Rewrite local headers check to be more robust and informative.
-rw-r--r--ChangeLog4
-rw-r--r--Makefile3
-rwxr-xr-xscripts/check-local-headers.sh31
3 files changed, 23 insertions, 15 deletions
diff --git a/ChangeLog b/ChangeLog
index 2ef1710c3c..70c31cb745 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
2011-07-02 Roland McGrath <roland@hack.frob.com>
+ * scripts/check-local-headers.sh: Rewritten using awk.
+ Match by word, not by line. Print error messages for matches.
+ * Makefile ($(objpfx)check-local-headers.out): Pass AWK in to it.
+
* Makerules [shlib-lds-flags empty]:
($(common-objpfx)libc_pic.opts): New target.
($(common-objpfx)libc_pic.os.clean): New target.
diff --git a/Makefile b/Makefile
index aac255713d..287f671c17 100644
--- a/Makefile
+++ b/Makefile
@@ -284,7 +284,8 @@ endif
endif
$(objpfx)check-local-headers.out: scripts/check-local-headers.sh
- scripts/check-local-headers.sh "$(includedir)" "$(objpfx)" > $@
+ AWK='$(AWK)' scripts/check-local-headers.sh \
+ "$(includedir)" "$(objpfx)" > $@
ifneq ($(PERL),no)
installed-headers = argp/argp.h assert/assert.h catgets/nl_types.h \
diff --git a/scripts/check-local-headers.sh b/scripts/check-local-headers.sh
index d15e9a4416..b73078d364 100755
--- a/scripts/check-local-headers.sh
+++ b/scripts/check-local-headers.sh
@@ -1,5 +1,5 @@
#! /bin/bash
-# Copyright (C) 2005, 2007, 2009 Free Software Foundation, Inc.
+# Copyright (C) 2005,2007,2009,2011 Free Software Foundation, Inc.
# This file is part of the GNU C Library.
# The GNU C Library is free software; you can redistribute it and/or
@@ -23,18 +23,21 @@ objpfx="$2"
# To avoid long paths.
cd "$objpfx"
-
# Search all dependency files for file names in the include directory.
# There are a few system headers we are known to use.
-if fgrep "$includedir" */*.{o,os,oS}.d |
-fgrep -v "$includedir/asm" |
-fgrep -v "$includedir/linux" |
-fgrep -v "$includedir/selinux" |
-fgrep -v "$includedir/sys/capability.h" |
-fgrep -v "$includedir/gd" |
-fgrep -v "$includedir/nss3"; then
- # If we found a match something is wrong.
- exit 1
-fi
-
-exit 0
+exec ${AWK} -v includedir="$includedir" '
+BEGIN {
+ status = 0
+ exclude = "^" includedir \
+ "/(asm[-/]|linux/|selinux/|gd|nss3/|sys/capability\\.h)"
+}
+/^[^ ]/ && $1 ~ /.*:/ { obj = $1 }
+{
+ for (i = 1; i <= NF; ++i) {
+ if ($i ~ ("^" includedir) && $i !~ exclude) {
+ print "***", obj, "uses", $i
+ status = 1
+ }
+ }
+}
+END { exit status }' */*.{o,os,oS}.d