spot.i 5.23 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
%module(directors="1") spot
23
24
25
26

%include "std_string.i"
%include "std_list.i"

27
28
%import "buddy.i"

29
%{
30
31
#include <iostream>
#include <fstream>
32
#include <sstream>
33
#include <signal.h>
34

35
#include "misc/version.hh"
36
37
#include "misc/bddalloc.hh"
#include "misc/minato.hh"
38
#include "misc/modgray.hh"
39

40
41
42
43
44
45
46
47
48
#include "ltlast/formula.hh"
#include "ltlast/refformula.hh"
#include "ltlast/atomic_prop.hh"
#include "ltlast/binop.hh"
#include "ltlast/constant.hh"
#include "ltlast/multop.hh"
#include "ltlast/unop.hh"
#include "ltlast/visitor.hh"

49
50
#include "ltlenv/environment.hh"
#include "ltlenv/defaultenv.hh"
51

52
53
54
#include "ltlparse/public.hh"

#include "ltlvisit/clone.hh"
55
#include "ltlvisit/destroy.hh"
56
57
58
59
#include "ltlvisit/dotty.hh"
#include "ltlvisit/dump.hh"
#include "ltlvisit/lunabbrev.hh"
#include "ltlvisit/nenoform.hh"
60
#include "ltlvisit/reduce.hh"
61
#include "ltlvisit/tostring.hh"
62
#include "ltlvisit/tunabbrev.hh"
63

64
65
66
67
68
69
70
71
72
73
74
75
76
#include "tgba/bdddict.hh"
#include "tgba/bddprint.hh"
#include "tgba/state.hh"
#include "tgba/succiter.hh"
#include "tgba/tgba.hh"
#include "tgba/statebdd.hh"
#include "tgba/tgbabddcoredata.hh"
#include "tgba/succiterconcrete.hh"
#include "tgba/tgbabddconcrete.hh"
#include "tgba/tgbaexplicit.hh"
#include "tgba/tgbaproduct.hh"
#include "tgba/tgbatba.hh"

77
#include "tgbaalgos/ltl2tgba_lacim.hh"
78
#include "tgbaalgos/ltl2tgba_fm.hh"
79
#include "tgbaalgos/dotty.hh"
80
#include "tgbaalgos/dupexp.hh"
81
82
#include "tgbaalgos/lbtt.hh"
#include "tgbaalgos/magic.hh"
83
#include "tgbaalgos/neverclaim.hh"
84
#include "tgbaalgos/save.hh"
85
#include "tgbaalgos/stats.hh"
86

87
using namespace spot::ltl;
88
using namespace spot;
89
90
%}

91
%include "misc/version.hh"
92
93
%include "misc/bddalloc.hh"
%include "misc/minato.hh"
94

95
96
97
%feature("director") spot::loopless_modular_mixed_radix_gray_code;
%include "misc/modgray.hh"

98
99
100
101
102
103
104
105
106
%include "ltlast/formula.hh"
%include "ltlast/refformula.hh"
%include "ltlast/atomic_prop.hh"
%include "ltlast/binop.hh"
%include "ltlast/constant.hh"
%include "ltlast/multop.hh"
%include "ltlast/unop.hh"
%include "ltlast/visitor.hh"

107
108
%include "ltlenv/environment.hh"
%include "ltlenv/defaultenv.hh"
109

110
111
112
%include "ltlparse/public.hh"

%include "ltlvisit/clone.hh"
113
%include "ltlvisit/destroy.hh"
114
115
116
117
%include "ltlvisit/dotty.hh"
%include "ltlvisit/dump.hh"
%include "ltlvisit/lunabbrev.hh"
%include "ltlvisit/nenoform.hh"
118
%include "ltlvisit/reduce.hh"
119
%include "ltlvisit/tostring.hh"
120
121
%include "ltlvisit/tunabbrev.hh"

122
%feature("new") spot::ltl_to_tgba_lacim;
123
%feature("new") spot::ltl_to_tgba_fm;
124
125
126
%feature("new") spot::tgba::get_init_state;
%feature("new") spot::tgba::succ_iter;
%feature("new") spot::tgba_succ_iterator::current_state;
127
128
%feature("new") spot::tgba_dupexp_bfs;
%feature("new") spot::tgba_dupexp_dfs;
129

130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
// Help SWIG with namespace lookups.
#define ltl spot::ltl
%include "tgba/bdddict.hh"
%include "tgba/bddprint.hh"
%include "tgba/state.hh"
%include "tgba/succiter.hh"
%include "tgba/tgba.hh"
%include "tgba/statebdd.hh"
%include "tgba/tgbabddcoredata.hh"
%include "tgba/succiterconcrete.hh"
%include "tgba/tgbabddconcrete.hh"
%include "tgba/tgbaexplicit.hh"
%include "tgba/tgbaproduct.hh"
%include "tgba/tgbatba.hh"

145
%include "tgbaalgos/ltl2tgba_lacim.hh"
146
%include "tgbaalgos/ltl2tgba_fm.hh"
147
%include "tgbaalgos/dotty.hh"
148
%include "tgbaalgos/dupexp.hh"
149
150
%include "tgbaalgos/lbtt.hh"
%include "tgbaalgos/magic.hh"
151
%include "tgbaalgos/neverclaim.hh"
152
%include "tgbaalgos/save.hh"
153
%include "tgbaalgos/stats.hh"
154
#undef ltl
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172

%extend spot::ltl::formula {

  // When comparing formula, make sure Python compare our
  // pointers, not the pointers to its wrappers.
  int
  __cmp__(const spot::ltl::formula* b)
  {
    return b - self;
  }

  std::string
  __str__(void)
  {
    return spot::ltl::to_string(self);
  }

}
173

174
175
176
177
178
179
180
181
182
%nodefault std::ostream;
namespace std {
  class ostream {};
  class ofstream : public ostream
  {
  public:
     ofstream(const char *fn);
     ~ofstream();
  };
183
184
185
186
187
188
189
  class ostringstream : public ostream
  {
  public:
     ostringstream();
     std::string str() const;
     ~ofstream();
  };
190
191
}

192
193
%inline %{

194
spot::ltl::parse_error_list
195
196
197
198
199
200
empty_parse_error_list()
{
  parse_error_list l;
  return l;
}

201
std::ostream&
202
203
204
205
206
get_cout()
{
  return std::cout;
}

207
std::ostream&
208
209
210
211
212
get_cerr()
{
  return std::cerr;
}

213
void
214
215
216
217
print_on(std::ostream& on, const std::string& what)
{
  on << what;
}
218

219
220
221
222
223
224
225
226
227
int
unblock_signal(int signum)
{
  sigset_t set;
  sigemptyset(&set);
  sigaddset(&set, signum);
  return sigprocmask(SIG_UNBLOCK, &set, 0);
}

228
%}