Big Tabbing Change
[satune.git] / src / Backend / satencoder.h
1 #ifndef SATENCODER_H
2 #define SATENCODER_H
3
4 #include "classlist.h"
5 #include "structs.h"
6 #include "inc_solver.h"
7 #include "constraint.h"
8
9 struct SATEncoder {
10         uint varcount;
11         CNF *cnf;
12 };
13
14 #include "satelemencoder.h"
15 #include "satorderencoder.h"
16 #include "satfunctableencoder.h"
17
18 SATEncoder *allocSATEncoder();
19 void deleteSATEncoder(SATEncoder *This);
20 void encodeAllSATEncoder(CSolver *csolver, SATEncoder *This);
21 Edge getNewVarSATEncoder(SATEncoder *This);
22 void getArrayNewVarsSATEncoder(SATEncoder *encoder, uint num, Edge *carray);
23 Edge encodeConstraintSATEncoder(SATEncoder *This, Boolean *constraint);
24 Edge encodeVarSATEncoder(SATEncoder *This, BooleanVar *constraint);
25 Edge encodeLogicSATEncoder(SATEncoder *This, BooleanLogic *constraint);
26 Edge encodePredicateSATEncoder(SATEncoder *This, BooleanPredicate *constraint);
27 Edge encodeTablePredicateSATEncoder(SATEncoder *This, BooleanPredicate *constraint);
28
29
30
31 void encodeElementSATEncoder(SATEncoder *encoder, Element *This);
32 void encodeElementFunctionSATEncoder(SATEncoder *encoder, ElementFunction *This);
33 void encodeTableElementFunctionSATEncoder(SATEncoder *encoder, ElementFunction *This);
34
35 #endif