mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-26 17:29:21 +00:00 
			
		
		
		
	reorganizing the code
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
		
							parent
							
								
									9c057b87d1
								
							
						
					
					
						commit
						f57d4b1b19
					
				
					 34 changed files with 602 additions and 181 deletions
				
			
		|  | @ -30,9 +30,9 @@ add_lib('old_params', ['model', 'simplifier']) | |||
| add_lib('cmd_context', ['tactic', 'rewriter', 'model', 'old_params', 'simplifier']) | ||||
| add_lib('substitution', ['ast'], 'ast/substitution') | ||||
| add_lib('normal_forms', ['rewriter', 'old_params'], 'ast/normal_forms') | ||||
| add_lib('pattern', ['normal_forms'], 'ast/pattern') | ||||
| add_lib('parser_util', ['ast']) | ||||
| add_lib('smt2parser', ['cmd_context', 'parser_util']) | ||||
| add_lib('pattern', ['normal_forms', 'smt2parser'], 'ast/pattern') | ||||
| add_lib('macros', ['simplifier', 'old_params'], 'ast/macros') | ||||
| add_lib('grobner', ['ast'], 'math/grobner') | ||||
| add_lib('euclid', ['util'], 'math/euclid') | ||||
|  | @ -64,4 +64,5 @@ add_exe('shell', ['api', 'sat', 'extra_cmds'], exe_name='z3') | |||
| add_exe('test', ['api', 'fuzzing'], exe_name='test-z3') | ||||
| add_dll('api_dll', ['api', 'sat', 'extra_cmds'], 'api/dll', dll_name='z3') | ||||
| 
 | ||||
| mk_auto_src() | ||||
| mk_makefile() | ||||
|  |  | |||
|  | @ -414,4 +414,17 @@ def mk_makefile(): | |||
|         else: | ||||
|             print "Type 'cd %s; make' to build Z3" % BUILD_DIR | ||||
|          | ||||
| # Generate automatically generated source code | ||||
| def mk_auto_src(): | ||||
|     mk_pat_db() | ||||
| 
 | ||||
| # TODO: delete after src/ast/pattern/expr_pattern_match | ||||
| # database.smt ==> database.h | ||||
| def mk_pat_db(): | ||||
|     c = _Name2Component['pattern'] | ||||
|     fin  = open('%s/database.smt2' % c.src_dir, 'r') | ||||
|     fout = open('%s/database.h'  % c.src_dir, 'w') | ||||
|     fout.write('char const * g_pattern_database =\n') | ||||
|     for line in fin: | ||||
|         fout.write('"%s\\n"\n' % line.strip('\n')) | ||||
|     fout.write(';\n')     | ||||
|  |  | |||
|  | @ -359,9 +359,9 @@ struct nnf::imp { | |||
|     void checkpoint() { | ||||
|         cooperate("nnf"); | ||||
|         if (memory::get_allocation_size() > m_max_memory) | ||||
|             throw nnf_exception(TACTIC_MAX_MEMORY_MSG); | ||||
|             throw nnf_exception(Z3_MAX_MEMORY_MSG); | ||||
|         if (m_cancel) | ||||
|             throw nnf_exception(TACTIC_CANCELED_MSG); | ||||
|             throw nnf_exception(Z3_CANCELED_MSG); | ||||
|     } | ||||
| 
 | ||||
|     void set_new_child_flag() { | ||||
|  |  | |||
							
								
								
									
										332
									
								
								src/ast/pattern/database.smt2
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										332
									
								
								src/ast/pattern/database.smt2
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,332 @@ | |||
| (declare-fun ?store (Int Int Int) Int) | ||||
| (declare-fun ?select (Int Int) Int) | ||||
| (declare-fun ?PO (Int Int) Int) | ||||
| (declare-fun ?asChild (Int Int) Int) | ||||
| (declare-fun ?classDown (Int Int) Int) | ||||
| (declare-fun ?array (Int) Int) | ||||
| (declare-fun ?elemtype (Int) Int) | ||||
| (declare-fun ?is (Int Int) Int) | ||||
| (declare-fun ?cast (Int Int) Int) | ||||
| (declare-fun ?Object () Int) | ||||
| (declare-fun ?null () Int) | ||||
| (declare-fun ?typeof (Int) Int) | ||||
| (declare-fun ?asElems (Int) Int) | ||||
| (declare-fun ?isAllocated (Int Int) Int)  | ||||
| (declare-fun ?fClosedTime (Int) Int) | ||||
| (declare-fun ?eClosedTime (Int) Int) | ||||
| (declare-fun ?max (Int) Int) | ||||
| (declare-fun ?asLockSet (Int) Int) | ||||
| (declare-fun ?isNewArray (Int) Int) | ||||
| (declare-fun ?classLiteral (Int) Int) | ||||
| (declare-fun ?Class () Int) | ||||
| (declare-fun ?alloc () Int) | ||||
| (declare-fun ?arrayType () Int) | ||||
| (declare-fun ?f (Int) Int) | ||||
| (declare-fun ?finv (Int) Int) | ||||
| (declare-fun ?select2 (Int Int Int) Int)  | ||||
| (declare-fun ?store2 (Int Int Int Int) Int) | ||||
| (declare-fun ?subtypes (Int Int) Bool) | ||||
| (declare-fun ?Unbox (Int) Int) | ||||
| (declare-fun ?UnboxedType (Int) Int) | ||||
| (declare-fun ?Box (Int Int) Int) | ||||
| (declare-fun ?System.Object () Int) | ||||
| (declare-fun ?Smt.true () Int) | ||||
| (declare-fun ?AsRepField (Int Int) Int) | ||||
| (declare-fun ?AsPeerField (Int) Int) | ||||
| (declare-fun ?nullObject () Int) | ||||
| (declare-fun ?ownerRef_ () Int) | ||||
| (declare-fun ?ownerFrame_ () Int) | ||||
| (declare-fun IntsHeap (Int) Int) | ||||
| (declare-fun ?localinv_ () Int) | ||||
| (declare-fun ?inv_ () Int) | ||||
| (declare-fun ?BaseClass_ (Int) Int) | ||||
| (declare-fun ?typeof_ (Int) Int) | ||||
| (declare-fun ?PeerGroupPlaceholder_ () Int) | ||||
| (declare-fun ?ClassRepr (Int) Int) | ||||
| (declare-fun ?RefArray (Int Int) Int) | ||||
| (declare-fun Ints_ (Int Int) Int) | ||||
| (declare-fun ?RefArrayGet (Int Int) Int) | ||||
| (declare-fun ?elements_ () Int) | ||||
| (declare-fun ?NonNullRefArray (Int Int) Int) | ||||
| (declare-fun IntsNotNull_ (Int Int) Int) | ||||
| (declare-fun ?Rank_ (Int) Int) | ||||
| (declare-fun ?ValueArray (Int Int) Int) | ||||
| (declare-fun ?ArrayCategory_ (Int) Int) | ||||
| (declare-fun ?ArrayCategoryValue_ () Int) | ||||
| (declare-fun ?ElementType_ (Int) Int) | ||||
| (declare-fun ?System.Array () Int) | ||||
| (declare-fun ?allocated_ () Int) | ||||
| (declare-fun ?StructGet_ (Int Int) Int) | ||||
| (declare-fun ?AsRangeField (Int Int) Int) | ||||
| (declare-fun IntsAllocated (Int Int) Int) | ||||
| (declare-fun IntnRange (Int Int) Bool) | ||||
| (declare-fun ?isAllocated_ (Int Int) Bool) | ||||
| (declare-fun ?AsDirectSubClass (Int Int) Int) | ||||
| (declare-fun ?OneClassDown (Int Int) Int) | ||||
| (assert (forall ((a Int) (i Int) (e Int)) | ||||
|                 (! | ||||
|                  (= (?select (?store a i e) i) e) | ||||
|                  :pattern (?store a i e) | ||||
|                  :weight 0))) | ||||
| (assert (forall ((a Int) (i Int) (j Int) (e Int)) | ||||
|                 (! | ||||
|                  (or (= i j) (= (?select (?store a i e) j) (?select a j))) | ||||
|                  :pattern (?select (?store a i e) j) | ||||
|                  :weight 0))) | ||||
| (assert (forall ((t0 Int) (t1 Int) (t2 Int)) | ||||
|                 (! | ||||
|                  (or (not (= (?PO t0 t1) 1)) | ||||
|                      (not (= (?PO t1 t2) 1)) | ||||
|                      (= (?PO t0 t2) 1)) | ||||
|                  :pattern ((?PO t0 t1) (?PO t1 t2))))) | ||||
| (assert (forall ((t0 Int) (t1 Int)) | ||||
|                 (! | ||||
|                  (or (not (= (?PO t0 t1) 1)) | ||||
|                      (not (= (?PO t1 t0) 1)) | ||||
|                      (= t0 t1)) | ||||
|                  :pattern ((?PO t0 t1) (?PO t1 t0))))) | ||||
| (assert (forall ((t0 Int) (t1 Int) (t2 Int)) | ||||
|                  (! | ||||
|                   (or (not (= (?PO t0 (?asChild t1 t2)) 1)) | ||||
|                       (= (?classDown t2 t0) (?asChild   t1 t2))) | ||||
|                   :pattern (?PO t0 (?asChild t1 t2))))) | ||||
| (assert (forall ((t Int)) | ||||
|                 (! | ||||
|                  (= (?finv (?f t)) t) | ||||
|                  :pattern (?f t)))) | ||||
| (assert (forall ((t0 Int) (t1 Int) ) | ||||
|                 (! | ||||
|                  (iff (= (?PO t0 (?array t1)) 1) | ||||
|                       (not (or (not (= t0 (?array (?elemtype t0)))) | ||||
|                                (not (= (?PO (?elemtype t0) t1) 1))))) | ||||
|                  :pattern (?PO t0 (?array t1))))) | ||||
| (assert (forall ((x Int) (t Int)) | ||||
|                 (! | ||||
|                  (or (not (= (?is x t) 1)) | ||||
|                      (= (?cast x t) x)) | ||||
|                  :pattern (?cast x t)))) | ||||
| (assert (forall ((x Int) (t Int)) | ||||
|                 (! | ||||
|                  (or (not (= (?PO t ?Object) 1)) | ||||
|                      (iff (= (?is x t) 1) | ||||
|                           (or (= x ?null) | ||||
|                               (= (?PO (?typeof x) t) 1)))) | ||||
|                  :pattern ((?PO t ?Object) (?is x t))))) | ||||
| (assert (forall ((e Int) (a Int) (i Int)) | ||||
|                 (! | ||||
|                  (= (?is (?select (?select (?asElems e) a) i) | ||||
|                          (?elemtype (?typeof a))) 1) | ||||
|                  :pattern (?select (?select (?asElems e) a) i)))) | ||||
| (assert (forall ((x Int) (f Int) (a0 Int)) | ||||
|                 (! | ||||
|                  (or (<= (+ a0 (* -1 (?fClosedTime f))) 0) | ||||
|                      (not (= (?isAllocated x a0) 1)) | ||||
|                      (= (?isAllocated (?select f x) a0) 1)) | ||||
|                  :pattern (?isAllocated (?select f x) a0)))) | ||||
| (assert (forall ((a Int) (e Int) (i Int) (a0 Int)) | ||||
|                 (! | ||||
|                  (or (<= (+ a0 (* -1 (?eClosedTime e))) 0) | ||||
|                      (not (= (?isAllocated a a0) 1)) | ||||
|                      (= (?isAllocated (?select (?select e a) i) a0) 1)) | ||||
|                  :pattern (?isAllocated (?select (?select e a) i) a0)))) | ||||
| (assert (forall ((S Int)) | ||||
|                 (! | ||||
|                  (= (?select (?asLockSet S) (?max (?asLockSet S))) 1) | ||||
|                  :pattern (?select (?asLockSet S) (?max (?asLockSet S)))))) | ||||
| (assert (forall ((s Int)) | ||||
|                 (! | ||||
|                  (or (not (= 1 (?isNewArray s))) | ||||
|                      (= (?PO (?typeof s) ?arrayType) 1)) | ||||
|                  :pattern (?isNewArray s)))) | ||||
| (assert (forall ((t Int)) | ||||
|                 (! | ||||
|                  (not (or (= (?classLiteral t) ?null) | ||||
|                           (not (= (?is (?classLiteral t) ?Class) 1)) | ||||
|                           (not (= (?isAllocated (?classLiteral t) ?alloc) 1)))) | ||||
|                  :pattern (?classLiteral t)))) | ||||
| (assert  (forall ((A Int) (o Int) (f Int) (v Int)) | ||||
|                  (! | ||||
|                   (= (?select2 (?store2 A o f v) o f) v) | ||||
|                   :pattern (?store2 A o f v) | ||||
|                   :weight 0))) | ||||
| (assert  (forall ((A Int) (o Int) (f Int) (p Int) (g Int) (v Int)) | ||||
|                  (! | ||||
|                   (or (= o p) (= (?select2 (?store2 A o f v) p g) (?select2 A p g))) | ||||
|                   :pattern (?select2 (?store2 A o f v) p g) | ||||
|                   :weight 0))) | ||||
| (assert  (forall ((A Int) (o Int) (f Int) (p Int) (g Int) (v Int)) | ||||
|                  (! | ||||
|                   (or (= f g) (= (?select2 (?store2 A o f v) p g) (?select2 A p g))) | ||||
|                   :pattern (?select2 (?store2 A o f v) p g) | ||||
|                   :weight 0))) | ||||
| (assert  (forall ((t Int) (u Int) (v Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes t u)) | ||||
|                       (not (?subtypes u v)) | ||||
|                       (?subtypes t v)) | ||||
|                   :pattern ((?subtypes t u) (?subtypes u v))))) | ||||
| (assert  (forall ((t Int) (u Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes t u)) | ||||
|                       (not (?subtypes u t)) | ||||
|                       (= t u)) | ||||
|                   :pattern ((?subtypes t u) (?subtypes u t))))) | ||||
| (assert  (forall ((x Int) (p Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes (?UnboxedType (?Box x p)) ?System.Object)) | ||||
|                       (not (= (?Box x p) p)) | ||||
|                       (= x p)) | ||||
|                   :pattern (?subtypes (?UnboxedType (?Box x p)) ?System.Object)))) | ||||
| (assert  (forall ((h Int) (o Int) (f Int) (T Int)) | ||||
|                  (! | ||||
|                   (or  | ||||
|                    (not (= (IntsHeap h) ?Smt.true)) | ||||
|                    (= (?select2 h o (?AsRepField f T)) ?nullObject) | ||||
|                    (not (or (not (= (?select2 h (?select2 h o (?AsRepField f T)) ?ownerRef_) o)) | ||||
|                             (not (= (?select2 h (?select2 h o (?AsRepField f T)) ?ownerFrame_) T))))) | ||||
|                   :pattern (?select2 h o (?AsRepField f T))))) | ||||
| (assert  (forall ((h Int) (o Int) (f Int)) | ||||
|                  (! | ||||
|                   (or | ||||
|                    (not (= (IntsHeap h) ?Smt.true)) | ||||
|                    (= (?select2 h o (?AsPeerField f)) ?nullObject) | ||||
|                    (not (or (not (= (?select2 h (?select2 h o (?AsPeerField f)) ?ownerRef_) (?select2 h o ?ownerRef_))) | ||||
|                             (not (= (?select2 h (?select2 h o (?AsPeerField f)) ?ownerFrame_) (?select2 h o ?ownerFrame_)))))) | ||||
|                   :pattern (?select2 h o (?AsPeerField f))))) | ||||
| (assert  (forall ((h Int) (o Int)) | ||||
|                  (! | ||||
|                   (or  | ||||
|                    (not (= (IntsHeap h) ?Smt.true)) | ||||
|                    (= (?select2 h o ?ownerFrame_) ?PeerGroupPlaceholder_) | ||||
|                    (not (?subtypes (?select2 h (?select2 h o ?ownerRef_) ?inv_) (?select2 h o ?ownerFrame_))) | ||||
|                    (= (?select2 h (?select2 h o ?ownerRef_) ?localinv_) (?BaseClass_ (?select2 h o ?ownerFrame_))) | ||||
|                    (not (or (not (= (?select2 h o ?inv_) (?typeof_ o))) | ||||
|                             (not (= (?select2 h o ?localinv_) (?typeof_ o)))))) | ||||
|                   :pattern (?subtypes (?select2 h (?select2 h o ?ownerRef_) ?inv_) (?select2 h o ?ownerFrame_))))) | ||||
| (assert  (forall ((T Int) (h Int)) | ||||
|                  (! | ||||
|                   (or (not (= (IntsHeap h) ?Smt.true)) | ||||
|                       (= (?select2 h (?ClassRepr T) ?ownerFrame_) ?PeerGroupPlaceholder_)) | ||||
|                   :pattern (?select2 h (?ClassRepr T) ?ownerFrame_)))) | ||||
| (assert  (forall ((a Int) (T Int) (i Int) (r Int) (heap Int)) | ||||
|                  (! | ||||
|                   (or (not (= (IntsHeap heap) ?Smt.true)) | ||||
|                       (not (?subtypes (?typeof_ a) (?RefArray T r))) | ||||
|                       (= (Ints_ (?RefArrayGet (?select2 heap a ?elements_) i) T) ?Smt.true)) | ||||
|                   :pattern ((?subtypes (?typeof_ a) (?RefArray T r)) (?RefArrayGet (?select2 heap a ?elements_) i))))) | ||||
| (assert  (forall ((a Int) (T Int) (r Int)) | ||||
|                  (! | ||||
|                   (or (= a ?nullObject)  | ||||
|                       (not (?subtypes (?typeof_ a) (?RefArray T r))) | ||||
|                       (= (?Rank_ a) r)) | ||||
|                   :pattern (?subtypes (?typeof_ a) (?RefArray T r))))) | ||||
| (assert  (forall ((T Int) (ET Int) (r Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes T (?ValueArray ET r))) | ||||
|                       (= (?ArrayCategory_ T) ?ArrayCategoryValue_)) | ||||
|                   :pattern (?subtypes T (?ValueArray ET r))))) | ||||
| (assert  (forall ((A Int) (r Int) (T Int)) | ||||
|                  (! | ||||
|                   (or | ||||
|                    (not (?subtypes T (?RefArray A r))) | ||||
|                    (not (or (not (= T (?RefArray (?ElementType_ T) r))) | ||||
|                             (not (?subtypes (?ElementType_ T) A))))) | ||||
|                   :pattern (?subtypes T (?RefArray A r))))) | ||||
| (assert  (forall ((A Int) (r Int) (T Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes T (?ValueArray A r))) | ||||
|                       (= T (?ValueArray A r))) | ||||
|                   :pattern (?subtypes T (?ValueArray A r))))) | ||||
| (assert  (forall ((A Int) (B Int) (C Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes C (?AsDirectSubClass B A))) | ||||
|                       (= (?OneClassDown C A) B)) | ||||
|                   :pattern (?subtypes C (?AsDirectSubClass B A))))) | ||||
| (assert  (forall ((o Int) (T Int)) | ||||
|                  (! | ||||
|                   (iff (= (Ints_ o T) ?Smt.true) | ||||
|                        (or (= o ?nullObject) | ||||
|                            (?subtypes (?typeof_ o) T))) | ||||
|                   :pattern (Ints_ o T)))) | ||||
| (assert  (forall ((o Int) (T Int)) | ||||
|                  (! | ||||
|                   (iff (= (IntsNotNull_ o T) ?Smt.true) | ||||
|                        (or (= o ?nullObject) | ||||
|                            (not (= (Ints_ o T) ?Smt.true)))) | ||||
|                   :pattern (IntsNotNull_ o T)))) | ||||
| (assert  (forall ((h Int) (o Int)) | ||||
|                  (! | ||||
|                   (or (not (= (IntsHeap h) ?Smt.true)) | ||||
|                       (= o ?nullObject) | ||||
|                       (not (?subtypes (?typeof_ o) ?System.Array)) | ||||
|                       (not (or (not (= (?select2 h o ?inv_) (?typeof_ o))) | ||||
|                                (not (= (?select2 h o ?localinv_) (?typeof_ o)))))) | ||||
|                   :pattern ((?subtypes (?typeof_ o) ?System.Array) (?select2 h o ?inv_))))) | ||||
| (assert  (forall ((h Int) (o Int) (f Int) (T Int)) | ||||
|                  (! | ||||
|                   (or (not (= (IntsHeap h) ?Smt.true)) | ||||
|                       (IntnRange (?select2 h o (?AsRangeField f T)) T)) | ||||
|                   :pattern (?select2 h o (?AsRangeField f T))))) | ||||
| (assert  (forall ((h Int) (o Int) (f Int)) | ||||
|                  (! | ||||
|                   (or | ||||
|                    (not (= (IntsHeap h) ?Smt.true)) | ||||
|                    (not (= (?select2 h o ?allocated_) ?Smt.true)) | ||||
|                    (= (IntsAllocated h (?select2 h o f)) ?Smt.true)) | ||||
|                   :pattern (IntsAllocated h (?select2 h o f))))) | ||||
| (assert  (forall ((h Int) (s Int) (f Int)) | ||||
|                  (! | ||||
|                   (or (not (= (IntsAllocated h s) ?Smt.true)) | ||||
|                       (= (IntsAllocated h (?StructGet_ s f)) ?Smt.true)) | ||||
|                   :pattern (IntsAllocated h (?StructGet_ s f))))) | ||||
| (assert  (forall ((x Int) (f Int) (a0 Int)) | ||||
|                  (! | ||||
|                   (or (<= (+ a0 (* -1 (?fClosedTime f))) 0) | ||||
|                       (not (?isAllocated_ x a0)) | ||||
|                       (?isAllocated_ (?select f x) a0)) | ||||
|                   :pattern (?isAllocated_ (?select f x) a0)))) | ||||
| (assert  (forall ((a Int) (e Int) (i Int) (a0 Int)) | ||||
|                  (! | ||||
|                   (or (<= (+ a0 (* -1 (?eClosedTime e))) 0) | ||||
|                       (not (?isAllocated_ a a0)) | ||||
|                       (?isAllocated_ (?select (?select e a) i) a0)) | ||||
|                   :pattern (?isAllocated_ (?select (?select e a) i) a0)))) | ||||
| (assert  (forall ((e Int) (a Int) (i Int)) | ||||
|                  (! | ||||
|                   (= (?is (?select (?select (?asElems e) a) i) | ||||
|                           (?elemtype (?typeof a))) ?Smt.true) | ||||
|                   :pattern (?select (?select (?asElems e) a) i)))) | ||||
| (assert  (forall ((t0 Int) (t1 Int)) | ||||
|                  (! | ||||
|                   (iff (?subtypes t0 (?array t1)) | ||||
|                        (not (or (not (= t0 (?array (?elemtype t0)))) | ||||
|                                 (not (?subtypes (?elemtype t0) t1))))) | ||||
|                     :pattern (?subtypes t0 (?array t1))))) | ||||
| (assert  (forall ((t0 Int) (t1 Int) (t2 Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes t0 (?asChild t1 t2))) | ||||
|                       (= (?classDown t2 t0) (?asChild   t1 t2))) | ||||
|                   :pattern (?subtypes t0 (?asChild t1 t2))))) | ||||
| (assert  (forall ((t0 Int) (t1 Int)) | ||||
|                  (! | ||||
|                   (iff (?subtypes t0 (?array t1)) | ||||
|                        (not (or (not (= t0 (?array (?elemtype t0)))) | ||||
|                                 (not (?subtypes (?elemtype t0) t1))))) | ||||
|                   :pattern (?subtypes t0 (?array t1))))) | ||||
| (assert  (forall ((x Int) (t Int)) | ||||
|                  (! | ||||
|                   (or (not (= (?is x t) ?Smt.true)) | ||||
|                       (= (?cast x t) x)) | ||||
|                   :pattern (?cast x t)))) | ||||
| (assert  (forall ((x Int) (t Int)) | ||||
|                  (! | ||||
|                   (or (not (?subtypes t ?Object)) | ||||
|                       (iff (= (?is x t) ?Smt.true) | ||||
|                            (or (= x ?null) | ||||
|                                (?subtypes (?typeof x) t)))) | ||||
|                   :pattern ((?subtypes t ?Object) (?is x t))))) | ||||
| (assert  (forall ((e Int) (a Int) (i Int)) | ||||
|                  (! | ||||
|                   (= (?is (?select (?select (?asElems e) a) i) | ||||
|                           (?elemtype (?typeof a))) 1) | ||||
|                   :pattern (?select (?select (?asElems e) a) i)))) | ||||
|  | @ -31,10 +31,12 @@ Notes: | |||
| 
 | ||||
| #include"ast.h" | ||||
| #include"expr_pattern_match.h" | ||||
| #include"smtparser.h" | ||||
| #include"for_each_ast.h" | ||||
| #include"ast_ll_pp.h" | ||||
| #include"ast_pp.h" | ||||
| #include"cmd_context.h" | ||||
| #include"smt2parser.h" | ||||
| #include"front_end_params.h" | ||||
| 
 | ||||
| expr_pattern_match::expr_pattern_match(ast_manager & manager): | ||||
|     m_manager(manager), m_precompiled(manager) {         | ||||
|  | @ -398,21 +400,18 @@ expr_pattern_match::initialize(char const * spec_string) { | |||
|     if (!m_instrs.empty()) { | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     m_instrs.push_back(instr(BACKTRACK)); | ||||
| 
 | ||||
|     smtlib::parser* parser = smtlib::parser::create(m_manager); | ||||
|     parser->initialize_smtlib(); | ||||
|     if (!parser->parse_string(spec_string)) { | ||||
|         UNREACHABLE(); | ||||
|     } | ||||
|     smtlib::benchmark* bench  = parser->get_benchmark(); | ||||
|     smtlib::theory::expr_iterator it  = bench->begin_formulas(); | ||||
|     smtlib::theory::expr_iterator end = bench->end_formulas(); | ||||
|     std::istringstream is(spec_string); | ||||
|     front_end_params p; | ||||
|     cmd_context      ctx(p, true, &m_manager); | ||||
|     VERIFY(parse_smt2_commands(ctx, is)); | ||||
| 
 | ||||
|     ptr_vector<expr>::const_iterator it  = ctx.begin_assertions(); | ||||
|     ptr_vector<expr>::const_iterator end = ctx.end_assertions(); | ||||
|     for (; it != end; ++it) { | ||||
|         compile(*it); | ||||
|     } | ||||
|     dealloc(parser); | ||||
|     TRACE("expr_pattern_match", display(tout); ); | ||||
| } | ||||
| 
 | ||||
|  | @ -23,9 +23,8 @@ Notes: | |||
| #include"ast.h" | ||||
| #include"map.h" | ||||
| #include"front_end_params.h" | ||||
| #include"pattern_inference.h" | ||||
| 
 | ||||
| class expr_pattern_match : public pattern_database { | ||||
| class expr_pattern_match { | ||||
| 
 | ||||
|     enum instr_kind { | ||||
|         BACKTRACK, | ||||
|  | @ -87,7 +87,7 @@ bool smaller_pattern::operator()(unsigned num_bindings, expr * p1, expr * p2) { | |||
|     return process(p1, p2); | ||||
| } | ||||
| 
 | ||||
| pattern_inference::pattern_inference(ast_manager & m, pattern_inference_params & params, pattern_database * db): | ||||
| pattern_inference::pattern_inference(ast_manager & m, pattern_inference_params & params): | ||||
|     simplifier(m), | ||||
|     m_params(params), | ||||
|     m_bfid(m.get_basic_family_id()), | ||||
|  | @ -99,7 +99,7 @@ pattern_inference::pattern_inference(ast_manager & m, pattern_inference_params & | |||
|     m_pattern_weight_lt(m_candidates_info), | ||||
|     m_collect(m, *this), | ||||
|     m_contains_subpattern(*this), | ||||
|     m_database(db) { | ||||
|     m_database(m) { | ||||
|     if (params.m_pi_arith == AP_NO) | ||||
|         register_forbidden_family(m_afid); | ||||
|     enable_ac_support(false); | ||||
|  | @ -574,6 +574,8 @@ void pattern_inference::mk_patterns(unsigned num_bindings, | |||
|     m_candidates.reset(); | ||||
| } | ||||
| 
 | ||||
| #include"database.h" // defines g_pattern_database
 | ||||
| 
 | ||||
| void pattern_inference::reduce1_quantifier(quantifier * q) { | ||||
|     TRACE("pattern_inference", tout << "processing:\n" << mk_pp(q, m_manager) << "\n";); | ||||
|     if (!q->is_forall()) { | ||||
|  | @ -583,10 +585,11 @@ void pattern_inference::reduce1_quantifier(quantifier * q) { | |||
| 
 | ||||
|     int weight = q->get_weight(); | ||||
| 
 | ||||
|     if (m_database) {  | ||||
|     if (m_params.m_pi_use_database) { | ||||
|         m_database.initialize(g_pattern_database); | ||||
|         app_ref_vector new_patterns(m_manager); | ||||
|         unsigned new_weight; | ||||
|         if (m_database->match_quantifier(q, new_patterns, new_weight)) { | ||||
|         if (m_database.match_quantifier(q, new_patterns, new_weight)) { | ||||
| #ifdef Z3DEBUG | ||||
|             for (unsigned i = 0; i < new_patterns.size(); i++) { SASSERT(is_well_sorted(m_manager, new_patterns.get(i))); } | ||||
| #endif | ||||
|  |  | |||
|  | @ -28,13 +28,7 @@ Revision History: | |||
| #include"obj_hashtable.h" | ||||
| #include"obj_pair_hashtable.h" | ||||
| #include"map.h" | ||||
| 
 | ||||
| class pattern_database { | ||||
| public: | ||||
|     virtual ~pattern_database() {} | ||||
|     virtual void initialize(char const * smt_patterns) = 0; | ||||
|     virtual bool match_quantifier(quantifier * qf, app_ref_vector & patterns, unsigned & weight) = 0; | ||||
| }; | ||||
| #include"expr_pattern_match.h" | ||||
| 
 | ||||
| /**
 | ||||
|    \brief A pattern p_1 is smaller than a pattern p_2 iff  | ||||
|  | @ -195,7 +189,7 @@ class pattern_inference : public simplifier { | |||
|     }; | ||||
| 
 | ||||
|     ptr_vector<pre_pattern>      m_pre_patterns; | ||||
|     pattern_database *           m_database; | ||||
|     expr_pattern_match           m_database; | ||||
| 
 | ||||
|     void candidates2unary_patterns(ptr_vector<app> const & candidate_patterns, | ||||
|                                    ptr_vector<app> & remaining_candidate_patterns, | ||||
|  | @ -223,7 +217,7 @@ class pattern_inference : public simplifier { | |||
|     virtual void reduce1_quantifier(quantifier * q); | ||||
| 
 | ||||
| public: | ||||
|     pattern_inference(ast_manager & m, pattern_inference_params & params, pattern_database * db); | ||||
|     pattern_inference(ast_manager & m, pattern_inference_params & params); | ||||
|      | ||||
|     void register_forbidden_family(family_id fid) { | ||||
|         SASSERT(fid != m_bfid); | ||||
|  |  | |||
|  | @ -246,17 +246,17 @@ protected: | |||
|     // check maximum number of scopes
 | ||||
|     void check_max_scopes() const {  | ||||
|         if (m_cfg.max_scopes_exceeded(this->m_scopes.size())) | ||||
|             throw rewriter_exception(TACTIC_MAX_SCOPES_MSG); | ||||
|             throw rewriter_exception(Z3_MAX_SCOPES_MSG); | ||||
|     } | ||||
|     // check maximum size of the frame stack
 | ||||
|     void check_max_frames() const {  | ||||
|         if (m_cfg.max_frames_exceeded(frame_stack().size())) | ||||
|             throw rewriter_exception(TACTIC_MAX_FRAMES_MSG); | ||||
|             throw rewriter_exception(Z3_MAX_FRAMES_MSG); | ||||
|     } | ||||
|     // check maximum number of rewriting steps
 | ||||
|     void check_max_steps() const {  | ||||
|         if (m_cfg.max_steps_exceeded(m_num_steps)) | ||||
|             throw rewriter_exception(TACTIC_MAX_STEPS_MSG); | ||||
|             throw rewriter_exception(Z3_MAX_STEPS_MSG); | ||||
|     } | ||||
| 
 | ||||
|     // If pre_visit returns false, then t children are not visited/rewritten.
 | ||||
|  |  | |||
|  | @ -577,7 +577,7 @@ void rewriter_tpl<Config>::resume_core(expr_ref & result, proof_ref & result_pr) | |||
|     SASSERT(!frame_stack().empty()); | ||||
|     while (!frame_stack().empty()) { | ||||
|         if (m_cancel) | ||||
|             throw rewriter_exception(TACTIC_CANCELED_MSG); | ||||
|             throw rewriter_exception(Z3_CANCELED_MSG); | ||||
|         SASSERT(!ProofGen || result_stack().size() == result_pr_stack().size()); | ||||
|         frame & fr = frame_stack().back(); | ||||
|         expr * t   = fr.m_curr; | ||||
|  |  | |||
|  | @ -19,7 +19,8 @@ Notes: | |||
| #ifndef _REWRITER_TYPES_H_ | ||||
| #define _REWRITER_TYPES_H_ | ||||
| 
 | ||||
| #include"tactic_exception.h" | ||||
| #include"z3_exception.h" | ||||
| #include"common_msgs.h" | ||||
| 
 | ||||
| /**
 | ||||
|    \brief Builtin rewrite result status | ||||
|  | @ -43,9 +44,9 @@ inline br_status unsigned2br_status(unsigned u) { | |||
|     return r; | ||||
| } | ||||
| 
 | ||||
| class rewriter_exception : public tactic_exception { | ||||
| class rewriter_exception : public default_exception { | ||||
| public:                                                 | ||||
|     rewriter_exception(char const * msg):tactic_exception(msg) {} | ||||
|     rewriter_exception(char const * msg):default_exception(msg) {} | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -96,7 +96,7 @@ struct th_rewriter_cfg : public default_rewriter_cfg { | |||
|     bool max_steps_exceeded(unsigned num_steps) const {  | ||||
|         cooperate("simplifier"); | ||||
|         if (memory::get_allocation_size() > m_max_memory) | ||||
|             throw rewriter_exception(TACTIC_MAX_MEMORY_MSG); | ||||
|             throw rewriter_exception(Z3_MAX_MEMORY_MSG); | ||||
|         return num_steps > m_max_steps; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -20,7 +20,8 @@ Revision History: | |||
| #include"interval_def.h" | ||||
| #include"buffer.h" | ||||
| #include"cooperate.h" | ||||
| #include"tactic_exception.h" | ||||
| #include"z3_exception.h" | ||||
| #include"common_msgs.h" | ||||
| 
 | ||||
| namespace subpaving { | ||||
| 
 | ||||
|  | @ -461,7 +462,7 @@ void context_t<C>::checkpoint() { | |||
|     if (m_cancel) | ||||
|         throw default_exception("canceled"); | ||||
|     if (memory::get_allocation_size() > m_max_memory) | ||||
|         throw default_exception(TACTIC_MAX_MEMORY_MSG); | ||||
|         throw default_exception(Z3_MAX_MEMORY_MSG); | ||||
|     cooperate("subpaving"); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -193,7 +193,7 @@ struct evaluator_cfg : public default_rewriter_cfg { | |||
|     bool max_steps_exceeded(unsigned num_steps) const {  | ||||
|         cooperate("model evaluator"); | ||||
|         if (memory::get_allocation_size() > m_max_memory) | ||||
|             throw rewriter_exception(TACTIC_MAX_MEMORY_MSG); | ||||
|             throw rewriter_exception(Z3_MAX_MEMORY_MSG); | ||||
|         return num_steps > m_max_steps; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -250,31 +250,36 @@ namespace qe { | |||
|             proof_converter_ref & pc,  | ||||
|             expr_dependency_ref& core)  | ||||
|         { | ||||
|             checkpoint(); | ||||
|             reset();             | ||||
|             ptr_vector<expr> fmls; | ||||
|             goal->get_formulas(fmls); | ||||
|             m_fml = m.mk_and(fmls.size(), fmls.c_ptr()); | ||||
|             TRACE("qe", tout << "input: " << mk_pp(m_fml,m) << "\n";); | ||||
|             simplify_rewriter_star rw(m); | ||||
|             expr_ref tmp(m); | ||||
|             rw(m_fml, tmp); | ||||
|             m_fml = tmp; | ||||
|             TRACE("qe", tout << "reduced: " << mk_pp(m_fml,m) << "\n";); | ||||
|             skolemize_existential_prefix(); | ||||
|             extract_alt_form(m_fml); | ||||
|             model_ref model; | ||||
|             expr_ref res = qt(0, m.mk_true(), model); | ||||
|             goal->inc_depth(); | ||||
|             if (m.is_false(res)) { | ||||
|                 goal->assert_expr(res); | ||||
|             try { | ||||
|                 checkpoint(); | ||||
|                 reset();             | ||||
|                 ptr_vector<expr> fmls; | ||||
|                 goal->get_formulas(fmls); | ||||
|                 m_fml = m.mk_and(fmls.size(), fmls.c_ptr()); | ||||
|                 TRACE("qe", tout << "input: " << mk_pp(m_fml,m) << "\n";); | ||||
|                 simplify_rewriter_star rw(m); | ||||
|                 expr_ref tmp(m); | ||||
|                 rw(m_fml, tmp); | ||||
|                 m_fml = tmp; | ||||
|                 TRACE("qe", tout << "reduced: " << mk_pp(m_fml,m) << "\n";); | ||||
|                 skolemize_existential_prefix(); | ||||
|                 extract_alt_form(m_fml); | ||||
|                 model_ref model; | ||||
|                 expr_ref res = qt(0, m.mk_true(), model); | ||||
|                 goal->inc_depth(); | ||||
|                 if (m.is_false(res)) { | ||||
|                     goal->assert_expr(res); | ||||
|                 } | ||||
|                 else { | ||||
|                     goal->reset(); | ||||
|                     // equi-satisfiable. What to do with model?
 | ||||
|                     mc = model2model_converter(&*model); | ||||
|                 } | ||||
|                 result.push_back(goal.get()); | ||||
|             } | ||||
|             else { | ||||
|                 goal->reset(); | ||||
|                 // equi-satisfiable. What to do with model?
 | ||||
|                 mc = model2model_converter(&*model); | ||||
|             catch (rewriter_exception & ex) { | ||||
|                 throw tactic_exception(ex.msg()); | ||||
|             } | ||||
|             result.push_back(goal.get()); | ||||
|         } | ||||
| 
 | ||||
|         virtual void collect_statistics(statistics & st) const { | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ Revision History: | |||
| #include"nlsat_evaluator.h" | ||||
| #include"nlsat_explain.h" | ||||
| #include"algebraic_numbers.h" | ||||
| #include"tactic_exception.h" | ||||
| #include"z3_exception.h" | ||||
| #include"chashtable.h" | ||||
| #include"id_gen.h" | ||||
| #include"dependency.h" | ||||
|  | @ -220,8 +220,8 @@ namespace nlsat { | |||
|         } | ||||
| 
 | ||||
|         void checkpoint() { | ||||
|             if (m_cancel) throw solver_exception(TACTIC_CANCELED_MSG); | ||||
|             if (memory::get_allocation_size() > m_max_memory) throw solver_exception(TACTIC_MAX_MEMORY_MSG); | ||||
|             if (m_cancel) throw solver_exception(Z3_CANCELED_MSG); | ||||
|             if (memory::get_allocation_size() > m_max_memory) throw solver_exception(Z3_MAX_MEMORY_MSG); | ||||
|         } | ||||
| 
 | ||||
|         // -----------------------
 | ||||
|  |  | |||
|  | @ -218,8 +218,8 @@ namespace sat { | |||
|         lbool status(clause const & c) const; | ||||
|         clause_offset get_offset(clause const & c) const { return m_cls_allocator.get_offset(&c); } | ||||
|         void checkpoint() { | ||||
|             if (m_cancel) throw solver_exception(TACTIC_CANCELED_MSG); | ||||
|             if (memory::get_allocation_size() > m_config.m_max_memory) throw solver_exception(TACTIC_MAX_MEMORY_MSG); | ||||
|             if (m_cancel) throw solver_exception(Z3_CANCELED_MSG); | ||||
|             if (memory::get_allocation_size() > m_config.m_max_memory) throw solver_exception(Z3_MAX_MEMORY_MSG); | ||||
|         } | ||||
|     protected: | ||||
|         watch_list & get_wlist(literal l) { return m_watches[l.index()]; } | ||||
|  |  | |||
|  | @ -22,7 +22,8 @@ Revision History: | |||
| #include"debug.h" | ||||
| #include"approx_set.h" | ||||
| #include"lbool.h" | ||||
| #include"tactic_exception.h" | ||||
| #include"z3_exception.h" | ||||
| #include"common_msgs.h" | ||||
| #include"vector.h" | ||||
| #include<iomanip> | ||||
| 
 | ||||
|  | @ -125,9 +126,9 @@ namespace sat { | |||
|     class integrity_checker; | ||||
|     typedef ptr_vector<clause> clause_vector; | ||||
| 
 | ||||
|     class solver_exception : public tactic_exception { | ||||
|     class solver_exception : public default_exception { | ||||
|     public:                                                 | ||||
|         solver_exception(char const * msg):tactic_exception(msg) {} | ||||
|         solver_exception(char const * msg):default_exception(msg) {} | ||||
|     }; | ||||
| 
 | ||||
|     typedef default_exception sat_param_exception; | ||||
|  |  | |||
|  | @ -1105,7 +1105,7 @@ void asserted_formulas::reduce_and_solve() { | |||
| void asserted_formulas::infer_patterns() { | ||||
|     IF_IVERBOSE(10, verbose_stream() << "pattern inference...\n";); | ||||
|     TRACE("before_pattern_inference", display(tout);); | ||||
|     pattern_inference infer(m_manager, m_params, m_database.get()); | ||||
|     pattern_inference infer(m_manager, m_params); | ||||
|     expr_ref_vector  new_exprs(m_manager); | ||||
|     proof_ref_vector new_prs(m_manager); | ||||
|     unsigned i  = m_asserted_qhead; | ||||
|  |  | |||
|  | @ -39,7 +39,6 @@ class bv_simplifier_plugin; | |||
| class asserted_formulas { | ||||
|     ast_manager &                m_manager; | ||||
|     front_end_params &           m_params; | ||||
|     scoped_ptr<pattern_database> m_database; | ||||
|     simplifier                   m_pre_simplifier; | ||||
|     subst_simplifier             m_simplifier; | ||||
|     basic_simplifier_plugin *    m_bsimp; | ||||
|  | @ -168,8 +167,6 @@ public: | |||
|     // TODO: improve precision of the following method.
 | ||||
|     bool has_quantifiers() const { return m_simplifier.visited_quantifier(); /* approximation */ } | ||||
|      | ||||
|     void set_pattern_database(pattern_database * db) { m_database = db; } | ||||
| 
 | ||||
|     // -----------------------------------
 | ||||
|     //
 | ||||
|     // Macros
 | ||||
|  |  | |||
|  | @ -329,7 +329,12 @@ public: | |||
|                             model_converter_ref & mc,  | ||||
|                             proof_converter_ref & pc, | ||||
|                             expr_dependency_ref & core) { | ||||
|         (*m_imp)(in, result, mc, pc, core); | ||||
|         try { | ||||
|             (*m_imp)(in, result, mc, pc, core); | ||||
|         } | ||||
|         catch (rewriter_exception & ex) { | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
|  | @ -335,7 +335,12 @@ public: | |||
|                             model_converter_ref & mc,  | ||||
|                             proof_converter_ref & pc, | ||||
|                             expr_dependency_ref & core) { | ||||
|         (*m_imp)(in, result, mc, pc, core); | ||||
|         try { | ||||
|             (*m_imp)(in, result, mc, pc, core); | ||||
|         } | ||||
|         catch (rewriter_exception & ex) { | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
|  | @ -181,7 +181,12 @@ public: | |||
|                             model_converter_ref & mc,  | ||||
|                             proof_converter_ref & pc, | ||||
|                             expr_dependency_ref & core) { | ||||
|         (*m_imp)(in, result, mc, pc, core); | ||||
|         try { | ||||
|             (*m_imp)(in, result, mc, pc, core); | ||||
|         } | ||||
|         catch (rewriter_exception & ex) { | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
|  | @ -870,22 +870,27 @@ public: | |||
|                             model_converter_ref & mc,  | ||||
|                             proof_converter_ref & pc, | ||||
|                             expr_dependency_ref & core) { | ||||
|         SASSERT(g->is_well_sorted()); | ||||
|         mc = 0; pc = 0; core = 0; | ||||
|         tactic_report report("purify-arith", *g); | ||||
|         bool produce_proofs = g->proofs_enabled(); | ||||
|         bool produce_models = g->models_enabled(); | ||||
|         bool elim_root_objs = m_params.get_bool(":elim-root-objects", true); | ||||
|         bool elim_inverses  = m_params.get_bool(":elim-inverses", true); | ||||
|         bool complete       = m_params.get_bool(":complete", true); | ||||
|         purify_arith_proc proc(m_util, m_aux_decls, produce_proofs, elim_root_objs, elim_inverses, complete); | ||||
|         try { | ||||
|             SASSERT(g->is_well_sorted()); | ||||
|             mc = 0; pc = 0; core = 0; | ||||
|             tactic_report report("purify-arith", *g); | ||||
|             bool produce_proofs = g->proofs_enabled(); | ||||
|             bool produce_models = g->models_enabled(); | ||||
|             bool elim_root_objs = m_params.get_bool(":elim-root-objects", true); | ||||
|             bool elim_inverses  = m_params.get_bool(":elim-inverses", true); | ||||
|             bool complete       = m_params.get_bool(":complete", true); | ||||
|             purify_arith_proc proc(m_util, m_aux_decls, produce_proofs, elim_root_objs, elim_inverses, complete); | ||||
|              | ||||
|         proc(*(g.get()), mc, produce_models); | ||||
|             proc(*(g.get()), mc, produce_models); | ||||
|              | ||||
|         g->inc_depth(); | ||||
|         result.push_back(g.get()); | ||||
|         TRACE("purify_arith", g->display(tout);); | ||||
|         SASSERT(g->is_well_sorted()); | ||||
|             g->inc_depth(); | ||||
|             result.push_back(g.get()); | ||||
|             TRACE("purify_arith", g->display(tout);); | ||||
|             SASSERT(g->is_well_sorted()); | ||||
|         } | ||||
|         catch (rewriter_exception & ex) { | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
|  | @ -416,7 +416,12 @@ public: | |||
|                     model_converter_ref & mc,  | ||||
|                     proof_converter_ref & pc, | ||||
|                     expr_dependency_ref & core) { | ||||
|         (*m_imp)(g, result, mc, pc, core); | ||||
|         try { | ||||
|             (*m_imp)(g, result, mc, pc, core); | ||||
|         } | ||||
|         catch (rewriter_exception & ex) { | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
|  | @ -244,7 +244,12 @@ public: | |||
|                             model_converter_ref & mc,  | ||||
|                             proof_converter_ref & pc, | ||||
|                             expr_dependency_ref & core) { | ||||
|         (*m_imp)(in, result, mc, pc, core); | ||||
|         try { | ||||
|             (*m_imp)(in, result, mc, pc, core); | ||||
|         } | ||||
|         catch (rewriter_exception & ex) { | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
|  | @ -97,10 +97,15 @@ void simplify_tactic::operator()(goal_ref const & in, | |||
|                                  model_converter_ref & mc,  | ||||
|                                  proof_converter_ref & pc, | ||||
|                                  expr_dependency_ref & core) { | ||||
|     (*m_imp)(*(in.get())); | ||||
|     in->inc_depth(); | ||||
|     result.push_back(in.get()); | ||||
|     mc = 0; pc = 0; core = 0; | ||||
|     try { | ||||
|         (*m_imp)(*(in.get())); | ||||
|         in->inc_depth(); | ||||
|         result.push_back(in.get()); | ||||
|         mc = 0; pc = 0; core = 0; | ||||
|     } | ||||
|     catch (rewriter_exception & ex) { | ||||
|         throw tactic_exception(ex.msg()); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void simplify_tactic::set_cancel(bool f) { | ||||
|  |  | |||
|  | @ -232,6 +232,7 @@ public: | |||
|             throw ex; | ||||
|         } | ||||
|         catch (z3_exception & ex) { | ||||
|             // convert all Z3 exceptions into tactic exceptions.
 | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -249,13 +249,19 @@ public: | |||
|                             model_converter_ref & mc,  | ||||
|                             proof_converter_ref & pc, | ||||
|                             expr_dependency_ref & core) { | ||||
|         m_imp->process(*in); | ||||
|         m_imp->collect_statistics(m_stats); | ||||
|         result.reset(); | ||||
|         result.push_back(in.get()); | ||||
|         mc   = 0; | ||||
|         pc   = 0; | ||||
|         core = 0; | ||||
|         try { | ||||
|             m_imp->process(*in); | ||||
|             m_imp->collect_statistics(m_stats); | ||||
|             result.reset(); | ||||
|             result.push_back(in.get()); | ||||
|             mc   = 0; | ||||
|             pc   = 0; | ||||
|             core = 0; | ||||
|         } | ||||
|         catch (z3_exception & ex) { | ||||
|             // convert all Z3 exceptions into tactic exceptions
 | ||||
|             throw tactic_exception(ex.msg()); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     virtual void cleanup() { | ||||
|  |  | |||
							
								
								
									
										41
									
								
								src/tactic/tactic_exception.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								src/tactic/tactic_exception.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,41 @@ | |||
| /*++
 | ||||
| Copyright (c) 2012 Microsoft Corporation | ||||
| 
 | ||||
| Module Name: | ||||
| 
 | ||||
|     tactic_exception.h | ||||
| 
 | ||||
| Abstract: | ||||
| 
 | ||||
|     Tactic expection object. | ||||
| 
 | ||||
| Author: | ||||
| 
 | ||||
|     Leonardo (leonardo) 2012-08-15 | ||||
| 
 | ||||
| Notes: | ||||
| 
 | ||||
| --*/ | ||||
| #ifndef _TACTIC_EXCEPTION_H_ | ||||
| #define _TACTIC_EXCEPTION_H_ | ||||
| 
 | ||||
| #include"z3_exception.h" | ||||
| #include"common_msgs.h" | ||||
| 
 | ||||
| class tactic_exception : public z3_exception { | ||||
| protected: | ||||
|     std::string m_msg; | ||||
| public: | ||||
|     tactic_exception(char const * msg):m_msg(msg) {} | ||||
|     virtual ~tactic_exception() {} | ||||
|     virtual char const * msg() const { return m_msg.c_str(); } | ||||
| }; | ||||
| 
 | ||||
| #define TACTIC_CANCELED_MSG      Z3_CANCELED_MSG | ||||
| #define TACTIC_MAX_MEMORY_MSG    Z3_MAX_MEMORY_MSG | ||||
| #define TACTIC_MAX_SCOPES_MSG    Z3_MAX_SCOPES_MSG | ||||
| #define TACTIC_MAX_STEPS_MSG     Z3_MAX_STEPS_MSG | ||||
| #define TACTIC_MAX_FRAMES_MSG    Z3_MAX_FRAMES_MSG | ||||
| #define TACTIC_NO_PROOF_GEN_MSG  Z3_NO_PROOF_GEN_MSG | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										26
									
								
								src/util/common_msgs.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/util/common_msgs.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,26 @@ | |||
| /*++
 | ||||
| Copyright (c) 2012 Microsoft Corporation | ||||
| 
 | ||||
| Module Name: | ||||
| 
 | ||||
|     common_msgs.cpp | ||||
| 
 | ||||
| Abstract: | ||||
| 
 | ||||
|     Common messages used in Z3. | ||||
| 
 | ||||
| Author: | ||||
| 
 | ||||
|     Leonardo (leonardo) 2012-10-25 | ||||
| 
 | ||||
| Notes: | ||||
| 
 | ||||
| --*/ | ||||
| #include"common_msgs.h" | ||||
| 
 | ||||
| char const * common_msgs::g_canceled_msg   = "canceled"; | ||||
| char const * common_msgs::g_max_memory_msg = "max. memory exceeded"; | ||||
| char const * common_msgs::g_max_scopes_msg = "max. scopes exceeded"; | ||||
| char const * common_msgs::g_max_steps_msg  = "max. steps exceeded"; | ||||
| char const * common_msgs::g_max_frames_msg = "max. frames exceeded"; | ||||
| char const * common_msgs::g_no_proofs_msg  = "component does not support proof generation"; | ||||
							
								
								
									
										39
									
								
								src/util/common_msgs.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								src/util/common_msgs.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,39 @@ | |||
| /*++
 | ||||
| Copyright (c) 2012 Microsoft Corporation | ||||
| 
 | ||||
| Module Name: | ||||
| 
 | ||||
|     common_msgs.h | ||||
| 
 | ||||
| Abstract: | ||||
| 
 | ||||
|     Common messages used in Z3. | ||||
| 
 | ||||
| Author: | ||||
| 
 | ||||
|     Leonardo (leonardo) 2012-10-25 | ||||
| 
 | ||||
| Notes: | ||||
| 
 | ||||
| --*/ | ||||
| #ifndef __COMMON_MSGS_H_ | ||||
| #define __COMMON_MSGS_H_ | ||||
| 
 | ||||
| class common_msgs { | ||||
| public: | ||||
|     static char const * g_canceled_msg; | ||||
|     static char const * g_max_memory_msg; | ||||
|     static char const * g_max_scopes_msg; | ||||
|     static char const * g_max_steps_msg; | ||||
|     static char const * g_max_frames_msg; | ||||
|     static char const * g_no_proofs_msg; | ||||
| }; | ||||
| 
 | ||||
| #define Z3_CANCELED_MSG      common_msgs::g_canceled_msg | ||||
| #define Z3_MAX_MEMORY_MSG    common_msgs::g_max_memory_msg | ||||
| #define Z3_MAX_SCOPES_MSG    common_msgs::g_max_scopes_msg | ||||
| #define Z3_MAX_STEPS_MSG     common_msgs::g_max_steps_msg | ||||
| #define Z3_MAX_FRAMES_MSG    common_msgs::g_max_frames_msg | ||||
| #define Z3_NO_PROOF_GEN_MSG  common_msgs::g_no_proofs_msg | ||||
| 
 | ||||
| #endif | ||||
|  | @ -1,26 +0,0 @@ | |||
| /*++
 | ||||
| Copyright (c) 2012 Microsoft Corporation | ||||
| 
 | ||||
| Module Name: | ||||
| 
 | ||||
|     tactic_exception.cpp | ||||
| 
 | ||||
| Abstract: | ||||
| 
 | ||||
|     Tactic expection object. | ||||
| 
 | ||||
| Author: | ||||
| 
 | ||||
|     Leonardo (leonardo) 2012-08-15 | ||||
| 
 | ||||
| Notes: | ||||
| 
 | ||||
| --*/ | ||||
| #include"tactic_exception.h" | ||||
| 
 | ||||
| char const * tactic_exception::g_tactic_canceled_msg   = "canceled"; | ||||
| char const * tactic_exception::g_tactic_max_memory_msg = "max. memory exceeded"; | ||||
| char const * tactic_exception::g_tactic_max_scopes_msg = "max. scopes exceeded"; | ||||
| char const * tactic_exception::g_tactic_max_steps_msg  = "max. steps exceeded"; | ||||
| char const * tactic_exception::g_tactic_max_frames_msg = "max. frames exceeded"; | ||||
| char const * tactic_exception::g_tactic_no_proofs_msg  = "tactic does not support proof generation"; | ||||
|  | @ -1,47 +0,0 @@ | |||
| /*++
 | ||||
| Copyright (c) 2012 Microsoft Corporation | ||||
| 
 | ||||
| Module Name: | ||||
| 
 | ||||
|     tactic_exception.h | ||||
| 
 | ||||
| Abstract: | ||||
| 
 | ||||
|     Tactic expection object. | ||||
| 
 | ||||
| Author: | ||||
| 
 | ||||
|     Leonardo (leonardo) 2012-08-15 | ||||
| 
 | ||||
| Notes: | ||||
| 
 | ||||
| --*/ | ||||
| #ifndef _TACTIC_EXCEPTION_H_ | ||||
| #define _TACTIC_EXCEPTION_H_ | ||||
| 
 | ||||
| #include"z3_exception.h" | ||||
| 
 | ||||
| class tactic_exception : public z3_exception { | ||||
| public: | ||||
|     static char const * g_tactic_canceled_msg; | ||||
|     static char const * g_tactic_max_memory_msg; | ||||
|     static char const * g_tactic_max_scopes_msg; | ||||
|     static char const * g_tactic_max_steps_msg; | ||||
|     static char const * g_tactic_max_frames_msg; | ||||
|     static char const * g_tactic_no_proofs_msg; | ||||
| protected: | ||||
|     std::string m_msg; | ||||
| public: | ||||
|     tactic_exception(char const * msg):m_msg(msg) {} | ||||
|     virtual ~tactic_exception() {} | ||||
|     virtual char const * msg() const { return m_msg.c_str(); } | ||||
| }; | ||||
| 
 | ||||
| #define TACTIC_CANCELED_MSG      tactic_exception::g_tactic_canceled_msg | ||||
| #define TACTIC_MAX_MEMORY_MSG    tactic_exception::g_tactic_max_memory_msg | ||||
| #define TACTIC_MAX_SCOPES_MSG    tactic_exception::g_tactic_max_scopes_msg | ||||
| #define TACTIC_MAX_STEPS_MSG     tactic_exception::g_tactic_max_steps_msg | ||||
| #define TACTIC_MAX_FRAMES_MSG    tactic_exception::g_tactic_max_frames_msg | ||||
| #define TACTIC_NO_PROOF_GEN_MSG  tactic_exception::g_tactic_no_proofs_msg | ||||
| 
 | ||||
| #endif | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue