While I'm looking at it, line up the SED lines
[oota-llvm.git] / Makefile.common
index 2612e6fc656b3cbe090ff6e3efae8fceef716a4c..dd9ad9bd1389d34040c1d844546918eca7a20d1e 100644 (file)
@@ -766,10 +766,16 @@ YACC_OUTPUT = $(addprefix $(YACC_FILES:%.y=%), .h .cpp .output)
 # FIXME.  (f.e. char Buffer[10000]; )
 #
 %.cpp: %.l
-       $(FLEX) -t $< | $(SED) '/^find_rule/d' | \
-                     $(SED) 's/void yyunput/inline void yyunput/' | \
+       @echo Flex\'ing $<...
+       $(VERB) $(FLEX) -t $< | \
+          $(SED) '/^find_rule/d' | \
+          $(SED) 's/void yyunput/inline void yyunput/' | \
           $(SED) 's/void \*yy_flex_realloc/inline void *yy_flex_realloc/' | \
-          $(SED) 's/#define YY_BUF_SIZE 16384/#define YY_BUF_SIZE (16384*64)/' > $@
+          $(SED) 's/#define YY_BUF_SIZE 16384/#define YY_BUF_SIZE (16384*64)/' \
+              > $@.tmp
+       $(VERB) diff -q $@ $@.tmp || ${MV} -f $@.tmp $@
+       @# remove the output of flex if it didn't get moved over...
+       @rm -f $@.tmp
 
 # Rule for building the bison parsers...
 %.c: %.y     # Cancel built-in rules for yacc
@@ -777,8 +783,10 @@ YACC_OUTPUT = $(addprefix $(YACC_FILES:%.y=%), .h .cpp .output)
 %.cpp %.h : %.y
        @echo Bison\'ing $<...
        $(VERB) $(BISON) -v -d -p $(<:%Parser.y=%) $*.y
-       $(VERB) ${MV} -f $*.tab.c $*.cpp
-       $(VERB) ${MV} -f $*.tab.h $*.h
+       $(VERB) diff -q $*.tab.c $*.cpp || ${MV} -f $*.tab.c $*.cpp
+       $(VERB) diff -q $*.tab.h $*.h || ${MV} -f $*.tab.h $*.h
+       @# If the files were not updated, don't leave them lying around...
+       @rm -f $*.tab.c $*.tab.h
 
 # To create the directories...
 %/.dir: