// This file is part of the "Nazara Development Kit" // For conditions of distribution and use, see copyright notice in Prerequesites.hpp #include #include namespace Ndk { std::unique_ptr LuaBinding_Base::BindUtility(LuaBinding& binding) { return std::make_unique(binding); } LuaBinding_Utility::LuaBinding_Utility(LuaBinding& binding) : LuaBinding_Base(binding) { /*********************************** Nz::AbstractImage **********************************/ abstractImage.Reset("AbstractImage"); { abstractImage.BindMethod("GetBytesPerPixel", &Nz::AbstractImage::GetBytesPerPixel); abstractImage.BindMethod("GetDepth", &Nz::AbstractImage::GetDepth, static_cast(0)); abstractImage.BindMethod("GetFormat", &Nz::AbstractImage::GetFormat); abstractImage.BindMethod("GetHeight", &Nz::AbstractImage::GetHeight, static_cast(0)); abstractImage.BindMethod("GetLevelCount", &Nz::AbstractImage::GetLevelCount); abstractImage.BindMethod("GetMaxLevel", &Nz::AbstractImage::GetMaxLevel); abstractImage.BindMethod("GetSize", &Nz::AbstractImage::GetSize, static_cast(0)); abstractImage.BindMethod("GetType", &Nz::AbstractImage::GetType); abstractImage.BindMethod("GetWidth", &Nz::AbstractImage::GetWidth, static_cast(0)); abstractImage.BindMethod("IsCompressed", &Nz::AbstractImage::IsCompressed); abstractImage.BindMethod("IsCubemap", &Nz::AbstractImage::IsCubemap); abstractImage.BindMethod("GetMemoryUsage", [] (Nz::LuaState& lua, Nz::AbstractImage* instance, std::size_t argumentCount) -> int { std::size_t argCount = std::min(argumentCount, 1U); switch (argCount) { case 0: return lua.Push(instance->GetMemoryUsage()); case 1: { int argIndex = 2; Nz::UInt8 level(lua.Check(&argIndex)); return lua.Push(instance->GetMemoryUsage(level)); } } lua.Error("No matching overload for method GetMemoryUsage"); return 0; }); abstractImage.BindMethod("Update", [] (Nz::LuaState& lua, Nz::AbstractImage* instance, std::size_t argumentCount) -> int { std::size_t argCount = std::min(argumentCount, 6U); int argIndex = 2; std::size_t bufferSize = 0; const Nz::UInt8* pixels = reinterpret_cast(lua.CheckString(argIndex++, &bufferSize)); if (argCount < 2 || lua.IsOfType(2, Nz::LuaType_Number)) { // bool Update(const UInt8* pixels, unsigned int srcWidth = 0, unsigned int srcHeight = 0, UInt8 level = 0) unsigned int srcWidth = lua.Check(&argIndex, 0); unsigned int srcHeight = lua.Check(&argIndex, 0); Nz::UInt8 level = lua.Check(&argIndex, 0); ///TODO: Buffer checks (Nz::ByteBufferView ?) return lua.Push(instance->Update(pixels, srcWidth, srcHeight, level)); } /* Disabled until Box and Rect have been ported else if (lua.IsOfType(2, "Box")) { // bool Update(const UInt8* pixels, const Boxui& box, unsigned int srcWidth = 0, unsigned int srcHeight = 0, UInt8 level = 0) Nz::Boxui box = lua.Check(&argIndex); unsigned int srcWidth = lua.Check(&argIndex, 0); unsigned int srcHeight = lua.Check(&argIndex, 0); Nz::UInt8 level = lua.Check(&argIndex, 0); ///TODO: Buffer checks (Nz::ByteBufferView ?) return lua.Push(abstractImage->Update(pixels, srcWidth, srcHeight, level)); } else if (lua.IsOfType(2, "Rect")) { // bool Update(const UInt8* pixels, const Rectui& rect, unsigned int z = 0, unsigned int srcWidth = 0, unsigned int srcHeight = 0, UInt8 level = 0) Nz::Rectui box = lua.Check(&argIndex); unsigned int srcWidth = lua.Check(&argIndex, 0); unsigned int srcHeight = lua.Check(&argIndex, 0); Nz::UInt8 level = lua.Check(&argIndex, 0); ///TODO: Buffer checks (Nz::ByteBufferView ?) return lua.Push(abstractImage->Update(pixels, srcWidth, srcHeight, level)); }*/ lua.Error("No matching overload for method Update"); return 0; }); } /*********************************** Nz::Font **********************************/ font.Reset("Font"); { font.SetConstructor([] (Nz::LuaState& /*lua*/, Nz::FontRef* instance, std::size_t /*argumentCount*/) { Nz::PlacementNew(instance, Nz::Font::New()); return true; }); font.BindMethod("ClearGlyphCache", &Nz::Font::ClearGlyphCache); font.BindMethod("ClearKerningCache", &Nz::Font::ClearKerningCache); font.BindMethod("ClearSizeInfoCache", &Nz::Font::ClearSizeInfoCache); font.BindMethod("Destroy", &Nz::Font::Destroy); font.BindMethod("GetCachedGlyphCount", [] (Nz::LuaState& lua, Nz::FontRef& instance, std::size_t argumentCount) -> int { std::size_t argCount = std::min(argumentCount, 2U); int argIndex = 2; switch (argCount) { case 0: lua.Push(instance->GetCachedGlyphCount()); return 1; case 2: { unsigned int characterSize = lua.Check(&argIndex); Nz::UInt32 style = lua.Check(&argIndex); lua.Push(instance->GetCachedGlyphCount(characterSize, style)); return 1; } } lua.Error("No matching overload for method GetCachedGlyphCount"); return 0; }); font.BindMethod("GetFamilyName", &Nz::Font::GetFamilyName); font.BindMethod("GetKerning", &Nz::Font::GetKerning); font.BindMethod("GetGlyphBorder", &Nz::Font::GetGlyphBorder); font.BindMethod("GetMinimumStepSize", &Nz::Font::GetMinimumStepSize); font.BindMethod("GetSizeInfo", &Nz::Font::GetSizeInfo); font.BindMethod("GetStyleName", &Nz::Font::GetStyleName); font.BindMethod("IsValid", &Nz::Font::IsValid); font.BindMethod("Precache", (bool(Nz::Font::*)(unsigned int, Nz::UInt32, const Nz::String&) const) &Nz::Font::Precache); font.BindMethod("OpenFromFile", &Nz::Font::OpenFromFile, Nz::FontParams()); font.BindMethod("SetGlyphBorder", &Nz::Font::SetGlyphBorder); font.BindMethod("SetMinimumStepSize", &Nz::Font::SetMinimumStepSize); font.BindStaticMethod("GetDefault", &Nz::Font::GetDefault); font.BindStaticMethod("GetDefaultGlyphBorder", &Nz::Font::GetDefaultGlyphBorder); font.BindStaticMethod("GetDefaultMinimumStepSize", &Nz::Font::GetDefaultMinimumStepSize); font.BindStaticMethod("SetDefaultGlyphBorder", &Nz::Font::SetDefaultGlyphBorder); font.BindStaticMethod("SetDefaultMinimumStepSize", &Nz::Font::SetDefaultMinimumStepSize); } /*********************************** Nz::Node **********************************/ node.Reset("Node"); { node.BindMethod("GetBackward", &Nz::Node::GetBackward); //nodeClass.SetMethod("GetChilds", &Nz::Node::GetChilds); node.BindMethod("GetDown", &Nz::Node::GetDown); node.BindMethod("GetForward", &Nz::Node::GetForward); node.BindMethod("GetInheritPosition", &Nz::Node::GetInheritPosition); node.BindMethod("GetInheritRotation", &Nz::Node::GetInheritRotation); node.BindMethod("GetInheritScale", &Nz::Node::GetInheritScale); node.BindMethod("GetInitialPosition", &Nz::Node::GetInitialPosition); //nodeClass.SetMethod("GetInitialRotation", &Nz::Node::GetInitialRotation); node.BindMethod("GetInitialScale", &Nz::Node::GetInitialScale); node.BindMethod("GetLeft", &Nz::Node::GetLeft); node.BindMethod("GetNodeType", &Nz::Node::GetNodeType); //nodeClass.SetMethod("GetParent", &Nz::Node::GetParent); node.BindMethod("GetPosition", &Nz::Node::GetPosition, Nz::CoordSys_Global); node.BindMethod("GetRight", &Nz::Node::GetRight); //nodeClass.SetMethod("GetRotation", &Nz::Node::GetRotation, Nz::CoordSys_Global); node.BindMethod("GetScale", &Nz::Node::GetScale, Nz::CoordSys_Global); //nodeClass.SetMethod("GetTransformMatrix", &Nz::Node::GetTransformMatrix); node.BindMethod("GetUp", &Nz::Node::GetUp); node.BindMethod("HasChilds", &Nz::Node::HasChilds); node.BindMethod("GetBackward", &Nz::Node::GetBackward); node.BindMethod("GetDown", &Nz::Node::GetDown); node.BindMethod("GetForward", &Nz::Node::GetForward); node.BindMethod("GetInheritPosition", &Nz::Node::GetInheritPosition); node.BindMethod("GetInheritRotation", &Nz::Node::GetInheritRotation); node.BindMethod("GetInheritScale", &Nz::Node::GetInheritScale); node.BindMethod("GetInitialPosition", &Nz::Node::GetInitialPosition); node.BindMethod("GetInitialRotation", &Nz::Node::GetInitialRotation); node.BindMethod("GetInitialScale", &Nz::Node::GetInitialScale); node.BindMethod("GetLeft", &Nz::Node::GetLeft); node.BindMethod("GetNodeType", &Nz::Node::GetNodeType); node.BindMethod("GetPosition", &Nz::Node::GetPosition, Nz::CoordSys_Global); node.BindMethod("GetRight", &Nz::Node::GetRight); node.BindMethod("GetRotation", &Nz::Node::GetRotation, Nz::CoordSys_Global); node.BindMethod("GetScale", &Nz::Node::GetScale, Nz::CoordSys_Global); node.BindMethod("GetUp", &Nz::Node::GetUp); node.BindMethod("SetInitialPosition", (void(Nz::Node::*)(const Nz::Vector3f&)) &Nz::Node::SetInitialPosition); node.BindMethod("SetInitialRotation", (void(Nz::Node::*)(const Nz::Quaternionf&)) &Nz::Node::SetInitialRotation); node.BindMethod("SetPosition", (void(Nz::Node::*)(const Nz::Vector3f&, Nz::CoordSys)) &Nz::Node::SetPosition, Nz::CoordSys_Local); node.BindMethod("SetRotation", (void(Nz::Node::*)(const Nz::Quaternionf&, Nz::CoordSys)) &Nz::Node::SetRotation, Nz::CoordSys_Local); node.BindMethod("Move", [] (Nz::LuaState& lua, Nz::Node& instance, std::size_t /*argumentCount*/) -> int { int argIndex = 2; Nz::Vector3f offset = lua.Check(&argIndex); Nz::CoordSys coordSys = lua.Check(&argIndex, Nz::CoordSys_Local); instance.Move(offset, coordSys); return 0; }); node.BindMethod("Rotate", [] (Nz::LuaState& lua, Nz::Node& instance, std::size_t /*argumentCount*/) -> int { int argIndex = 2; Nz::Quaternionf rotation = lua.Check(&argIndex); Nz::CoordSys coordSys = lua.Check(&argIndex, Nz::CoordSys_Local); instance.Rotate(rotation, coordSys); return 0; }); node.BindMethod("Scale", [] (Nz::LuaState& lua, Nz::Node& instance, std::size_t argumentCount) -> int { std::size_t argCount = std::min(argumentCount, 4U); int argIndex = 2; switch (argCount) { case 1: { if (lua.IsOfType(argIndex, Nz::LuaType_Number)) instance.Scale(lua.Check(&argIndex)); else instance.Scale(lua.Check(&argIndex)); return 0; } case 3: instance.Scale(lua.Check(&argIndex)); return 0; } lua.Error("No matching overload for method Scale"); return 0; }); node.BindMethod("SetScale", [] (Nz::LuaState& lua, Nz::Node& instance, std::size_t argumentCount) -> int { std::size_t argCount = std::min(argumentCount, 4U); int argIndex = 2; switch (argCount) { case 1: case 2: { if (lua.IsOfType(argIndex, Nz::LuaType_Number)) { float scale = lua.Check(&argIndex); Nz::CoordSys coordSys = lua.Check(&argIndex, Nz::CoordSys_Local); instance.SetScale(scale, coordSys); } else instance.SetScale(lua.Check(&argIndex)); return 0; } case 3: case 4: { Nz::Vector3f scale = lua.Check(&argIndex); Nz::CoordSys coordSys = lua.Check(&argIndex, Nz::CoordSys_Local); instance.SetScale(scale, coordSys); return 0; } } lua.Error("No matching overload for method SetScale"); return 0; }); node.BindMethod("SetInitialScale", [] (Nz::LuaState& lua, Nz::Node& instance, std::size_t argumentCount) -> int { std::size_t argCount = std::min(argumentCount, 4U); int argIndex = 2; switch (argCount) { case 1: { if (lua.IsOfType(argIndex, Nz::LuaType_Number)) instance.SetInitialScale(lua.Check(&argIndex)); else instance.SetInitialScale(lua.Check(&argIndex)); return 0; } case 2: case 3: instance.SetInitialScale(lua.Check(&argIndex)); return 0; } lua.Error("No matching overload for method SetInitialScale"); return 0; }); } } /*! * \brief Registers the classes that will be used by the Lua instance * * \param instance Lua instance that will interact with the Utility classes */ void LuaBinding_Utility::Register(Nz::LuaState& state) { abstractImage.Register(state); font.Register(state); node.Register(state); } }