x
Yes
No
Do you want to visit DriveHQ English website?
Inicio
Características
Precios
Prueba gratuita
Software cliente
Acerca de nosotros
Servidor de archivos
|
Solución de copias de seguridad
|
Servidor FTP
|
Servidor de correo electrónico
|
Alojamiento web
|
Software cliente
Servidor de archivos
Solución de copia de seguridad
Servidor FTP
Servidor de correo electrónico
Alojamiento web
Software cliente
dynamic_at_c.hpp - Hosted on DriveHQ Cloud IT Platform
Arriba
Subir
Descargar
Compartir
Publicar
Nueva carpeta
Nuevo archivo
Copiar
Cortar
Eliminar
Pegar
Clasificación
Actualizar
Ruta de la carpeta: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\gil\extension\dynamic_image\dynamic_at_c.hpp
Girar
Efecto
Propiedad
Historial
/* Copyright 2005-2007 Adobe Systems Incorporated Use, modification and distribution are 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). See http://opensource.adobe.com/gil for most recent version including documentation. */ /*************************************************************************************************/ #ifndef GIL_DYNAMIC_AT_C_HPP #define GIL_DYNAMIC_AT_C_HPP #include "../../gil_config.hpp" #include
#include
#include
#include
//////////////////////////////////////////////////////////////////////////////////////// /// \file /// \brief Constructs for static-to-dynamic integer convesion /// \author Lubomir Bourdev and Hailin Jin \n /// Adobe Systems Incorporated /// \date 2005-2007 \n Last updated on May 4, 2006 /// //////////////////////////////////////////////////////////////////////////////////////// namespace boost { namespace gil { #define GIL_AT_C_VALUE(z, N, text) mpl::at_c
::type::value, #define GIL_DYNAMIC_AT_C_LIMIT 226 // size of the maximum vector to handle #define GIL_AT_C_LOOKUP(z, NUM, text) \ template
\ struct at_c_fn
{ \ template
inline \ static ValueType apply(std::size_t index) { \ static ValueType table[] = { \ BOOST_PP_REPEAT(NUM, GIL_AT_C_VALUE, BOOST_PP_EMPTY) \ }; \ return table[index]; \ } \ }; namespace detail { namespace at_c { template
struct at_c_fn; BOOST_PP_REPEAT(GIL_DYNAMIC_AT_C_LIMIT, GIL_AT_C_LOOKUP, BOOST_PP_EMPTY) template
struct at_c_impl; template <> struct at_c_impl<0> { template
inline static ValueType apply(std::size_t index) { return at_c_fn<0,mpl::size
::value>::template apply
(index); } }; template <> struct at_c_impl<1> { template
inline static ValueType apply(std::size_t index) { const std::size_t SIZE=mpl::size
::value; const std::size_t REM = SIZE % GIL_DYNAMIC_AT_C_LIMIT; switch (index / GIL_DYNAMIC_AT_C_LIMIT) { case 0: return at_c_fn<0 ,GIL_DYNAMIC_AT_C_LIMIT-1>::template apply
(index); case 1: return at_c_fn
::template apply
(index - GIL_DYNAMIC_AT_C_LIMIT); }; throw; } }; template <> struct at_c_impl<2> { template
inline static ValueType apply(std::size_t index) { const std::size_t SIZE=mpl::size
::value; const std::size_t REM = SIZE % GIL_DYNAMIC_AT_C_LIMIT; switch (index / GIL_DYNAMIC_AT_C_LIMIT) { case 0: return at_c_fn<0 ,GIL_DYNAMIC_AT_C_LIMIT-1>::template apply
(index); case 1: return at_c_fn
::template apply
(index - GIL_DYNAMIC_AT_C_LIMIT); case 2: return at_c_fn
::template apply
(index - GIL_DYNAMIC_AT_C_LIMIT*2); }; throw; } }; template <> struct at_c_impl<3> { template
inline static ValueType apply(std::size_t index) { const std::size_t SIZE=mpl::size
::value; const std::size_t REM = SIZE % GIL_DYNAMIC_AT_C_LIMIT; switch (index / GIL_DYNAMIC_AT_C_LIMIT) { case 0: return at_c_fn<0 ,GIL_DYNAMIC_AT_C_LIMIT-1>::template apply
(index); case 1: return at_c_fn
::template apply
(index - GIL_DYNAMIC_AT_C_LIMIT); case 2: return at_c_fn
::template apply
(index - GIL_DYNAMIC_AT_C_LIMIT*2); case 3: return at_c_fn
::template apply
(index - GIL_DYNAMIC_AT_C_LIMIT*3); }; throw; } }; } } //////////////////////////////////////////////////////////////////////////////////// /// /// \brief Given an MPL Random Access Sequence and a dynamic index n, returns the value of the n-th element /// It constructs a lookup table at compile time /// //////////////////////////////////////////////////////////////////////////////////// template
inline ValueType at_c(std::size_t index) { const std::size_t Size=mpl::size
::value; return detail::at_c::at_c_impl
::template apply
(index); } #undef GIL_AT_C_VALUE #undef GIL_DYNAMIC_AT_C_LIMIT #undef GIL_AT_C_LOOKUP } } // namespace boost::gil #endif
dynamic_at_c.hpp
Dirección de la página
Dirección del archivo
Anterior
6/10
Siguiente
Descargar
( 5 KB )
Comments
Total ratings:
0
Average rating:
No clasificado
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.