updated Android build to use "gcc --sysroot" technique, first available in NDKr4
[olsrd.git] / Makefile.inc
index 239d6d9..d70578e 100644 (file)
@@ -5,7 +5,7 @@
 #
 
 # activate debugging with 1 or deactivate with 0
-DEBUG ?= 0
+DEBUG ?= 1
 
 # compile OLSR_PRINTF out
 NO_DEBUG_MESSAGES ?= 0
@@ -17,6 +17,13 @@ OPTIMIZE ?=
 # you need a recent enough gcc and the libmudflap installed
 MUDFLAP ?= 0
 
+# OS detection
+ifeq ($(OS),Windows_NT)
+OS := win32
+endif
+ifeq ($(OS),)
+OS := $(shell sh $(TOPDIR)/make/guess_os.sh)
+endif
 
 ######################
 #
@@ -40,15 +47,17 @@ FLEX ?=             flex
 TAGCMD ?=      etags
 
 # target directories and names
-DESTDIR ?=
-SBINDIR ?= $(DESTDIR)/usr/sbin
-ETCDIR  ?= $(DESTDIR)/etc
-LIBDIR  ?= $(DESTDIR)/usr/lib
-DOCDIR  ?= $(DESTDIR)/usr/share/doc
-MANDIR  ?= $(DESTDIR)/usr/share/man
-EXENAME ?= olsrd
-CFGNAME ?= $(EXENAME).conf
-CFGFILE ?= $(ETCDIR)/$(CFGNAME)
+DESTDIR  ?=
+ETCDIR   ?= $(DESTDIR)/etc
+USRDIR   ?= $(DESTDIR)/usr
+LIBDIR   ?= $(USRDIR)/lib
+SBINDIR  ?= $(USRDIR)/sbin
+SHAREDIR ?= $(USRDIR)/share
+DOCDIR   ?= $(SHAREDIR)/doc
+MANDIR   ?= $(SHAREDIR)/man
+EXENAME  ?= olsrd
+CFGNAME  ?= $(EXENAME).conf
+CFGFILE  ?= $(ETCDIR)/$(CFGNAME)
 
 CPPFLAGS =     -Isrc
 ifneq ($(TOPDIR),.)
@@ -76,10 +85,11 @@ WARNINGS += -Wwrite-strings
 WARNINGS +=    -Wbad-function-cast
 WARNINGS +=    -Wpointer-arith
 WARNINGS +=    -Wcast-qual
-# the following 5 do not work yet and need more work on it
-#WARNINGS +=   -Wshadow
-#WARNINGS +=   -Wpointer-arith
-#WARNINGS +=   -Wcast-align
+WARNINGS +=    -Wshadow
+WARNINGS +=    -Wformat
+WARNINGS +=    -Wsequence-point
+WARNINGS +=    -Wcast-align
+# the following 2 do not work yet and need more work on it
 #WARNINGS +=   -Wconversion
 #WARNINGS +=   -Wredundant-decls
 ifeq ($(MUDFLAP),0)
@@ -90,8 +100,9 @@ endif
 #WARNINGS +=   -Wunreachable-code
 WARNINGS +=    -Winline
 WARNINGS +=    -Wdisabled-optimization
-WARNINGS +=    -Werror
+# WARNINGS +=  -Werror
 WARNINGS +=    -finline-functions-called-once
+WARNINGS +=    -funit-at-a-time
 WARNINGS +=    -fearly-inlining
 ifeq ($(DEBUG),0)
 WARNINGS +=    -fomit-frame-pointer
@@ -122,12 +133,19 @@ endif
 ifdef OLSRD_PLUGIN
 # c and ld flags for libraries (plugins)
 CPPFLAGS +=    -DOLSR_PLUGIN
+ifeq ($(OS),win32)
+  LDFLAGS +=   -Wl,-export-all-symbols,--enable-auto-import
+endif
 LDFLAGS +=     -shared
-LDFLAGS +=     -Wl,-soname,$(PLUGIN_NAME)
+LDFLAGS +=     -Wl,-soname,$(PLUGIN_SONAME)
 LDFLAGS +=     -Wl,--version-script=version-script.txt 
 else
 # c and ld flags for main
-LDFLAGS +=     -Wl,-export-dynamic 
+ifeq ($(OS),win32)
+  LDFLAGS +=   -Wl,-export-all-symbols
+else 
+  LDFLAGS +=   -Wl,-export-dynamic 
+endif
 LDFLAGS +=     -Wl,-rpath,$(LIBDIR)
 endif
 # LDFLAGS for all 
@@ -158,13 +176,6 @@ CPPFLAGS +=     -DUSE_FPM
 SRCS +=                $(wildcard src/common/*.c src/*.c *.c)
 HDRS +=                $(wildcard src/common/*.h src/*.h *.h)
 
-# OS detection
-ifeq ($(OS),Windows_NT)
-OS := win32
-endif
-ifeq ($(OS),)
-OS := $(shell sh $(TOPDIR)/make/guess_os.sh)
-endif
 ifeq ($(OS),UNKNOWN)
 all: help
 else
@@ -180,14 +191,11 @@ OBJS +=           $(SRCS:%.c=%.o)
 ifeq ($(DEBUG),1)
 CPPFLAGS +=    -DDEBUG
 CFLAGS +=      -ggdb
-OPTIMIZE = -O0
 else
 CPPFLAGS +=    -DNDEBUG
-OPTIMIZE = -O2
 endif
 ifeq ($(NO_DEBUG_MESSAGES),1)
 CPPFLAGS +=    -DNODEBUG
-OPTIMIZE = -Os
 endif
 
 # a make function to quote "/" and "."
@@ -197,6 +205,10 @@ quote = $(subst .,\.,$(subst /,\/,$1))
 %.d: %.c
        @$(filter-out $(CCACHE),$(CC)) -M $(strip $(CPPFLAGS)) "$<" | sed -e '1s/\($(call quote,$(*F))\.o\)[ :]*/$(call quote,$(*D)/\1 $@: Makefile $(TOPDIR)$(if $(TOPDIR),/)Makefile.inc) /g' >"$@"
 
+%.o: %.c
+       @echo "[CC] $<"
+       @$(CC) $(CFLAGS) $(CPPFLAGS) -c -o $@ $<
+
 # we always need the includes and defines
 # for legacy since now
 CPPFLAGS += $(INCLUDES) $(DEFINES)
@@ -218,12 +230,13 @@ help:
        @echo ' by setting the OS variable! Valid  '
        @echo ' target OSes are:                   '
        @echo ' ---------------------------------  '
-       @echo ' linux - GNU/Linux                  '
-       @echo ' win32 - MS Windows                 '
-       @echo ' fbsd  - FreeBSD                    '
-       @echo ' nbsd  - NetBSD                     '
-       @echo ' obsd  - OpenBSD                    '
-       @echo ' osx   - Mac OS X                   '
+       @echo ' linux   - GNU/Linux                '
+       @echo ' win32   - MS Windows               '
+       @echo ' fbsd    - FreeBSD                  '
+       @echo ' nbsd    - NetBSD                   '
+       @echo ' obsd    - OpenBSD                  '
+       @echo ' osx     - Mac OS X                 '
+       @echo ' android - Android                  '
        @echo ' ---------------------------------  '
        @echo ' Example - build for windows:       '
        @echo ' make OS=win32                      '