/***************************************************************************** * * 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 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 from_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 from_wkb_impl(path_type& p, std::string const& wkb) { mapnik::geometry_utils::from_wkb(p, wkb.c_str(), wkb.size(), true); } } 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("area",&geometry_type::area) // TODO add other geometry_type methods ; class_("Path") .def("__getitem__", getitem_impl,return_value_policy()) .def("__len__", &path_type::size) .def("from_wkt",from_wkt_impl) .def("from_wkb",from_wkb_impl) ; }