help-make
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: trouble cleaning the right files ..


From: sharan basappa
Subject: Re: trouble cleaning the right files ..
Date: Mon, 18 Jun 2007 11:22:24 +0000

Hi Philip,

I have a question regarding the target specific variable :

How will a construct clean_dir1: local_objs := $(local_objs) do the work
since this will be followed by same rule
clean_dir1 :
        \rm $(local_objs)

In this case too the variable assignment will be deferred. Isnt it ?

Regards,
Sharan


From: "Philip Guenther" <address@hidden>
To: "sharan basappa" <address@hidden>
CC: address@hidden
Subject: Re: trouble cleaning the right files ..
Date: Mon, 18 Jun 2007 04:22:47 -0600

On 6/18/07, sharan basappa <address@hidden> wrote:
...
Each module make appends its clean target to clean variable as :
clean     += clean_dir1 .. so eventually clean_all looks like
clean_all : clean_dir1 clean_dir2

clean_dir1 (for example) rule is :

clean_dir1 :
        \rm $(local_objs)

The expansion of variables in command rules is always deferred until
the command is run.  That doesn't take place until the makefiles have
been completely parsed.  Ergo, unless you use a target-specific
variable assignment, the above will use the value of local_objs that
was last set during the parsing.  That's what's causing your problem.

There are two solutions:
1) use target-specific variables.  Check out the info pages for the details
   (just search for "target-specific"), but the quick-n-dirty kludge would
  be to add something like:
       clean_dir1: local_objs := $(local_objs)
  near where the clean_dir1 target is defined and similar with other
such targets.

2) instead of using the same variable for all the directories, use a different
   name for each:
       local_objs_dir1 := $(subst .c,.o,$(local_src))
       dir1: $(local_objs_dir1)
       clean_dir1:
               $(RM) $(local_objs_dir1)

  That can be mostly automated using computed names:
       local_objs_$(local_dir) := $(subst .c,.o,$(local_src))
       dir1: $(local_objs_$(local_dir))
       clean_dir1:
               $(RM) $(local_objs_$(subst clean_,,$@))

  ...but that's probably only worthwhile if you factor out that code
into a file
  that each submakefile then included.


Philip Guenther

_________________________________________________________________
Get Married in 2007. Join Shaadi.com FREE! http://www.shaadi.com/ptnr.php?ptnr=mhottag





reply via email to

[Prev in Thread] Current Thread [Next in Thread]