mirror of
https://github.com/mapnik/mapnik.git
synced 2025-12-08 20:13:09 +00:00
optimized WKTReader for parsing WKT into geometry paths
This commit is contained in:
parent
3c69c42a3b
commit
6bfbb53eac
@ -75,6 +75,7 @@ void export_view_transform();
|
|||||||
void export_raster_colorizer();
|
void export_raster_colorizer();
|
||||||
void export_label_collision_detector();
|
void export_label_collision_detector();
|
||||||
void export_logger();
|
void export_logger();
|
||||||
|
void export_wkt_reader();
|
||||||
|
|
||||||
#include <mapnik/version.hpp>
|
#include <mapnik/version.hpp>
|
||||||
#include <mapnik/value_error.hpp>
|
#include <mapnik/value_error.hpp>
|
||||||
@ -535,6 +536,7 @@ BOOST_PYTHON_MODULE(_mapnik)
|
|||||||
export_raster_colorizer();
|
export_raster_colorizer();
|
||||||
export_label_collision_detector();
|
export_label_collision_detector();
|
||||||
export_logger();
|
export_logger();
|
||||||
|
export_wkt_reader();
|
||||||
|
|
||||||
def("clear_cache", &clear_cache,
|
def("clear_cache", &clear_cache,
|
||||||
"\n"
|
"\n"
|
||||||
|
|||||||
55
bindings/python/mapnik_wkt_reader.cpp
Normal file
55
bindings/python/mapnik_wkt_reader.cpp
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
*
|
||||||
|
* This file is part of Mapnik (c++ mapping toolkit)
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Artem Pavlenko, Jean-Francois Doyon
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
// boost
|
||||||
|
#include <boost/python.hpp>
|
||||||
|
#include <boost/noncopyable.hpp>
|
||||||
|
#include <boost/shared_ptr.hpp>
|
||||||
|
#include <boost/ptr_container/ptr_vector.hpp>
|
||||||
|
#include <boost/make_shared.hpp>
|
||||||
|
// mapnik
|
||||||
|
#include <mapnik/geometry.hpp>
|
||||||
|
#include <mapnik/wkt/wkt_factory.hpp>
|
||||||
|
|
||||||
|
namespace impl {
|
||||||
|
|
||||||
|
typedef boost::ptr_vector<mapnik::geometry_type> path_type;
|
||||||
|
|
||||||
|
boost::shared_ptr<path_type> from_wkt(mapnik::wkt_parser & p, std::string const& wkt)
|
||||||
|
{
|
||||||
|
boost::shared_ptr<path_type> paths = boost::make_shared<path_type>();
|
||||||
|
if (!p.parse(wkt, *paths))
|
||||||
|
throw std::runtime_error("Failed to parse WKT");
|
||||||
|
return paths;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void export_wkt_reader()
|
||||||
|
{
|
||||||
|
using mapnik::wkt_parser;
|
||||||
|
using namespace boost::python;
|
||||||
|
|
||||||
|
class_<wkt_parser, boost::noncopyable>("WKTReader",init<>())
|
||||||
|
.def("read",&impl::from_wkt)
|
||||||
|
;
|
||||||
|
}
|
||||||
@ -102,10 +102,15 @@ def test_geojson_parsing():
|
|||||||
pass
|
pass
|
||||||
eq_(count,len(path))
|
eq_(count,len(path))
|
||||||
|
|
||||||
|
reader = mapnik.WKTReader()
|
||||||
|
|
||||||
def compare_wkb_from_wkt(wkt,num=None):
|
def compare_wkb_from_wkt(wkt,num=None):
|
||||||
|
|
||||||
# create a Path from geometry(s)
|
# create a Path from geometry(s)
|
||||||
paths = mapnik.Path.from_wkt(wkt)
|
# easy api, but slower
|
||||||
|
#paths = mapnik.Path.from_wkt(wkt)
|
||||||
|
# fast api
|
||||||
|
paths = reader.read(wkt);
|
||||||
|
|
||||||
# add geometry(s) to feature from wkt
|
# add geometry(s) to feature from wkt
|
||||||
f = mapnik.Feature(mapnik.Context(),1)
|
f = mapnik.Feature(mapnik.Context(),1)
|
||||||
@ -136,7 +141,10 @@ def compare_wkb_from_wkt(wkt,num=None):
|
|||||||
|
|
||||||
def compare_wkt_from_wkt(wkt,num=None):
|
def compare_wkt_from_wkt(wkt,num=None):
|
||||||
# create a Path from geometry(s)
|
# create a Path from geometry(s)
|
||||||
paths = mapnik.Path.from_wkt(wkt)
|
# easy api, but slower
|
||||||
|
#paths = mapnik.Path.from_wkt(wkt)
|
||||||
|
# fast api
|
||||||
|
paths = reader.read(wkt);
|
||||||
|
|
||||||
# add geometry(s) to feature from wkt
|
# add geometry(s) to feature from wkt
|
||||||
f = mapnik.Feature(mapnik.Context(),1)
|
f = mapnik.Feature(mapnik.Context(),1)
|
||||||
@ -185,7 +193,10 @@ def test_wkb_simple():
|
|||||||
@raises(IndexError)
|
@raises(IndexError)
|
||||||
def test_geometry_index_error():
|
def test_geometry_index_error():
|
||||||
wkt = 'Point (0 0)'
|
wkt = 'Point (0 0)'
|
||||||
paths = mapnik.Path.from_wkt(wkt)
|
# easy api, but slower
|
||||||
|
#paths = mapnik.Path.from_wkt(wkt)
|
||||||
|
# fast api
|
||||||
|
paths = reader.read(wkt);
|
||||||
paths[3]
|
paths[3]
|
||||||
f = mapnik.Feature(mapnik.Context(),1)
|
f = mapnik.Feature(mapnik.Context(),1)
|
||||||
f.add_geometries_from_wkt(wkt)
|
f.add_geometries_from_wkt(wkt)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user