Fixes #86. * src/ltlvisit/lbt.hh, src/ltlvisit/lbt.cc: Delete and move contents into... * src/ltlvisit/tostring.hh, src/ltlvisit/tostring.cc: ... these. * doc/org/tut01.org, src/bin/common_output.cc, src/bin/common_trans.cc, src/bin/ltlcross.cc, src/ltlvisit/Makefile.am, src/twaalgos/lbtt.cc, wrap/python/spot_impl.i: Adjust.
173 lines
7 KiB
C++
173 lines
7 KiB
C++
// -*- coding: utf-8 -*-
|
|
// Copyright (C) 2010, 2011, 2012, 2013, 2014, 2015 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
|
|
// et Marie Curie.
|
|
//
|
|
// This file is part of Spot, a model checking library.
|
|
//
|
|
// Spot is free software; you can redistribute it and/or modify it
|
|
// under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation; either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Spot is distributed in the hope that it will be useful, but WITHOUT
|
|
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
// License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#pragma once
|
|
|
|
#include <ltlast/formula.hh>
|
|
#include <iosfwd>
|
|
|
|
namespace spot
|
|
{
|
|
namespace ltl
|
|
{
|
|
/// \addtogroup ltl_io
|
|
/// @{
|
|
|
|
/// \brief Output a formula as a string which is parsable unless the formula
|
|
/// contains automaton operators (used in ELTL formulae).
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::ostream&
|
|
to_string(const formula* f, std::ostream& os, bool full_parent = false,
|
|
bool ratexp = false);
|
|
|
|
/// \brief Output a formula as a string which is parsable unless the formula
|
|
/// contains automaton operators (used in ELTL formulae).
|
|
/// \param f The formula to translate.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::string
|
|
to_string(const formula* f, bool full_parent = false, bool ratexp = false);
|
|
|
|
/// \brief Output a formula as an utf8 string which is parsable unless
|
|
/// the formula contains automaton operators (used in ELTL formulae).
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::ostream&
|
|
to_utf8_string(const formula* f, std::ostream& os, bool full_parent = false,
|
|
bool ratexp = false);
|
|
|
|
/// \brief Output a formula as an utf8 string which is parsable
|
|
/// unless the formula contains automaton operators (used in ELTL formulae).
|
|
/// \param f The formula to translate.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::string
|
|
to_utf8_string(const formula* f, bool full_parent = false,
|
|
bool ratexp = false);
|
|
|
|
/// \brief Output a formula as a string parsable by Spin.
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
SPOT_API std::ostream&
|
|
to_spin_string(const formula* f, std::ostream& os,
|
|
bool full_parent = false);
|
|
|
|
/// \brief Convert a formula into a string parsable by Spin.
|
|
/// \param f The formula to translate.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
SPOT_API std::string
|
|
to_spin_string(const formula* f, bool full_parent = false);
|
|
|
|
/// \brief Output a formula as a string parsable by Wring.
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
SPOT_API std::ostream&
|
|
to_wring_string(const formula* f, std::ostream& os);
|
|
|
|
/// \brief Convert a formula into a string parsable by Wring
|
|
/// \param f The formula to translate.
|
|
SPOT_API std::string
|
|
to_wring_string(const formula* f);
|
|
|
|
/// \brief Output a formula as an LaTeX string which is parsable.
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::ostream&
|
|
to_latex_string(const formula* f, std::ostream& os,
|
|
bool full_parent = false, bool ratexp = false);
|
|
|
|
/// \brief Output a formula as a LaTeX string which is parsable.
|
|
/// unless the formula contains automaton operators (used in ELTL formulae).
|
|
/// \param f The formula to translate.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::string
|
|
to_latex_string(const formula* f,
|
|
bool full_parent = false, bool ratexp = false);
|
|
|
|
|
|
/// \brief Output a formula as a self-contained LaTeX string.
|
|
///
|
|
/// The result cannot be parsed back.
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::ostream&
|
|
to_sclatex_string(const formula* f, std::ostream& os,
|
|
bool full_parent = false, bool ratexp = false);
|
|
|
|
/// \brief Output a formula as a self-contained LaTeX string.
|
|
///
|
|
/// The result cannot be parsed bacl.
|
|
/// \param f The formula to translate.
|
|
/// \param full_parent Whether or not the string should by fully
|
|
/// parenthesized.
|
|
/// \param ratexp Whether we are printing a SERE.
|
|
SPOT_API std::string
|
|
to_sclatex_string(const formula* f,
|
|
bool full_parent = false, bool ratexp = false);
|
|
|
|
/// \brief Output an LTL formula as a string in LBT's format.
|
|
///
|
|
/// The formula must be an LTL formula (ELTL and PSL operators
|
|
/// are not supported). The M and W operator will be output
|
|
/// as-is, because this is accepted by LBTT, however if you
|
|
/// plan to use the output with other tools, you should probably
|
|
/// rewrite these two operators using unabbreviate_wm().
|
|
///
|
|
/// \param f The formula to translate.
|
|
/// \param os The stream where it should be output.
|
|
SPOT_API std::ostream&
|
|
to_lbt_string(const formula* f, std::ostream& os);
|
|
|
|
/// \brief Output an LTL formula as a string in LBT's format.
|
|
///
|
|
/// The formula must be an LTL formula (ELTL and PSL operators
|
|
/// are not supported). The M and W operator will be output
|
|
/// as-is, because this is accepted by LBTT, however if you
|
|
/// plan to use the output with other tools, you should probably
|
|
/// rewrite these two operators using unabbreviate_wm().
|
|
///
|
|
/// \param f The formula to translate.
|
|
SPOT_API std::string
|
|
to_lbt_string(const formula* f);
|
|
/// @}
|
|
}
|
|
}
|