Search code examples
c++cmakefiledependencies

generate dependencies for a makefile for a project in C/C++


I have a project that has a makefile with broken dependencies. Is there any best known way to generate a list of dependencies for the project that I can use in the makefile, other than examining each source file by hand or with a hand written perl script?


Solution

  • GNU make's documentation provides a good solution.

    Absolutely. g++ -MM <your file> will generate a GMake compatible list of dependencies. I use something like this:

    # Add .d to Make's recognized suffixes.
    SUFFIXES += .d
    
    #We don't need to clean up when we're making these targets
    NODEPS:=clean tags svn
    #Find all the C++ files in the src/ directory
    SOURCES:=$(shell find src/ -name "*.cpp")
    #These are the dependency files, which make will clean up after it creates them
    DEPFILES:=$(patsubst %.cpp,%.d,$(SOURCES))
    
    #Don't create dependencies when we're cleaning, for instance
    ifeq (0, $(words $(findstring $(MAKECMDGOALS), $(NODEPS))))
        #Chances are, these files don't exist.  GMake will create them and
        #clean up automatically afterwards
        -include $(DEPFILES)
    endif
    
    #This is the rule for creating the dependency files
    src/%.d: src/%.cpp
        $(CXX) $(CXXFLAGS) -MM -MT '$(patsubst src/%.cpp,obj/%.o,$<)' $< -MF $@
    
    #This rule does the compilation
    obj/%.o: src/%.cpp src/%.d src/%.h
        @$(MKDIR) $(dir $@)
        $(CXX) $(CXXFLAGS) -o $@ -c $<
    

    Note: $(CXX)/gcc command must be preceded with a hard tab

    What this will do is automatically generate the dependencies for each file that has changed, and compile them according to whatever rule you have in place. This allows me to just dump new files into the src/ directory, and have them compiled automatically, dependencies and all.