// -*- 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 "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; %} // 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 }; // 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(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()); } } // 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; %include %include %include %include %include %include %implicitconv std::vector; %include namespace std { %template(liststr) list; %template(vectorformula) vector; %template(atomic_prop_set) set; %template(relabeling_map) map; } %include %include %include /* these must come before apcollect.hh */ %include %include %include %feature("flatnested") spot::acc_cond::mark_t; %feature("flatnested") spot::acc_cond::acc_code; %apply bool* OUTPUT {bool& max, bool& odd}; %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include // 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::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::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(); } }