X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=Makefile;h=e3131e39521cd7b80a2e42b582d7542ee732aa1b;hb=90a79f28e095c7e368971ee5408ba8a10e0043c9;hp=50554a085f77680a6991bd28c6d91c9685b65f3b;hpb=4cd2d1351b6646142d0159665dccccbcb72ab19a;p=cassiopeia.git diff --git a/Makefile b/Makefile index 50554a0..e3131e3 100644 --- a/Makefile +++ b/Makefile @@ -15,7 +15,7 @@ ifneq (,$(filter parallel=%,$(DEB_BUILD_OPTIONS))) endif BIN="bin/cassiopeia" -LIBS=openssl collissiondetect +LIBS=openssl collisiondetect CC=libtool --mode=compile gcc CC_DEP=g++ @@ -32,19 +32,28 @@ else CFLAGS += -O2 endif -CFLAGS+=${ADDFLAGS} -Wall -Werror -Wextra -pedantic -std=c++11 -Ilib/openssl/include -Isrc +CFLAGS+=${ADDFLAGS} -Wall -Werror -Wextra -pedantic -std=c++1y -Ilib/openssl/include -Isrc CXXFLAGS=$(CFLAGS) LDFLAGS+=${ADDFLAGS} -L/usr/lib/i386-linux-gnu/ -lssl -lcrypto -ldl -Llib/openssl +ifneq (,$(filter coverage,$(DEB_BUILD_OPTIONS))) + LDFLAGS += -lgcov + CFLAGS += -fprofile-arcs -ftest-coverage +endif + + SRC_DIR=src OBJ_DIR=obj DEP_DIR=dep -FS_SRC=$(filter-out ${SRC_DIR}/mysql--disabled.cpp,$(wildcard ${SRC_DIR}/*.cpp)) +FS_SRC=$(wildcard ${SRC_DIR}/*.cpp) $(wildcard ${SRC_DIR}/log/*.cpp) $(wildcard ${SRC_DIR}/io/*.cpp) $(wildcard ${SRC_DIR}/crypto/*.cpp) $(wildcard ${SRC_DIR}/db/*.cpp) + FS_BIN=$(wildcard ${SRC_DIR}/app/*.cpp) FS_LIBS=$(wildcard lib/*/) FS_OBJ=$(FS_SRC:${SRC_DIR}/%.cpp=${OBJ_DIR}/%.lo) FS_DEP=$(FS_SRC:${SRC_DIR}/%.cpp=${DEP_DIR}/%.d) +LIB_OPENSSL=lib/openssl/libssl.a + .SUFFIXES: .c .cpp .d @@ -54,6 +63,8 @@ all: build .PHONY: clean clean:: -rm -rf .libs + -rm -rf *.gcov + -rm -rf gcov.log -rm -rf *.a -rm -rf *.d -rm -rf *.o @@ -70,7 +81,7 @@ endif .PHONY: dist-clean dist-clean: clean ${MAKE} -C lib/openssl clean - ${MAKE} -C lib/collissiondetect clean + ${MAKE} -C lib/collisiondetect clean build: cassiopeia @@ -88,26 +99,36 @@ install: build libs: ${LIBS} .PHONY: openssl -openssl: +openssl lib/openssl/libssl.a lib/openssl/libcrypto.a: ${MAKE} -C lib openssl -.PHONY: collissiondetect -collissiondetect: - ${MAKE} -C lib/collissiondetect +.PHONY: collisiondetect +collisiondetect: + ${MAKE} -C lib collisiondetect + +.PHONY: coverage +coverage: + find . -name "*.gcda" -exec rm {} + &&\ + rm -rf coverage &&\ + rm -rf coverage.info coverage_stripped.info &&\ + ${MAKE} "DEB_BUILD_OPTIONS=coverage noopt" &&\ + lcov -c --directory obj --directory test/obj --output-file coverage.info &&\ + lcov -r coverage.info "/usr/**" -o coverage_stripped.info &&\ + genhtml -p $(shell pwd) coverage_stripped.info --output-directory coverage # -------- cassiopeia: bin/cassiopeia bin/cassiopeia-signer bin/cassiopeia: libs ${FS_OBJ} ${OBJ_DIR}/apps/client.lo - ${MKDIR} $(shell dirname $@) && ${LD} ${LDFLAGS} -lmysqlclient -o $@ ${FS_OBJ} ${OBJ_DIR}/apps/client.lo + ${MKDIR} $(shell dirname $@) && ${LD} ${LDFLAGS} -lmysqlclient -lpqxx -lpq -o $@ ${FS_OBJ} ${OBJ_DIR}/apps/client.lo bin/cassiopeia-signer: libs ${FS_OBJ} ${OBJ_DIR}/apps/signer.lo - ${MKDIR} $(shell dirname $@) && ${LD} ${LDFLAGS} -o $@ $(filter-out ${OBJ_DIR}/mysql.lo,${FS_OBJ}) ${OBJ_DIR}/apps/signer.lo + ${MKDIR} $(shell dirname $@) && ${LD} ${LDFLAGS} -o $@ $(filter-out ${OBJ_DIR}/db/psql.lo, $(filter-out ${OBJ_DIR}/db/mysql.lo,${FS_OBJ})) ${OBJ_DIR}/apps/signer.lo -${DEP_DIR}/%.d: ${SRC_DIR}/%.cpp +${DEP_DIR}/%.d: ${SRC_DIR}/%.cpp ${LIB_OPENSSL} ${MKDIR} $(shell dirname $@) && $(CXX_DEP) $(CXXFLAGS) -M -MF $@ $< -${DEP_DIR}/%.d: ${SRC_DIR}/%.c +${DEP_DIR}/%.d: ${SRC_DIR}/%.c ${LIB_OPENSSL} ${MKDIR} $(shell dirname $@) && $(CC) $(CXXFLAGS) -M -MF $@ $< ${OBJ_DIR}/%.lo ${OBJ_DIR}/%.o: ${SRC_DIR}/%.c ${DEP_DIR}/%.d