Skip to main content

Python Client for the Alloy Language Server

Project description

PythonAlloyClient

This is a Python client library for interacting with the Alloy Language Server. Currently, it supports checking the syntax of a given Alloy code snippet with the Alloy language server, but more features are planned for the future to make use of the full capabilities of the Alloy language server.

Installation

You can install the package from PyPI using pip.

pip install PythonAlloyClient

Or install directly from the source.

git clone https://github.com/mrigankpawagi/PythonAlloyClient.git
cd PythonAlloyClient
pip install -e .

Requirements

  • Python 3.6+
  • Java Virtual Machine (JVM) 17 or later for running the Alloy language server

Usage

Basic Usage

from PythonAlloyClient import AlloyServer

server = AlloyServer() # Initialize the server
server.start() # Start the server

syntax_status = server.check_syntax("sig Person {}")
server.stop() # Stop the server

print(syntax_status.success) # True

Once the server is started, you can use the check_syntax method to check the syntax of an Alloy code snippet which is supplied as a string. The method returns a SyntaxStatus object with the following attributes.

  • success (bool): True if the syntax check passed, False otherwise
  • error_type (str): Type of error (always Syntax error for now), None if success is True
  • line_number (int): Line number where the error occurred, None if success is True
  • column_number (int): Column number where the error occurred, None if success is True
  • error_message (str): Error message, None if success is True
  • full_error_message (str): Full error message from Alloy, None if success is True

If a syntax check failed due to an unexpected error, the full_error_message attribute will contain the error message, success will be False, and all other attributes will be None.

Another Example

alloy_code = """
sig X {}
sig A extends X {}
sig A extends X {}
"""
syntax_check = server.check_syntax(alloy_code)

print(syntax_check.success) # False
print(syntax_check.error_type) # Syntax error
print(syntax_check.line_number) # 4
print(syntax_check.column_number) # 5
print(syntax_check.error_message) # "A" is already the name of a sig/parameter in this module.

Custom Alloy Build

By default, PythonAlloyClient uses the JAR file at PythonAlloyClient/resources/org.alloytools.alloy.dist.jar to run the Alloy language server. If you want to use a custom build of the Alloy language server, you can specify the path to the JAR file when initializing the AlloyServer object.

from PythonAlloyClient import AlloyServer

server = AlloyServer(alloy_jar_path="path/to/alloy.jar")

Other Options

PythonAlloyClient can print logs about the server's status and the requests being made to the server by setting the quiet attribute to False. This is set to True by default.

from PythonAlloyClient import AlloyServer

server = AlloyServer(quiet=False)

You can also set the try_get_diagnostics parameter while checking syntax in order to catch any error-level diagnostics sent by the server. This can be useful for cases where the syntax is correct but there are compilation errors like type-errors. It is set to False by default, and has a very minor time overhead. The error returned in this case will have error_type as Diagnostics error.

from PythonAlloyClient import AlloyServer

server = AlloyServer()
server.start()
syntax_check = server.check_syntax(alloy_code, try_get_diagnostics=True)

Development

Setting Up the Development Environment

This project uses pytest for testing. This is listed in requirements.txt and can be installed using pip.

Running Tests

python -m pytest tests/

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit Pull Requests or issues.

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

pythonalloyclient-0.1.3.tar.gz (20.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pythonalloyclient-0.1.3-py3-none-any.whl (20.7 MB view details)

Uploaded Python 3

File details

Details for the file pythonalloyclient-0.1.3.tar.gz.

File metadata

  • Download URL: pythonalloyclient-0.1.3.tar.gz
  • Upload date:
  • Size: 20.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pythonalloyclient-0.1.3.tar.gz
Algorithm Hash digest
SHA256 3ed2eb0af96dcb2be9de7a822e1d06a4bdab986b502cfd9119d453c407dc1a91
MD5 dc84d96339eedf9debc6ea91424a39a7
BLAKE2b-256 f6255577b8d9da9826a03321fcfcbc22466b9d9d48d1688a407160786e812f58

See more details on using hashes here.

File details

Details for the file pythonalloyclient-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for pythonalloyclient-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ab31ad49a837a10ab4a3fdffc6074a2f6ae47410f27e7cf705fc1d222ed27e20
MD5 a90fceed82eab88ee0130d26c70b1ba9
BLAKE2b-256 4b96ab21c9e4195458b66b0c8bb2ad67726f9073f3eb4a0921d3aec21346e7bf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page