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
out_value_policy.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\luabind\luabind\out_value_policy.hpp
Girar
Efecto
Propiedad
Historial
// Copyright (c) 2003 Daniel Wallin and Arvid Norberg // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the "Software"), // to deal in the Software without restriction, including without limitation // the rights to use, copy, modify, merge, publish, distribute, sublicense, // and/or sell copies of the Software, and to permit persons to whom the // Software is furnished to do so, subject to the following conditions: // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF // ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED // TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A // PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT // SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR // ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE // OR OTHER DEALINGS IN THE SOFTWARE. #ifndef LUABIND_OUT_VALUE_POLICY_HPP_INCLUDED #define LUABIND_OUT_VALUE_POLICY_HPP_INCLUDED #include
#include
#include
namespace luabind { namespace detail { template
struct char_array { char storage[N]; }; #if defined(__GNUC__) && ( __GNUC__ == 3 && __GNUC_MINOR__ == 1 ) template
char_array
indirect_sizeof_test(by_reference
); template
char_array
indirect_sizeof_test(by_const_reference
); template
char_array
indirect_sizeof_test(by_pointer
); template
char_array
indirect_sizeof_test(by_const_pointer
); template
char_array
indirect_sizeof_test(by_value
); #else template
char_array
::type)> indirect_sizeof_test(by_reference
); template
char_array
::type)> indirect_sizeof_test(by_const_reference
); template
char_array
::type)> indirect_sizeof_test(by_pointer
); template
char_array
::type)> indirect_sizeof_test(by_const_pointer
); template
char_array
::type)> indirect_sizeof_test(by_value
); #endif template
struct indirect_sizeof { BOOST_STATIC_CONSTANT(int, value = sizeof(indirect_sizeof_test(LUABIND_DECORATE_TYPE(T)))); }; namespace mpl = boost::mpl; template
struct out_value_converter { template
T& apply(lua_State* L, by_reference
, int index) { typedef typename find_conversion_policy<1, Policies>::type converter_policy; typename mpl::apply_wrap2
::type converter; new (m_storage) T(converter.apply(L, LUABIND_DECORATE_TYPE(T), index)); return *reinterpret_cast
(m_storage); } template
static int match(lua_State* L, by_reference
, int index) { typedef typename find_conversion_policy<1, Policies>::type converter_policy; typedef typename mpl::apply_wrap2
::type converter; return converter::match(L, LUABIND_DECORATE_TYPE(T), index); } template
void converter_postcall(lua_State* L, by_reference
, int) { typedef typename find_conversion_policy<2, Policies>::type converter_policy; typename mpl::apply_wrap2
::type converter; converter.apply(L, *reinterpret_cast
(m_storage)); reinterpret_cast
(m_storage)->~T(); } template
T* apply(lua_State* L, by_pointer
, int index) { typedef typename find_conversion_policy<1, Policies>::type converter_policy; typename mpl::apply_wrap2
::type converter; new (m_storage) T(converter.apply(L, LUABIND_DECORATE_TYPE(T), index)); return reinterpret_cast
(m_storage); } template
static int match(lua_State* L, by_pointer
, int index) { typedef typename find_conversion_policy<1, Policies>::type converter_policy; typedef typename mpl::apply_wrap2
::type converter; return converter::match(L, LUABIND_DECORATE_TYPE(T), index); } template
void converter_postcall(lua_State* L, by_pointer
, int) { typedef typename find_conversion_policy<2, Policies>::type converter_policy; typename mpl::apply_wrap2
::type converter; converter.apply(L, *reinterpret_cast
(m_storage)); reinterpret_cast
(m_storage)->~T(); } char m_storage[Size]; }; template
struct out_value_policy : conversion_policy
{ static void precall(lua_State*, const index_map&) {} static void postcall(lua_State*, const index_map&) {} struct only_accepts_nonconst_references_or_pointers {}; struct can_only_convert_from_lua_to_cpp {}; template
struct apply { typedef typename boost::mpl::if_
, typename boost::mpl::if_
, is_nonconst_pointer
> , out_value_converter
::value, Policies> , only_accepts_nonconst_references_or_pointers >::type , can_only_convert_from_lua_to_cpp >::type type; }; }; template
struct pure_out_value_converter { template
T& apply(lua_State* L, by_reference
, int index) { new (m_storage) T(); return *reinterpret_cast
(m_storage); } template
static int match(lua_State* L, by_reference
, int index) { return 0; } template
void converter_postcall(lua_State* L, by_reference
, int) { typedef typename find_conversion_policy<1, Policies>::type converter_policy; typename mpl::apply_wrap2
::type converter; converter.apply(L, *reinterpret_cast
(m_storage)); reinterpret_cast
(m_storage)->~T(); } template
T* apply(lua_State* L, by_pointer
, int index) { new (m_storage) T(); return reinterpret_cast
(m_storage); } template
static int match(lua_State* L, by_pointer
, int index) { return 0; } template
void converter_postcall(lua_State* L, by_pointer
, int) { typedef typename find_conversion_policy<1, Policies>::type converter_policy; typename mpl::apply_wrap2
::type converter; converter.apply(L, *reinterpret_cast
(m_storage)); reinterpret_cast
(m_storage)->~T(); } char m_storage[Size]; }; template
struct pure_out_value_policy : conversion_policy
{ static void precall(lua_State*, const index_map&) {} static void postcall(lua_State*, const index_map&) {} struct only_accepts_nonconst_references_or_pointers {}; struct can_only_convert_from_lua_to_cpp {}; template
struct apply { typedef typename boost::mpl::if_
, typename boost::mpl::if_
, is_nonconst_pointer
> , pure_out_value_converter
::value, Policies> , only_accepts_nonconst_references_or_pointers >::type , can_only_convert_from_lua_to_cpp >::type type; }; }; }} namespace luabind { template
detail::policy_cons
, detail::null_type> out_value(LUABIND_PLACEHOLDER_ARG(N)) { return detail::policy_cons
, detail::null_type>(); } template
detail::policy_cons
, detail::null_type> out_value(LUABIND_PLACEHOLDER_ARG(N), const Policies&) { return detail::policy_cons
, detail::null_type>(); } template
detail::policy_cons
, detail::null_type> pure_out_value(LUABIND_PLACEHOLDER_ARG(N)) { return detail::policy_cons
, detail::null_type>(); } template
detail::policy_cons
, detail::null_type> pure_out_value(LUABIND_PLACEHOLDER_ARG(N), const Policies&) { return detail::policy_cons
, detail::null_type>(); } } #endif // LUABIND_OUT_VALUE_POLICY_HPP_INCLUDED
out_value_policy.hpp
Dirección de la página
Dirección del archivo
Anterior
23/31
Siguiente
Descargar
( 8 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.