From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:54173) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SeMtD-00006d-Pq for qemu-devel@nongnu.org; Tue, 12 Jun 2012 04:55:58 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1SeMtA-0006jA-Vi for qemu-devel@nongnu.org; Tue, 12 Jun 2012 04:55:51 -0400 Received: from mail-pb0-f45.google.com ([209.85.160.45]:55176) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SeMtA-0006i2-NC for qemu-devel@nongnu.org; Tue, 12 Jun 2012 04:55:48 -0400 Received: by pbbro12 with SMTP id ro12so526401pbb.4 for ; Tue, 12 Jun 2012 01:55:46 -0700 (PDT) Sender: Paolo Bonzini Message-ID: <4FD702D9.8060204@redhat.com> Date: Tue, 12 Jun 2012 10:50:33 +0200 From: Paolo Bonzini MIME-Version: 1.0 References: In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] one question on the makefile List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Wei Yang Cc: Richard Yang , qemu-devel@nongnu.org Il 12/06/2012 10:33, Wei Yang ha scritto: > .PHONY: $(patsubst %, check-qtest-%, $(QTEST_TARGETS)) > $(patsubst %, check-qtest-%, $(QTEST_TARGETS)): check-qtest-%: $(check-qtest-y) > $(call quiet-command,QTEST_QEMU_BINARY=$*-softmmu/qemu-system-$* \ > gtester $(GTESTER_OPTIONS) -m=$(SPEED) $(check-qtest-$*-y),"GTESTER $@") > > I know the general idea is to create a rule for target such as > check-qtest-x86_64. > > There are two colons, usually there is one colon in dependency. Search for "Static pattern rules". Static pattern rules are probably the single most useful GNU make extension. They greatly limit the amount of "magic" the make does, so the resulting Makefiles are more easily debuggable. Here is an extract from the GNU make manual: ===== TARGETS ...: TARGET-PATTERN: PREREQ-PATTERNS ... RECIPE ... The TARGETS list specifies the targets that the rule applies to. The targets can contain wildcard characters, just like the targets of ordinary rules (*note Using Wildcard Characters in File Names: Wildcards.). The TARGET-PATTERN and PREREQ-PATTERNS say how to compute the prerequisites of each target. Each target is matched against the TARGET-PATTERN to extract a part of the target name, called the "stem". This stem is substituted into each of the PREREQ-PATTERNS to make the prerequisite names (one from each PREREQ-PATTERN). ===== $* is also replaced by the stem. In fact in this case, the stem is not used in the PREREQ-PATTERNS, it is only used in the commands. Paolo