/***************************************************************************** * * This file is part of Mapnik (c++ mapping toolkit) * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * *****************************************************************************/ //$Id$ // boost #include #include #include #include #include #include // mapnik #include #include #include #include #include namespace { using mapnik::from_wkt; using mapnik::geometry_type; typedef boost::ptr_vector path_type; geometry_type const& getitem_impl(path_type & p, int key) { if (key >=0 && key < p.size()) return p[key]; PyErr_SetString(PyExc_IndexError, "Index is out of range"); throw boost::python::error_already_set(); } void add_wkt_impl(path_type& p, std::string const& wkt) { bool result = mapnik::from_wkt(wkt , p); if (!result) throw std::runtime_error("Failed to parse WKT"); } void add_wkb_impl(path_type& p, std::string const& wkb) { mapnik::geometry_utils::from_wkb(p, wkb.c_str(), wkb.size(), true); } boost::shared_ptr from_wkt_impl(std::string const& wkt) { boost::shared_ptr paths = boost::make_shared(); bool result = mapnik::from_wkt(wkt, *paths); if (!result) throw std::runtime_error("Failed to parse WKT"); return paths; } boost::shared_ptr from_wkb_impl(std::string const& wkb) { boost::shared_ptr paths = boost::make_shared(); mapnik::geometry_utils::from_wkb(*paths, wkb.c_str(), wkb.size(), true); return paths; } } PyObject* to_wkb( geometry_type const& geom) { mapnik::util::wkb_buffer_ptr wkb = mapnik::util::to_wkb(geom,mapnik::util::wkbXDR); return #if PY_VERSION_HEX >= 0x03000000 ::PyBytes_FromStringAndSize #else ::PyString_FromStringAndSize #endif ((const char*)wkb->buffer(),wkb->size()); } std::string to_wkt( geometry_type const& geom) { std::string wkt; // Use Python String directly ? bool result = mapnik::util::to_wkt(wkt,geom); if (!result) { throw std::runtime_error("Generate WKT failed"); } return wkt; } void export_geometry() { using namespace boost::python; enum_("GeometryType") .value("Point",mapnik::Point) .value("LineString",mapnik::LineString) .value("Polygon",mapnik::Polygon) .value("MultiPoint",mapnik::MultiPoint) .value("MultiLineString",mapnik::MultiLineString) .value("MultiPolygon",mapnik::MultiPolygon) ; using mapnik::geometry_type; class_, boost::noncopyable>("Geometry2d",no_init) .def("envelope",&geometry_type::envelope) // .def("__str__",&geometry_type::to_string) .def("type",&geometry_type::type) .def("to_wkb",&to_wkb) .def("to_wkt",&to_wkt) // TODO add other geometry_type methods ; class_, boost::noncopyable>("Path") .def("__getitem__", getitem_impl,return_value_policy()) .def("__len__", &path_type::size) .def("add_wkt",add_wkt_impl) .def("add_wkb",add_wkb_impl) .def("from_wkt",from_wkt_impl) .def("from_wkb",from_wkb_impl) .staticmethod("from_wkt") .staticmethod("from_wkb") ; }