Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added 'RegisterHookFromBP' and 'UnregisterHookFromBP' for BP Mods #421

Open
wants to merge 16 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions UE4SS/include/LuaType/LuaUFunction.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

#include <LuaMadeSimple/LuaMadeSimple.hpp>
#include <LuaType/LuaUObject.hpp>
#include <LuaType/LuaUStruct.hpp>

namespace RC::Unreal
{
Expand Down Expand Up @@ -45,6 +46,9 @@ namespace RC::LuaType
};
class UFunction : public UObjectBase<Unreal::UFunction, UFunctionName>
{
public:
using Super = UStruct;

private:
// This is the 'this' pointer for this UFunction
Unreal::UObject* m_base{};
Expand Down
28 changes: 28 additions & 0 deletions UE4SS/include/LuaType/LuaUInt64.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
#pragma once

#include <cstdint>

#include <LuaType/LuaUObject.hpp>

namespace RC::LuaType
{
struct UInt64Name
{
constexpr static const char* ToString()
{
return "UInt64";
}
};
class UInt64 : public LocalObjectBase<uint64_t, UInt64Name>
{
private:
explicit UInt64(uint64_t object);

public:
UInt64() = delete;
auto static construct(const LuaMadeSimple::Lua&, uint64_t) -> const LuaMadeSimple::Lua::Table;

private:
auto static setup_metamethods(BaseObject&) -> void;
};
} // namespace RC::LuaType
2 changes: 1 addition & 1 deletion UE4SS/include/LuaType/LuaXBoolProperty.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ namespace RC::LuaType
{
constexpr static const char* ToString()
{
return "ObjectProperty";
return "BoolProperty";
}
};
class XBoolProperty : public RemoteObjectBase<Unreal::FBoolProperty, FBoolPropertyName>
Expand Down
39 changes: 39 additions & 0 deletions UE4SS/include/LuaType/LuaXNumericProperty.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
#pragma once

#include <LuaType/LuaXProperty.hpp>

namespace RC::Unreal
{
class FNumericProperty;
}

namespace RC::LuaType
{
struct FNumericPropertyName
{
constexpr static const char* ToString()
{
return "NumericProperty";
}
};
class XNumericProperty : public RemoteObjectBase<Unreal::FNumericProperty, FNumericPropertyName>
{
public:
using Super = XProperty;

private:
explicit XNumericProperty(Unreal::FNumericProperty* object);

public:
XNumericProperty() = delete;
auto static construct(const LuaMadeSimple::Lua&, Unreal::FNumericProperty*) -> const LuaMadeSimple::Lua::Table;
auto static construct(const LuaMadeSimple::Lua&, BaseObject&) -> const LuaMadeSimple::Lua::Table;

private:
auto static setup_metamethods(BaseObject&) -> void;

private:
template <LuaMadeSimple::Type::IsFinal is_final>
auto static setup_member_functions(const LuaMadeSimple::Lua::Table&) -> void;
};
} // namespace RC::LuaType
2 changes: 2 additions & 0 deletions UE4SS/src/LuaType/LuaUFunction.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,8 @@ namespace RC::LuaType
template <LuaMadeSimple::Type::IsFinal is_final>
auto UFunction::setup_member_functions(const LuaMadeSimple::Lua::Table& table) -> void
{
Super::setup_member_functions<LuaMadeSimple::Type::IsFinal::No>(table);

table.add_pair("GetFunctionFlags", [](const LuaMadeSimple::Lua& lua) -> int {
const auto& lua_object = lua.get_userdata<LuaType::UFunction>();
lua.set_integer(lua_object.get_remote_cpp_object()->GetFunctionFlags());
Expand Down
44 changes: 44 additions & 0 deletions UE4SS/src/LuaType/LuaUInt64.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
#include <LuaType/LuaUInt64.hpp>

namespace RC::LuaType
{
UInt64::UInt64(uint64_t number) : LocalObjectBase<uint64_t, UInt64Name>(std::move(number))
{
}

auto UInt64::construct(const LuaMadeSimple::Lua& lua, uint64_t number) -> const LuaMadeSimple::Lua::Table
{
LuaType::UInt64 lua_object{number};

static constexpr auto metatable_name = ClassName::ToString();

auto table = lua.get_metatable(metatable_name);
if (lua.is_nil(-1))
{
lua.discard_value(-1);
lua.prepare_new_table();
setup_metamethods(lua_object);
lua.new_metatable<LuaType::UInt64>(metatable_name, lua_object.get_metamethods());
}

lua.transfer_stack_object(std::move(lua_object), metatable_name, lua_object.get_metamethods());
return LuaMadeSimple::Lua::Table{lua};
}

auto UInt64::setup_metamethods(BaseObject& base_object) -> void
{
base_object.get_metamethods().create(LuaMadeSimple::Lua::MetaMethod::BinaryAnd, [](const LuaMadeSimple::Lua& lua) -> int {
auto& lua_object = lua.get_userdata<LuaType::UInt64>();
auto& lua_object_other = lua.get_userdata<LuaType::UInt64>();
LuaType::UInt64::construct(lua, lua_object.get_local_cpp_object() & lua_object_other.get_local_cpp_object());
return 1;
});

base_object.get_metamethods().create(LuaMadeSimple::Lua::MetaMethod::BinaryOr, [](const LuaMadeSimple::Lua& lua) -> int {
auto& lua_object = lua.get_userdata<LuaType::UInt64>();
auto& lua_object_other = lua.get_userdata<LuaType::UInt64>();
LuaType::UInt64::construct(lua, lua_object.get_local_cpp_object() | lua_object_other.get_local_cpp_object());
return 1;
});
}
} // namespace RC::LuaType
76 changes: 76 additions & 0 deletions UE4SS/src/LuaType/LuaXNumericProperty.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
#include <LuaType/LuaUClass.hpp>
#include <LuaType/LuaUObject.hpp>
#include <LuaType/LuaXNumericProperty.hpp>
#pragma warning(disable : 4005)
#include <Unreal/Property/FNumericProperty.hpp>
#pragma warning(default : 4005)

namespace RC::LuaType
{
XNumericProperty::XNumericProperty(Unreal::FNumericProperty* object) : RemoteObjectBase<Unreal::FNumericProperty, FNumericPropertyName>(object)
{
}

auto XNumericProperty::construct(const LuaMadeSimple::Lua& lua, Unreal::FNumericProperty* unreal_object) -> const LuaMadeSimple::Lua::Table
{
LuaType::XNumericProperty lua_object{unreal_object};

auto metatable_name = ClassName::ToString();

LuaMadeSimple::Lua::Table table = lua.get_metatable(metatable_name);
if (lua.is_nil(-1))
{
lua.discard_value(-1);
LuaMadeSimple::Type::RemoteObject<Unreal::FNumericProperty>::construct(lua, lua_object);
setup_metamethods(lua_object);
setup_member_functions<LuaMadeSimple::Type::IsFinal::Yes>(table);
lua.new_metatable<LuaType::XNumericProperty>(metatable_name, lua_object.get_metamethods());
}

// Create object & surrender ownership to Lua
lua.transfer_stack_object(std::move(lua_object), metatable_name, lua_object.get_metamethods());

return table;
}

auto XNumericProperty::construct(const LuaMadeSimple::Lua& lua, BaseObject& construct_to) -> const LuaMadeSimple::Lua::Table
{
LuaMadeSimple::Lua::Table table = LuaMadeSimple::Type::RemoteObject<Unreal::FNumericProperty>::construct(lua, construct_to);

setup_member_functions<LuaMadeSimple::Type::IsFinal::No>(table);

setup_metamethods(construct_to);

return table;
}

auto XNumericProperty::setup_metamethods([[maybe_unused]] BaseObject& base_object) -> void
{
// XNumericProperty has no metamethods
}

template <LuaMadeSimple::Type::IsFinal is_final>
auto XNumericProperty::setup_member_functions(const LuaMadeSimple::Lua::Table& table) -> void
{
Super::setup_member_functions<LuaMadeSimple::Type::IsFinal::No>(table);

table.add_pair("IsFloatingPoint", [](const LuaMadeSimple::Lua& lua) -> int {
const auto& lua_object = lua.get_userdata<XNumericProperty>();
lua.set_bool(lua_object.get_remote_cpp_object()->IsFloatingPoint());
return 1;
});


if constexpr (is_final == LuaMadeSimple::Type::IsFinal::Yes)
{
table.add_pair("type", [](const LuaMadeSimple::Lua& lua) -> int {
lua.set_string(ClassName::ToString());
return 1;
});

// If this is the final object then we also want to finalize creating the table
// If not then it's the responsibility of the overriding object to call 'make_global()'
// table.make_global(ClassName::ToString());
}
}
} // namespace RC::LuaType
51 changes: 51 additions & 0 deletions UE4SS/src/LuaType/LuaXProperty.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,16 @@
#include <LuaType/LuaXObjectProperty.hpp>
#include <LuaType/LuaXProperty.hpp>
#include <LuaType/LuaXStructProperty.hpp>
#include <LuaType/LuaXNumericProperty.hpp>
#include <LuaType/LuaUInt64.hpp>
#pragma warning(disable : 4005)
#include <Unreal/FProperty.hpp>
#include <Unreal/Property/FArrayProperty.hpp>
#include <Unreal/Property/FBoolProperty.hpp>
#include <Unreal/Property/FEnumProperty.hpp>
#include <Unreal/Property/FObjectProperty.hpp>
#include <Unreal/Property/FStructProperty.hpp>
#include <Unreal/Property/FNumericProperty.hpp>
#pragma warning(default : 4005)

namespace RC::LuaType
Expand Down Expand Up @@ -45,6 +48,10 @@ namespace RC::LuaType
{
XArrayProperty::construct(lua, as_array_property);
}
else if (auto* as_numeric_property = Unreal::CastField<Unreal::FNumericProperty>(property); as_numeric_property)
{
XNumericProperty::construct(lua, as_numeric_property);
}
else
{
XProperty::construct(lua, property);
Expand Down Expand Up @@ -137,6 +144,44 @@ namespace RC::LuaType
return 1;
});

table.add_pair("HasAnyPropertyFlags", [](const LuaMadeSimple::Lua& lua) -> int {
std::string error_overload_not_found{R"(
No overload found for function 'Property.HasAnyPropertyFlags'.
Overloads:
#1: HasAnyPropertyFlags(EPropertyFlags PropertyFlags))"};

const auto& lua_object = lua.get_userdata<SelfType>();

if (!lua.is_userdata())
{
lua.throw_error(error_overload_not_found);
}

auto& lua_uint64 = lua.get_userdata<LuaType::UInt64>();
auto object_flags = static_cast<Unreal::EPropertyFlags>(lua_uint64.get_local_cpp_object());
lua.set_bool(lua_object.get_remote_cpp_object()->HasAnyPropertyFlags(object_flags));
return 1;
});

table.add_pair("HasAllPropertyFlags", [](const LuaMadeSimple::Lua& lua) -> int {
std::string error_overload_not_found{R"(
No overload found for function 'Property.HasAllPropertyFlags'.
Overloads:
#1: HasAllPropertyFlags(EPropertyFlags PropertyFlags))"};

const auto& lua_object = lua.get_userdata<SelfType>();

if (!lua.is_userdata())
{
lua.throw_error(error_overload_not_found);
}

auto& lua_uint64 = lua.get_userdata<LuaType::UInt64>();
auto object_flags = static_cast<Unreal::EPropertyFlags>(lua_uint64.get_local_cpp_object());
lua.set_bool(lua_object.get_remote_cpp_object()->HasAllPropertyFlags(object_flags));
return 1;
});

table.add_pair("IsA", [](const LuaMadeSimple::Lua& lua) -> int {
std::string error_overload_not_found{R"(
No overload found for function 'IsA'.
Expand Down Expand Up @@ -178,6 +223,12 @@ No overload found for function 'IsA'.
}
return 1;
}
else if (lua.is_userdata()) // FFieldClass, returned from Property:GetClass()
{
auto ffield_class = lua.get_userdata<LuaType::XFieldClass>();
lua.set_bool(lua_object.get_remote_cpp_object()->IsA(ffield_class.get_local_cpp_object()));
return 1;
}
else
{
lua.throw_error(error_overload_not_found);
Expand Down
Loading