8 VectorBoolean * constraints;
10 VectorElement * elements;
13 CSolver * allocCSolver();
14 Set * createSet(CSolver *, VarType type, uint64_t * elements, uint num);
15 Set * createRangeSet(CSolver *, VarType type, uint64_t lowrange, uint64_t highrange);
16 MutableSet * createMutableSet(CSolver *, VarType type);
18 void addItem(CSolver *, MutableSet * set, uint64_t element);
19 uint64_t createUniqueItem(CSolver *, MutableSet * set);
21 Element * getElementVar(CSolver *, Set * set);
22 Boolean * getBooleanVar(CSolver *, VarType type);
24 Function * createFunctionOperator(CSolver *, enum ArithOp op, Set ** domain, Set * range, enum OverFlowBehavior overflowbehavior, Boolean * overflowstatus);
26 Function * createFunctionOperatorPure(CSolver *, enum ArithOp op);
27 Predicate * createPredicateOperator(CSolver *, enum CompOp op, Set ** domain);
29 Table * createTable(CSolver *, Set **domains, Set * range);
30 void addTableEntry(CSolver *, Element ** inputs, Element *result);
31 Function * completeTable(CSolver *, struct Table *);
33 Element * applyFunction(CSolver *, Function * function, Element ** array);
34 Boolean * applyPredicate(CSolver *, Predicate * predicate, Element ** inputs);
35 Boolean * applyLogicalOperation(CSolver *, enum LogicOp op, Boolean ** array);
37 void addBoolean(CSolver *, Boolean * constraint);
39 Order * createOrder(CSolver *, enum OrderType type, Set * set);
40 Boolean * orderConstraint(CSolver *, Order * order, uint64_t first, uint64_t second);