123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- // 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
|