* src/tgbaalgos/ltl2tgba.hh, src/tgbaalgos/ltl2tgba.cc: ... here. * src/tgba/Makefile.am, src/tgbaalgos/Makefile.am: Adjust. * src/tgba/public.hh: Do not include ltl2tgba.hh. * src/tgbatests/explprod.cc, src/tgbatests/ltl2tgba.cc, src/tgbatests/ltlprod.cc, src/tgbatests/mixprod.cc, src/tgbatests/reach.cc, src/tgbatests/tripprod.cc: Adjust inclusions.
53 lines
1.3 KiB
C++
53 lines
1.3 KiB
C++
#include <iostream>
|
|
#include <cassert>
|
|
#include "ltlvisit/destroy.hh"
|
|
#include "ltlast/allnodes.hh"
|
|
#include "ltlparse/public.hh"
|
|
#include "tgbaalgos/ltl2tgba.hh"
|
|
#include "tgba/tgbaproduct.hh"
|
|
#include "tgba/tgbabddconcreteproduct.hh"
|
|
#include "tgbaparse/public.hh"
|
|
#include "tgbaalgos/save.hh"
|
|
|
|
void
|
|
syntax(char* prog)
|
|
{
|
|
std::cerr << prog << " formula file" << std::endl;
|
|
exit(2);
|
|
}
|
|
|
|
int
|
|
main(int argc, char** argv)
|
|
{
|
|
int exit_code = 0;
|
|
|
|
if (argc != 3)
|
|
syntax(argv[0]);
|
|
|
|
spot::ltl::environment& env(spot::ltl::default_environment::instance());
|
|
|
|
spot::ltl::parse_error_list pel1;
|
|
spot::ltl::formula* f1 = spot::ltl::parse(argv[1], pel1, env);
|
|
if (spot::ltl::format_parse_errors(std::cerr, argv[1], pel1))
|
|
return 2;
|
|
|
|
spot::tgba_parse_error_list pel2;
|
|
spot::tgba_explicit* a2 = spot::tgba_parse(argv[2], pel2, env);
|
|
if (spot::format_tgba_parse_errors(std::cerr, pel2))
|
|
return 2;
|
|
|
|
{
|
|
spot::tgba_bdd_concrete a1 = spot::ltl_to_tgba(f1);
|
|
spot::ltl::destroy(f1);
|
|
spot::tgba_product p(a1, *a2);
|
|
|
|
spot::tgba_save_reachable(std::cout, p);
|
|
}
|
|
|
|
assert(spot::ltl::unop::instance_count() == 0);
|
|
assert(spot::ltl::binop::instance_count() == 0);
|
|
assert(spot::ltl::multop::instance_count() == 0);
|
|
delete a2;
|
|
assert(spot::ltl::atomic_prop::instance_count() == 0);
|
|
return exit_code;
|
|
}
|