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                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="JAJ.Packages.LuaNET" Version="1.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add JAJ.Packages.LuaNET --version 1.1.0                
#r "nuget: JAJ.Packages.LuaNET, 1.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .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#
Version Downloads Last updated
1.1.0 181 1/14/2025
1.0.0 828 12/16/2023