3

I've a lot of C files, some have a header (.h), some files not.

Here's my makefile :

.SUFFIXES: 

SRC := $(wildard ./src/*.c)
OBJ := $(SRC:%.c=%.o)

all: $(OBJ)

%.o: %.c
    $(MyNotGCCCompiler) "@../$(*F).cmd"

It works fine except that if I change a header file, the target isn't recompiled because not included in the dependencies.

How can I manage this case?

Thanks

2 Answers 2

3

The standard approach is to generate header dependencies automatically while compiling.

For the first compilation no dependencies are necessary since every source file must be compiled. Subsequent recompilations load dependencies generated by the previous compilation to determine what needs to be recompiled.

Your $(MyNotGCCCompiler) is likely to have a command line option to generate a dependencies file.

When using gcc it works like this:

.SUFFIXES: 

SRC := $(wildard ./src/*.c)
OBJ := $(SRC:%.c=%.o)
DEP := $(OBJ:%.o=%.d)

all: $(OBJ)

# when compiling produce a .d file as well 
%.o: %.c
    gcc -c -o $@ $(CPPFLAGS) $(CFLAGS) -MD -MP -MF ${@:.o=.d} $<

# don't fail on missing .d files
# there won't be any on the first run
-include $(DEP) 
0

(I'm not sure how this is not stating the obvious, but anyway:)

Add rules to list those dependencies explicitly, file by file. Preferably in a separate makefile that you include from the main one.

Tools exist (such as gcc) that can generate them for you; if you can't use or build such a tool, you'll need to maintain these rules yourself.

4
  • Makefile is generic and used in several projects. There is too many files that have an header in order to maintain it manually.
    – Arnaud F.
    Commented Mar 7, 2012 at 9:32
  • That's why you have to generate this file and include it in the generic Makefile. This is one of the reasons tools like the GNU autotools and CMake exist. Commented Mar 7, 2012 at 9:58
  • @reinierpost: these tools exist more for portability reasons than to generate dependencies. Commented Mar 8, 2012 at 21:10
  • @Maxim Yegorushkin: certainly. Commented Mar 9, 2012 at 15:31

Not the answer you're looking for? Browse other questions tagged or ask your own question.