Skip to main content

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

isarepl-0.4.0.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

IsaREPL-0.4.0-py3-none-any.whl (24.6 kB view details)

Uploaded Python 3

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

Hashes for isarepl-0.4.0.tar.gz
Algorithm Hash digest
SHA256 26e8ec9a7a625ea0829dc276bca8c1ca525297d64eb5bd62448527f65aeba9f4
MD5 cee722b09edbdfd325da6bfa27b7fd52
BLAKE2b-256 756678f755040e6b0c7828616c1c8ad89c5af2911ae3cab6531ff64388ed0921

See more details on using hashes here.

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

Hashes for IsaREPL-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 96cdc1e5935d04f7792d7b55b921db9b304a1c2492da78763ddcd6d48e40e050
MD5 7612bf9ad50cfbfb4fdd03648d0cf7f1
BLAKE2b-256 ce40f6f814eae916ab5a81525e9badaaac456662c9c704fb75ea6af4f72ac514

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