spot.i 9.45 KB
Newer Older
1
2
3
// -*- encoding: utf-8 -*-
// Copyright (C) 2009, 2010, 2011, 2012  Laboratoire de Recherche
// et Développement de l'Epita (LRDE).
4
// Copyright (C) 2003, 2004, 2005, 2006  Laboratoire d'Informatique
5
6
// de Paris 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
// Université Pierre et Marie Curie.
Alexandre Duret-Lutz's avatar
Alexandre Duret-Lutz committed
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//
// 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.

25
26
27
28
29
30
%{
  // Workaround for SWIG 2.0.2 using ptrdiff_t but not including cstddef.
  // It matters with g++ 4.6.
#include <cstddef>
%}

31
%module(directors="1") spot
32
33
34
35

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

36
37
38
39
namespace std {
   %template(liststr) list<string>;
};

40
41
%import "buddy.i"

42
%{
43
44
#include <iostream>
#include <fstream>
45
#include <sstream>
46
#include <signal.h>
47

48
#include "misc/version.hh"
49
50
#include "misc/bddalloc.hh"
#include "misc/minato.hh"
51
#include "misc/modgray.hh"
52
#include "misc/optionmap.hh"
53
#include "misc/random.hh"
54

55
#include "ltlast/formula.hh"
56
57
58
59
60
61
62
#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"
63

64
65
#include "ltlenv/environment.hh"
#include "ltlenv/defaultenv.hh"
66

67
68
69
70
71
72
#include "ltlparse/public.hh"

#include "ltlvisit/dotty.hh"
#include "ltlvisit/dump.hh"
#include "ltlvisit/lunabbrev.hh"
#include "ltlvisit/nenoform.hh"
73
#include "ltlvisit/simplify.hh"
74
#include "ltlvisit/tostring.hh"
75
#include "ltlvisit/tunabbrev.hh"
76

77
78
79
80
81
82
#include "tgba/bdddict.hh"
#include "tgba/bddprint.hh"
#include "tgba/state.hh"
#include "tgba/succiter.hh"
#include "tgba/tgba.hh"
#include "tgba/statebdd.hh"
83
#include "tgba/taatgba.hh"
84
85
86
87
88
89
90
#include "tgba/tgbabddcoredata.hh"
#include "tgba/succiterconcrete.hh"
#include "tgba/tgbabddconcrete.hh"
#include "tgba/tgbaexplicit.hh"
#include "tgba/tgbaproduct.hh"
#include "tgba/tgbatba.hh"

91
#include "tgbaalgos/dottydec.hh"
92
#include "tgbaalgos/dotty.hh"
93
#include "tgbaalgos/dupexp.hh"
94
95
#include "tgbaalgos/emptiness.hh"
#include "tgbaalgos/gtec/gtec.hh"
96
97
98
99
#include "tgbaalgos/lbtt.hh"
#include "tgbaalgos/ltl2taa.hh"
#include "tgbaalgos/ltl2tgba_fm.hh"
#include "tgbaalgos/ltl2tgba_lacim.hh"
100
#include "tgbaalgos/magic.hh"
101
#include "tgbaalgos/minimize.hh"
102
#include "tgbaalgos/neverclaim.hh"
103
#include "tgbaalgos/rundotdec.hh"
104
#include "tgbaalgos/save.hh"
105
#include "tgbaalgos/safety.hh"
106
#include "tgbaalgos/sccfilter.hh"
107
#include "tgbaalgos/stats.hh"
108
#include "tgbaalgos/simulation.hh"
109

110
using namespace spot::ltl;
111
using namespace spot;
112
113
%}

114
115
116
117
// For spot::emptiness_check_instantiator::construct and any other
// function that return errors via a "char **err" argument.
%typemap(in, numinputs=0) char** OUTPUT (char* temp)
  "$1 = &temp;";
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
%typemap(argout) char** OUTPUT {
  PyObject *obj = SWIG_FromCharPtr(*$1);
  if (!$result) {
    $result = obj;
  //# If the function returns null_ptr (i.e. Py_None), we
  //# don't want to override it with OUTPUT as in the
  //# default implementation of t_output_helper.
  // } else if ($result == Py_None) {
  //   Py_DECREF($result);
  //   $result = obj;
  } else {
    if (!PyList_Check($result)) {
      PyObject *o2 = $result;
      $result = PyList_New(1);
      PyList_SetItem($result, 0, o2);
    }
    PyList_Append($result,obj);
    Py_DECREF(obj);
  }
 };
138
139
%apply char** OUTPUT { char** err };

140
141
142
143
144
// False and True cannot be redefined in Python3, even in a class.
// Spot uses these in an enum of the constant class.
%rename(FalseVal) False;
%rename(TrueVal) True;

145
%include "misc/version.hh"
146
147
%include "misc/bddalloc.hh"
%include "misc/minato.hh"
148
%include "misc/optionmap.hh"
149
%include "misc/random.hh"
150

151
152
153
%feature("director") spot::loopless_modular_mixed_radix_gray_code;
%include "misc/modgray.hh"

154
%include "ltlast/formula.hh"
155
156
157
158
159
160
161
%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"
162

163
164
%include "ltlenv/environment.hh"
%include "ltlenv/defaultenv.hh"
165

166
167
168
169
170
171
%include "ltlparse/public.hh"

%include "ltlvisit/dotty.hh"
%include "ltlvisit/dump.hh"
%include "ltlvisit/lunabbrev.hh"
%include "ltlvisit/nenoform.hh"
172
%include "ltlvisit/simplify.hh"
173
%include "ltlvisit/tostring.hh"
174
175
%include "ltlvisit/tunabbrev.hh"

176
%feature("new") spot::emptiness_check::check;
177
178
%feature("new") spot::emptiness_check_instantiator::construct;
%feature("new") spot::emptiness_check_instantiator::instanciate;
179
%feature("new") spot::emptiness_check_result::accepting_run;
180
181
%feature("new") spot::explicit_magic_search;
%feature("new") spot::explicit_se05_search;
182
183
184
%feature("new") spot::ltl_to_taa;
%feature("new") spot::ltl_to_tgba_fm;
%feature("new") spot::ltl_to_tgba_lacim;
185
186
%feature("new") spot::minimize_wdba;
%feature("new") spot::minimize_monitor;
187
%feature("new") spot::scc_filter;
188
189
190
191
192
%feature("new") spot::tgba_dupexp_bfs;
%feature("new") spot::tgba_dupexp_dfs;
%feature("new") spot::tgba::get_init_state;
%feature("new") spot::tgba::succ_iter;
%feature("new") spot::tgba_succ_iterator::current_state;
193
%feature("new") spot::simulation;
194
195
196
197
198
199
200
201
// 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"
202
%include "tgba/taatgba.hh"
203
204
205
206
207
208
209
%include "tgba/tgbabddcoredata.hh"
%include "tgba/succiterconcrete.hh"
%include "tgba/tgbabddconcrete.hh"
%include "tgba/tgbaexplicit.hh"
%include "tgba/tgbaproduct.hh"
%include "tgba/tgbatba.hh"

210
211
212
213
214
215
216
217
218
219
%template(explicit_graph__string_tgba)
  spot::explicit_graph<state_explicit_string, tgba>;
%template(explicit_graph__number_tgba)
  spot::explicit_graph<state_explicit_number, tgba>;
%template(explicit_graph__formula_tgba)
  spot::explicit_graph<state_explicit_formula, tgba>;
%template(tgba_explicit__string) spot::tgba_explicit<state_explicit_string>;
%template(tgba_explicit__number) spot::tgba_explicit<state_explicit_number>;
%template(tgba_explicit__formula) spot::tgba_explicit<state_explicit_formula>;

220
%include "tgbaalgos/dottydec.hh"
221
%include "tgbaalgos/dotty.hh"
222
%include "tgbaalgos/dupexp.hh"
223
224
%include "tgbaalgos/emptiness.hh"
%include "tgbaalgos/gtec/gtec.hh"
225
226
227
228
%include "tgbaalgos/lbtt.hh"
%include "tgbaalgos/ltl2taa.hh"
%include "tgbaalgos/ltl2tgba_fm.hh"
%include "tgbaalgos/ltl2tgba_lacim.hh"
229
%include "tgbaalgos/magic.hh"
230
%include "tgbaalgos/minimize.hh"
231
%include "tgbaalgos/neverclaim.hh"
232
%include "tgbaalgos/rundotdec.hh"
233
%include "tgbaalgos/save.hh"
234
%include "tgbaalgos/safety.hh"
235
%include "tgbaalgos/sccfilter.hh"
236
%include "tgbaalgos/stats.hh"
237
%include "tgbaalgos/simulation.hh"
238
#undef ltl
239
240
241
242
243

%extend spot::ltl::formula {

  // When comparing formula, make sure Python compare our
  // pointers, not the pointers to its wrappers.
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260

  // __cmp__ is for Python 2.0
  int __cmp__(const spot::ltl::formula* b) { return self - b; }
  // These are for Python 2.1+ or 3.x.  They more closely match
  // the logic in Spot.
  bool __lt__(const spot::ltl::formula* b)
  { spot::ltl::formula_ptr_less_than lt; return lt(self, b); }
  bool __le__(const spot::ltl::formula* b)
  { spot::ltl::formula_ptr_less_than lt; return !lt(b, self); }
  bool __eq__(const spot::ltl::formula* b) { return self == b; }
  bool __ne__(const spot::ltl::formula* b) { return self != b; }
  bool __gt__(const spot::ltl::formula* b)
  { spot::ltl::formula_ptr_less_than lt; return lt(b, self); }
  bool __ge__(const spot::ltl::formula* b)
  { spot::ltl::formula_ptr_less_than lt; return !lt(self, b); }

  size_t __hash__() { return self->hash(); }
261
262
263
264
265
266
267
268

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

}
269

270
%nodefaultctor std::ostream;
271
272
273
274
275
276
277
278
namespace std {
  class ostream {};
  class ofstream : public ostream
  {
  public:
     ofstream(const char *fn);
     ~ofstream();
  };
279
280
281
282
283
  class ostringstream : public ostream
  {
  public:
     ostringstream();
     std::string str() const;
284
     ~ostringstream();
285
  };
286
287
}

288
289
%feature("new") minimize_obligation_new;

290
291
%inline %{

292
293
294
295
296
297
298
299
300
301
302
303
304
// A variant of minimize_obligation() that always return a new object.
const spot::tgba*
minimize_obligation_new(const spot::tgba* a, const spot::ltl::formula* f)
{
  const tgba* res = spot::minimize_obligation(a, f);
  // Return 0 if the output is the same as the input, otherwise
  // it is hard for swig to know if the output is "new" or not.
  if (res == a)
    return 0;
  else
    return res;
}

305
spot::ltl::parse_error_list
306
307
308
309
310
311
empty_parse_error_list()
{
  parse_error_list l;
  return l;
}

312
std::ostream&
313
314
315
316
317
get_cout()
{
  return std::cout;
}

318
319
320
321
322
323
void
nl_cout()
{
  std::cout << std::endl;
}

324
std::ostream&
325
326
327
328
329
get_cerr()
{
  return std::cerr;
}

330
331
332
333
334
335
void
nl_cerr()
{
  std::cerr << std::endl;
}

336
void
337
338
339
340
print_on(std::ostream& on, const std::string& what)
{
  on << what;
}
341

342
343
344
345
346
347
348
349
350
int
unblock_signal(int signum)
{
  sigset_t set;
  sigemptyset(&set);
  sigaddset(&set, signum);
  return sigprocmask(SIG_UNBLOCK, &set, 0);
}

351
%}
352
353
354
355
356
357
358
359
360
361

%extend spot::ltl::parse_error_list {

bool
__nonzero__()
{
  return !self->empty();
}

}