spot.i 10.4 KB
Newer Older
1
// -*- coding: utf-8 -*-
2
3
// 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
#include "tgba/bdddict.hh"
#include "tgba/bddprint.hh"
#include "tgba/state.hh"
#include "tgba/succiter.hh"
#include "tgba/tgba.hh"
82
#include "tgba/sba.hh"
83
#include "tgba/statebdd.hh"
84
#include "tgba/taatgba.hh"
85
86
87
88
89
90
91
#include "tgba/tgbabddcoredata.hh"
#include "tgba/succiterconcrete.hh"
#include "tgba/tgbabddconcrete.hh"
#include "tgba/tgbaexplicit.hh"
#include "tgba/tgbaproduct.hh"
#include "tgba/tgbatba.hh"

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

112
113
#include "tgbaparse/public.hh"

114
using namespace spot::ltl;
115
using namespace spot;
116
117
%}

118
119
120
121
// 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;";
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
%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);
  }
 };
142
143
%apply char** OUTPUT { char** err };

144
145
146
147
148
// 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;

149
%include "misc/version.hh"
150
151
%include "misc/bddalloc.hh"
%include "misc/minato.hh"
152
%include "misc/optionmap.hh"
153
%include "misc/random.hh"
154

155
156
157
%feature("director") spot::loopless_modular_mixed_radix_gray_code;
%include "misc/modgray.hh"

158
%include "ltlast/formula.hh"
159
160
161
162
163
164
165
%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"
166

167
168
%include "ltlenv/environment.hh"
%include "ltlenv/defaultenv.hh"
169

170
171
172
173
174
175
%include "ltlparse/public.hh"

%include "ltlvisit/dotty.hh"
%include "ltlvisit/dump.hh"
%include "ltlvisit/lunabbrev.hh"
%include "ltlvisit/nenoform.hh"
176
%include "ltlvisit/simplify.hh"
177
%include "ltlvisit/tostring.hh"
178
179
%include "ltlvisit/tunabbrev.hh"

180
%feature("new") spot::emptiness_check::check;
181
182
%feature("new") spot::emptiness_check_instantiator::construct;
%feature("new") spot::emptiness_check_instantiator::instanciate;
183
%feature("new") spot::emptiness_check_result::accepting_run;
184
185
%feature("new") spot::explicit_magic_search;
%feature("new") spot::explicit_se05_search;
186
187
188
%feature("new") spot::ltl_to_taa;
%feature("new") spot::ltl_to_tgba_fm;
%feature("new") spot::ltl_to_tgba_lacim;
189
190
%feature("new") spot::minimize_wdba;
%feature("new") spot::minimize_monitor;
191
%feature("new") spot::scc_filter;
192
193
194
195
196
%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;
197
%feature("new") spot::simulation;
198
%feature("new") spot::degeneralize;
199
200
%feature("new") spot::tgba_parse;

201
202
203
204
205
206
207
// 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"
208
%include "tgba/sba.hh"
209
%include "tgba/statebdd.hh"
210
%include "tgba/taatgba.hh"
211
212
213
214
215
216
217
%include "tgba/tgbabddcoredata.hh"
%include "tgba/succiterconcrete.hh"
%include "tgba/tgbabddconcrete.hh"
%include "tgba/tgbaexplicit.hh"
%include "tgba/tgbaproduct.hh"
%include "tgba/tgbatba.hh"

218
219
220
221
222
223
%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>;
224
225

%template(explicit_string_tgba)
226
  spot::tgba_explicit<state_explicit_string>;
227
228
%template(explicit__number_tgba)
  spot::tgba_explicit<state_explicit_number>;
229
230
%template(explicit_formula_tgba)
  spot::tgba_explicit<state_explicit_formula>;
231
232
233
234
235
236
237
238
239
240

%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>;
241

242
%include "tgbaalgos/degen.hh"
243
%include "tgbaalgos/dottydec.hh"
244
%include "tgbaalgos/dotty.hh"
245
%include "tgbaalgos/dupexp.hh"
246
247
%include "tgbaalgos/emptiness.hh"
%include "tgbaalgos/gtec/gtec.hh"
248
249
250
251
%include "tgbaalgos/lbtt.hh"
%include "tgbaalgos/ltl2taa.hh"
%include "tgbaalgos/ltl2tgba_fm.hh"
%include "tgbaalgos/ltl2tgba_lacim.hh"
252
%include "tgbaalgos/magic.hh"
253
%include "tgbaalgos/minimize.hh"
254
%include "tgbaalgos/neverclaim.hh"
255
%include "tgbaalgos/rundotdec.hh"
256
%include "tgbaalgos/save.hh"
257
%include "tgbaalgos/safety.hh"
258
%include "tgbaalgos/sccfilter.hh"
259
%include "tgbaalgos/stats.hh"
260
%include "tgbaalgos/simulation.hh"
261
262
263

%include "tgbaparse/public.hh"

264
#undef ltl
265
266
267
268
269

%extend spot::ltl::formula {

  // When comparing formula, make sure Python compare our
  // pointers, not the pointers to its wrappers.
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286

  // __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(); }
287
288
289
290
291
292
293
294

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

}
295

296
%nodefaultctor std::ostream;
297
298
299
300
301
302
303
304
namespace std {
  class ostream {};
  class ofstream : public ostream
  {
  public:
     ofstream(const char *fn);
     ~ofstream();
  };
305
306
307
308
309
  class ostringstream : public ostream
  {
  public:
     ostringstream();
     std::string str() const;
310
     ~ostringstream();
311
  };
312
313
}

314
315
%feature("new") minimize_obligation_new;

316
317
%inline %{

318
319
320
321
322
323
324
325
326
327
328
329
330
// 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;
}

331
332
333
334
335
336
337
338
void
tgba_enable_utf8(spot::tgba* a)
{
  if (spot::tgba_explicit_formula* tef =
      dynamic_cast<spot::tgba_explicit_formula*>(a))
    tef->enable_utf8();
}

339
spot::ltl::parse_error_list
340
341
342
343
344
345
empty_parse_error_list()
{
  parse_error_list l;
  return l;
}

346
347
348
349
350
351
352
spot::tgba_parse_error_list
empty_tgba_parse_error_list()
{
  tgba_parse_error_list l;
  return l;
}

353
std::ostream&
354
355
356
357
358
get_cout()
{
  return std::cout;
}

359
360
361
362
363
364
void
nl_cout()
{
  std::cout << std::endl;
}

365
std::ostream&
366
367
368
369
370
get_cerr()
{
  return std::cerr;
}

371
372
373
374
375
376
void
nl_cerr()
{
  std::cerr << std::endl;
}

377
void
378
379
380
381
print_on(std::ostream& on, const std::string& what)
{
  on << what;
}
382

383
384
385
386
387
388
389
390
391
int
unblock_signal(int signum)
{
  sigset_t set;
  sigemptyset(&set);
  sigaddset(&set, signum);
  return sigprocmask(SIG_UNBLOCK, &set, 0);
}

392
%}
393
394
395
396
397
398
399
400
401
402

%extend spot::ltl::parse_error_list {

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

}
403
404
405
406
407
408
409
410
411
412

%extend spot::tgba_parse_error_list {

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

}