// -*- coding: utf-8 -*- // Copyright (C) 2009, 2010, 2011, 2012, 2013, 2014, 2015 Laboratoire de // Recherche et Développement de l'Epita (LRDE). // Copyright (C) 2003, 2004, 2005, 2006 Laboratoire d'Informatique // de Paris 6 (LIP6), département Systèmes Répartis Coopératifs (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 3 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 this program. If not, see . %{ // Workaround for SWIG 2.0.2 using ptrdiff_t but not including cstddef. // It matters with g++ 4.6. #include %} %module(director="1") spot_impl %include "std_shared_ptr.i" %include "std_vector.i" %include "std_string.i" %include "std_list.i" %include "std_set.i" %include "std_map.i" %include "std_pair.i" %include "stdint.i" %include "exception.i" %include "typemaps.i" // git grep 'typedef.*std::shared_ptr' | grep -v const | // sed 's/.*<\(.*\)>.*/%shared_ptr(spot::\1)/g' %shared_ptr(spot::dstar_aut) %shared_ptr(spot::parsed_aut) %shared_ptr(spot::fair_kripke) %shared_ptr(spot::kripke) %shared_ptr(spot::kripke_graph) %shared_ptr(spot::kripke) %shared_ptr(spot::ta) %shared_ptr(spot::ta_explicit) %shared_ptr(spot::ta_product) %shared_ptr(spot::tgta) %shared_ptr(spot::tgta_explicit) %shared_ptr(spot::bdd_dict) %shared_ptr(spot::twa) %shared_ptr(spot::twa_graph) %shared_ptr(spot::twa_product) %shared_ptr(spot::twa_product_init) %shared_ptr(spot::taa_tgba) %shared_ptr(spot::taa_tgba_string) %shared_ptr(spot::taa_tgba_formula) %shared_ptr(spot::twa_safra_complement) %shared_ptr(spot::twa_run) %shared_ptr(spot::emptiness_check_result) %shared_ptr(spot::emptiness_check) %shared_ptr(spot::emptiness_check_instantiator) %shared_ptr(spot::tgbasl) %import "buddy.i" %{ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace spot; %} // Swig come with iterators that implement a decrement method. // This is not supported in our "successor" iterators. %fragment("ForwardIterator_T","header",fragment="SwigPyIterator_T") { namespace swig { template::value_type, typename FromOper = from_oper > class ForwardIterator_T : public SwigPyIterator_T { public: FromOper from; typedef OutIterator out_iterator; typedef ValueType value_type; typedef SwigPyIterator_T base; typedef ForwardIterator_T self_type; ForwardIterator_T(out_iterator curr, out_iterator first, out_iterator last, PyObject *seq) : SwigPyIterator_T(curr, seq), begin(first), end(last) { } PyObject *value() const { if (base::current == end) { throw stop_iteration(); } else { return from(static_cast(*(base::current))); } } SwigPyIterator *copy() const { return new self_type(*this); } SwigPyIterator *incr(size_t n = 1) { while (n--) { if (base::current == end) { throw stop_iteration(); } else { ++base::current; } } return this; } private: out_iterator begin; out_iterator end; }; template inline SwigPyIterator* make_forward_iterator(const OutIter& current, const OutIter& begin, const OutIter& end, PyObject *seq = 0) { return new ForwardIterator_T(current, begin, end, seq); } } } %fragment("ForwardIterator_T"); // 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; } %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); } }; %apply char** OUTPUT { char** err }; // This is mainly for acc_cond::is_parity() %typemap(in, numinputs=0) bool& (bool temp) { $1 = &temp; }; %typemap(argout) bool& { PyObject *obj = SWIG_From_bool(*$1); if (!$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); } }; // Allow None to be passed for formula. Some functions like // postprocessor::run() take an optional formula that defaults to // nullptr. So it make sense to have function that take formulas that // default to None on the Python side. %typemap(in) spot::formula { void *tmp; int res = SWIG_ConvertPtr($input, &tmp, $descriptor(spot::formula*), 0); if (!SWIG_IsOK(res)) { %argument_fail(res, "spot::formula", $symname, $argnum); } if (tmp) { spot::formula* temp = reinterpret_cast< spot::formula * >(tmp); $1 = *temp; if (SWIG_IsNewObj(res)) delete temp; } // if tmp == nullptr, then the default value of $1 is fine. } %typemap(typecheck) spot::formula { $1 = SWIG_CheckState(SWIG_ConvertPtr($input, nullptr, $descriptor(spot::formula*), 0)); } %typemap(out) spot::formula { if (!$1) $result = SWIG_Py_Void(); else $result = SWIG_NewPointerObj(new spot::formula($1), $descriptor(spot::formula*), SWIG_POINTER_OWN); } %typemap(out) std::string* { if (!$1) $result = SWIG_Py_Void(); else $result = SWIG_FromCharPtr($1->c_str()); } %exception { try { $action } catch (const spot::parse_error& e) { std::string er("\n"); er += e.what(); SWIG_exception(SWIG_SyntaxError, er.c_str()); } catch (const std::invalid_argument& e) { SWIG_exception(SWIG_ValueError, e.what()); } catch (const std::runtime_error& e) { SWIG_exception(SWIG_RuntimeError, e.what()); } } %include %include %include %include %include %include %implicitconv std::vector; %include namespace std { %template(liststr) list; %template(vectorformula) vector; %template(vectorunsigned) vector; %template(atomic_prop_set) set; %template(relabeling_map) map; } %include %include %include /* these must come before apcollect.hh */ %include %include %include %implicitconv spot::acc_cond::mark_t; %feature("flatnested") spot::acc_cond::mark_t; %feature("flatnested") spot::acc_cond::acc_code; %apply bool* OUTPUT {bool& max, bool& odd}; %include %template(pair_bool_mark) std::pair; %include %include %include %include %include %include %include %include %include %include %include %include %include %include %nodefaultctor spot::digraph; %nodefaultctor spot::internal::state_out; %traits_swigtype(spot::internal::edge_storage >); %fragment(SWIG_Traits_frag(spot::internal::edge_storage >)); %typemap(out, optimal="1") spot::internal::state_out> { $result = SWIG_NewPointerObj(new $1_ltype($1), $&1_descriptor, SWIG_POINTER_OWN); } %noexception spot::twa_graph::out; %include %template(twa_graph_state_out) spot::internal::state_out>; %template(twa_graph_edge_boxed_data) spot::internal::boxed_label; %template(twa_graph_edge_storage) spot::internal::edge_storage >; // Should come after the definition of twa_graph %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include #undef ltl %exception spot::formula::__getitem__ { try { $action } catch (const std::runtime_error& e) { SWIG_exception(SWIG_IndexError, e.what()); } } %extend spot::formula { // __cmp__ is for Python 2.0 int __cmp__(spot::formula b) { return self->id() - b.id(); } size_t __hash__() { return self->id(); } unsigned __len__() { return self->size(); } formula __getitem__(unsigned pos) { return (*self)[pos]; } std::string __repr__() { return spot::str_psl(*self); } std::string _repr_latex_() { return std::string("$") + spot::str_sclatex_psl(*self) + '$'; } std::string __str__() { return spot::str_psl(*self); } } %extend spot::twa { void set_name(std::string name) { self->set_named_prop("automaton-name", new std::string(name)); } std::string* get_name() { return self->get_named_prop("automaton-name"); } } %extend spot::internal::state_out> { swig::SwigPyIterator* __iter__(PyObject **PYTHON_SELF) { return swig::make_forward_iterator(self->begin(), self->begin(), self->end(), *PYTHON_SELF); } } %extend spot::acc_cond::acc_code { std::string __repr__() { std::ostringstream os; os << *self; return os.str(); } std::string __str__() { std::ostringstream os; os << *self; return os.str(); } } %extend spot::acc_cond::mark_t { // http://comments.gmane.org/gmane.comp.programming.swig/14822 mark_t(const std::vector& f) { return new spot::acc_cond::mark_t(f.begin(), f.end()); } std::string __repr__() { std::ostringstream os; os << *self; return os.str(); } std::string __str__() { std::ostringstream os; os << *self; return os.str(); } } %extend spot::acc_cond { std::string __repr__() { std::ostringstream os; os << *self; return os.str(); } std::string __str__() { std::ostringstream os; os << *self; return os.str(); } } %extend spot::twa_run { std::string __str__() { std::ostringstream os; os << *self; return os.str(); } } %nodefaultctor std::ostream; namespace std { class ostream {}; class ofstream : public ostream { public: ofstream(const char *fn); ~ofstream(); }; class ostringstream : public ostream { public: ostringstream(); std::string str() const; ~ostringstream(); }; } %inline %{ bool fnode_instances_check() { return spot::fnode::instances_check(); } spot::parse_error_list empty_parse_error_list() { parse_error_list l; return l; } spot::parse_aut_error_list empty_parse_aut_error_list() { parse_aut_error_list l; return l; } spot::twa_graph_ptr ensure_digraph(const spot::twa_ptr& a) { auto aa = std::dynamic_pointer_cast(a); if (aa) return aa; return spot::make_twa_graph(a, spot::twa::prop_set::all()); } std::ostream& get_cout() { return std::cout; } void nl_cout() { std::cout << std::endl; } std::ostream& get_cerr() { return std::cerr; } void nl_cerr() { std::cerr << std::endl; } void print_on(std::ostream& on, const std::string& what) { on << what; } int unblock_signal(int signum) { sigset_t set; sigemptyset(&set); sigaddset(&set, signum); return sigprocmask(SIG_UNBLOCK, &set, 0); } %} %extend spot::parse_error_list { bool __nonzero__() { return !self->empty(); } bool __bool__() { return !self->empty(); } } %extend spot::parse_aut_error_list { bool __nonzero__() { return !self->empty(); } bool __bool__() { return !self->empty(); } }