Only use some gcc flags if gcc actually supports them.
This commit is contained in:
parent
6e2ef07dd3
commit
049948eb09
24
src/Makefile
24
src/Makefile
@ -4,15 +4,29 @@
|
|||||||
CC ?= gcc
|
CC ?= gcc
|
||||||
|
|
||||||
CFLAGS ?= -Wall -O2 -pipe
|
CFLAGS ?= -Wall -O2 -pipe
|
||||||
|
|
||||||
|
# Saying that, this function only works with GNU Make :/
|
||||||
|
check_gcc=$(shell if $(CC) $(1) -S -o /dev/null -xc /dev/null >/dev/null 2>&1; \
|
||||||
|
then echo "$(1)"; else echo "$(2)"; fi)
|
||||||
|
|
||||||
|
# Luckily we can do this more long winded thing with pmake used by the BSDs
|
||||||
|
# FIXME: Look into making this into a loop
|
||||||
|
WAFTST != if $(CC) -Wextra -S -o /dev/null -xc /dev/null >/dev/null 2>&1; \
|
||||||
|
then echo "-Wdeclaration-after-statement"; fi
|
||||||
|
WSEQ != if $(CC) -Wextra -S -o /dev/null -xc /dev/null >/dev/null 2>&1; \
|
||||||
|
then echo "-Wsequence-point"; fi
|
||||||
|
WEXTRA != if $(CC) -Wextra -S -o /dev/null -xc /dev/null >/dev/null 2>&1; \
|
||||||
|
then echo "-Wextra"; fi
|
||||||
|
|
||||||
|
# Loads of nice flags to ensure our code is good
|
||||||
CFLAGS += -pedantic -std=c99 \
|
CFLAGS += -pedantic -std=c99 \
|
||||||
-Wall -Wunused -Wimplicit -Wshadow -Wformat=2 \
|
-Wall -Wunused -Wimplicit -Wshadow -Wformat=2 \
|
||||||
-Wmissing-declarations -Wno-missing-prototypes -Wwrite-strings \
|
-Wmissing-declarations -Wno-missing-prototypes -Wwrite-strings \
|
||||||
-Wbad-function-cast -Wnested-externs -Wcomment -Winline \
|
-Wbad-function-cast -Wnested-externs -Wcomment -Winline \
|
||||||
-Wchar-subscripts -Wcast-align -Wno-format-nonliteral
|
-Wchar-subscripts -Wcast-align -Wno-format-nonliteral \
|
||||||
|
$(call check_gcc, -Wdeclaration-after-statement) \
|
||||||
# Early GCC versions don't support these flags, so you may need to comment
|
$(call check_gcc, -Wsequence-point) \
|
||||||
# this line out
|
$(call check_gcc, -Wextra) $(WAFTST) $(WSEQ) $(WEXTRA)
|
||||||
CFLAGS += -Wsequence-point -Wextra -Wdeclaration-after-statement
|
|
||||||
|
|
||||||
# For debugging. -Werror is pointless due to ISO C issues with dlsym
|
# For debugging. -Werror is pointless due to ISO C issues with dlsym
|
||||||
#CFLAGS += -ggdb
|
#CFLAGS += -ggdb
|
||||||
|
Loading…
Reference in New Issue
Block a user