Skip to main content

Toolkit for compiling and executing the Linden Scripting Language as Python

Project description

Lummao

Lummao is a toolkit for compiling and executing the Linden Scripting Language as Python. It aims to ease testing of LSL code by leveraging Python's existing ecosystem for debugging and testing. Think of it as the less opinionated, stupider cousin of LSLForge's unit testing framework.

The runtime is largely handled by the excellent implementation of LSL's basic operations and library functions from Sei Lisa's LSL-PyOptimizer. See vendor/lslopt for Lummao's vendored copy of LSL-Pyoptimizer.

To see an example input script and its Python output, see the test_resources directory.

Setup

pip install --upgrade pip
pip install lummao

From source

How

For a real-world example, see https://github.com/SaladDais/SLGraphPather's tests and test coverage reporting.

Along with the python API, a helper lummao script is provided that takes in an LSL file and outputs a python file. It can be invoked like lummao input.lsl output.py.

Why

If you've ever written a sufficiently complicated system in LSL, you know how annoying it is to debug your scripts or be sure if they're even correct. Clearly the sanest way to bring sanity to your workflow is to convert your LSL scripts to Python, so you can mock LSL library functions and use Python debuggers. Hence the name "Lummao".

TODO

  • Symbol shadowing behavior is not correct. Python has very different shadowing rules.
  • Provide mock helpers for:
    • inter-script communication
    • HTTP
    • auto-stubs for all functions
    • state-aware event queueing

License

GPLv3

Licensing Clarifications

The output of the compiler necessarily links against the GPL-licensed runtime code from LSL-PyOptimizer for functionality, and LSL-PyOptimizer does not provide a library exception in its license. You should assume that any LSL converted to Python by the compiler and any testcases you write exercising them must also be distributable under the GPL.

In short: If or when you distribute your testcases, you must also allow distribution of their direct dependencies (your LSL scripts) under the terms of the GPL. This does not necessarily change the license of your LSL scripts themselves, or require consumers of your scripts to license their own scripts under the GPL. It is perfectly possible to have an otherwise MIT-licensed or proprietary library with a GPL-licensed test suite. No distribution of testcases == no requirement to distribute under the GPL.

Suggested reading to understand your rights and obligations under the GPL when using a GPL-licensed test suite:

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

lummao-0.1.4.post3.tar.gz (97.9 kB view details)

Uploaded Source

Built Distributions

lummao-0.1.4.post3-cp38-abi3-win_amd64.whl (158.2 kB view details)

Uploaded CPython 3.8+ Windows x86-64

lummao-0.1.4.post3-cp38-abi3-manylinux_2_24_x86_64.whl (2.2 MB view details)

Uploaded CPython 3.8+ manylinux: glibc 2.24+ x86-64

lummao-0.1.4.post3-cp38-abi3-macosx_10_15_x86_64.whl (194.4 kB view details)

Uploaded CPython 3.8+ macOS 10.15+ x86-64

File details

Details for the file lummao-0.1.4.post3.tar.gz.

File metadata

  • Download URL: lummao-0.1.4.post3.tar.gz
  • Upload date:
  • Size: 97.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for lummao-0.1.4.post3.tar.gz
Algorithm Hash digest
SHA256 fdf63985e094b67f0a4f0f015e72dd8f7482d1c3073dcab41801d14d8909b238
MD5 863d27bbc61cb25978946b8e46684559
BLAKE2b-256 1225de4ecb713f18a8d6d5263b5438582fe9cadc1719217c8003569c91847e4a

See more details on using hashes here.

File details

Details for the file lummao-0.1.4.post3-cp38-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for lummao-0.1.4.post3-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 83b3fa432329c1b8c13dd82414f7320c280b5255a7210ce5967e33f5487cfbb1
MD5 a2e9e5cbfbc525ea8bd040710321f454
BLAKE2b-256 a01ef67d040aba063a9f65b4a9652d5da756b9ce283b14cda1480a09363ccd69

See more details on using hashes here.

File details

Details for the file lummao-0.1.4.post3-cp38-abi3-manylinux_2_24_x86_64.whl.

File metadata

File hashes

Hashes for lummao-0.1.4.post3-cp38-abi3-manylinux_2_24_x86_64.whl
Algorithm Hash digest
SHA256 77dcdc61e679eb3cd68b9fa1df37b5803bc8e996fa9569f5acc7d98fefa6cd31
MD5 a6a03638e4fa0942e281f592b037c461
BLAKE2b-256 904682341fd646bcf9ec9d741e903e7dc30b3230dfebf890aff8390541fc7f73

See more details on using hashes here.

File details

Details for the file lummao-0.1.4.post3-cp38-abi3-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for lummao-0.1.4.post3-cp38-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 5bb3fab4b962a8f15b0a00d19185824d9036085056f2a58fb688d4b15615a746
MD5 5913d15d0794e6d13ad551d01448834e
BLAKE2b-256 83d33c663cc6cfd213e7af61087186bc3776c0677eae6028592abd16f1946ea2

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