TP 11 exo1: Makefile: differenciate the compiliator flags for libraries
authorJérôme Benoit <jerome.benoit@piment-noir.org>
Thu, 9 Mar 2017 12:36:17 +0000 (13:36 +0100)
committerJérôme Benoit <jerome.benoit@piment-noir.org>
Thu, 9 Mar 2017 12:36:17 +0000 (13:36 +0100)
building.

Signed-off-by: Jérôme Benoit <jerome.benoit@piment-noir.org>
TP_11/exo2/Makefile
TP_13/exo1/Makefile

index 3edfbf669cb6305b6ea56093c290940cad468634..6f840e6e8bcda47f43c28d7a98d3c071b9197695 100644 (file)
@@ -12,9 +12,8 @@
 # Automatic dependencies code from:
 # http://make.mad-scientist.net/papers/advanced-auto-dependency-generation/#tldr
 BINARY_NAME=exo2
-LIBOBJS=clist.o ui.o# object to put in the library
+LIBOBJS=clist.o ui.o # object to put in the library
 LIBRARY_NAME=libtpC
-#LDLIBS=-L. -ltpC
 BUILD_TYPE=debug
 
 # ====================================
@@ -66,7 +65,7 @@ $(LIBRARY_NAME).a: $(OBJSLIB)
 
 $(LIBRARY_NAME).so: $(OBJSLIB)
        @echo "[LD ShO] $@"
-       @$(LD) $(CFLAGS) $(LIBLDFLAGS) $^ $(LDLIBS) -o $@
+       @$(LD) $(CFLAGS) $(LIBLDFLAGS) $^ -o $@
 
 $(BINARY_NAME): $(OBJS)
        @echo "[LD ] $@"
index 8168c4511e29cf8dbbfba56ff2e96621e183a50b..146115f0af178fc9623f83ebfacc19a8f3fa5930 100644 (file)
@@ -15,7 +15,6 @@ BINARY_NAME=exo1
 BINARY_PATH:=src
 LIBRARY_NAME=libexo1
 LIBRARY_PATH:=lib
-#LDLIBS=-L$(LIBRARY_PATH) -l$(BINARY_NAME)
 BUILD_TYPE=debug
 
 # ====================================
@@ -43,11 +42,12 @@ STRIP_FLAG = -s
 OPTI_FLAG = -O3
 endif
 
-#FIXME: Add a way to better control the library build flag
-CFLAGS := -fPIC $(CFLAGS) $(WARN_FLAGS) $(STD_FLAG) $(OPTI_FLAG) $(DEBUG_FLAG)
+CFLAGS := $(CFLAGS) $(WARN_FLAGS) $(STD_FLAG) $(OPTI_FLAG) $(DEBUG_FLAG)
+LIBCFLAGS := -fPIC $(CFLAGS)
 LDFLAGS := $(LDFLAGS) $(STRIP_FLAG)
 LIBLDFLAGS := -shared $(LDFLAGS)
 STATICLIBLDFLAGS := -static $(LDFLAGS)
+LDLIBS := $(LDLIBS) -L$(LIBRARY_PATH) -l$(BINARY_NAME)
 
 OBJDIR := $(BUILDDIR)/objs
 $(shell mkdir -p $(OBJDIR))
@@ -77,39 +77,38 @@ $(LIBRARY_PATH)/$(LIBRARY_NAME).a: $(LIBOBJS)
 
 $(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 $@
+       @$(LD) $(CFLAGS) $(STATICLIBLDFLAGS) $^ $(LDLIBS) -o $@
 
 #$(BINARY_NAME).staticlocal: $(OBJS) $(LIBRARY_PATH)/$(LIBRARY_NAME).a
 #      @echo "[LD ] $@"
-#      @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(LOCALLDLIBS) $(LDLIBS) -o $@
+#      @$(LD) $(CFLAGS) $(LDFLAGS) $^ $(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  ] $*"
+       @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 $@
+       @echo "[C  ] $(notdir $*)"
+       @$(CC) $(DEPFLAGS) $(LIBCFLAGS) -c $< -o $@
        @$(POSTCOMPILE)
 
 include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(LIBSRCS))))
@@ -118,6 +117,8 @@ $(DEPDIR)/%.d: ;
 
 .PRECIOUS: $(DEPDIR)/%.d
 
+#FIXME: add an install target
+
 clean:
        @echo "[CLN]"
        -@rm -r $(BUILDDIR)