X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=TP_13%2Fexo1%2FMakefile;h=152498c48fc1188a4a3dafeff884d071e6cde775;hb=5d64063095177554839e67ddc73193929f115d07;hp=8168c4511e29cf8dbbfba56ff2e96621e183a50b;hpb=eddc018ded5c49cd7301031d7c6c80022fb91f9d;p=TD_C.git diff --git a/TP_13/exo1/Makefile b/TP_13/exo1/Makefile index 8168c45..152498c 100644 --- a/TP_13/exo1/Makefile +++ b/TP_13/exo1/Makefile @@ -1,22 +1,28 @@ # Sample Makefile to build simple project. # # This Makefile expect all source files (.c) to be at the same level, in the -# current working directory. +# $(SRC_PATH) directory. +# +# This Makefile expect all embedded library source files (.c) to be at the same level, in the +# $(LIBRARY_PATH) directory. # # It will automatically generate dependencies, compile all files, and produce a -# binary using the provided name. +# binary using the provided name linked against the library if necessary. # # Set BINARY_NAME to the name of the binary file to build. -# Set BUILD_TYPE to either debug or release +# Set LIBRARY_NAME to the name of the library file to build. +# The default path for the library code and object is lib. +# By default the linker will look for $(BINARY_NAME) library name. +# Set BUILD_TYPE to either debug or release. # # Automatic dependencies code from: # http://make.mad-scientist.net/papers/advanced-auto-dependency-generation/#tldr BINARY_NAME=exo1 -BINARY_PATH:=src +SRC_PATH:=src LIBRARY_NAME=libexo1 LIBRARY_PATH:=lib -#LDLIBS=-L$(LIBRARY_PATH) -l$(BINARY_NAME) BUILD_TYPE=debug +#BUILD_TYPE=release # ==================================== # DO NOT CHANGE STUFF BEYOND THIS LINE @@ -30,29 +36,50 @@ AR=ar WARN_FLAGS = -Wall -Wextra STD_FLAG = -std=c11 +UNAME := $(shell uname -o) ifeq ($(BUILD_TYPE),debug) BUILDDIR := .build/debug DEBUG_FLAG = -g STRIP_FLAG = OPTI_FLAG = -O0 +LTO_SUPPORT = yes +GOLD_SUPPORT = yes else BUILDDIR := .build/release DEBUG_FLAG = STRIP_FLAG = -s OPTI_FLAG = -O3 +LTO_SUPPORT = yes +GOLD_SUPPORT = yes +endif + +ifeq ($(UNAME),Cygwin) +GOLD_SUPPORT = no +endif + +ifeq ($(LTO_SUPPORT),yes) +CFLAGS_LTO = -flto -ffat-lto-objects +LDFLAGS_LTO = -fuse-linker-plugin -flto +endif + +ifeq ($(GOLD_SUPPORT),yes) +LDFLAGS_GOLD = -fuse-ld=gold endif -#FIXME: Add a way to better control the library build flag -CFLAGS := -fPIC $(CFLAGS) $(WARN_FLAGS) $(STD_FLAG) $(OPTI_FLAG) $(DEBUG_FLAG) -LDFLAGS := $(LDFLAGS) $(STRIP_FLAG) +# Putting header files in the source directory is not the purpose of this INCLUDES variable +INCLUDES := $(INCLUDES) -I$(LIBRARY_PATH) +CFLAGS := $(CFLAGS) $(CFLAGS_LTO) $(WARN_FLAGS) $(STD_FLAG) $(OPTI_FLAG) $(DEBUG_FLAG) $(INCLUDES) +LIBCFLAGS := -fPIC $(CFLAGS) +LDFLAGS := $(LDFLAGS) $(LDFLAGS_LTO) $(LDFLAGS_GOLD) $(STRIP_FLAG) LIBLDFLAGS := -shared $(LDFLAGS) STATICLIBLDFLAGS := -static $(LDFLAGS) +LDLIBS := $(LDLIBS) -L$(LIBRARY_PATH) -l$(BINARY_NAME) OBJDIR := $(BUILDDIR)/objs $(shell mkdir -p $(OBJDIR)) -SRCS=$(wildcard $(BINARY_PATH)/*.c) +SRCS=$(wildcard $(SRC_PATH)/*.c) LIBSRCS=$(wildcard $(LIBRARY_PATH)/*.c) OBJS=$(patsubst %.c,$(OBJDIR)/%.o,$(notdir $(SRCS))) LIBOBJS=$(patsubst %.c,$(OBJDIR)/%.o,$(notdir $(LIBSRCS))) @@ -62,54 +89,40 @@ $(shell mkdir -p $(DEPDIR)) DEPFLAGS = -MT $@ -MMD -MP -MF $(DEPDIR)/$(notdir $*).Td POSTCOMPILE = mv -f $(DEPDIR)/$(notdir $*).Td $(DEPDIR)/$(notdir $*).d -print: - @echo $(basename $(notdir $(SRCS))) - @echo $(notdir $(SRCS)) - @echo $(DEPDIR)/%d - @echo $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(SRCS)))) - @echo $(OBJS) $(LIBOBJS) - @echo $(SRCS) $(LIBSRCS) - @echo $(POSTCOMPILE) - $(LIBRARY_PATH)/$(LIBRARY_NAME).a: $(LIBOBJS) @echo "[AR StO] $@" @$(AR) rcs $@ $^ $(LIBRARY_PATH)/$(LIBRARY_NAME).so: $(LIBOBJS) @echo "[LD ShO] $@" - @$(LD) $(CFLAGS) $(LIBLDFLAGS) $^ $(LDLIBS) -o $@ + @$(LD) $(LIBCFLAGS) $(LIBLDFLAGS) $^ -o $@ #$(BINARY_NAME): $(OBJS) $(LIBOBJS) # @echo "[LD ] $@" -# $(LD) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@ +# @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@ $(BINARY_NAME): $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).a @echo "[LD ] $@" - @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LOCALLDLIBS) $(LDLIBS) -o $@ + @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@ -LOCALLDLIBS=-L$(LIBRARY_PATH) -l$(BINARY_NAME) $(BINARY_NAME).static: $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).a @echo "[LD ] $@" - @$(LD) $(CFLAGS) $(STATICLIBLDFLAGS) $^ $(LOCALLDLIBS) $(LDLIBS) -o $@ - -#$(BINARY_NAME).staticlocal: $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).a -# @echo "[LD ] $@" -# @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LOCALLDLIBS) $(LDLIBS) -o $@ + @$(LD) $(CFLAGS) $(STATICLIBLDFLAGS) $^ $(LDLIBS) -o $@ $(BINARY_NAME).dynamic: $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).so @echo "[LD ] $@" - @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LOCALLDLIBS) $(LDLIBS) -o $@ + @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@ -$(OBJS): $(SRCS) $(DEPDIR)/%.d - @echo "[C ] $*" +$(OBJDIR)/%.o: $(SRC_PATH)/%.c $(DEPDIR)/%.d + @echo "[C ] $(notdir $*)" @$(CC) $(DEPFLAGS) $(CFLAGS) -c $< -o $@ @$(POSTCOMPILE) include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(SRCS)))) -$(LIBOBJS): $(LIBSRCS) $(DEPDIR)/%.d - @echo "[C ] $*" - @$(CC) $(DEPFLAGS) $(CFLAGS) -c $< -o $@ +$(OBJDIR)/%.o: $(LIBRARY_PATH)/%.c $(DEPDIR)/%.d + @echo "[C ] $(notdir $*)" + @$(CC) $(DEPFLAGS) $(LIBCFLAGS) -c $< -o $@ @$(POSTCOMPILE) include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(LIBSRCS)))) @@ -118,6 +131,8 @@ $(DEPDIR)/%.d: ; .PRECIOUS: $(DEPDIR)/%.d +#FIXME: add an install target + clean: @echo "[CLN]" -@rm -r $(BUILDDIR)