CC := gcc-4.9 CXX := g++-4.9 LD := g++-4.9 CP := cp PROG := abc MODULES := src/base/abc src/base/abci src/base/cmd \ src/base/io src/base/main src/base/ver \ src/aig/ivy src/aig/hop src/aig/rwt src/aig/deco \ src/aig/mem src/aig/dar src/aig/fra src/aig/cnf \ src/aig/csw src/aig/ec src/aig/aig src/aig/kit \ src/aig/bdc \ 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 \ src/misc/extra src/misc/mvc src/misc/st src/misc/util \ src/misc/espresso src/misc/nm src/misc/vec \ src/misc/hash \ src/opt/cut src/opt/dec src/opt/fxu src/opt/rwr \ src/opt/sim src/opt/ret src/opt/res src/opt/lpk \ src/sat/bsat src/sat/csat src/sat/msat src/sat/fraig \ src/phys/place default: $(PROG) #OPTFLAGS := -DNDEBUG -O3 OPTFLAGS := -g -O CFLAGS += -w $(OPTFLAGS) $(patsubst %, -I%, $(MODULES)) CFLAGS += -MD -MP CXXFLAGS += $(CFLAGS) #LIBS := -ldl -rdynamic -ltermcap LIBS := -ldl -rdynamic SRC := GARBAGE := core core.* *.stackdump ./tags $(PROG) .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 # Jason Luu Oct 26: Not necessary due to -MP -MD #%.d: %.c # ./depends.sh $(CC) `dirname $*.c` $(CFLAGS) $*.c > $@ # #%.d: %.cc # ./depends.sh $(CXX) `dirname $*.cc` $(CXXFLAGS) $(CFLAGS) $*.cc > $@ # #-include $(DEP) # Actual targets depend: $(DEP) clean: rm -rf $(PROG) $(OBJ) $(GARBAGE) $(OBJ:.o=.d) tags: ctags -R . $(PROG): $(OBJ) lib$(PROG).a $(LD) -o $@ $^ $(LIBS) lib$(PROG).a: $(OBJ) ar rv $@ $? ranlib $@ docs: doxygen doxygen.conf