spot.i 12.3 KB
Newer Older
1
// -*- coding: utf-8 -*-
2
// Copyright (C) 2009, 2010, 2011, 2012, 2013  Laboratoire de Recherche
3
// 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
//
// 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
12
// the Free Software Foundation; either version 3 of the License, or
Alexandre Duret-Lutz's avatar
Alexandre Duret-Lutz committed
13
14
15
16
17
18
19
20
// (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
21
// along with this program.  If not, see <http://www.gnu.org/licenses/>.
Alexandre Duret-Lutz's avatar
Alexandre Duret-Lutz committed
22

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

29
%module(directors="1") spot
30
31
32
33

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

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

38
39
%import "buddy.i"

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

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

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

62
63
#include "ltlenv/environment.hh"
#include "ltlenv/defaultenv.hh"
64

65
66
67
68
69
70
#include "ltlparse/public.hh"

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

76
77
78
79
80
#include "tgba/bdddict.hh"
#include "tgba/bddprint.hh"
#include "tgba/state.hh"
#include "tgba/succiter.hh"
#include "tgba/tgba.hh"
81
#include "tgba/sba.hh"
82
#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/degen.hh"
94
#include "tgbaalgos/dupexp.hh"
95
96
#include "tgbaalgos/emptiness.hh"
#include "tgbaalgos/gtec/gtec.hh"
97
98
99
100
#include "tgbaalgos/lbtt.hh"
#include "tgbaalgos/ltl2taa.hh"
#include "tgbaalgos/ltl2tgba_fm.hh"
#include "tgbaalgos/ltl2tgba_lacim.hh"
101
#include "tgbaalgos/magic.hh"
102
#include "tgbaalgos/minimize.hh"
103
#include "tgbaalgos/neverclaim.hh"
104
#include "tgbaalgos/rundotdec.hh"
105
#include "tgbaalgos/save.hh"
106
#include "tgbaalgos/safety.hh"
107
#include "tgbaalgos/sccfilter.hh"
108
#include "tgbaalgos/stats.hh"
109
#include "tgbaalgos/isdet.hh"
110
#include "tgbaalgos/simulation.hh"
111
#include "tgbaalgos/postproc.hh"
112

113
114
#include "tgbaparse/public.hh"

115
116
117
118
119
120
121
122
123
#include "ta/ta.hh"
#include "ta/tgta.hh"
#include "ta/taexplicit.hh"
#include "ta/tgtaexplicit.hh"
#include "taalgos/tgba2ta.hh"
#include "taalgos/dotty.hh"
#include "taalgos/stats.hh"
#include "taalgos/minimize.hh"

124
using namespace spot::ltl;
125
using namespace spot;
126
127
%}

128
129
130
131
// 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;";
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
%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);
  }
 };
152
153
%apply char** OUTPUT { char** err };

154
155
156
157
158
// 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;

159
%include "misc/version.hh"
160
161
%include "misc/bddalloc.hh"
%include "misc/minato.hh"
162
%include "misc/optionmap.hh"
163
%include "misc/random.hh"
164

165
166
167
%feature("director") spot::loopless_modular_mixed_radix_gray_code;
%include "misc/modgray.hh"

168
%include "ltlast/formula.hh"
169
170
171
172
173
174
175
%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"
176

177
178
%include "ltlenv/environment.hh"
%include "ltlenv/defaultenv.hh"
179

180
181
182
183
184
185
%include "ltlparse/public.hh"

%include "ltlvisit/dotty.hh"
%include "ltlvisit/dump.hh"
%include "ltlvisit/lunabbrev.hh"
%include "ltlvisit/nenoform.hh"
186
%include "ltlvisit/simplify.hh"
187
%include "ltlvisit/tostring.hh"
188
%include "ltlvisit/tunabbrev.hh"
189
%include "ltlvisit/apcollect.hh"
190

191
%feature("new") spot::emptiness_check::check;
192
193
%feature("new") spot::emptiness_check_instantiator::construct;
%feature("new") spot::emptiness_check_instantiator::instanciate;
194
%feature("new") spot::emptiness_check_result::accepting_run;
195
196
%feature("new") spot::explicit_magic_search;
%feature("new") spot::explicit_se05_search;
197
198
199
%feature("new") spot::ltl_to_taa;
%feature("new") spot::ltl_to_tgba_fm;
%feature("new") spot::ltl_to_tgba_lacim;
200
201
%feature("new") spot::minimize_wdba;
%feature("new") spot::minimize_monitor;
202
%feature("new") spot::scc_filter;
203
204
205
206
207
%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;
208
%feature("new") spot::simulation;
209
210
%feature("new") spot::cosimulation;
%feature("new") spot::iterated_simulations;
211
%feature("new") spot::degeneralize;
212
%feature("new") spot::tgba_parse;
213
214
%feature("new") spot::tgba_to_ta;
%feature("new") spot::tgba_to_tgta;
215
216
217
218
219
220
%feature("new") spot::postprocessor::run;

// The argument to postprocessor::run() will be deleted.
// Apparently SWIG can only disown arguments based on their
// names...
%apply SWIGTYPE *DISOWN { SWIGTYPE * input_disown };
221

222
223
224
225
226
227
228
// 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"
229
%include "tgba/sba.hh"
230
%include "tgba/statebdd.hh"
231
%include "tgba/taatgba.hh"
232
233
234
235
236
237
238
%include "tgba/tgbabddcoredata.hh"
%include "tgba/succiterconcrete.hh"
%include "tgba/tgbabddconcrete.hh"
%include "tgba/tgbaexplicit.hh"
%include "tgba/tgbaproduct.hh"
%include "tgba/tgbatba.hh"

239
240
241
242
243
244
%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>;
245
246

%template(explicit_string_tgba)
247
  spot::tgba_explicit<state_explicit_string>;
248
%template(explicit_number_tgba)
249
  spot::tgba_explicit<state_explicit_number>;
250
251
%template(explicit_formula_tgba)
  spot::tgba_explicit<state_explicit_formula>;
252
253
254
255
256
257
258
259
260
261

%template(explicit_string__tgba)
  spot::explicit_conf<tgba_explicit<state_explicit_string>,
                      state_explicit_string>;
%template(explicit_number__tgba)
  spot::explicit_conf<tgba_explicit<state_explicit_number>,
		      state_explicit_number>;
%template(explicit_formula__tgba)
  spot::explicit_conf<tgba_explicit<state_explicit_formula>,
		      state_explicit_formula>;
262

263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
%template(explicit_graph__string_sba)
  spot::explicit_graph<state_explicit_string, sba>;
%template(explicit_graph__number_sba)
  spot::explicit_graph<state_explicit_number, sba>;
%template(explicit_graph__formula_sba)
  spot::explicit_graph<state_explicit_formula, sba>;

%template(explicit_string_sba)
  spot::sba_explicit<state_explicit_string>;
%template(explicit_number_sba)
  spot::sba_explicit<state_explicit_number>;
%template(explicit_formula_sba)
  spot::sba_explicit<state_explicit_formula>;

%template(explicit_string__sba)
  spot::explicit_conf<sba_explicit<state_explicit_string>,
                      state_explicit_string>;
%template(explicit_number__sba)
  spot::explicit_conf<sba_explicit<state_explicit_number>,
		      state_explicit_number>;
%template(explicit_formula__sba)
  spot::explicit_conf<sba_explicit<state_explicit_formula>,
		      state_explicit_formula>;

287
%include "tgbaalgos/degen.hh"
288
%include "tgbaalgos/dottydec.hh"
289
%include "tgbaalgos/dotty.hh"
290
%include "tgbaalgos/dupexp.hh"
291
292
%include "tgbaalgos/emptiness.hh"
%include "tgbaalgos/gtec/gtec.hh"
293
294
295
296
%include "tgbaalgos/lbtt.hh"
%include "tgbaalgos/ltl2taa.hh"
%include "tgbaalgos/ltl2tgba_fm.hh"
%include "tgbaalgos/ltl2tgba_lacim.hh"
297
%include "tgbaalgos/magic.hh"
298
%include "tgbaalgos/minimize.hh"
299
%include "tgbaalgos/neverclaim.hh"
300
%include "tgbaalgos/rundotdec.hh"
301
%include "tgbaalgos/save.hh"
302
%include "tgbaalgos/safety.hh"
303
%include "tgbaalgos/sccfilter.hh"
304
%include "tgbaalgos/stats.hh"
305
%include "tgbaalgos/isdet.hh"
306
%include "tgbaalgos/simulation.hh"
307
%include "tgbaalgos/postproc.hh"
308
309
310

%include "tgbaparse/public.hh"

311
312
313
314
315
316
317
318
319
320
321
%include "ta/ta.hh"
%include "ta/tgta.hh"
%include "ta/taexplicit.hh"
%include "ta/tgtaexplicit.hh"
%include "taalgos/tgba2ta.hh"
%include "taalgos/dotty.hh"
%include "taalgos/stats.hh"
%include "taalgos/minimize.hh"



322
#undef ltl
323
324
325
326
327

%extend spot::ltl::formula {

  // When comparing formula, make sure Python compare our
  // pointers, not the pointers to its wrappers.
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344

  // __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(); }
345
346
347
348
349
350
351
352

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

}
353

354
%nodefaultctor std::ostream;
355
356
357
358
359
360
361
362
namespace std {
  class ostream {};
  class ofstream : public ostream
  {
  public:
     ofstream(const char *fn);
     ~ofstream();
  };
363
364
365
366
367
  class ostringstream : public ostream
  {
  public:
     ostringstream();
     std::string str() const;
368
     ~ostringstream();
369
  };
370
371
}

372
373
%feature("new") minimize_obligation_new;

374
375
%inline %{

376
377
378
379
380
381
382
383
384
385
386
387
388
// 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;
}

389
390
391
392
393
394
void
tgba_enable_utf8(spot::tgba* a)
{
  if (spot::tgba_explicit_formula* tef =
      dynamic_cast<spot::tgba_explicit_formula*>(a))
    tef->enable_utf8();
Alexandre Duret-Lutz's avatar
Alexandre Duret-Lutz committed
395
396
397
  else if (spot::sba_explicit_formula* sef =
	   dynamic_cast<spot::sba_explicit_formula*>(a))
    sef->enable_utf8();
398
399
}

400
spot::ltl::parse_error_list
401
402
403
404
405
406
empty_parse_error_list()
{
  parse_error_list l;
  return l;
}

407
408
409
410
411
412
413
spot::tgba_parse_error_list
empty_tgba_parse_error_list()
{
  tgba_parse_error_list l;
  return l;
}

414
std::ostream&
415
416
417
418
419
get_cout()
{
  return std::cout;
}

420
421
422
423
424
425
void
nl_cout()
{
  std::cout << std::endl;
}

426
std::ostream&
427
428
429
430
431
get_cerr()
{
  return std::cerr;
}

432
433
434
435
436
437
void
nl_cerr()
{
  std::cerr << std::endl;
}

438
void
439
440
441
442
print_on(std::ostream& on, const std::string& what)
{
  on << what;
}
443

444
445
446
447
448
449
450
451
452
int
unblock_signal(int signum)
{
  sigset_t set;
  sigemptyset(&set);
  sigaddset(&set, signum);
  return sigprocmask(SIG_UNBLOCK, &set, 0);
}

453
%}
454
455
456
457
458
459
460
461
462
463

%extend spot::ltl::parse_error_list {

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

}
464
465
466
467
468
469
470
471
472
473

%extend spot::tgba_parse_error_list {

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

}