• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 349
  • Last Modified:

About Makefile

I have to include certain library paths only is a particular condition is true.
for example,
i need to include file.h,
INCLUDE_HEADER = file1.h file.h
only if s=1
otherwise
i need only INCLUDE_HEADER = file1.h

How can i test this condition in a Makefile.

0
aishwaria
Asked:
aishwaria
  • 4
  • 4
  • 3
  • +1
1 Solution
 
avizitCommented:
ref to

http://www.gnu.org/software/make/manual/html_mono/make.html#SEC79


there is a example given which matches your requrements.

basically you have to check

ifeq($(s), 1)
 INCLUDE_HEADER = file1.h file.h
else
 etc etc etc etc ..

read the link , that should be sufficient for your purpose.

/abhijit/


0
 
avizitCommented:
ankuratvb slipped in,

anyway what i said is for GNU "make"

I don't know if that will work in microsoft environ

-/abhijit/
0
What Kind of Coding Program is Right for You?

There are many ways to learn to code these days. From coding bootcamps like Flatiron School to online courses to totally free beginner resources. The best way to learn to code depends on many factors, but the most important one is you. See what course is best for you.

 
aishwariaAuthor Commented:
Can i get the s value as a command line argument
0
 
ankuratvbCommented:
>Can i get the s value as a command line argument

I am not sure about that.

Another Option.You could write a shell script for this.
0
 
aishwariaAuthor Commented:
Can you give me some examples for this.
0
 
ankuratvbCommented:
#!/bin/bash
S=1
SS=$1 #first command line argument

if [ $S -eq $SS ]      
then
#ur makefile command here      
else
#ur other makefile command here
fi

Save as:urfilename.sh

Execute as:bash urfilename.sh 2
where 2 is the value of S
0
 
aishwariaAuthor Commented:
but then the makefile is executed as
make -f Makefile

So i wish if it is done something like,

make -f Makefile -d 2

where 2 is the argument

can you suggest me some way to do like this.

-aishwaria
0
 
avizitCommented:
Just as a sidenote , if your makefile is named "Makefile" or "makefile"
you dont need the "-f  Makefile"

make by default looks for a file called "Makefile" failing which it looks for "makefile"

/abhijit/
0
 
ankuratvbCommented:
You could do this:

#!/bin/bash
S=1
SS=$1 #first command line argument

if [ $S -eq $SS ]    
then
make -f Makefile1
else
make -f Makefile2
fi


where Makefile1 is the makefile with the first include option
and MakeFile2 is the makefile with the other option.
Hope this helps.
0
 
ssnkumarCommented:
You can set some environment variables and export them.
This can be processed from inside the Makefile.

-ssnkumar
0
 
avizitCommented:
from what i have gathered

using "autoconf" and "automake" sounds like a good idea but I am not good at those but if someone knows he/she can help.

/abhijit/
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

What Kind of Coding Program is Right for You?

There are many ways to learn to code these days. From coding bootcamps like Flatiron School to online courses to totally free beginner resources. The best way to learn to code depends on many factors, but the most important one is you. See what course is best for you.

  • 4
  • 4
  • 3
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now