libcarla/include/system/boost/geometry/srs/projections/impl/base_static.hpp
2024-10-18 13:19:59 +08:00

172 lines
4.6 KiB
C++

// Boost.Geometry (aka GGL, Generic Geometry Library)
// Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands.
// This file was modified by Oracle on 2017-2020.
// Modifications copyright (c) 2017-2020, Oracle and/or its affiliates.
// Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle
// Use, modification and distribution is subject to the Boost Software License,
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
#ifndef BOOST_GEOMETRY_PROJECTIONS_IMPL_BASE_STATIC_HPP
#define BOOST_GEOMETRY_PROJECTIONS_IMPL_BASE_STATIC_HPP
#if defined(_MSC_VER)
// For CRTP, *this is acceptable in constructor -> turn warning off
#pragma warning( disable : 4355 )
#endif // defined(_MSC_VER)
#include <string>
#include <boost/geometry/core/assert.hpp>
#include <boost/geometry/core/static_assert.hpp>
#include <boost/geometry/core/tags.hpp>
#include <boost/geometry/srs/projections/impl/pj_fwd.hpp>
#include <boost/geometry/srs/projections/impl/pj_inv.hpp>
namespace boost { namespace geometry { namespace projections
{
#ifndef DOXYGEN_NO_DETAIL
namespace detail
{
template <typename Prj, typename CSTag, typename SP, typename CT, typename P>
struct static_projection_type
{
BOOST_GEOMETRY_STATIC_ASSERT_FALSE(
"Not implemented for this projection or coordinate system.",
Prj, CSTag, SP, CT, P);
};
#define BOOST_GEOMETRY_PROJECTIONS_DETAIL_STATIC_PROJECTION_F(PROJ, P_SPHXXX) \
template <typename SP, typename CT, typename P> \
struct static_projection_type<PROJ, srs_sphere_tag, SP, CT, P> \
{ \
typedef projections::detail::static_wrapper_f<P_SPHXXX<CT, P>, P> type; \
}; \
template <typename SP, typename CT, typename P> \
struct static_projection_type<PROJ, srs_spheroid_tag, SP, CT, P> \
{ \
typedef projections::detail::static_wrapper_f<P_SPHXXX<CT, P>, P> type; \
}; \
#define BOOST_GEOMETRY_PROJECTIONS_DETAIL_STATIC_PROJECTION_FI(PROJ, P_SPHXXX) \
template <typename SP, typename CT, typename P> \
struct static_projection_type<PROJ, srs_sphere_tag, SP, CT, P> \
{ \
typedef projections::detail::static_wrapper_fi<P_SPHXXX<CT, P>, P> type; \
}; \
template <typename SP, typename CT, typename P> \
struct static_projection_type<PROJ, srs_spheroid_tag, SP, CT, P> \
{ \
typedef projections::detail::static_wrapper_fi<P_SPHXXX<CT, P>, P> type; \
}; \
#define BOOST_GEOMETRY_PROJECTIONS_DETAIL_STATIC_PROJECTION_FI2(PROJ, P_SPHERE, P_SPHEROID) \
template <typename SP, typename CT, typename P> \
struct static_projection_type<PROJ, srs_sphere_tag, SP, CT, P> \
{ \
typedef projections::detail::static_wrapper_fi<P_SPHERE<CT, P>, P> type; \
}; \
template <typename SP, typename CT, typename P> \
struct static_projection_type<PROJ, srs_spheroid_tag, SP, CT, P> \
{ \
typedef projections::detail::static_wrapper_fi<P_SPHEROID<CT, P>, P> type; \
}; \
template <typename P>
struct static_wrapper_b
{
inline explicit static_wrapper_b(P const& par)
: m_par(par)
{}
std::string name() const { return m_par.id.name; }
P const& params() const { return m_par; }
P& mutable_params() { return m_par; }
protected:
P m_par;
};
// Forward
template <typename Prj, typename P>
struct static_wrapper_f
: public static_wrapper_b<P>
, public Prj
{
public:
template <typename Params>
inline static_wrapper_f(Params const& params, P const& par)
: static_wrapper_b<P>(par)
, Prj(params, this->m_par) // prj can modify parameters
{}
template <typename LL, typename XY>
inline bool forward(LL const& lp, XY& xy) const
{
try
{
pj_fwd(*this, this->m_par, lp, xy);
return true;
}
catch (...)
{
return false;
}
}
template <typename XY, typename LL>
inline bool inverse(XY const&, LL&) const
{
BOOST_GEOMETRY_STATIC_ASSERT_FALSE(
"This projection is not invertable.",
Prj);
return false;
}
};
// Forward/inverse
template <typename Prj, typename P>
struct static_wrapper_fi
: public static_wrapper_f<Prj, P>
{
public:
template <typename Params>
inline static_wrapper_fi(Params const& params, P const& par)
: static_wrapper_f<Prj, P>(params, par)
{}
template <typename XY, typename LL>
inline bool inverse(XY const& xy, LL& lp) const
{
try
{
pj_inv(*this, this->m_par, xy, lp);
return true;
}
catch (...)
{
return false;
}
}
};
} // namespace detail
#endif // DOXYGEN_NO_DETAIL
}}} // namespace boost::geometry::projections
#endif // BOOST_GEOMETRY_PROJECTIONS_IMPL_BASE_STATIC_HPP