X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=Makefile;h=83e6852a578d91203cc476017c700d8b83f1b92c;hp=1797de0086cb2c05b6a8fa88be6d452f44199436;hb=b5986420fc150a8c54e907fe7fdd7b89d6e93b55;hpb=5f8a5bfd39feb9822bb6184955a3653f4ef11dc9 diff --git a/Makefile b/Makefile index 1797de0..83e6852 100644 --- a/Makefile +++ b/Makefile @@ -1,9 +1,24 @@ -GTEST_DIR = /usr/src/gtest +GTEST_DIR ?= /usr/src/gtest + +EIGEN_CXXFLAGS := $(shell pkg-config --cflags eigen3) +ifeq ($(EIGEN_CXXFLAGS),) +$(error Empty EIGEN_CXXFLAGS. You probably need to install Eigen3) +endif + +GLEW_CXXFLAGS := $(shell pkg-config --cflags glew) +ifeq ($(GLEW_CXXFLAGS),) +$(error Empty GLEW_CXXFLAGS. You probably need to install GLEW) +endif + +GLEW_LIBS := $(shell pkg-config --libs glew) +ifeq ($(GLEW_LIBS),) +$(error Empty GLEW_LIBS. You probably need to install GLEW) +endif CC=gcc CXX=g++ -CXXFLAGS=-Wall -g -I$(GTEST_DIR)/include $(shell pkg-config --cflags eigen3 ) -LDFLAGS=-lSDL -lSDL_image -lGL -lrt -lpthread +CXXFLAGS=-Wall -g -I$(GTEST_DIR)/include $(EIGEN_CXXFLAGS) $(GLEW_CXXFLAGS) +LDFLAGS=-lSDL -lSDL_image -lGL -lrt -lpthread -lpng $(GLEW_LIBS) RANLIB=ranlib ifeq ($(COVERAGE),1) @@ -12,10 +27,32 @@ LDFLAGS += -fprofile-arcs -ftest-coverage endif DEMO_OBJS=demo.o -TESTS=effect_chain_test mix_effect_test gamma_expansion_effect_test gamma_compression_effect_test saturation_effect_test deconvolution_sharpen_effect_test + +# Unit tests. +TESTS=effect_chain_test +TESTS += mix_effect_test +TESTS += overlay_effect_test +TESTS += gamma_expansion_effect_test +TESTS += gamma_compression_effect_test +TESTS += colorspace_conversion_effect_test +TESTS += alpha_multiplication_effect_test +TESTS += alpha_division_effect_test +TESTS += saturation_effect_test +TESTS += deconvolution_sharpen_effect_test +TESTS += blur_effect_test +TESTS += unsharp_mask_effect_test +TESTS += glow_effect_test +TESTS += diffusion_effect_test +TESTS += white_balance_effect_test +TESTS += lift_gamma_gain_effect_test +TESTS += resample_effect_test +TESTS += padding_effect_test +TESTS += dither_effect_test +TESTS += flat_input_test +TESTS += ycbcr_input_test # Core. -LIB_OBJS=util.o widgets.o effect.o effect_chain.o +LIB_OBJS=util.o widgets.o effect.o effect_chain.o init.o # Inputs. LIB_OBJS += flat_input.o @@ -27,6 +64,8 @@ LIB_OBJS += white_balance_effect.o LIB_OBJS += gamma_expansion_effect.o LIB_OBJS += gamma_compression_effect.o LIB_OBJS += colorspace_conversion_effect.o +LIB_OBJS += alpha_multiplication_effect.o +LIB_OBJS += alpha_division_effect.o LIB_OBJS += saturation_effect.o LIB_OBJS += vignette_effect.o LIB_OBJS += mirror_effect.o @@ -35,7 +74,11 @@ LIB_OBJS += diffusion_effect.o LIB_OBJS += glow_effect.o LIB_OBJS += unsharp_mask_effect.o LIB_OBJS += mix_effect.o +LIB_OBJS += overlay_effect.o LIB_OBJS += resize_effect.o +LIB_OBJS += padding_effect.o +LIB_OBJS += resample_effect.o +LIB_OBJS += dither_effect.o LIB_OBJS += deconvolution_sharpen_effect.o LIB_OBJS += sandbox_effect.o @@ -51,17 +94,7 @@ gtest_sdl_main.o: gtest_sdl_main.cpp $(CXX) -MMD $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) -c $< -o $@ # Unit tests. -effect_chain_test: effect_chain_test.o $(TEST_OBJS) libmovit.a - $(CXX) -o $@ $^ $(LDFLAGS) -mix_effect_test: mix_effect_test.o $(TEST_OBJS) libmovit.a - $(CXX) -o $@ $^ $(LDFLAGS) -gamma_expansion_effect_test: gamma_expansion_effect_test.o $(TEST_OBJS) libmovit.a - $(CXX) -o $@ $^ $(LDFLAGS) -gamma_compression_effect_test: gamma_compression_effect_test.o $(TEST_OBJS) libmovit.a - $(CXX) -o $@ $^ $(LDFLAGS) -saturation_effect_test: saturation_effect_test.o $(TEST_OBJS) libmovit.a - $(CXX) -o $@ $^ $(LDFLAGS) -deconvolution_sharpen_effect_test: deconvolution_sharpen_effect_test.o $(TEST_OBJS) libmovit.a +$(TESTS): %: %.o $(TEST_OBJS) libmovit.a $(CXX) -o $@ $^ $(LDFLAGS) OBJS=$(DEMO_OBJS) $(LIB_OBJS) $(TEST_OBJS) $(TESTS:=.o) @@ -76,19 +109,29 @@ libmovit.a: $(LIB_OBJS) $(RANLIB) $@ %.o: %.cpp - $(CXX) -MMD $(CPPFLAGS) $(CXXFLAGS) -o $@ -c $< + $(CXX) -MMD -MP $(CPPFLAGS) $(CXXFLAGS) -o $@ -c $< DEPS=$(OBJS:.o=.d) -include $(DEPS) clean: $(RM) demo $(TESTS) libmovit.a $(OBJS) $(OBJS:.o=.gcno) $(OBJS:.o=.gcda) $(DEPS) step-*.dot + $(RM) -r movit.info coverage/ check: $(TESTS) - FAIL=0; \ + FAILED_TESTS=""; \ for TEST in $(TESTS); do \ - ./$$TEST || FAIL=1; \ + ./$$TEST || FAILED_TESTS="$$TEST $$FAILED_TESTS"; \ done; \ - exit $$FAIL - -.PHONY: clean check all + if [ "$$FAILED_TESTS" ]; then \ + echo Failed tests: $$FAILED_TESTS; \ + exit 1; \ + fi + +# You need to build with COVERAGE=1 to use this target. +coverage: check + lcov -d . -c -o movit.info + lcov --remove movit.info '*_test.cpp' '*/test_util.{cpp,h}' -o movit.info + genhtml -o coverage movit.info + +.PHONY: coverage clean check all