2006-03-31 12:32:02 +02:00
|
|
|
/*****************************************************************************
|
2011-11-14 04:54:32 +01:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* This file is part of Mapnik (c++ mapping toolkit)
|
2006-02-01 00:09:52 +01:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* Copyright (C) 2006 Artem Pavlenko, Jean-Francois Doyon
|
2006-02-01 00:09:52 +01:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* 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,
|
2006-02-01 00:09:52 +01:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2006-03-31 12:32:02 +02:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
2006-02-01 00:09:52 +01:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* 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
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
2006-02-01 00:09:52 +01:00
|
|
|
//$Id$
|
|
|
|
|
|
|
|
#include <boost/python.hpp>
|
2006-02-25 12:03:30 +01:00
|
|
|
#include <boost/python/implicit.hpp>
|
2009-03-05 05:44:34 +01:00
|
|
|
#include <boost/python/detail/api_placeholder.hpp>
|
2006-02-01 00:09:52 +01:00
|
|
|
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
|
|
|
|
2006-10-04 13:22:18 +02:00
|
|
|
#include <mapnik/rule.hpp>
|
2009-02-17 06:23:10 +01:00
|
|
|
#include <mapnik/filter_factory.hpp>
|
2009-12-16 21:02:06 +01:00
|
|
|
#include <mapnik/expression_string.hpp>
|
2006-02-01 00:09:52 +01:00
|
|
|
|
2011-01-13 22:35:01 +01:00
|
|
|
using mapnik::rule;
|
2009-12-16 21:02:06 +01:00
|
|
|
using mapnik::expr_node;
|
|
|
|
using mapnik::expression_ptr;
|
2009-02-17 06:23:10 +01:00
|
|
|
using mapnik::Feature;
|
|
|
|
using mapnik::point_symbolizer;
|
|
|
|
using mapnik::line_symbolizer;
|
|
|
|
using mapnik::line_pattern_symbolizer;
|
|
|
|
using mapnik::polygon_symbolizer;
|
|
|
|
using mapnik::polygon_pattern_symbolizer;
|
|
|
|
using mapnik::raster_symbolizer;
|
|
|
|
using mapnik::shield_symbolizer;
|
|
|
|
using mapnik::text_symbolizer;
|
|
|
|
using mapnik::building_symbolizer;
|
2009-10-19 16:22:11 +02:00
|
|
|
using mapnik::markers_symbolizer;
|
2009-02-17 06:23:10 +01:00
|
|
|
using mapnik::symbolizer;
|
2009-12-16 21:02:06 +01:00
|
|
|
using mapnik::to_expression_string;
|
2009-02-17 06:23:10 +01:00
|
|
|
|
2009-10-19 16:22:11 +02:00
|
|
|
struct pickle_symbolizer : public boost::static_visitor<>
|
|
|
|
{
|
2009-10-19 17:16:16 +02:00
|
|
|
public:
|
2011-11-14 04:54:32 +01:00
|
|
|
pickle_symbolizer( boost::python::list syms):
|
2009-10-19 16:22:11 +02:00
|
|
|
syms_(syms) {}
|
|
|
|
|
2009-10-19 17:16:16 +02:00
|
|
|
template <typename T>
|
|
|
|
void operator () ( T const& sym )
|
|
|
|
{
|
2010-06-02 13:03:30 +02:00
|
|
|
syms_.append(sym);
|
2009-10-19 17:16:16 +02:00
|
|
|
}
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2009-10-19 17:16:16 +02:00
|
|
|
private:
|
|
|
|
boost::python::list syms_;
|
2009-10-19 16:22:11 +02:00
|
|
|
};
|
|
|
|
|
2009-10-19 17:16:16 +02:00
|
|
|
|
2009-10-19 16:22:11 +02:00
|
|
|
struct extract_symbolizer : public boost::static_visitor<>
|
|
|
|
{
|
2009-10-19 17:16:16 +02:00
|
|
|
public:
|
2011-11-14 04:54:32 +01:00
|
|
|
extract_symbolizer( rule& r):
|
2009-10-19 16:22:11 +02:00
|
|
|
r_(r) {}
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2009-10-19 17:16:16 +02:00
|
|
|
template <typename T>
|
|
|
|
void operator () ( T const& sym )
|
|
|
|
{
|
2010-06-02 13:03:30 +02:00
|
|
|
r_.append(sym);
|
2009-10-19 17:16:16 +02:00
|
|
|
}
|
|
|
|
private:
|
2011-01-13 22:35:01 +01:00
|
|
|
rule& r_;
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2009-10-19 16:22:11 +02:00
|
|
|
};
|
|
|
|
|
2009-02-17 06:23:10 +01:00
|
|
|
struct rule_pickle_suite : boost::python::pickle_suite
|
2006-02-01 00:09:52 +01:00
|
|
|
{
|
2009-10-19 17:16:16 +02:00
|
|
|
static boost::python::tuple
|
2011-01-13 22:35:01 +01:00
|
|
|
getinitargs(const rule& r)
|
2009-10-19 17:16:16 +02:00
|
|
|
{
|
2011-12-13 17:47:45 +01:00
|
|
|
return boost::python::make_tuple(r.get_name(),r.get_min_scale(),r.get_max_scale());
|
2009-10-19 17:16:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static boost::python::tuple
|
2011-01-13 22:35:01 +01:00
|
|
|
getstate(const rule& r)
|
2009-10-19 17:16:16 +02:00
|
|
|
{
|
2009-02-17 06:23:10 +01:00
|
|
|
boost::python::list syms;
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2011-01-13 22:35:01 +01:00
|
|
|
rule::symbolizers::const_iterator begin = r.get_symbolizers().begin();
|
2011-11-14 04:54:32 +01:00
|
|
|
rule::symbolizers::const_iterator end = r.get_symbolizers().end();
|
2009-10-19 16:22:11 +02:00
|
|
|
pickle_symbolizer serializer( syms );
|
|
|
|
std::for_each( begin, end , boost::apply_visitor( serializer ));
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2010-06-02 13:03:30 +02:00
|
|
|
// We serialize filter expressions AST as strings
|
2009-12-16 21:02:06 +01:00
|
|
|
std::string filter_expr = to_expression_string(*r.get_filter());
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2011-12-13 17:47:45 +01:00
|
|
|
return boost::python::make_tuple(filter_expr,r.has_else_filter(),r.has_also_filter(),syms);
|
2009-10-19 17:16:16 +02:00
|
|
|
}
|
2009-02-17 06:23:10 +01:00
|
|
|
|
2009-10-19 17:16:16 +02:00
|
|
|
static void
|
2011-01-13 22:35:01 +01:00
|
|
|
setstate (rule& r, boost::python::tuple state)
|
2009-10-19 17:16:16 +02:00
|
|
|
{
|
2009-02-17 06:23:10 +01:00
|
|
|
using namespace boost::python;
|
|
|
|
if (len(state) != 4)
|
|
|
|
{
|
|
|
|
PyErr_SetObject(PyExc_ValueError,
|
2010-06-02 13:03:30 +02:00
|
|
|
("expected 4-item tuple in call to __setstate__; got %s"
|
|
|
|
% state).ptr()
|
|
|
|
);
|
2009-02-17 06:23:10 +01:00
|
|
|
throw_error_already_set();
|
|
|
|
}
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2009-02-17 06:23:10 +01:00
|
|
|
if (state[0])
|
|
|
|
{
|
2011-01-13 22:35:01 +01:00
|
|
|
rule dfl;
|
2009-10-19 16:22:11 +02:00
|
|
|
std::string filter = extract<std::string>(state[1]);
|
2009-12-16 21:02:06 +01:00
|
|
|
std::string default_filter = "<TODO>";//dfl.get_filter()->to_string();
|
2009-10-19 16:22:11 +02:00
|
|
|
if ( filter != default_filter)
|
|
|
|
{
|
2009-12-16 21:02:06 +01:00
|
|
|
r.set_filter(mapnik::parse_expression(filter,"utf8"));
|
2009-10-19 16:22:11 +02:00
|
|
|
}
|
2011-11-14 04:54:32 +01:00
|
|
|
}
|
2009-02-17 06:23:10 +01:00
|
|
|
|
2011-12-13 17:47:45 +01:00
|
|
|
if (state[1])
|
2009-02-17 06:23:10 +01:00
|
|
|
{
|
|
|
|
r.set_else(true);
|
2011-11-14 04:54:32 +01:00
|
|
|
}
|
2011-08-30 19:38:27 +02:00
|
|
|
|
2011-12-13 17:47:45 +01:00
|
|
|
if (state[2])
|
2011-08-30 19:38:27 +02:00
|
|
|
{
|
|
|
|
r.set_also(true);
|
|
|
|
}
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2011-08-30 19:38:27 +02:00
|
|
|
boost::python::list syms=extract<boost::python::list>(state[4]);
|
2009-10-19 16:22:11 +02:00
|
|
|
extract_symbolizer serializer( r );
|
2009-02-17 06:23:10 +01:00
|
|
|
for (int i=0;i<len(syms);++i)
|
|
|
|
{
|
2011-10-19 16:29:24 +02:00
|
|
|
//symbolizer symbol = extract<symbolizer>(syms[i]);
|
|
|
|
//boost::apply_visitor( serializer, symbol );
|
2011-11-14 04:54:32 +01:00
|
|
|
}
|
2009-10-19 17:16:16 +02:00
|
|
|
}
|
2009-02-17 06:23:10 +01:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
void export_rule()
|
|
|
|
{
|
2009-03-05 04:47:15 +01:00
|
|
|
using namespace boost::python;
|
2006-02-25 12:03:30 +01:00
|
|
|
implicitly_convertible<point_symbolizer,symbolizer>();
|
|
|
|
implicitly_convertible<line_symbolizer,symbolizer>();
|
|
|
|
implicitly_convertible<line_pattern_symbolizer,symbolizer>();
|
|
|
|
implicitly_convertible<polygon_symbolizer,symbolizer>();
|
2007-11-02 13:50:15 +01:00
|
|
|
implicitly_convertible<building_symbolizer,symbolizer>();
|
2006-02-25 12:03:30 +01:00
|
|
|
implicitly_convertible<polygon_pattern_symbolizer,symbolizer>();
|
|
|
|
implicitly_convertible<raster_symbolizer,symbolizer>();
|
2006-10-17 16:12:53 +02:00
|
|
|
implicitly_convertible<shield_symbolizer,symbolizer>();
|
2006-02-25 12:03:30 +01:00
|
|
|
implicitly_convertible<text_symbolizer,symbolizer>();
|
2011-04-29 19:39:11 +02:00
|
|
|
implicitly_convertible<markers_symbolizer,symbolizer>();
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2011-01-13 22:35:01 +01:00
|
|
|
class_<rule::symbolizers>("Symbolizers",init<>("TODO"))
|
|
|
|
.def(vector_indexing_suite<rule::symbolizers>())
|
2010-06-02 13:03:30 +02:00
|
|
|
;
|
2011-11-14 04:54:32 +01:00
|
|
|
|
2011-01-13 22:35:01 +01:00
|
|
|
class_<rule>("Rule",init<>("default constructor"))
|
2006-05-31 23:25:21 +02:00
|
|
|
.def(init<std::string const&,
|
2011-12-13 17:47:45 +01:00
|
|
|
boost::python::optional<double,double> >())
|
2009-10-19 16:22:11 +02:00
|
|
|
.def_pickle(rule_pickle_suite())
|
2006-05-31 23:25:21 +02:00
|
|
|
.add_property("name",make_function
|
2011-01-13 22:35:01 +01:00
|
|
|
(&rule::get_name,
|
2006-05-31 23:25:21 +02:00
|
|
|
return_value_policy<copy_const_reference>()),
|
2011-01-13 22:35:01 +01:00
|
|
|
&rule::set_name)
|
2006-05-31 23:25:21 +02:00
|
|
|
.add_property("filter",make_function
|
2011-01-13 22:35:01 +01:00
|
|
|
(&rule::get_filter,return_value_policy<copy_const_reference>()),
|
|
|
|
&rule::set_filter)
|
|
|
|
.add_property("min_scale",&rule::get_min_scale,&rule::set_min_scale)
|
|
|
|
.add_property("max_scale",&rule::get_max_scale,&rule::set_max_scale)
|
|
|
|
.def("set_else",&rule::set_else)
|
|
|
|
.def("has_else",&rule::has_else_filter)
|
2011-08-30 19:38:27 +02:00
|
|
|
.def("set_also",&rule::set_also)
|
|
|
|
.def("has_also",&rule::has_also_filter)
|
2011-01-13 22:35:01 +01:00
|
|
|
.def("active",&rule::active)
|
2006-05-31 23:25:21 +02:00
|
|
|
.add_property("symbols",make_function
|
2011-01-13 22:35:01 +01:00
|
|
|
(&rule::get_symbolizers,return_value_policy<reference_existing_object>()))
|
2006-05-31 23:25:21 +02:00
|
|
|
;
|
2006-02-01 00:09:52 +01:00
|
|
|
}
|
|
|
|
|