fix Python bindings for relabeling_map, and document them

This fixes #61, and addresses one item of #14.

* src/ltlvisit/relabel.hh: Use a map rather than a unordered_map,
because the Swig binding for unordered_map do not seem functional.
* wrap/python/spot_impl.i: Adjust.
* wrap/python/tests/relabel.py: New file.
* wrap/python/tests/Makefile.am: Add it.
* doc/org/tut02.org: New file.
* doc/Makefile.am: Add it.
This commit is contained in:
Alexandre Duret-Lutz 2015-06-07 14:18:42 +02:00
parent a8f5e7fd8b
commit 6c2985e753
6 changed files with 225 additions and 22 deletions

View file

@ -32,6 +32,7 @@
%include "std_string.i"
%include "std_list.i"
%include "std_set.i"
%include "std_map.i"
%include "exception.i"
%include "typemaps.i"
@ -223,6 +224,28 @@ using namespace spot;
%include "ltlast/unop.hh"
%include "ltlast/visitor.hh"
namespace std {
%template(atomic_prop_set) set<const spot::ltl::atomic_prop*,
spot::ltl::formula_ptr_less_than>;
%template(mapff) map<const spot::ltl::formula*, const spot::ltl::formula*,
spot::ltl::formula_ptr_less_than>;
}
%{
namespace swig {
template <> struct traits<atomic_prop> {
typedef pointer_category category;
static const char* type_name() { return "spot::ltl::atomic_prop"; }
};
template <> struct traits<formula> {
typedef pointer_category category;
static const char* type_name() { return "spot::ltl::formula"; }
};
}
%}
%include "ltlenv/environment.hh"
%include "ltlenv/defaultenv.hh"
@ -299,21 +322,6 @@ using namespace spot;
#undef ltl
namespace std {
%template(atomic_prop_set) set<const spot::ltl::atomic_prop*,
spot::ltl::formula_ptr_less_than>;
}
%{
namespace swig {
template <> struct traits<atomic_prop> {
typedef pointer_category category;
static const char* type_name() { return"atomic_prop const *"; }
};
}
%}
%extend spot::ltl::formula {
// When comparing formula, make sure Python compare our