@@ -22,6 +22,21 @@ ifneq ($(MINISAT2),)
22
22
CLEANFILES += $(MINISAT2_LIB ) $(patsubst % $(OBJEXT ) , % $(DEPEXT ) , $(MINISAT2_LIB ) )
23
23
endif
24
24
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
+
25
40
ifneq ($(IPASIR ) ,)
26
41
IPASIR_SRC =sat/satcheck_ipasir.cpp
27
42
IPASIR_INCLUDE =-I $(IPASIR )
@@ -75,6 +90,7 @@ SRC = $(BOOLEFORCE_SRC) \
75
90
$(GLUCOSE_SRC ) \
76
91
$(LINGELING_SRC ) \
77
92
$(MINISAT2_SRC ) \
93
+ $(MERGESAT_SRC ) \
78
94
$(IPASIR_SRC ) \
79
95
$(MINISAT_SRC ) \
80
96
$(PICOSAT_SRC ) \
@@ -230,6 +246,31 @@ $(MINISAT2)/minisat/core/Solver$(OBJEXT): $(MINISAT2)/minisat/core/Solver.cc
230
246
endif
231
247
endif
232
248
249
+ ifneq ($(MERGESAT ) ,)
250
+ ifeq ($(BUILD_ENV_ ) ,MSVC)
251
+ sat/satcheck_minisat2$(OBJEXT ) : sat/satcheck_minisat2.cpp
252
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
253
+
254
+ $(MERGESAT ) /minisat/core/Lookahead$(OBJEXT ) : $(MERGESAT ) /minisat/core/Lookahead.cc
255
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
256
+
257
+ $(MERGESAT ) /minisat/core/Solver$(OBJEXT ) : $(MERGESAT ) /minisat/core/Solver.cc
258
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
259
+
260
+ $(MERGESAT ) /minisat/simp/SimpSolver$(OBJEXT ) : $(MERGESAT ) /minisat/simp/SimpSolver.cc
261
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
262
+
263
+ $(MERGESAT ) /minisat/utils/ccnr$(OBJEXT ) : $(MERGESAT ) /minisat/utils/ccnr.cc
264
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
265
+
266
+ $(MERGESAT ) /minisat/utils/Options$(OBJEXT ) : $(MERGESAT ) /minisat/utils/Options.cc
267
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
268
+
269
+ $(MERGESAT ) /minisat/utils/System$(OBJEXT ) : $(MERGESAT ) /minisat/utils/System.cc
270
+ $(CXX ) $(CP_CXXFLAGS ) /w /nologo /c /EHsc $< /Fo$@
271
+ endif
272
+ endif
273
+
233
274
ifneq ($(GLUCOSE ) ,)
234
275
ifeq ($(BUILD_ENV_ ) ,MSVC)
235
276
sat/satcheck_glucose$(OBJEXT ) : sat/satcheck_glucose.cpp
@@ -245,6 +286,7 @@ endif
245
286
246
287
INCLUDES += -I .. \
247
288
$(CHAFF_INCLUDE ) $(BOOLEFORCE_INCLUDE ) $(MINISAT_INCLUDE ) $(MINISAT2_INCLUDE ) \
289
+ $(MERGESAT_INCLUDE ) \
248
290
$(IPASIR_INCLUDE ) \
249
291
$(SQUOLEM2_INC ) $(CUDD_INCLUDE ) $(GLUCOSE_INCLUDE ) \
250
292
$(PICOSAT_INCLUDE ) $(LINGELING_INCLUDE ) $(CADICAL_INCLUDE )
@@ -263,7 +305,7 @@ endif
263
305
endif
264
306
265
307
SOLVER_LIB = $(CHAFF_LIB ) $(BOOLEFORCE_LIB ) $(MINISAT_LIB ) \
266
- $(MINISAT2_LIB ) $(SQUOLEM2_LIB ) $(CUDD_LIB ) \
308
+ $(MINISAT2_LIB ) $(MERGESAT_LIB ) $( SQUOLEM2_LIB ) $(CUDD_LIB ) \
267
309
$(PICOSAT_LIB ) $(LINGELING_LIB ) $(GLUCOSE_LIB ) $(CADICAL_LIB )
268
310
269
311
SOLVER_OBJS = $(filter % $(OBJEXT ) , $(SOLVER_LIB ) )
0 commit comments