dotty.cc 2.24 KB
Newer Older
1
// Copyright (C) 2003, 2004  Laboratoire d'Informatique de Paris 6 (LIP6),
Alexandre Duret-Lutz's avatar
Alexandre Duret-Lutz committed
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// dpartement Systmes Rpartis Coopratifs (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 2 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 Spot; see the file COPYING.  If not, write to the Free
// Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
// 02111-1307, USA.

22
#include <ostream>
23
#include "tgba/tgba.hh"
24
25
#include "dotty.hh"
#include "tgba/bddprint.hh"
26
#include "reachiter.hh"
27
#include "misc/escape.hh"
28
29
30

namespace spot
{
31

32
  class dotty_bfs : public tgba_reachable_iterator_breadth_first
33
  {
34
35
36
37
38
39
40
41
42
43
  public:
    dotty_bfs(const tgba* a, std::ostream& os)
      : tgba_reachable_iterator_breadth_first(a), os_(os)
    {
    }

    void
    start()
    {
      os_ << "digraph G {" << std::endl;
44
      os_ << "  0 [label=\"\", style=invis, height=0]" << std::endl;
45
46
47
48
49
50
51
52
53
54
55
56
      os_ << "  0 -> 1" << std::endl;
    }

    void
    end()
    {
      os_ << "}" << std::endl;
    }

    void
    process_state(const state* s, int n, tgba_succ_iterator*)
    {
57
58
      os_ << "  " << n << " [label=\"";
      escape_str(os_, automata_->format_state(s)) << "\"]" << std::endl;
59
60
61
62
63
64
    }

    void
    process_link(int in, int out, const tgba_succ_iterator* si)
    {
      os_ << "  " << in << " -> " << out << " [label=\"";
65
66
67
68
69
70
      escape_str(os_, bdd_format_formula(automata_->get_dict(),
					 si->current_condition())) << "\\n";
      escape_str(os_,
		 bdd_format_accset(automata_->get_dict(),
				   si->current_acceptance_conditions()))
	<< "\"]" << std::endl;
71
72
73
74
75
    }

  private:
    std::ostream& os_;
  };
76
77

  std::ostream&
78
  dotty_reachable(std::ostream& os, const tgba* g)
79
  {
80
81
    dotty_bfs d(g, os);
    d.run();
82
83
84
85
86
    return os;
  }


}