Next: , Previous: Pattern Intro, Up: Pattern Rules

10.5.2 Pattern Rule Examples

Here are some examples of pattern rules actually predefined in make. First, the rule that compiles ‘.c’ files into ‘.o’ files:

     %.o : %.c
             $(CC) -c $(CFLAGS) $(CPPFLAGS) $< -o $@

defines a rule that can make any file x.o from x.c. The recipe uses the automatic variables ‘$@’ and ‘$<’ to substitute the names of the target file and the source file in each case where the rule applies (see Automatic Variables).

Here is a second built-in rule:

     % :: RCS/%,v
             $(CO) $(COFLAGS) $<

defines a rule that can make any file x whatsoever from a corresponding file x,v in the subdirectory RCS. Since the target is ‘%’, this rule will apply to any file whatever, provided the appropriate prerequisite file exists. The double colon makes the rule terminal, which means that its prerequisite may not be an intermediate file (see Match-Anything Pattern Rules).

This pattern rule has two targets: %.y
             bison -d $<

This tells make that the recipe ‘bison -d x.y’ will make both and If the file foo depends on the files and scan.o and the file scan.o depends on the file, when parse.y is changed, the recipe ‘bison -d parse.y’ will be executed only once, and the prerequisites of both and scan.o will be satisfied. (Presumably the file will be recompiled from and the file scan.o from scan.c, while foo is linked from, scan.o, and its other prerequisites, and it will execute happily ever after.)