Skip to main content

cffi binding of lua for python

Project description

build coverage version license

A modern two-way bridge between Python and Lua.

Major Features

For Python Users

  • Integrate Lua into Python using CFFI as backend, which runs fast on both CPython and PyPy.

  • Run multiple Lua runtimes in one Python process.

  • Link to multiple lua libraries installed in system and use their luarocks.

  • Zero-copy data sharing between Python and Lua.

  • Seamless operations on Lua objects.

  • Hackable and extendable; customizable interacting behaviors.

  • Parallel numerical calculation using Lua to break the limit of Python’s GIL.

For Lua Users

  • Enrich Lua’s abilities by using Python’s modules.

  • Link to CPython and PyPy.

  • Seamless operations on Python objects.

Above all, ffilupa has plenty of fun!

Why ffilupa

Compare to lupa

  • lupa uses Cython as it’s backend, which is less friendly to PyPy and not extendable.

  • lupa doesn’t support Lua as the host language, which means you can’t use it in a Lua program.

  • lupa doesn’t support seamless operations on Lua objects.

  • lupa is not under actively development.

  • lupa inspired ffilupa a lot.

Compare to LunaticPython

  • Well, LunaticPython is too old and out of development for a long time.

  • LunaticPython doesn’t support multiple Lua runtimes.

  • LunaticPython leaks new features.

Installation

Before installing ffilupa, please check whether you have installed the development library of lua. On Ubuntu, you can install liblua5.3-dev or liblua5.2-dev:

$ sudo apt install [liblua5.3-dev|liblua5.2-dev]

On Mac OS X, you can use Homebrew:

$ brew install lua pkg-config

During installation, ffilupa will automatically find lua libraries through pkg-config.

Make sure you have installed Python 3.5+ in your system, including it’s development files and the suitable C compiler. On Ubuntu:

$ sudo apt install python3-dev

On Mac OS X:

$ brew install python

You’d better install the dependencies of ffilupa:

$ pip install cffi semantic_version

It’s optional; ffilupa will install them if you haven’t installed before.

Install stable version

For Python Users

$ pip install ffilupa

Install development version from Git branch

For Python Users

$ pip install git+https://github.com/TitanSnow/ffilupa.git

For Lua Users

Make sure you have installed luarocks.

$ git clone https://github.com/TitanSnow/ffilupa.git
$ cd ffilupa
$ luarocks make

FAQ about installation

How to deal with the exception ‘Required lua lib not found’?

Please check the installation of Lua. ffilupa currently only supports Lua 5.2 and 5.3. Then reinstall ffilupa in order to find the recently installed Lua libraries.

Does ffilupa support Windows?

ffilupa can support Windows, but not now. It might support Windows in next minor release.

Usage

For Python Users

A Brief Look

>>> import ffilupa
>>> lua = ffilupa.LuaRuntime()
>>> lua_func = lua.eval('''
...     function(a, b) -- a plus b
...         return a + b
...     end
... ''')
>>> lua_func(22, 33)
55

Access Globals of Lua

>>> def greeting(name='World'): # greeting someone
...     print('Hello, {}!'.format(name))
>>> lua._G.greeting = greeting
>>> lua.execute('greeting()')
Hello, World!
>>> lua.execute('greeting("John")')
Hello, John!

Zero-copy Data Sharing

>>> poem = {
...     'the': 'quick',
...     'brown': 'fox',
...     'jumps': 'over',
... }
>>> lua_func = lua.eval('''
...     function(poem) -- finish the poem
...         poem['lazy'] = 'doges'
...     end
... ''')
>>> lua_func(poem)
>>> poem['lazy']
'doges'

Deal with Lua Table

>>> table = lua.table_from(poem)
>>> lua_func = lua.eval('''
...     function(poem) -- shuffle the poem
...         local new_poem = {}
...         for k, v in pairs(poem) do
...             new_poem[v] = k
...         end
...         return new_poem
...     end
... ''')
>>> new_poem = lua_func(table)
>>> for k in sorted(new_poem):
...     print(k, new_poem[k], end=' ')
doges lazy fox brown over jumps quick the

For Lua Users

A Brief Look

ffilupa = require 'ffilupa'
Fraction = ffilupa.import_module('fractions').Fraction
a = Fraction(1, 2)
b = Fraction(1, 3)
c = a + b    -- c == 5/6

Extend Lua’s Abilities

Path = ffilupa.import_module('pathlib').Path
p = Path('.')
p = p / 'ffilupa'
for _, filename in pairs(p:iterdir()) do
    print(filename)    -- print all filename in ./ffilupa
end

Acknowledgements

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ffilupa-3.0.1.zip (407.0 kB view details)

Uploaded Source

File details

Details for the file ffilupa-3.0.1.zip.

File metadata

  • Download URL: ffilupa-3.0.1.zip
  • Upload date:
  • Size: 407.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/40.5.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.5

File hashes

Hashes for ffilupa-3.0.1.zip
Algorithm Hash digest
SHA256 2f063a69b91a2d3965558738908ff36f62cf04a573132ce8437a8f0b2fc7fb94
MD5 902faf73e5390860e3335581b7731ede
BLAKE2b-256 7fa75c55bfbb6cbe18faa10fb2f8485d51f41546263f8b572a884eeefcde52ff

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page