Makefile 2.71 KB
Newer Older
Alan Mishchenko committed
1
CC   := gcc
2
CXX  := g++
Alan Mishchenko committed
3 4 5 6 7
LD   := g++
CP   := cp

PROG := abc

Alan Mishchenko committed
8
MODULES := \
9
        $(wildcard src/ext) src/misc/ext \
10 11 12 13 14
	src/base/abc src/base/abci src/base/cmd src/base/io \
	src/base/main src/base/ver src/base/test \
	src/bdd/cudd src/bdd/dsd src/bdd/epd src/bdd/mtr src/bdd/parse \
	src/bdd/reo src/bdd/cas \
	src/map/fpga src/map/mapper src/map/mio src/map/super src/map/if \
15
	src/map/amap src/map/cov src/map/scl \
16 17 18 19 20 21 22
	src/misc/extra src/misc/mvc src/misc/st src/misc/util src/misc/nm \
	src/misc/vec src/misc/hash src/misc/tim src/misc/bzlib src/misc/zlib \
	src/misc/mem src/misc/bar src/misc/bbl \
	src/opt/cut src/opt/fxu src/opt/rwr src/opt/mfs src/opt/sim \
	src/opt/ret src/opt/res src/opt/lpk src/opt/nwk src/opt/rwt \
	src/opt/cgt src/opt/csw src/opt/dar \
	src/sat/bsat src/sat/csat src/sat/msat src/sat/psat src/sat/cnf \
Alan Mishchenko committed
23
	src/bool/bdc src/bool/deco src/bool/dec src/bool/kit src/bool/lucky \
24 25
	src/proof/pdr src/proof/int src/proof/bbr src/proof/llb src/proof/live \
	src/proof/cec src/proof/dch src/proof/fraig src/proof/fra src/proof/ssw \
26
	src/proof/abs \
27
	src/aig/aig src/aig/saig src/aig/gia src/aig/ioa src/aig/ivy src/aig/hop \
28
	src/aig/miniaig \
29
	src/python 
Alan Mishchenko committed
30

31
all: $(PROG)
Alan Mishchenko committed
32
default: $(PROG)
Alan Mishchenko committed
33

34
arch_flags : arch_flags.c
35
	$(CC) arch_flags.c -o arch_flags
36

37
ARCHFLAGS := $(shell $(CC) arch_flags.c -o arch_flags && ./arch_flags)
38
OPTFLAGS  := -g -O #-DABC_NAMESPACE=xxx
Alan Mishchenko committed
39

40
CFLAGS   += -Wall -Wno-unused-function -Wno-unused-but-set-variable $(OPTFLAGS) $(ARCHFLAGS) -I$(PWD)/src
Alan Mishchenko committed
41 42
CXXFLAGS += $(CFLAGS) 

43
#LIBS := -m32 -ldl -rdynamic -lreadline -ltermcap
44
LIBS := -ldl -lreadline -lpthread
45

Alan Mishchenko committed
46
SRC  := 
47
GARBAGE := core core.* *.stackdump ./tags $(PROG) arch_flags
Alan Mishchenko committed
48 49 50 51 52 53 54 55 56 57 58 59 60 61

.PHONY: tags clean docs

include $(patsubst %, %/module.make, $(MODULES))

OBJ := \
	$(patsubst %.cc, %.o, $(filter %.cc, $(SRC))) \
	$(patsubst %.c, %.o,  $(filter %.c, $(SRC)))  \
	$(patsubst %.y, %.o,  $(filter %.y, $(SRC))) 

DEP := $(OBJ:.o=.d)

# implicit rules

62 63 64 65 66 67 68 69
%.o: %.c
	@echo "\`\` Compiling:" $(LOCAL_PATH)/$<
	@$(CC) -c $(CFLAGS) $< -o $@

%.o: %.cc
	@echo "\`\` Compiling:" $(LOCAL_PATH)/$<
	@$(CC) -c $(CXXFLAGS) $< -o $@

Alan Mishchenko committed
70
%.d: %.c
71 72
	@echo "\`\` Dependency:" $(LOCAL_PATH)/$<
	@./depends.sh $(CC) `dirname $*.c` $(CFLAGS) $*.c > $@
Alan Mishchenko committed
73 74

%.d: %.cc
75 76
	@echo "\`\` Generating dependency:" $(LOCAL_PATH)/$<
	@./depends.sh $(CXX) `dirname $*.cc` $(CXXFLAGS) $(CFLAGS) $*.cc > $@
Alan Mishchenko committed
77 78 79 80 81 82 83 84

-include $(DEP)

# Actual targets

depend: $(DEP)

clean: 
85 86
	@echo "\`\` Cleaning up..."
	@rm -rvf $(PROG) lib$(PROG).a $(OBJ) $(GARBAGE) $(OBJ:.o=.d) 
Alan Mishchenko committed
87 88 89 90 91

tags:
	ctags -R .

$(PROG): $(OBJ)
92 93
	@echo "\`\` Building binary:" $(notdir $@)
	@$(LD) -o $@ $^ $(LIBS)
Alan Mishchenko committed
94

Alan Mishchenko committed
95
lib$(PROG).a: $(OBJ)
96 97 98
	@echo "\`\` Linking:" $(notdir $@)
	@ar rv $@ $?
	@ranlib $@
Alan Mishchenko committed
99

Alan Mishchenko committed
100
docs:
101 102
	@echo "\`\` Building documentation." $(notdir $@)
	@doxygen doxygen.conf