Files
cvc5/examples/api/python/parser.py
Andrew Reynolds 68fc815e03 Add setStringInput to the parser APIs (#10230)
This PR:

Updates the functionality of setIncrementalStringInput / appendIncrementalStringInput to a more intuitive behavior where append does not replace the current contents of the input.
Adds setStringInput to the API and updates the interactive shell to use this interface.
Updates the examples
Adds new unit tests
2023-12-15 19:50:57 +00:00

58 lines
1.7 KiB
Python

#!/usr/bin/env python
###############################################################################
# Top contributors (to current version):
# Daniel Larraz
#
# This file is part of the cvc5 project.
#
# Copyright (c) 2009-2023 by the authors listed in the file AUTHORS
# in the top-level source directory and their institutional affiliations.
# All rights reserved. See the file COPYING in the top-level source
# directory for licensing information.
# #############################################################################
#
# A simple demonstration of using the parser via Python API
##
import cvc5
if __name__ == "__main__":
slv = cvc5.Solver()
# set that we should print success after each successful command
slv.setOption("print-success", "true")
# construct an input parser associated the solver above
parser = cvc5.InputParser(slv)
input = """
(set-logic QF_LIA)
(declare-fun a () Int)
(declare-fun b () Int)
(declare-fun c () Int)
(assert (> a (+ b c)))
(assert (< a b))
(assert (> c 0))
"""
parser.setStringInput(cvc5.InputLanguage.SMT_LIB_2_6, input, "MyInput")
# get the symbol manager of the parser, used when invoking commands below
sm = parser.getSymbolManager()
# parse commands until finished
while True:
cmd = parser.nextCommand()
if cmd.isNull():
break
print(f"Executing command {cmd}:")
# invoke the command on the solver and the symbol manager, print the result
print(cmd.invoke(slv, sm), end="")
print("Finished parsing commands")
# now, check sat with the solver
r = slv.checkSat()
print("expected: unsat")
print(f"result: {r}")