mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	smtio: Emit mode: start options before set-logic command and any other options after it.
				
					
				
			Refer to the SMT-LIB specification, section 4.1.7. According to the spec, some options can only be specified in `start` mode. Once the solver sees `set-logic`, it moves to `assert` mode.
This commit is contained in:
		
							parent
							
								
									654864658f
								
							
						
					
					
						commit
						42fb75c570
					
				
					 1 changed files with 8 additions and 1 deletions
				
			
		|  | @ -262,13 +262,20 @@ class SmtIo: | ||||||
|         if self.produce_models: |         if self.produce_models: | ||||||
|             self.write("(set-option :produce-models true)") |             self.write("(set-option :produce-models true)") | ||||||
| 
 | 
 | ||||||
|  |         #See the SMT-LIB Standard, Section 4.1.7 | ||||||
|  |         modestart_options = [":global-declarations", ":interactive-mode", ":produce-assertions", ":produce-assignments", ":produce-models", ":produce-proofs", ":produce-unsat-assumptions", ":produce-unsat-cores", ":random-seed"] | ||||||
|  |         for key, val in self.smt2_options.items(): | ||||||
|  |             if key in modestart_options: | ||||||
|  |                 self.write("(set-option {} {})".format(key, val)) | ||||||
|  | 
 | ||||||
|         self.write("(set-logic %s)" % self.logic) |         self.write("(set-logic %s)" % self.logic) | ||||||
| 
 | 
 | ||||||
|         if self.forall and self.solver == "yices": |         if self.forall and self.solver == "yices": | ||||||
|             self.write("(set-option :yices-ef-max-iters 1000000000)") |             self.write("(set-option :yices-ef-max-iters 1000000000)") | ||||||
| 
 | 
 | ||||||
|         for key, val in self.smt2_options.items(): |         for key, val in self.smt2_options.items(): | ||||||
|             self.write("(set-option {} {})".format(key, val)) |             if key not in modestart_options: | ||||||
|  |                 self.write("(set-option {} {})".format(key, val)) | ||||||
| 
 | 
 | ||||||
|     def timestamp(self): |     def timestamp(self): | ||||||
|         secs = int(time() - self.start_time) |         secs = int(time() - self.start_time) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue