abc/Makefile

153 lines
4.1 KiB
Makefile
Raw Normal View History

2013-11-27 21:17:00 +01:00
CC := gcc
2010-11-01 09:35:04 +01:00
CXX := g++
LD := $(CXX)
2014-07-24 19:57:40 +02:00
MSG_PREFIX ?=
$(info $(MSG_PREFIX)Using CC=$(CC))
$(info $(MSG_PREFIX)Using CXX=$(CXX))
$(info $(MSG_PREFIX)Using LD=$(LD))
2005-07-29 17:01:00 +02:00
PROG := abc
2008-07-02 17:01:00 +02:00
MODULES := \
$(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 \
2014-09-12 22:40:48 +02:00
src/base/main src/base/ver src/base/wlc src/base/test \
2012-01-21 13:30:10 +01:00
src/bdd/cudd src/bdd/dsd src/bdd/epd src/bdd/mtr src/bdd/parse \
src/bdd/reo src/bdd/cas \
src/map/mapper src/map/mio src/map/super src/map/if \
2013-07-12 22:02:32 +02:00
src/map/amap src/map/cov src/map/scl src/map/mpm \
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 \
src/sat/bsat src/sat/csat src/sat/msat src/sat/psat src/sat/cnf src/sat/bmc \
src/bool/bdc src/bool/deco src/bool/dec src/bool/kit src/bool/lucky \
src/bool/rsb src/bool/rpo \
2014-01-28 08:46:10 +01:00
src/proof/pdr src/proof/abs src/proof/bbr src/proof/llb src/proof/live \
2012-01-21 13:30:10 +01:00
src/proof/cec src/proof/dch src/proof/fraig src/proof/fra src/proof/ssw \
2014-01-28 08:46:10 +01:00
src/proof/ssc src/proof/int \
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
$(CC) arch_flags.c -o arch_flags
ARCHFLAGS ?= $(shell $(CC) arch_flags.c -o arch_flags && ./arch_flags)
OPTFLAGS ?= -g -O #-DABC_NAMESPACE=xxx
2005-09-02 17:01:00 +02:00
CFLAGS += -Wall -Wno-unused-function -Wno-write-strings -Wno-sign-compare $(OPTFLAGS) $(ARCHFLAGS) -Isrc
# Set -Wno-unused-bug-set-variable for GCC 4.6.0 and greater only
ifneq ($(or $(findstring gcc,$(CC)),$(findstring g++,$(CC))),)
empty:=
space:=$(empty) $(empty)
GCC_VERSION=$(shell $(CC) -dumpversion)
GCC_MAJOR=$(word 1,$(subst .,$(space),$(GCC_VERSION)))
GCC_MINOR=$(word 2,$(subst .,$(space),$(GCC_VERSION)))
2014-07-24 19:57:40 +02:00
$(info $(MSG_PREFIX)Found GCC_VERSION $(GCC_VERSION))
ifeq ($(findstring $(GCC_MAJOR),0 1 2 3),)
2014-07-24 19:57:40 +02:00
$(info $(MSG_PREFIX)Found GCC_MAJOR>=4)
ifeq ($(findstring $(GCC_MINOR),0 1 2 3 4 5),)
2014-07-24 19:57:40 +02:00
$(info $(MSG_PREFIX)Found GCC_MINOR>=6)
CFLAGS += -Wno-unused-but-set-variable
endif
endif
endif
2013-08-15 09:58:23 +02:00
# LIBS := -ldl -lrt
LIBS := -ldl
ifneq ($(findstring Darwin, $(shell uname)), Darwin)
LIBS += -lrt
endif
2005-07-29 17:01:00 +02:00
ifneq ($(READLINE),0)
CFLAGS += -DABC_USE_READLINE
LIBS += -lreadline
endif
ifneq ($(PTHREADS),0)
CFLAGS += -DABC_USE_PTHREADS
LIBS += -lpthread
endif
2014-07-24 19:57:40 +02:00
$(info $(MSG_PREFIX)Using CFLAGS=$(CFLAGS))
CXXFLAGS += $(CFLAGS)
2010-11-01 09:35:04 +01:00
2005-07-29 17:01:00 +02:00
SRC :=
GARBAGE := core core.* *.stackdump ./tags $(PROG) arch_flags
2005-07-29 17:01:00 +02:00
.PHONY: all default tags clean docs
2005-07-29 17:01:00 +02:00
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
%.o: %.c
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` Compiling:" $(LOCAL_PATH)/$<
@$(CC) -c $(CFLAGS) $< -o $@
%.o: %.cc
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` Compiling:" $(LOCAL_PATH)/$<
@$(CXX) -c $(CXXFLAGS) $< -o $@
2014-10-22 04:45:52 +02:00
%.o: %.cpp
@echo "$(MSG_PREFIX)\`\` Compiling:" $(LOCAL_PATH)/$<
@$(CXX) -c $(CXXFLAGS) $< -o $@
2005-07-29 17:01:00 +02:00
%.d: %.c
2014-10-22 04:45:52 +02:00
@echo "$(MSG_PREFIX)\`\` Generating dependency:" $(LOCAL_PATH)/$<
@./depends.sh $(CC) `dirname $*.c` $(CFLAGS) $*.c > $@
2005-07-29 17:01:00 +02:00
%.d: %.cc
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` Generating dependency:" $(LOCAL_PATH)/$<
@./depends.sh $(CXX) `dirname $*.cc` $(CXXFLAGS) $*.cc > $@
2005-07-29 17:01:00 +02:00
2014-10-22 04:45:52 +02:00
%.d: %.cpp
@echo "$(MSG_PREFIX)\`\` Generating dependency:" $(LOCAL_PATH)/$<
@./depends.sh $(CXX) `dirname $*.cpp` $(CXXFLAGS) $*.cpp > $@
2005-07-29 17:01:00 +02:00
-include $(DEP)
# Actual targets
depend: $(DEP)
clean:
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` 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)
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` 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)
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` Linking:" $(notdir $@)
@ar rv $@ $?
@ranlib $@
2008-01-31 05:01:00 +01:00
2005-07-29 17:01:00 +02:00
docs:
2013-11-27 21:17:00 +01:00
@echo "$(MSG_PREFIX)\`\` Building documentation." $(notdir $@)
@doxygen doxygen.conf