@@ -22,6 +22,21 @@ ifneq ($(MINISAT2),)
2222 CLEANFILES += $(MINISAT2_LIB ) $(patsubst % $(OBJEXT ) , % $(DEPEXT ) , $(MINISAT2_LIB ) )
2323endif
2424
25+ ifneq ($(MERGESAT ) ,)
26+ # MergeSat is based on MiniSat2 and is invoked (with suitable defines/ifdefs)
27+ # via satcheck_minisat2.{h,cpp}
28+ MERGESAT_SRC =sat/satcheck_minisat2.cpp
29+ MERGESAT_INCLUDE =-I $(MERGESAT )
30+ MERGESAT_LIB =$(MERGESAT ) /minisat/core/Lookahead$(OBJEXT ) \
31+ $(MERGESAT ) /minisat/core/Solver$(OBJEXT ) \
32+ $(MERGESAT ) /minisat/simp/SimpSolver$(OBJEXT ) \
33+ $(MERGESAT ) /minisat/utils/ccnr$(OBJEXT ) \
34+ $(MERGESAT ) /minisat/utils/Options$(OBJEXT ) \
35+ $(MERGESAT ) /minisat/utils/System$(OBJEXT )
36+ CP_CXXFLAGS += -DHAVE_MERGESAT -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS
37+ CLEANFILES += $(MERGESAT_LIB ) $(patsubst % $(OBJEXT ) , % $(DEPEXT ) , $(MERGESAT_LIB ) )
38+ endif
39+
2540ifneq ($(IPASIR ) ,)
2641 IPASIR_SRC =sat/satcheck_ipasir.cpp
2742 IPASIR_INCLUDE =-I $(IPASIR )
@@ -74,6 +89,7 @@ SRC = $(BOOLEFORCE_SRC) \
7489 $(GLUCOSE_SRC ) \
7590 $(LINGELING_SRC ) \
7691 $(MINISAT2_SRC ) \
92+ $(MERGESAT_SRC ) \
7793 $(IPASIR_SRC ) \
7894 $(MINISAT_SRC ) \
7995 $(PICOSAT_SRC ) \
@@ -227,6 +243,31 @@ $(MINISAT2)/minisat/core/Solver$(OBJEXT): $(MINISAT2)/minisat/core/Solver.cc
227243endif
228244endif
229245
246+ ifneq ($(MERGESAT ) ,)
247+ ifeq ($(BUILD_ENV_ ) ,MSVC)
248+ sat/satcheck_minisat2$(OBJEXT ) : sat/satcheck_minisat2.cpp
249+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
250+
251+ $(MERGESAT ) /minisat/core/Lookahead$(OBJEXT ) : $(MERGESAT ) /minisat/core/Lookahead.cc
252+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
253+
254+ $(MERGESAT ) /minisat/core/Solver$(OBJEXT ) : $(MERGESAT ) /minisat/core/Solver.cc
255+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
256+
257+ $(MERGESAT ) /minisat/simp/SimpSolver$(OBJEXT ) : $(MERGESAT ) /minisat/simp/SimpSolver.cc
258+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
259+
260+ $(MERGESAT ) /minisat/utils/ccnr$(OBJEXT ) : $(MERGESAT ) /minisat/utils/ccnr.cc
261+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
262+
263+ $(MERGESAT ) /minisat/utils/Options$(OBJEXT ) : $(MERGESAT ) /minisat/utils/Options.cc
264+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
265+
266+ $(MERGESAT ) /minisat/utils/System$(OBJEXT ) : $(MERGESAT ) /minisat/utils/System.cc
267+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
268+ endif
269+ endif
270+
230271ifneq ($(GLUCOSE ) ,)
231272ifeq ($(BUILD_ENV_ ) ,MSVC)
232273sat/satcheck_glucose$(OBJEXT ) : sat/satcheck_glucose.cpp
@@ -242,6 +283,7 @@ endif
242283
243284INCLUDES += -I .. \
244285 $(CHAFF_INCLUDE ) $(BOOLEFORCE_INCLUDE ) $(MINISAT_INCLUDE ) $(MINISAT2_INCLUDE ) \
286+ $(MERGESAT_INCLUDE ) \
245287 $(IPASIR_INCLUDE ) \
246288 $(SQUOLEM2_INC ) $(CUDD_INCLUDE ) $(GLUCOSE_INCLUDE ) \
247289 $(PICOSAT_INCLUDE ) $(LINGELING_INCLUDE ) $(CADICAL_INCLUDE )
@@ -260,7 +302,7 @@ endif
260302endif
261303
262304SOLVER_LIB = $(CHAFF_LIB ) $(BOOLEFORCE_LIB ) $(MINISAT_LIB ) \
263- $(MINISAT2_LIB ) $(SQUOLEM2_LIB ) $(CUDD_LIB ) \
305+ $(MINISAT2_LIB ) $(MERGESAT_LIB ) $( SQUOLEM2_LIB ) $(CUDD_LIB ) \
264306 $(PICOSAT_LIB ) $(LINGELING_LIB ) $(GLUCOSE_LIB ) $(CADICAL_LIB )
265307
266308SOLVER_OBJS = $(filter % $(OBJEXT ) , $(SOLVER_LIB ) )
0 commit comments