koehlma / jaspy

A Python byte code VM written entirely from scratch in JavaScript with some unique features.
582 stars 52 forks source link
experimental interpreter javascript python web

Jaspy

|pypi| |build| |coverage| |docs| |gitter|

Jaspy is a Python VM written entirely from scratch in JavaScript with some unique features. Jaspy supports multiple threads, comes with an integrated debugger which offers remote debugging and provides a flexible preprocessor based architecture. Speed is explicitly not a main goal of this project. Jaspy aims to illustrate how web programming on the client side could be done by exploring new ways.

Features

.. _BigInteger.js: https://github.com/peterolson/BigInteger.js .. _time: https://github.com/koehlma/jaspy/blob/master/modules/time.js .. _dom: https://github.com/koehlma/jaspy/blob/master/modules/dom.js

Quickstart

Jaspy comes with an integrated development server and interactive debugger!

First install the dependencies, if they are not installed already:

.. code:: sh

pip3 install --user -r requirements.txt
pip3 install --user ptpython pygments

Clone the repository and build the interpreter:

.. code:: sh

git clone --recursive https://github.com/koehlma/jaspy.git; cd jaspy
python3 build.py  # build the interpreter

Switch to the example directory and start the server in interactive mode:

.. code:: sh

cd example
PYTHONPATH=../ python3 -m jaspy.cli --interactive

Visit http://localhost:8080/hello.html in your browser and click run:

.. image:: https://raw.githubusercontent.com/koehlma/jaspy/master/example/debugger.gif :alt: Jaspy Screencast :align: center

Alternatives

There are already many other Python-to-JavaScript approaches out there:

Most of them are faster than Jaspy but none of them offers the unique features of Jaspy, which are the fully suspendable interpreter with threading support, the integrated debugger and the flexible, preprocessor based architecture.

Speed

Just to get an impression how slow Jaspy really is!

+-----------------------------------------------+------------------+ | | pystones/second | +===============================================+==================+ | Jaspy (enabled Debugger, enabled Threading) | 195 | +-----------------------------------------------+------------------+ | Jaspy (disabled Debugger, enabled Threading) | 199 | +-----------------------------------------------+------------------+ | Jaspy (disabled Debugger, disabled Threading) | 206 | +-----------------------------------------------+------------------+ | Brython | 4184 | +-----------------------------------------------+------------------+ | PyPy.js (cold) | 41425 | +-----------------------------------------------+------------------+ | PyPy.js (warm) | 847457 | +-----------------------------------------------+------------------+

However this is a somewhat unfair benchmark because no dom manipulation or anything else browser specific is going on. Surprisingly threading and debugging introduces nearly no overhead.

State

This project is still in an alpha state. The APIs are unstable, it is untested and not ready for productive use. Some of the features listed above are not yet implemented.

I started this project in my semester break and now, as the new semester started, I have much less spare time. Therefore it might take a while until I will be able to invest much more time into it. However I very welcome all sorts of contributions.

Contributions

If you like the ideas of Jaspy feel free to join, there are many things to do:

Do not hesitate to contribute or ask if there is anything unclear about the code or the process of contributing in general.

Structure

:libs: third-party dependencies :modules: bundled native JavaScript modules :src: JavaScript source files (need to be preprocessed) :jaspy: Python server, converter and remote debugger

Credits

Many thanks to the Brython <http://www.brython.info/> project for the inspiration for many parts of code of the builtin-classes. Many thanks also to the book “500 Lines or Less” which is a good starting point if you want to know how the interpreter works.

.. _“500 Lines or Less”: http://aosabook.org/en/500L/a-python-interpreter-written-in-python.html

.. |pypi| image:: https://img.shields.io/pypi/v/jaspy.svg?style=flat-square&label=latest%20version :target: https://pypi.python.org/pypi/jaspy

.. |build| image:: https://img.shields.io/travis/koehlma/jaspy/master.svg?style=flat-square&label=build :target: https://travis-ci.org/koehlma/jaspy

.. |docs| image:: https://readthedocs.org/projects/jaspy/badge/?version=latest&style=flat-square :target: https://jaspy.readthedocs.org/en/latest/

.. |coverage| image:: https://img.shields.io/coveralls/koehlma/jaspy/master.svg?style=flat-square :target: https://coveralls.io/github/koehlma/jaspy?branch=master

.. |gitter| image:: https://img.shields.io/badge/gitter-join%20chat-1dce73.svg?style=flat-square :target: https://gitter.im/koehlma/jaspy