mirror of
https://github.com/EQEmu/Server.git
synced 2026-06-28 00:57:15 +00:00
Swapped luabind for non-boost fork
https://github.com/decimad/luabind-deboostified
This commit is contained in:
@@ -25,95 +25,75 @@
|
||||
#define LUABIND_DEPENDENCY_POLICY_HPP_INCLUDED
|
||||
|
||||
#include <luabind/config.hpp>
|
||||
#include <luabind/detail/policy.hpp>
|
||||
#include <luabind/detail/policy.hpp> // for policy_cons, etc
|
||||
#include <luabind/detail/object_rep.hpp> // for object_rep
|
||||
#include <luabind/detail/primitives.hpp> // for null_type
|
||||
|
||||
namespace luabind { namespace detail
|
||||
{
|
||||
// makes A dependent on B, meaning B will outlive A.
|
||||
// internally A stores a reference to B
|
||||
template<int A, int B>
|
||||
struct dependency_policy
|
||||
{
|
||||
static void postcall(lua_State* L, const index_map& indices)
|
||||
namespace luabind {
|
||||
namespace detail {
|
||||
|
||||
// makes A dependent on B, meaning B will outlive A.
|
||||
// internally A stores a reference to B
|
||||
template<int A, int B>
|
||||
struct dependency_policy
|
||||
{
|
||||
int nurse_index = indices[A];
|
||||
int patient = indices[B];
|
||||
template< unsigned int... StackIndices >
|
||||
static void postcall(lua_State* L, int results, meta::index_list<StackIndices...>)
|
||||
{
|
||||
object_rep* nurse = static_cast<object_rep*>(lua_touserdata(L, meta::get<meta::index_list<StackIndices...>, A>::value));
|
||||
|
||||
object_rep* nurse = static_cast<object_rep*>(lua_touserdata(L, nurse_index));
|
||||
// If the nurse isn't an object_rep, just make this a nop.
|
||||
if(nurse == 0)
|
||||
return;
|
||||
|
||||
// If the nurse isn't an object_rep, just make this a nop.
|
||||
if (nurse == 0)
|
||||
return;
|
||||
|
||||
nurse->add_dependency(L, patient);
|
||||
}
|
||||
};
|
||||
|
||||
}}
|
||||
|
||||
#if defined (BOOST_MSVC) && (BOOST_MSVC <= 1200)
|
||||
|
||||
namespace luabind
|
||||
{
|
||||
// most absurd workaround of all time?
|
||||
namespace detail
|
||||
{
|
||||
template<int N>
|
||||
struct size_char_array
|
||||
{
|
||||
char storage[N + 2];
|
||||
nurse->add_dependency(L, meta::get<meta::index_list<StackIndices...>, B>::value);
|
||||
}
|
||||
};
|
||||
|
||||
template<int N>
|
||||
size_char_array<N> deduce_size(LUABIND_PLACEHOLDER_ARG(N));
|
||||
|
||||
template<class T>
|
||||
struct get_index_workaround
|
||||
template<int B>
|
||||
struct dependency_policy<0, B>
|
||||
{
|
||||
static T t;
|
||||
BOOST_STATIC_CONSTANT(int, value = sizeof(deduce_size(t)) - 2);
|
||||
template< unsigned int... StackIndices >
|
||||
static void postcall(lua_State* L, int results, meta::index_list<StackIndices...>)
|
||||
{
|
||||
object_rep* nurse = static_cast<object_rep*>(lua_touserdata(L, meta::get<meta::index_list<StackIndices...>, 0>::value + results));
|
||||
|
||||
// If the nurse isn't an object_rep, just make this a nop.
|
||||
if(nurse == 0)
|
||||
return;
|
||||
|
||||
nurse->add_dependency(L, meta::get<meta::index_list<StackIndices...>, B>::value);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
template<class A, class B>
|
||||
detail::policy_cons<detail::dependency_policy<detail::get_index_workaround<A>::value
|
||||
, detail::get_index_workaround<B>::value>, detail::null_type> dependency(A,B)
|
||||
{
|
||||
return detail::policy_cons<detail::dependency_policy<
|
||||
detail::get_index_workaround<A>::value, detail::get_index_workaround<B>::value>
|
||||
, detail::null_type>();
|
||||
}
|
||||
template<int A>
|
||||
struct dependency_policy<A, 0>
|
||||
{
|
||||
template< unsigned int... StackIndices >
|
||||
static void postcall(lua_State* L, int results, meta::index_list<StackIndices...>)
|
||||
{
|
||||
object_rep* nurse = static_cast<object_rep*>(lua_touserdata(L, meta::get<meta::index_list<StackIndices...>, A>::value));
|
||||
|
||||
// If the nurse isn't an object_rep, just make this a nop.
|
||||
if(nurse == 0)
|
||||
return;
|
||||
|
||||
nurse->add_dependency(L, meta::get<meta::index_list<StackIndices...>, 0>::value + results);
|
||||
}
|
||||
};
|
||||
|
||||
template<class A>
|
||||
detail::policy_cons<detail::dependency_policy<0
|
||||
, detail::get_index_workaround<A>::value>, detail::null_type>
|
||||
return_internal_reference(A)
|
||||
{
|
||||
return detail::policy_cons<detail::dependency_policy<0
|
||||
, detail::get_index_workaround<A>::value>, detail::null_type>();
|
||||
}
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
namespace luabind
|
||||
{
|
||||
template<int A, int B>
|
||||
detail::policy_cons<detail::dependency_policy<A, B>, detail::null_type>
|
||||
dependency(LUABIND_PLACEHOLDER_ARG(A), LUABIND_PLACEHOLDER_ARG(B))
|
||||
{
|
||||
return detail::policy_cons<detail::dependency_policy<A, B>, detail::null_type>();
|
||||
}
|
||||
// Caution: If we use the aliased type "policy_list" here, MSVC crashes.
|
||||
template<unsigned int A, unsigned int B>
|
||||
using dependency_policy = meta::type_list<call_policy_injector<detail::dependency_policy<A, B>>>;
|
||||
|
||||
template<int A>
|
||||
detail::policy_cons<detail::dependency_policy<0, A>, detail::null_type>
|
||||
return_internal_reference(LUABIND_PLACEHOLDER_ARG(A))
|
||||
{
|
||||
return detail::policy_cons<detail::dependency_policy<0, A>, detail::null_type>();
|
||||
}
|
||||
template<unsigned int A>
|
||||
using return_internal_reference = meta::type_list<call_policy_injector<detail::dependency_policy<0, A>>>;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
#endif // LUABIND_DEPENDENCY_POLICY_HPP_INCLUDED
|
||||
|
||||
|
||||
Reference in New Issue
Block a user