2005-07-29 17:01:00 +02:00
|
|
|
CC := gcc
|
2010-11-01 09:35:04 +01:00
|
|
|
CXX := g++
|
2005-07-29 17:01:00 +02:00
|
|
|
LD := g++
|
|
|
|
|
CP := cp
|
|
|
|
|
|
|
|
|
|
PROG := abc
|
|
|
|
|
|
2008-07-02 17:01:00 +02:00
|
|
|
MODULES := \
|
2010-11-01 10:06:26 +01:00
|
|
|
$(wildcard src/ext) src/misc/ext \
|
2012-01-21 13:30:10 +01:00
|
|
|
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 \
|
2012-12-10 10:11:44 +01:00
|
|
|
src/map/mapper src/map/mio src/map/super src/map/if \
|
2012-08-25 06:31:46 +02:00
|
|
|
src/map/amap src/map/cov src/map/scl \
|
2012-01-21 13:30:10 +01:00
|
|
|
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 \
|
2013-04-03 07:22:49 +02:00
|
|
|
src/opt/cgt src/opt/csw src/opt/dar src/opt/dau src/opt/sfm \
|
2012-11-14 22:55:24 +01:00
|
|
|
src/sat/bsat src/sat/csat src/sat/msat src/sat/psat src/sat/cnf src/sat/bmc \
|
2013-04-01 08:09:51 +02:00
|
|
|
src/bool/bdc src/bool/deco src/bool/dec src/bool/kit src/bool/lucky src/bool/rsb \
|
2012-01-21 13:30:10 +01:00
|
|
|
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 \
|
2013-04-26 00:32:30 +02:00
|
|
|
src/proof/abs src/proof/ssc \
|
2012-01-21 13:30:10 +01:00
|
|
|
src/aig/aig src/aig/saig src/aig/gia src/aig/ioa src/aig/ivy src/aig/hop \
|
2012-09-30 01:44:45 +02:00
|
|
|
src/aig/miniaig \
|
2010-11-01 10:06:26 +01:00
|
|
|
src/python
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2010-11-01 09:35:04 +01:00
|
|
|
all: $(PROG)
|
2005-09-10 17:01:00 +02:00
|
|
|
default: $(PROG)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2012-01-21 13:30:10 +01:00
|
|
|
arch_flags : arch_flags.c
|
2012-01-22 03:38:09 +01:00
|
|
|
$(CC) arch_flags.c -o arch_flags
|
2011-11-24 23:25:47 +01:00
|
|
|
|
2012-01-22 03:38:09 +01:00
|
|
|
ARCHFLAGS := $(shell $(CC) arch_flags.c -o arch_flags && ./arch_flags)
|
2012-01-21 13:30:10 +01:00
|
|
|
OPTFLAGS := -g -O #-DABC_NAMESPACE=xxx
|
2005-09-02 17:01:00 +02:00
|
|
|
|
2013-05-04 20:10:25 +02:00
|
|
|
CFLAGS += -Wall -Wno-unused-function $(OPTFLAGS) $(ARCHFLAGS) -I$(PWD)/src
|
|
|
|
|
|
|
|
|
|
ifeq ($(shell $(CC) -dumpversion | awk '{FS="."; print ($$1>=4 && $$2>=6)}'),1)
|
|
|
|
|
# Set -Wno-unused-bug-set-variable for GCC 4.6.0 and greater only
|
|
|
|
|
CFLAGS += -Wno-unused-but-set-variable
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
LIBS := -ldl
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2013-05-04 20:10:25 +02:00
|
|
|
ifneq ($(READLINE),0)
|
|
|
|
|
CFLAGS += -DABC_USE_READLINE
|
|
|
|
|
LIBS += -lreadline
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
ifneq ($(PTHREADS),0)
|
|
|
|
|
CFLAGS += -DABC_USE_PTHREADS
|
|
|
|
|
LIBS += -lpthread
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
CXXFLAGS += $(CFLAGS)
|
2010-11-01 09:35:04 +01:00
|
|
|
|
2005-07-29 17:01:00 +02:00
|
|
|
SRC :=
|
2012-01-22 03:38:09 +01:00
|
|
|
GARBAGE := core core.* *.stackdump ./tags $(PROG) arch_flags
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
.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
|
|
|
|
|
|
2012-02-17 05:57:03 +01:00
|
|
|
%.o: %.c
|
|
|
|
|
@echo "\`\` Compiling:" $(LOCAL_PATH)/$<
|
|
|
|
|
@$(CC) -c $(CFLAGS) $< -o $@
|
|
|
|
|
|
|
|
|
|
%.o: %.cc
|
|
|
|
|
@echo "\`\` Compiling:" $(LOCAL_PATH)/$<
|
2013-05-04 20:10:25 +02:00
|
|
|
@$(CXX) -c $(CXXFLAGS) $< -o $@
|
2012-02-17 05:57:03 +01:00
|
|
|
|
2005-07-29 17:01:00 +02:00
|
|
|
%.d: %.c
|
2012-02-17 05:57:03 +01:00
|
|
|
@echo "\`\` Dependency:" $(LOCAL_PATH)/$<
|
|
|
|
|
@./depends.sh $(CC) `dirname $*.c` $(CFLAGS) $*.c > $@
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
%.d: %.cc
|
2012-02-17 05:57:03 +01:00
|
|
|
@echo "\`\` Generating dependency:" $(LOCAL_PATH)/$<
|
2013-05-04 20:10:25 +02:00
|
|
|
@./depends.sh $(CXX) `dirname $*.cc` $(CXXFLAGS) $*.cc > $@
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
-include $(DEP)
|
|
|
|
|
|
|
|
|
|
# Actual targets
|
|
|
|
|
|
|
|
|
|
depend: $(DEP)
|
|
|
|
|
|
|
|
|
|
clean:
|
2012-02-17 05:57:03 +01:00
|
|
|
@echo "\`\` Cleaning up..."
|
|
|
|
|
@rm -rvf $(PROG) lib$(PROG).a $(OBJ) $(GARBAGE) $(OBJ:.o=.d)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
tags:
|
2012-10-29 23:35:02 +01:00
|
|
|
etags `find . -type f -regex '.*\.\(c\|h\)'`
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
$(PROG): $(OBJ)
|
2012-02-17 05:57:03 +01:00
|
|
|
@echo "\`\` Building binary:" $(notdir $@)
|
|
|
|
|
@$(LD) -o $@ $^ $(LIBS)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2008-01-31 05:01:00 +01:00
|
|
|
lib$(PROG).a: $(OBJ)
|
2012-02-17 05:57:03 +01:00
|
|
|
@echo "\`\` Linking:" $(notdir $@)
|
|
|
|
|
@ar rv $@ $?
|
|
|
|
|
@ranlib $@
|
2008-01-31 05:01:00 +01:00
|
|
|
|
2005-07-29 17:01:00 +02:00
|
|
|
docs:
|
2012-02-17 05:57:03 +01:00
|
|
|
@echo "\`\` Building documentation." $(notdir $@)
|
|
|
|
|
@doxygen doxygen.conf
|