Isabelle REPL client
Project description
Isabelle REPL
Unofficial support for Isabelle's Read-Eval-Print-Loop.
Features
- Python Client, easy for Machine Learning.
- Full support for all Isabelle commands
- Tracing the proof state and the output panel for each step of evaluation.
- Plugin: collecting data from Isabelle's internal representations by plugins written in Isabelle/ML (example).
- Socket based remote communication
- Socket based Concurrency
- State rollback (example)
- Parsing terms & Retrival of lemmas (example)
Installation
We only support Isabelle2023 and Isabelle2024.
Ensuring <ISABELLE-BASE-DIRECTORY>/bin
is in your $PATH
environment
git clone https://github.com/xqyww123/Isa-REPL.git
cd Isa-REPL
git checkout $(isabelle version) # Error can raise if you are using an unsupported version of Isabelle
isabelle components -u .
pip install IsaREPL
Start up the REPL server
# merely an example:
./repl_server.sh 127.0.0.1:6666 HOL ./tmp
Run ./repl_server.sh
to see the full explanation of the arguments and options.
Example Clients
Every interface of our client is will documented (it is highly recommended to read our source). Some examples are given in the example folder.
# Run an example
./examples/example_eval.py 127.0.0.1:6666
To evaluate a whole theory file
./examples/eval_file.py 127.0.0.1:6666 $(isabelle getenv -b ISABELLE_HOME)/src/HOL/List.thy
Notes
Documents
All documents are given as docstrings attaching to Python client interfaces, see the source.
Concurrency
This REPL supports concurrent evaluation of multiple files. However, to ensure proper error tracking and result tracing, it disables Isabelle's concurrency between commands within a single theory file. While Isabelle typically executes by
commands asynchronously (continuing to the next command before completion), this REPL enforces synchronous evaluation. Each command must complete before the next begins, allowing for accurate capture and reporting of any failures.
Sledgehammer (via our auto_sledgehamemr
wrapper, see example) is still concurrent.
Communication Protocol
It is possible to implement a client in other languages. However, the document for the communication protocol is not provided and I refer you to read our source code, as it should be simple enough.
Contribution
Feel free to open any GitHub issue if you have any feature requests.
I am not a professional python developer, so contribution is highly welcome to enrich the client's features.
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
Built Distribution
File details
Details for the file isarepl-0.4.0.tar.gz
.
File metadata
- Download URL: isarepl-0.4.0.tar.gz
- Upload date:
- Size: 18.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 26e8ec9a7a625ea0829dc276bca8c1ca525297d64eb5bd62448527f65aeba9f4 |
|
MD5 | cee722b09edbdfd325da6bfa27b7fd52 |
|
BLAKE2b-256 | 756678f755040e6b0c7828616c1c8ad89c5af2911ae3cab6531ff64388ed0921 |
File details
Details for the file IsaREPL-0.4.0-py3-none-any.whl
.
File metadata
- Download URL: IsaREPL-0.4.0-py3-none-any.whl
- Upload date:
- Size: 24.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 96cdc1e5935d04f7792d7b55b921db9b304a1c2492da78763ddcd6d48e40e050 |
|
MD5 | 7612bf9ad50cfbfb4fdd03648d0cf7f1 |
|
BLAKE2b-256 | ce40f6f814eae916ab5a81525e9badaaac456662c9c704fb75ea6af4f72ac514 |