JAJ.Packages.LuaNET
1.1.0
dotnet add package JAJ.Packages.LuaNET --version 1.1.0
NuGet\Install-Package JAJ.Packages.LuaNET -Version 1.1.0
<PackageReference Include="JAJ.Packages.LuaNET" Version="1.1.0" />
paket add JAJ.Packages.LuaNET --version 1.1.0
#r "nuget: JAJ.Packages.LuaNET, 1.1.0"
// Install JAJ.Packages.LuaNET as a Cake Addin #addin nuget:?package=JAJ.Packages.LuaNET&version=1.1.0 // Install JAJ.Packages.LuaNET as a Cake Tool #tool nuget:?package=JAJ.Packages.LuaNET&version=1.1.0
LuaNET
A modified fork of https://github.com/tilkinsc/Lua.NET but only with support for LuaJIT. This library uses a more C-Sharp styled API, with built-in functionality to load modules and call C-Sharp methods directly by function pointer.
Installation
The easiest way to install is with NuGet
dotnet add package JAJ.Packages.LuaNET --version 1.1.0
Changes in 1.1.0
- Add support for OSX ARM64.
Basic Example
The basic example just prints 'Hello world' to the console.
using System;
using System.IO;
using LuaNET;
namespace LuaNETExample
{
class Program
{
static void Main(string[] args)
{
string code = "print(\"Hello world\")";
LuaState state = Lua.NewState();
if (!state.IsNull)
{
Lua.OpenLibs(state);
Lua.DoString(state, code);
Lua.Close(state);
}
}
}
}
Advanced Example
The advanced example creates a Lua module that can call C# methods and prints the output to the console. This is not the typical way of doing interop, but it illustrates the power and flexibility of LuaJIT. First create a file and call it example.lua and paste in the following code:
local test = require('test')
local result = test.addNumbers(10, 20)
test.writeLine('result: ' .. result)
Next create a new file and call it test.lua. Paste in the following code:
local ffi = require ('ffi')
local luanet = require('luanet')
--You can name this variable however you like
local csharp = {}
csharp.WriteLine = luanet.findMethod('WriteLine', 'void (__cdecl*)(char*)')
csharp.AddNumbers = luanet.findMethod('AddNumbers', 'int (__cdecl*)(int,int)')
local test = {}
function test.writeLine(message)
--If user passes in a number, converts it to a string
if type(message) == 'number' then
message = tostring(message)
end
--Interop does not allow to pass Lua strings directly so they need to be converted to a C-type
--Allocate enough memory for the string + null terminator
local c_message = ffi.new('char[?]', #message + 1)
--Copy the Lua string to the allocated memory
ffi.copy(c_message, message)
--Call the C# method
csharp.WriteLine(c_message)
end
function test.addNumbers(a, b)
local c_a = ffi.cast('int', a)
local c_b = ffi.cast('int', b)
local result = csharp.AddNumbers(c_a, c_b)
return tonumber(result)
end
return test
Finally create a file and call it Program.cs and add following code to it:
using System;
using LuaNET;
using LuaNET.Interop;
using LuaNET.Modules;
namespace LuaNETExample
{
class Program
{
static void Main(string[] args)
{
LuaNETModule luanetModule = new LuaNETModule();
TestModule testModule = new TestModule();
LuaState state = Lua.NewState();
if (!state.IsNull)
{
Lua.OpenLibs(state);
//LuaNetModule is used to find C# methods and TestModule requires it
//Loading order of modules is important in this case
luanetModule.Initialize(state);
testModule.Initialize(state);
//Note that this file path assumes that example.lua is in the same directory as the executable
Lua.DoFile(state, "example.lua");
Lua.Close(state);
}
}
}
public class TestModule : LuaModule
{
public override void Initialize(LuaState L)
{
//Register the marked methods before loading the module
RegisterExternalMethods();
//Note that this file path assumes that test.lua is in the same directory as the executable
LuaModuleLoader.RegisterFromFile(L, "test", "test.lua");
}
[LuaExternalMethod]
private static unsafe void WriteLine(byte* text)
{
string s = new string((sbyte*)text);
Console.WriteLine(s);
}
[LuaExternalMethod]
private static unsafe int AddNumbers(int a, int b)
{
return a + b;
}
}
}
More Examples
See Examples.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
-
.NETStandard 2.1
- No dependencies.
-
net7.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on JAJ.Packages.LuaNET:
Repository | Stars |
---|---|
OpenCoreMMO/OpenCoreMMO
Modern MMORPG server emulator written in C#
|