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)

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.2.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.2-py3-none-any.whl (20.7 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pythonalloyclient-0.1.2.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.2.tar.gz
Algorithm Hash digest
SHA256 6996567a3ce3222716afac162aa9fda9a1b70dd4e9143be214d479a155eeb42e
MD5 d1828a903922247cc71ab4b19cac3ca4
BLAKE2b-256 3b1b8af313f8838162810d6be69d466f5de5522ec8cf394e5eae267699e537f5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pythonalloyclient-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5775dc5778eed96812c96a742d90d8e5b9d3c283c13dabe44bbcd64dc6494978
MD5 2a9cc39c509294313d11ac82773a31bd
BLAKE2b-256 dd0683d6b86b6e29a90ed3f0a470d24d17cafcaaa9b320b5ee39ad1b28926c69

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