Merge branch 'master' of ssh://demsky.eecs.uci.edu/home/git/constraint_compiler into...
[satune.git] / src / Makefile
1 include common.mk
2
3 PHONY += directories
4 MKDIR_P = mkdir -p
5 OBJ_DIR = bin
6
7 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)
8
9 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)
10
11 HEADERS := $(wildcard *.h) $(wildcard AST/*.h) $(wildcard ASTTransform/*.h) $(wildcard ASTAnalyses/*.h) $(wildcard Tuner/*.h) $(wildcard Collections/*.h) $(wildcard Backend/*.h) $(wildcard Encoders/*.h)
12
13 OBJECTS := $(CPP_SOURCES:%.cc=$(OBJ_DIR)/%.o) $(C_SOURCES:%.c=$(OBJ_DIR)/%.o)
14
15 CFLAGS := -Wall -g -O0
16 CFLAGS += -IAST -IASTTransform -IASTAnalyses -ICollections -IBackend -I. -IEncoders -ITuner
17 LDFLAGS := -ldl -lrt -rdynamic
18 SHARED := -shared
19
20 # Mac OSX options
21 ifeq ($(UNAME), Darwin)
22 LDFLAGS := -ldl
23 SHARED := -Wl,-undefined,dynamic_lookup -dynamiclib
24 endif
25
26 MARKDOWN := ../docs/Markdown/Markdown.pl
27
28 all: directories ${OBJ_DIR}/$(LIB_SO)
29
30 directories: ${OBJ_DIR}
31
32 ${OBJ_DIR}:
33         ${MKDIR_P} ${OBJ_DIR}
34         ${MKDIR_P} ${OBJ_DIR}/AST
35         ${MKDIR_P} ${OBJ_DIR}/ASTAnalyses
36         ${MKDIR_P} ${OBJ_DIR}/ASTTransform
37         ${MKDIR_P} ${OBJ_DIR}/Tuner
38         ${MKDIR_P} ${OBJ_DIR}/Collections
39         ${MKDIR_P} ${OBJ_DIR}/Backend
40         ${MKDIR_P} ${OBJ_DIR}/Encoders
41
42 debug: CFLAGS += -DCONFIG_DEBUG
43 debug: all
44
45 test: all
46         make -C Test
47
48 PHONY += docs
49 docs: $(C_SOURCES) $(HEADERS)
50         doxygen
51
52 ${OBJ_DIR}/$(LIB_SO): $(OBJECTS)
53         $(CXX) -g $(SHARED) -o ${OBJ_DIR}/$(LIB_SO) $+ $(LDFLAGS)
54
55 ${OBJ_DIR}/%.o: %.cc
56         $(CXX) -fPIC -c $< -o $@ $(CFLAGS) -Wno-unused-variable
57
58 ${OBJ_DIR}/%.o: %.c
59         $(CC) -fPIC -c $< -o $@ $(CFLAGS) -Wno-unused-variable
60
61 -include $(OBJECTS:%=$OBJ_DIR/.%.d)
62
63 PHONY += clean
64 clean:
65         rm -f *.o *.so
66         rm -rf $(OBJ_DIR)
67
68 PHONY += mrclean
69 mrclean: clean
70         rm -rf ../docs
71
72 PHONY += tags
73 tags:
74         ctags -R
75
76 tabbing:
77         uncrustify -c C.cfg --no-backup *.cc */*.cc
78         uncrustify -c C.cfg --no-backup *.h */*.h
79
80 wc:
81         wc */*.cc */*.h *.cc *.h
82
83 .PHONY: $(PHONY)