Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andreal2000/whitespaceevaluator
Whitespace Programming Language evaluator written in Scala using the Scala Parser Combinators
https://github.com/andreal2000/whitespaceevaluator
interpreter parsercombinator scala scala3 whitespace-language
Last synced: 13 days ago
JSON representation
Whitespace Programming Language evaluator written in Scala using the Scala Parser Combinators
- Host: GitHub
- URL: https://github.com/andreal2000/whitespaceevaluator
- Owner: Andreal2000
- License: mit
- Created: 2024-01-25T21:45:38.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-02-06T17:53:23.000Z (12 months ago)
- Last Synced: 2024-11-09T09:48:38.510Z (2 months ago)
- Topics: interpreter, parsercombinator, scala, scala3, whitespace-language
- Language: Witcher Script
- Homepage: https://gist.github.com/Andreal2000/8d876ba97b70240b50b68e5993119584
- Size: 18.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Whitespace Evaluator
![GitHub Actions Workflow Status](https://github.com/Andreal2000/WhitespaceEvaluator/actions/workflows/scala.yml/badge.svg)
Whitespace Evaluator is an interpreter for the [Whitespace programming language](https://esolangs.org/wiki/Whitespace) written in [Scala 3](https://scala-lang.org/). The interpreter utilizes [scala parser combinators](https://github.com/scala/scala-parser-combinators) for parsing Whitespace code and is built using [sbt](https://www.scala-sbt.org/index.html) (Simple Build Tool).
## What is Whitespace?
Whitespace is an esoteric programming language where the only meaningful characters are space, tab, and newline. All other characters are ignored, making the code visually resemble whitespace. Programs in Whitespace are defined by sequences of these whitespace characters, and they are executed based on the lengths of these sequences.
## Features
- **Whitespace Interpreter**: Parses and interprets Whitespace code.
- **Parser Combinators**: Utilizes Scala 3's parser combinators for stability and easy to understand code.
- **SBT Build:** Uses SBT as the building tool for the project.
- **CI/CD Testing:** CI/CD pipeline ensures continuous testing of the interpreter.## Requirements
Ensure you have the following prerequisites installed before using the Whitespace Evaluator:
- [Scala 3](https://www.scala-lang.org/download/)
- [SBT (Scala Build Tool)](https://www.scala-sbt.org/download/)## Installation
1. Clone this repository to your local machine:
```bash
git clone https://github.com/Andreal2000/WhitespaceEvaluator.git
```2. Navigate to the project directory:
```bash
cd WhitespaceEvaluator
```3. Build the project using SBT:
```bash
sbt compile
```## Usage
To execute a whitespace program, provide the program as input to the interpreter:
```bash
sbt "run path/to/your/whitespace-program.ws"
```To execute multiple whitespace programs in succession, provide the paths to the programs as input to the interpreter:
```bash
sbt "run path/to/first/whitespace-program.ws path/to/second/whitespace-program.ws ... path/to/nth/whitespace-program.ws"
```This command will execute each whitespace program in the specified order. Adjust the file paths accordingly to include all the whitespace programs you want to run.
## Testing
This project includes unit tests to ensure the correctness of the interpreter. To run the tests, use the following command:
```bash
sbt test
```The CI/CD pipeline also automatically runs these tests to ensure continuous integration.