]> git.wh0rd.org Git - fontconfig.git/commitdiff
makealias: handle missing funcs better cleanup
authorMike Frysinger <vapier@gentoo.org>
Tue, 8 Nov 2011 19:19:57 +0000 (14:19 -0500)
committerMike Frysinger <vapier@gentoo.org>
Tue, 21 Feb 2012 19:15:58 +0000 (14:15 -0500)
When adding new functions, if the actual definition doesn't match the
header (say due to a typo), the regeneration of the internal headers
get confused and output bad cpp logic.  This causes gcc to barf due
to mismatched #ifdef/#endif.  Which is a pain to figure out due to
the sheer voulme of generated code.

So tweak the makealias script to detect this case and error out.
While we're here, improve the cpp output a bit to indent, include
comments, and merge similar ifdef blocks.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
src/makealias

index fd9c3fd1fc06880a258fa6a6744a6ce49ca6d1ee..fca94d4a2d7cb051307fd86e0b14aa1922703427 100755 (executable)
@@ -17,12 +17,22 @@ while read name; do
                hattr='__attribute((visibility("hidden")))'
                echo "extern __typeof ($name) $alias $hattr;" >> $HEAD
                echo "#define $name $alias" >> $HEAD
-               grep -l '^'$name'[ (]' "$SRCDIR"/*.c | sed -n 1p | sed -e 's/^.*\/\([^.]*\)\.c/#ifdef __\1__/' >> $TAIL
-               echo "#undef $name" >> $TAIL
+               ifdef=$(grep -l '^'$name'[ (]' "$SRCDIR"/*.c | sed -n 1p | sed -e 's/^.*\/\([^.]*\)\.c/__\1__/')
+               if [ -z "$ifdef" ] ; then
+                       echo "error: could not locate $name in src/*.c" 1>&2
+                       exit 1
+               fi
+               if [ "$ifdef" != "$last" ] ; then
+                       [ -n "$last" ] && echo "#endif /* $last */" >> $TAIL
+                       echo "#ifdef $ifdef" >> $TAIL
+                       last=$ifdef
+               fi
+               echo "# undef $name" >> $TAIL
                cattr='__attribute((alias("'$alias'"), visibility("default")))'
                echo "extern __typeof ($name) $name $cattr;" >> $TAIL
-               echo "#endif" >> $TAIL
                ;;
        esac
 done
-echo "#endif" >> $TAIL
+[ $? -ne 0 ] && exit 1
+echo "#endif /* $ifdef */" >> $TAIL
+echo "#endif /* HAVE_GNUC_ATTRIBUTE */" >> $TAIL