npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

com.ellyality.xlua

v1.0.3

Published

Provide lua runtime environment

Downloads

185

Readme

license release PRs Welcome Build status

Lua programming solution for C#

xLua adds Lua scripting capability to Unity, .Net, Mono, and other C# environments. With xLua, Lua code and C# code can easily call each other.

xLua's superior features

xLua has many breakthroughs in function, performance, and ease of use. The most significant features are:

  • You can use C# implementations (methods, operators, properties, events, etc...) in Lua.
  • Outstanding GC optimization, customized struct, no C# gc alloc when passing the enumerated objects between C# and Lua;
  • Lightweight development with no needs to generate code in editor mode;

Installation

Unpack the ZIP package and you will see an Assets directory, which corresponds to the Unity project's Assets directory. Keep the directory structure in your Unity project.

If you want to install it to another directory, please see the FAQs.

Documents

Quick Start

A complete example requires only 3 lines of code:

Install xLua, create a MonoBehaviour drag scenario, add the following code to Start:

XLua.LuaEnv luaenv = new XLua.LuaEnv();
luaenv.DoString("CS.UnityEngine.Debug.Log('hello world')");
luaenv.Dispose();
  1. The DoString parameter is a string, and you can enter any allowable Lua code. In this example, Lua calls C#’s UnityEngine.Debug.Log to print a log.

  2. A LuaEnv instance corresponds to a Lua virtual machine. Due to overhead, it is recommended that the Lua virtual machine be globally unique.

It is simple that C# actively calls Lua. For example, the recommended method to call Lua's system function is:

  • Declare
[XLua.CSharpCallLua]
public delegate double LuaMax(double a, double b);
  • Bind
var max = luaenv.Global.GetInPath<LuaMax>("math.max");
  • Call
Debug.Log("max:" + max(32, 12));

It is recommended that you bind once and reuse it. If code is generated, no gc alloc is generated when calling max.

Hotfix

  • This has lower intrusiveness, and it can be used without any modification of the original code of the old project.
  • This has little impact on the runtime, which is almost the same as the original program which hotfix is not used.
  • If you have problems, you can also use Lua to patch. Then the Lua code logic is involved.

Here is the usage guide:

More Examples

  • 01_Helloworld: Quick Start Examples
  • 02_U3DScripting: This example shows how to use Mono to write MonoBehaviour.
  • 03_UIEvent: This example shows how to use Lua to write UI logic.
  • 04_LuaObjectOrented: This example shows the cooperation between Lua's object-oriented programming and C#.
  • 05_NoGc: This example shows how to avoid the value type GC.
  • 06_Coroutine: This example shows how Lua coroutines work with Unity coroutines.
  • 07_AsyncTest: This example shows how to use Lua coroutines to synchronize asynchronous logic.
  • 08_Hotfix: These are Hotfix examples (Please enable hotfix feature. See the Guide for details).
  • 09_GenericMethod: This is a generic function support demo.
  • 10_SignatureLoader: This example shows how to read the Lua script with a digital signature. See the Digital Signature document for details.
  • 11_RawObject: This example shows how to specify transferring a Lua number in the int after boxing when the C# parameter is an object.
  • 12_ReImplementInLua: This shows how to change complex value types to Lua implementations.

Technical support

QQ Group 1: 612705778 (may be full)

QQ Group 2: 703073338

QQ Group 3: 811246782

Check answers: If you encounter a problem, please read the FAQs first.