Makefiles: Force building 32 or 64 bit by setting ARCH=32 or 64
[sdk] / compiler / bootstrap / ecc / Makefile
index 4c3bb03..0cf1c1d 100644 (file)
@@ -1,19 +1,47 @@
 .PHONY: all objdir clean realclean distclean
 
-# CONTENT
+# CORE VARIABLES
 
 MODULE := ecc
 CONFIG := bootstrap
+ifndef COMPILER
 COMPILER := default
+endif
+
 TARGET_TYPE = executable
 
-OBJ = obj/$(CONFIG).$(PLATFORM)/
+# FLAGS
 
-RES = 
+ECFLAGS =
+ifndef DEBIAN_PACKAGE
+CFLAGS =
+LDFLAGS =
+endif
+PRJ_CFLAGS =
+CECFLAGS =
+OFLAGS =
+LIBS =
+
+ifdef DEBUG
+NOSTRIP := y
+endif
+
+CONSOLE = -mconsole
+
+# INCLUDES
+
+_CF_DIR = ../../../
 
-CONSOLE = 
+include $(_CF_DIR)crossplatform.mk
+include $(_CF_DIR)default.cf
 
-TARGET = obj/$(CONFIG).$(PLATFORM)/ecc$(E)
+# POST-INCLUDES VARIABLES
+
+OBJ = obj/$(CONFIG).$(PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/
+
+RES = 
+
+TARGET = obj/$(CONFIG).$(PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/ecc$(E)
 
 OBJECTS = \
        $(OBJ)ecc.o \
@@ -23,50 +51,43 @@ SOURCES = \
        bootstrap/ecc.c \
        bootstrap/ecc.main.c
 
-# CROSS-PLATFORM MAGIC
-
-include ../../../include.mk
-
-# FLAGS
-
-CFLAGS = -fmessage-length=0 -O2 -ffast-math -m32 $(FPIC) -w \
-        -DECERE_STATIC
-
-CECFLAGS =
+LIBS += $(SHAREDLIB) $(EXECUTABLE) $(LINKOPT)
 
-ECFLAGS = -nolinenumbers
+ifndef STATIC_LIBRARY_TARGET
+LIBS += \
+       $(call _L,ecereBootstrap) \
+       $(call _L,ecBootstrap)
+endif
 
-OFLAGS = -m32 \
-        -L../ecere/obj/bootstrap.$(PLATFORM) \
-        -L../libec/obj/bootstrap.$(PLATFORM)
+PRJ_CFLAGS += \
+        $(if $(DEBUG), -g, -O2 -ffast-math) $(FPIC) -w \
+                        -DECERE_STATIC
 
-LIBS = -lecereBootstrap -lecBootstrap $(SHAREDLIB) $(EXECUTABLE) $(LINKOPT)
 
-UPXFLAGS = -9 -q
+ECFLAGS += \
+        -nolinenumbers
 
-# HARD CODED PLATFORM-SPECIFIC OPTIONS
-ifdef LINUX
-OFLAGS += -Wl,--no-undefined
-endif
 
 # PLATFORM-SPECIFIC OPTIONS
 
-ifdef WINDOWS
+ifdef LINUX_TARGET
 
-LIBS += -Wl,--enable-stdcall-fixup
+ifndef STATIC_LIBRARY_TARGET
+LIBS += \
+       $(call _L,m) \
+       $(call _L,dl)
+endif
 
-else
-ifdef LINUX
+endif
 
-LIBS += -lm -ldl
 
-else
-ifdef OSX
 
-LIBS += -lm -ldl
+CECFLAGS += -cpp $(_CPP)
 
-endif
-endif
+ifndef STATIC_LIBRARY_TARGET
+OFLAGS += \
+        -L../ecere/obj/bootstrap.$(PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX) \
+        -L../libec/obj/bootstrap.$(PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)
 endif
 
 # TARGETS
@@ -85,17 +106,17 @@ endif
 # OBJECT RULES
 
 $(OBJ)ecc.o: bootstrap/ecc.c
-       $(CC) $(CFLAGS) $(FVISIBILITY) -c bootstrap/ecc.c -o $(OBJ)ecc.o
+       $(CC) $(CFLAGS) $(PRJ_CFLAGS) $(FVISIBILITY) -c bootstrap/ecc.c -o $(OBJ)ecc.o
 
 $(OBJ)ecc.main.o: bootstrap/ecc.main.c
-       $(CC) $(CFLAGS) $(FVISIBILITY) -c bootstrap/ecc.main.c -o $(OBJ)ecc.main.o
+       $(CC) $(CFLAGS) $(PRJ_CFLAGS) $(FVISIBILITY) -c bootstrap/ecc.main.c -o $(OBJ)ecc.main.o
 
 clean: objdir
        $(call rmq,$(TARGET))
        $(call rmq,$(OBJECTS))
 
-realclean:
+realclean: objdir
        $(call rmrq,$(OBJ))
 
-distclean:
+distclean: objdir
        $(call rmrq,obj/)