Skip to content

rslabbert/PyLisp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PyLisp

Dependencies

  • Python 3

Usage

OSX/Linux

Execute the bin/pylisp.sh file, or run python3 src/main.py.

Windows

Execute the bin/pylisp.bat file, or run src/main.py through IDLE.

If pylisp is run without any arguments it starts an interpreter session, if run with an argument it attempts to open it as a file.

Inside the interpreter pressing tab will attempt to complete any variable names or core syntactic keywords, and entering a newline while there are more opening parenthesis than closing parenthesis will result in an indent newline that accepts input, allowing multi-line expressions.

Extending the standard library

The standard library is contained in the PyLib directory. Each directory within the pylib directory is a module which can be imported. To create a new module, make a directory in the PyLib directory and populate it with pylisp(.pyl) or python(.py) files. Any definitions in the pylisp file automatically get exported to the importer's environment. Python files need to define a dictionary called export which maps environment names to values/functions.

License

Copyright (C) 2021 Ruben Slabbert

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.

About

Scheme implemented in python

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages