Merge branch 'master' of github.com:mapnik/mapnik
This commit is contained in:
commit
d0e375b25c
3 changed files with 129 additions and 9 deletions
|
@ -175,11 +175,23 @@ mapnik::value_holder get_param(mapnik::parameter const& p, int index)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
boost::shared_ptr<mapnik::parameter> create_parameter(std::string const& key, mapnik::value_holder const& value)
|
boost::shared_ptr<mapnik::parameter> create_parameter(UnicodeString const& key, mapnik::value_holder const& value)
|
||||||
{
|
{
|
||||||
return boost::make_shared<mapnik::parameter>(key,mapnik::value_holder(value));
|
std::string key_utf8;
|
||||||
|
mapnik::to_utf8(key, key_utf8);
|
||||||
|
return boost::make_shared<mapnik::parameter>(key_utf8,value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// needed for Python_Unicode to std::string (utf8) conversion
|
||||||
|
|
||||||
|
boost::shared_ptr<mapnik::parameter> create_parameter_from_string(UnicodeString const& key, UnicodeString const& ustr)
|
||||||
|
{
|
||||||
|
std::string key_utf8;
|
||||||
|
std::string ustr_utf8;
|
||||||
|
mapnik::to_utf8(key, key_utf8);
|
||||||
|
mapnik::to_utf8(ustr,ustr_utf8);
|
||||||
|
return boost::make_shared<mapnik::parameter>(key_utf8, ustr_utf8);
|
||||||
|
}
|
||||||
|
|
||||||
void export_parameters()
|
void export_parameters()
|
||||||
{
|
{
|
||||||
|
@ -193,6 +205,10 @@ void export_parameters()
|
||||||
.def("__init__", make_constructor(create_parameter),
|
.def("__init__", make_constructor(create_parameter),
|
||||||
"Create a mapnik.Parameter from a pair of values, the first being a string\n"
|
"Create a mapnik.Parameter from a pair of values, the first being a string\n"
|
||||||
"and the second being either a string, and integer, or a float")
|
"and the second being either a string, and integer, or a float")
|
||||||
|
.def("__init__", make_constructor(create_parameter_from_string),
|
||||||
|
"Create a mapnik.Parameter from a pair of values, the first being a string\n"
|
||||||
|
"and the second being either a string, and integer, or a float")
|
||||||
|
|
||||||
.def_pickle(parameter_pickle_suite())
|
.def_pickle(parameter_pickle_suite())
|
||||||
.def("__getitem__",get_param)
|
.def("__getitem__",get_param)
|
||||||
;
|
;
|
||||||
|
|
|
@ -26,41 +26,140 @@
|
||||||
// mapnik
|
// mapnik
|
||||||
#include <mapnik/params.hpp>
|
#include <mapnik/params.hpp>
|
||||||
#include <mapnik/value_types.hpp>
|
#include <mapnik/value_types.hpp>
|
||||||
|
#include <mapnik/util/conversions.hpp>
|
||||||
// boost
|
// boost
|
||||||
#include <boost/variant/static_visitor.hpp>
|
#include <boost/variant/static_visitor.hpp>
|
||||||
#include <boost/variant/apply_visitor.hpp> // keep gcc happy
|
#include <boost/variant/apply_visitor.hpp> // keep gcc happy
|
||||||
#include <boost/variant/variant.hpp>
|
#include <boost/variant/variant.hpp>
|
||||||
#include <boost/optional.hpp>
|
#include <boost/optional.hpp>
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
|
#include <boost/format.hpp>
|
||||||
// stl
|
// stl
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace mapnik
|
namespace mapnik { namespace detail {
|
||||||
|
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct extract_value
|
||||||
{
|
{
|
||||||
|
static inline boost::optional<T> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
std::string err_msg = (boost::format("No conversion from std::string to %s") % typeid(T).name()).str();
|
||||||
|
throw std::runtime_error(err_msg);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct extract_value<mapnik::boolean>
|
||||||
|
{
|
||||||
|
static inline boost::optional<mapnik::boolean> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
bool result;
|
||||||
|
if (mapnik::util::string2bool(source, result))
|
||||||
|
return boost::optional<mapnik::boolean>(result);
|
||||||
|
return boost::optional<mapnik::boolean>();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct extract_value<int>
|
||||||
|
{
|
||||||
|
static inline boost::optional<int> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
mapnik::value_integer result;
|
||||||
|
if (mapnik::util::string2int(source, result))
|
||||||
|
return boost::optional<int>(result);
|
||||||
|
return boost::optional<int>();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef BIGINT
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct extract_value<mapnik::value_integer>
|
||||||
|
{
|
||||||
|
static inline boost::optional<mapnik::value_integer> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
mapnik::value_integer result;
|
||||||
|
if (mapnik::util::string2int(source, result))
|
||||||
|
return boost::optional<mapnik::value_integer>(result);
|
||||||
|
return boost::optional<mapnik::value_integer>();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct extract_value<mapnik::value_double>
|
||||||
|
{
|
||||||
|
static inline boost::optional<mapnik::value_double> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
mapnik::value_double result;
|
||||||
|
if (mapnik::util::string2double(source, result))
|
||||||
|
return boost::optional<double>(result);
|
||||||
|
return boost::optional<double>();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct extract_value<mapnik::value_null>
|
||||||
|
{
|
||||||
|
static inline boost::optional<mapnik::value_null> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
return boost::optional<mapnik::value_null>(); // FIXME
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct extract_value<std::string>
|
||||||
|
{
|
||||||
|
static inline boost::optional<std::string> do_extract_from_string(std::string const& source)
|
||||||
|
{
|
||||||
|
return boost::optional<std::string>(source);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
boost::optional<T> param_cast(std::string const& source)
|
||||||
|
{
|
||||||
|
return extract_value<T>::do_extract_from_string(source);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // end namespace detail
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct value_extractor_visitor : public boost::static_visitor<>
|
struct value_extractor_visitor : public boost::static_visitor<>
|
||||||
{
|
{
|
||||||
|
|
||||||
value_extractor_visitor(boost::optional<T> & var)
|
value_extractor_visitor(boost::optional<T> & var)
|
||||||
:var_(var) {}
|
:var_(var) {}
|
||||||
|
|
||||||
void operator () (T val) const
|
void operator() (std::string const& val) const
|
||||||
{
|
{
|
||||||
var_ = val;
|
var_ = detail::param_cast<T>(val);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T1>
|
template <typename T1>
|
||||||
void operator () (T1 val) const
|
void operator () (T1 val) const
|
||||||
{
|
{
|
||||||
|
// TODO
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var_ = boost::lexical_cast<T>(val);
|
var_ = boost::lexical_cast<T>(val);
|
||||||
}
|
}
|
||||||
catch (boost::bad_lexical_cast & ) {}
|
catch (boost::bad_lexical_cast & ) {}
|
||||||
|
//std::string err_msg = (boost::format("No conversion from %s to %s")
|
||||||
|
// % typeid(T1).name()
|
||||||
|
// % typeid(T).name()).str();
|
||||||
|
//throw std::runtime_error(err_msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
boost::optional<T> & var_;
|
boost::optional<T> & var_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -69,7 +168,8 @@ namespace params_detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct converter
|
struct converter
|
||||||
{
|
{
|
||||||
typedef boost::optional<T> return_type;
|
typedef T value_type;
|
||||||
|
typedef boost::optional<value_type> return_type;
|
||||||
static return_type extract(parameters const& params,
|
static return_type extract(parameters const& params,
|
||||||
std::string const& name,
|
std::string const& name,
|
||||||
boost::optional<T> const& default_opt_value)
|
boost::optional<T> const& default_opt_value)
|
||||||
|
@ -101,4 +201,3 @@ boost::optional<T> parameters::get(std::string const& key, T const& default_opt_
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,11 @@ def test_parameter_string():
|
||||||
eq_(p[0],'key')
|
eq_(p[0],'key')
|
||||||
eq_(p[1],'value')
|
eq_(p[1],'value')
|
||||||
|
|
||||||
|
def test_parameter_unicode():
|
||||||
|
p = mapnik.Parameter('key',u'value')
|
||||||
|
eq_(p[0],'key')
|
||||||
|
eq_(p[1],u'value')
|
||||||
|
|
||||||
def test_parameter_integer():
|
def test_parameter_integer():
|
||||||
p = mapnik.Parameter('int',sys.maxint)
|
p = mapnik.Parameter('int',sys.maxint)
|
||||||
eq_(p[0],'int')
|
eq_(p[0],'int')
|
||||||
|
|
Loading…
Reference in a new issue