parsetl: change the interface to return a parsed_formula
This gets the interface of all the functions parsing formula in line with the interface of the automaton parser: both return a "parsed_*" object (parsed_formula or parsed_automaton) that contains the said object and its list of errors. Doing so avoid having to declare the parse_error_list in advance. * spot/tl/parse.hh, spot/parsetl/parsetl.yy: Do the change. * spot/parsetl/fmterror.cc: Adjust the error printer. * NEWS: Document it. * bin/common_finput.cc, bin/common_finput.hh, bin/ltlcross.cc, bin/ltldo.cc, bin/ltlfilt.cc, doc/org/tut01.org, doc/org/tut02.org, doc/org/tut10.org, doc/org/tut20.org, python/ajax/spotcgi.in, python/spot/impl.i, spot/parseaut/parseaut.yy, tests/core/checkpsl.cc, tests/core/checkta.cc, tests/core/consterm.cc, tests/core/emptchk.cc, tests/core/equalsf.cc, tests/core/ikwiad.cc, tests/core/kind.cc, tests/core/length.cc, tests/core/ltlprod.cc, tests/core/ltlrel.cc, tests/core/randtgba.cc, tests/core/readltl.cc, tests/core/reduc.cc, tests/core/safra.cc, tests/core/syntimpl.cc, tests/core/tostring.cc, tests/ltsmin/modelcheck.cc, tests/python/alarm.py, tests/python/interdep.py, tests/python/ltl2tgba.py, tests/python/ltlparse.py: Adjust all uses.
This commit is contained in:
parent
cf4f58c34b
commit
22f442f758
37 changed files with 359 additions and 374 deletions
|
|
@ -1,6 +1,6 @@
|
|||
# -*- mode: python; coding: utf-8 -*-
|
||||
# Copyright (C) 2012, 2014, 2015 Laboratoire de Recherche et Développement
|
||||
# de l'Epita
|
||||
# Copyright (C) 2012, 2014, 2015, 2016 Laboratoire de Recherche et
|
||||
# Développement de l'Epita
|
||||
#
|
||||
# This file is part of Spot, a model checking library.
|
||||
#
|
||||
|
|
@ -43,8 +43,7 @@ P_Rbt2.moins || P_Rbt2.stop))-> G((F "map[0]==1") && (F "map[1]==1")
|
|||
"map[9]==3")))"""
|
||||
|
||||
e = spot.default_environment.instance()
|
||||
p = spot.empty_parse_error_list()
|
||||
f = spot.parse_infix_psl(f, p, e)
|
||||
pf = spot.parse_infix_psl(f, e)
|
||||
d = spot.make_bdd_dict()
|
||||
|
||||
spot.unblock_signal(signal.SIGALRM)
|
||||
|
|
@ -58,9 +57,9 @@ if child != 0:
|
|||
# If the child returns, before we get the alarm it's a bug.
|
||||
exit(1)
|
||||
|
||||
# This is expected to take WAY more that 2s.
|
||||
# This is expected to take WAY more than 2s.
|
||||
print("Before")
|
||||
spot.ltl_to_tgba_fm(f, d, True)
|
||||
spot.ltl_to_tgba_fm(pf.f, d, True)
|
||||
print("After")
|
||||
|
||||
exit(1)
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
# -*- mode: python; coding: utf-8 -*-
|
||||
# Copyright (C) 2010, 2012, 2014, 2015 Laboratoire de Recherche et
|
||||
# Copyright (C) 2010, 2012, 2014, 2015, 2016 Laboratoire de Recherche et
|
||||
# Développement de l'EPITA.
|
||||
# Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6
|
||||
# (LIP6), département Systèmes Répartis Coopératifs (SRC), Université
|
||||
|
|
@ -29,12 +29,11 @@ import sys
|
|||
simp = spot.tl_simplifier()
|
||||
|
||||
e = spot.default_environment.instance()
|
||||
p = spot.empty_parse_error_list()
|
||||
f = spot.parse_infix_psl('GFa', p, e)
|
||||
pf = spot.parse_infix_psl('GFa', e)
|
||||
d = simp.get_dict()
|
||||
a = spot.ltl_to_tgba_fm(f, d)
|
||||
g = spot.parse_infix_boolean('b&c', p, e)
|
||||
b = simp.as_bdd(g)
|
||||
a = spot.ltl_to_tgba_fm(pf.f, d)
|
||||
g = spot.parse_infix_boolean('b&c', e)
|
||||
b = simp.as_bdd(g.f)
|
||||
buddy.bdd_printset(b); spot.nl_cout()
|
||||
del g
|
||||
|
||||
|
|
@ -54,5 +53,5 @@ del it
|
|||
del s0
|
||||
del b
|
||||
del c
|
||||
del f
|
||||
del pf
|
||||
del simp
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
# -*- mode: python; coding: utf-8 -*-
|
||||
# Copyright (C) 2009, 2010, 2012, 2014, 2015 Laboratoire de Recherche et
|
||||
# Copyright (C) 2009, 2010, 2012, 2014, 2015, 2016 Laboratoire de Recherche et
|
||||
# Développement de l'Epita (LRDE).
|
||||
# Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||
# département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||
|
|
@ -83,11 +83,11 @@ cout = spot.get_cout()
|
|||
cerr = spot.get_cerr()
|
||||
|
||||
e = spot.default_environment.instance()
|
||||
p = spot.empty_parse_error_list()
|
||||
|
||||
f = spot.parse_infix_psl(args[0], p, e, debug_opt)
|
||||
if spot.format_parse_errors(cerr, args[0], p):
|
||||
pf = spot.parse_infix_psl(args[0], e, debug_opt)
|
||||
if pf.format_errors(cerr):
|
||||
exit_code = 1
|
||||
f = pf.f
|
||||
|
||||
dict = spot.make_bdd_dict()
|
||||
|
||||
|
|
@ -128,5 +128,6 @@ if f:
|
|||
else:
|
||||
exit_code = 1
|
||||
|
||||
del pf
|
||||
del dict
|
||||
assert spot.fnode_instances_check()
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
# -*- mode: python; coding: utf-8 -*-
|
||||
# Copyright (C) 2009, 2010, 2012, 2014, 2015 Laboratoire de Recherche et
|
||||
# Copyright (C) 2009, 2010, 2012, 2014, 2015, 2016 Laboratoire de Recherche et
|
||||
# Développement de l'Epita (LRDE).
|
||||
# Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||
# département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||
|
|
@ -24,22 +24,21 @@ import sys
|
|||
import spot
|
||||
|
||||
e = spot.default_environment.instance()
|
||||
p = spot.empty_parse_error_list()
|
||||
|
||||
l = ['GFa', 'a U (((b)) xor c)', '!(FFx <=> Fx)', 'a \/ a \/ b \/ a \/ a'];
|
||||
|
||||
for str1 in l:
|
||||
f = spot.parse_infix_psl(str1, p, e, False)
|
||||
if spot.format_parse_errors(spot.get_cout(), str1, p):
|
||||
pf = spot.parse_infix_psl(str1, e, False)
|
||||
if pf.format_errors(spot.get_cout()):
|
||||
sys.exit(1)
|
||||
str2 = str(f)
|
||||
del f
|
||||
str2 = str(pf.f)
|
||||
del pf
|
||||
sys.stdout.write(str2 + "\n")
|
||||
# Try to reparse the stringified formula
|
||||
f = spot.parse_infix_psl(str2, p, e)
|
||||
if spot.format_parse_errors(spot.get_cout(), str2, p):
|
||||
pf = spot.parse_infix_psl(str2, e)
|
||||
if pf.format_errors(spot.get_cout()):
|
||||
sys.exit(1)
|
||||
sys.stdout.write(str(f) + "\n")
|
||||
del f
|
||||
sys.stdout.write(str(pf.f) + "\n")
|
||||
del pf
|
||||
|
||||
assert spot.fnode_instances_check()
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue