Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/luvit/luvit

Lua + libUV + jIT = pure awesomesauce
https://github.com/luvit/luvit

hacktoberfest libuv lua luajit luvit

Last synced: about 9 hours ago
JSON representation

Lua + libUV + jIT = pure awesomesauce

Awesome Lists containing this project

README

        

# Luvit 2.0 - Node.JS for the Lua Inventor

[![Linux Build Status](https://github.com/luvit/luvit/actions/workflows/ci.yml/badge.svg)](https://github.com/luvit/luvit/actions/workflows/ci.yml)
[![Windows Build status](https://ci.appveyor.com/api/projects/status/72ccr146fm51k7up/branch/master?svg=true)](https://ci.appveyor.com/project/racker-buildbot/luvit/branch/master)
[![Coverage Status](https://coveralls.io/repos/github/luvit/luvit/badge.svg?branch=master)](https://coveralls.io/github/luvit/luvit?branch=master)

Welcome to the source code for Luvit 2.0. This repo contains the luvit/luvit metapackage and all luvit/* packages as published to [lit][].

This collection of packages and modules implements a node.js style API for the [luvi][]/[lit][] runtime. It can be used as both a library or a standalone executable.

See the main project webpage for more details.

## Need Help?

Ask questions here through issues, on [Discord](https://discord.gg/luvit) or the [mailing list](https://groups.google.com/forum/#!forum/luvit).

## Binary Modules

Luvit supports FFI and Lua based binary modules. There is a wiki entry
explaining how to manage and include a binary module within a bundled
application. [Publishing Compiled Code][]

## Hacking on Luvit Core

First you need to clone and build luvit, this is easy and works cross-platform thanks to `Makefile` and `make.bat`.

```sh
git clone https://github.com/luvit/luvit.git
cd luvit
make
```

If you want to test luvit without constantly building, use `luvi`.

```sh
luvi .
```

Always make sure to run `make test` before submitting a PR.

## Notes to Maintainers

- Use `luvi /path/to/luvit` to test changes without rebuilding the binary.
- To run the test suite, run `make test` to build a luvit and use that.
- If you want to test a custom built luvi, run `luvi . -- tests/run.lua`
- If you want to run a specific test file with a custom built luvi, run `luvi . -- tests/test-.lua` (e.g. `luvi . -- tests/test-http.lua`)
- There is a wiki page on making new luvit releases at .

The packages in deps live primarily in this repo, but some are duplicated in
luvit/lit to ease `lit` bootstrapping. Updates can be pushed from either repo
to lit, just make sure to keep them in sync. One way to do this is to `rm -rf
deps && lit install`. This will install the latest version of all the
packages from lit. Check the diff carefully to make sure you're not undoing
any work. There might have been unpublished changes locally in luvit that
aren't in the lit central database yet.

[Publishing Compiled Code]: https://github.com/luvit/lit/wiki/Publishing-Compiled-Code
[lit]: https://github.com/luvit/lit/
[luvi]: https://github.com/luvit/luvi/