Skip to main content

A Lox implementation written in Python.

Project description

pylox

My first implementation of Lox, written in Python.

This implementation is actually a superset of the Lox programming language defined in the Crafting Interpreters book. Meaning, every valid lox program will run on this interpreter too, but programs that would throw an error in the book's implementation, might work in mine.

For example, this one supports single quotes:

$ lox
> print 'Single quotes!';
Single quotes!

Installation and usage

  • Install via pip:
pip install mypylox
  • Run it interactively:
$ lox
> print "Hi!";
Hi!
> var num = 2.5 + 2.5;
> print num;
5.0
  • Run a file:
$ cat myfile.lox
var name = "Tushar";
var age = "21";

print "My name is " + name + " and I'm " + age + " years old.";

$ lox myfile.lox
My name is Tushar and I'm 21 years old.

Progress

What has already been implemented:

  • Entire lexer implementation
  • Expression parsing
  • Syntax Errors
  • Expression execution
  • Print statements
  • Variable declaration, and global scope
  • Interactive REPL
  • Variable assignment
  • Proper runtime errors
  • Synchronization and reporting multiple parse errors
  • Local scope, enclosing scope, blocks and nesting
  • if-else statements
  • while loops
  • for loops
  • Logical and and or operators
  • Function declarations, calls, first class functions and callbacks
  • Return values
  • Closures
  • Compile time variable resolution and binding
  • Class declarations, objects, and properties
  • Class properties
  • Methods
  • this attribute
  • Constructors
  • Inheritance

Changes / Extra features

There's a small number of changes from the reference language:

  • Defining a variable as itself inside a block does not result in a parse error. Instead, it uses the value from outer scope to define itself in local scope. This lets us simplify the resolver code: We don't need a separate declare and define method anymore, and each scope is a set, not a dictionary.

  • You can access methods directly on a class, you don't need to necessarily create an object to do so. Doing this returns an "unbound method". The main reason to do this is for better DX, and to allow dir(C) to work. It is not yet decided if unbound methods are just not usable at all, or if some sort of binding mechanism will be implemented to allow for that. [TODO]

Here's the full set of extra features, and their progress:

  • Much better error messages
  • Allowing single quotes for strings
  • String escapes: \n, \t, \', \", \\ and \↵
  • New operators:
    • Modulo %
    • Integer division \
    • Power **
  • Augmented versions of all operators: +=, **=, etc.
  • New data types:
    • int: 42
    • list: [42, 56]
    • dictionary: {42: "Forty two"}
  • Indexing support: for lists, dictionaries and strings
  • Comparison operators work on strings
  • break and continue semantics in loops
  • Exceptions, try / except blocks and raise statements
  • Added builtin functions:
    • input
    • format (Python equivalent, for string interpolation)
    • min, max and abs
    • map, filter and reduce that take lists and return new lists
    • dir to print out an object's attributes
  • An import system
  • A standard library
    • random module
    • io module string and binary reads/writes to files
    • http library to make a web server and client

Examples of all of these will be available in the examples folder.

Ideas to tinker with

The following are ideas that I'm not 100% sure about, but would like to try. Some of these will not be compatible with the original lox language, so if I implement those, I'll do that in a separate branch.

  • No nil. Variables will always have to be initialized with a value, and functions will either never return anything, or return in every case. This will be checked at compile time.
  • Declaration scope vs. Block scope. The idea being, if we don't allow nil, block scope might cause an issue, but no nil + declaration scope might work.
  • Adding whitespace tokens to the lexer and AST, and adding a code formatting module into the standard library.
  • Built-in benchmarking library.

Testing / Development

Get the project:

git clone https://github.com/tusharsadhwani/pylox
cd pylox

Get the dev requirements:

pip install -r requirements-dev.txt

Run tests:

pytest

Type check the code:

mypy .

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

mypylox-1.2.0.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

mypylox-1.2.0-py3-none-any.whl (24.5 kB view details)

Uploaded Python 3

File details

Details for the file mypylox-1.2.0.tar.gz.

File metadata

  • Download URL: mypylox-1.2.0.tar.gz
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.7

File hashes

Hashes for mypylox-1.2.0.tar.gz
Algorithm Hash digest
SHA256 3e85f7680d199713a09bbb5cb56a996fe4c6b0bdd1004f761bb373d37b3c0c38
MD5 ba1b999d3a4e642e69f4b2d33beabdd2
BLAKE2b-256 3adf971e233ae5e4236a1c6ebcdc90a887141b8d52960862bafdae2dd1659acd

See more details on using hashes here.

File details

Details for the file mypylox-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: mypylox-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 24.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.7

File hashes

Hashes for mypylox-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6843825719cf106f2affd5f6eadc9090c87fb391437b186a6a21db2f8e5b6453
MD5 536623b5516c13f90d0e312cc30a10f1
BLAKE2b-256 c4da3f1acb90117cfe847c8b217428342bb85059e38012eaebef60544b24c1fe

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