X-Git-Url: http://plrg.eecs.uci.edu/git/?p=satune.git;a=blobdiff_plain;f=src%2FMakefile;h=5adb178ee6b95c31692f857c4d424bc09bb396e3;hp=ff0452f1062fe541c6abd2d23bdcbbb909719dce;hb=ef5d7a44cfe435c24e5f104e320b1a81835626e7;hpb=3bdede18c78d5ce85e8d7b98c095e3a714349ca2 diff --git a/src/Makefile b/src/Makefile index ff0452f..5adb178 100644 --- a/src/Makefile +++ b/src/Makefile @@ -4,11 +4,16 @@ PHONY += directories MKDIR_P = mkdir -p OBJ_DIR = bin -CPP_SOURCES := constraint.cc inc_solver.cc set.cc mutableset.cc element.cc function.cc order.cc table.cc predicate.cc boolean.cc +CPP_SOURCES := $(wildcard *.cc) $(wildcard AST/*.cc) $(wildcard ASTTransform/*.cc) $(wildcard ASTAnalyses/*.cc) $(wildcard Tuner/*.cc) $(wildcard Collections/*.cc) $(wildcard Backend/*.cc) $(wildcard Encoders/*.cc) + +C_SOURCES := $(wildcard *.c) $(wildcard AST/*.c) $(wildcard ASTTransform/*.c) $(wildcard ASTAnalyses/*.c) $(wildcard Tuner/*.c) $(wildcard Collections/*.c) $(wildcard Backend/*.c) $(wildcard Encoders/*.c) + +HEADERS := $(wildcard *.h) $(wildcard AST/*.h) $(wildcard ASTTransform/*.h) $(wildcard ASTAnalyses/*.h) $(wildcard Tuner/*.h) $(wildcard Collections/*.h) $(wildcard Backend/*.h) $(wildcard Encoders/*.h) OBJECTS := $(CPP_SOURCES:%.cc=$(OBJ_DIR)/%.o) $(C_SOURCES:%.c=$(OBJ_DIR)/%.o) -CPPFLAGS += -Iinclude -I. +CFLAGS := -Wall -g -O0 +CFLAGS += -IAST -IASTTransform -IASTAnalyses -ICollections -IBackend -I. -IEncoders -ITuner LDFLAGS := -ldl -lrt -rdynamic SHARED := -shared @@ -20,31 +25,38 @@ endif MARKDOWN := ../docs/Markdown/Markdown.pl -all: directories $(LIB_SO) +all: directories ${OBJ_DIR}/$(LIB_SO) directories: ${OBJ_DIR} ${OBJ_DIR}: ${MKDIR_P} ${OBJ_DIR} - -debug: CPPFLAGS += -DCONFIG_DEBUG + ${MKDIR_P} ${OBJ_DIR}/AST + ${MKDIR_P} ${OBJ_DIR}/ASTAnalyses + ${MKDIR_P} ${OBJ_DIR}/ASTTransform + ${MKDIR_P} ${OBJ_DIR}/Tuner + ${MKDIR_P} ${OBJ_DIR}/Collections + ${MKDIR_P} ${OBJ_DIR}/Backend + ${MKDIR_P} ${OBJ_DIR}/Encoders + +debug: CFLAGS += -DCONFIG_DEBUG debug: all +test: all + make -C Test + PHONY += docs -docs: *.cc *.h +docs: $(C_SOURCES) $(HEADERS) doxygen -$(LIB_SO): $(OBJECTS) - $(CXX) -g $(SHARED) -o $(LIB_SO) $+ $(LDFLAGS) - -${OBJ_DIR}/%.o: %.c - $(CC) -fPIC -c $< -o $@ $(CPPFLAGS) -Wno-unused-variable +${OBJ_DIR}/$(LIB_SO): $(OBJECTS) + $(CXX) -g $(SHARED) -o ${OBJ_DIR}/$(LIB_SO) $+ $(LDFLAGS) ${OBJ_DIR}/%.o: %.cc - $(CXX) -MMD -MF $@.d -o $@ -fPIC -c $< $(CPPFLAGS) + $(CXX) -fPIC -c $< -o $@ $(CFLAGS) -Wno-unused-variable -%.pdf: %.dot - dot -Tpdf $< -o $@ +${OBJ_DIR}/%.o: %.c + $(CC) -fPIC -c $< -o $@ $(CFLAGS) -Wno-unused-variable -include $(OBJECTS:%=$OBJ_DIR/.%.d) @@ -55,18 +67,17 @@ clean: PHONY += mrclean mrclean: clean - rm -rf docs + rm -rf ../docs PHONY += tags tags: ctags -R tabbing: - uncrustify -c C.cfg --no-backup *.cc - uncrustify -c C.cfg --no-backup *.h + uncrustify -c C.cfg --no-backup *.cc */*.cc + uncrustify -c C.cfg --no-backup *.h */*.h -.PHONY: $(PHONY) +wc: + wc */*.cc */*.h *.cc *.h -# A 1-inch margin PDF generated by 'pandoc' -%.pdf: %.md - pandoc -o $@ $< -V header-includes='\usepackage[margin=1in]{geometry}' +.PHONY: $(PHONY)