repositories
/
TD_C.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Buildsystem: be more friendly with cygwin environment
[TD_C.git]
/
TP_13
/
exo1
/
Makefile
diff --git
a/TP_13/exo1/Makefile
b/TP_13/exo1/Makefile
index 8168c4511e29cf8dbbfba56ff2e96621e183a50b..152498c48fc1188a4a3dafeff884d071e6cde775 100644
(file)
--- 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
# 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
#
# 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 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
#
# 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
LIBRARY_NAME=libexo1
LIBRARY_PATH:=lib
-#LDLIBS=-L$(LIBRARY_PATH) -l$(BINARY_NAME)
BUILD_TYPE=debug
BUILD_TYPE=debug
+#BUILD_TYPE=release
# ====================================
# DO NOT CHANGE STUFF BEYOND THIS LINE
# ====================================
# DO NOT CHANGE STUFF BEYOND THIS LINE
@@
-30,29
+36,50
@@
AR=ar
WARN_FLAGS = -Wall -Wextra
STD_FLAG = -std=c11
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
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
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
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)
LIBLDFLAGS := -shared $(LDFLAGS)
STATICLIBLDFLAGS := -static $(LDFLAGS)
+LDLIBS := $(LDLIBS) -L$(LIBRARY_PATH) -l$(BINARY_NAME)
OBJDIR := $(BUILDDIR)/objs
$(shell mkdir -p $(OBJDIR))
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)))
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
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] $@"
$(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 ] $@"
#$(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 ] $@"
$(BINARY_NAME): $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).a
@echo "[LD ] $@"
- @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(L
OCALLDLIBS) $(L
DLIBS) -o $@
+ @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@
-LOCALLDLIBS=-L$(LIBRARY_PATH) -l$(BINARY_NAME)
$(BINARY_NAME).static: $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).a
@echo "[LD ] $@"
$(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 ] $@"
$(BINARY_NAME).dynamic: $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).so
@echo "[LD ] $@"
- @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(L
OCALLDLIBS) $(L
DLIBS) -o $@
+ @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@
-$(OBJ
S): $(SRCS)
$(DEPDIR)/%.d
- @echo "[C ] $
*
"
+$(OBJ
DIR)/%.o: $(SRC_PATH)/%.c
$(DEPDIR)/%.d
+ @echo "[C ] $
(notdir $*)
"
@$(CC) $(DEPFLAGS) $(CFLAGS) -c $< -o $@
@$(POSTCOMPILE)
include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(SRCS))))
@$(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) $(
LIB
CFLAGS) -c $< -o $@
@$(POSTCOMPILE)
include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(LIBSRCS))))
@$(POSTCOMPILE)
include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(LIBSRCS))))
@@
-118,6
+131,8
@@
$(DEPDIR)/%.d: ;
.PRECIOUS: $(DEPDIR)/%.d
.PRECIOUS: $(DEPDIR)/%.d
+#FIXME: add an install target
+
clean:
@echo "[CLN]"
-@rm -r $(BUILDDIR)
clean:
@echo "[CLN]"
-@rm -r $(BUILDDIR)