On Wed, 2023-09-27 at 16:50 +0200, Renaud Pacalet wrote:
> Thanks for your answer, Bahman. Not sure what "equivalent" means but
> with the following Makefile:
> 
> %.a: %.b
> 
> a.a: a.c
>      echo $^

The first pattern rule here does not define a pattern rule.  It
*cancels* a pattern rule.  See:
https://www.gnu.org/software/make/manual/html_node/Canceling-Rules.html

It's not possible for two different pattern rules to both be in effect
when building the same target, just like it's not possible for multiple
implicit rules with recipes to be in effect.

Basically, the way it works is that the prerequisites on the rule that
has the recipe come first, and any other prerequisites added by rules
without recipes are added afterwards, in the order in which they appear
in the makefile.

-- 
Paul D. Smith <psm...@gnu.org>            Find some GNU make tips at:
https://www.gnu.org                       http://make.mad-scientist.net
"Please remain calm...I may be mad, but I am a professional." --Mad
Scientist

Reply via email to