Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rybla/imp-interpreter
This is a small Haskell implementation of the IMP language, as specified in the K Framework tutorial here.
https://github.com/rybla/imp-interpreter
Last synced: 4 days ago
JSON representation
This is a small Haskell implementation of the IMP language, as specified in the K Framework tutorial here.
- Host: GitHub
- URL: https://github.com/rybla/imp-interpreter
- Owner: rybla
- License: bsd-3-clause
- Created: 2020-12-11T22:56:45.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2020-12-11T23:05:51.000Z (about 4 years ago)
- Last Synced: 2024-11-07T11:13:46.726Z (about 2 months ago)
- Language: Haskell
- Homepage:
- Size: 11.7 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog.md
- License: LICENSE
Awesome Lists containing this project
README
# IMP-Interpreter
This is a small Haskell implementation of the IMP language, as specified in the [K Framework](https://kframework.org) tutorial here: [imp.md](https://github.com/kframework/k/blob/master/k-distribution/tutorial/1_k/2_imp/lesson_5/imp.md).
This was written as a programming exercise for applying to an internship at [Runtime Verification](https://www.runtimeverification.com),## Building
This is a [Haskell stack](https://docs.haskellstack.org/en/stable/README/) project, which should easily build via
```sh
stack build
```There may be some minor annoyances with managing the lens library dependency, which I had to add in the `extra-deps` of the `stack.yaml`.
Troubleshooting:
- make sure to have the [lens](http://hackage.haskell.org/package/lens) library installed with stack (e.g. `stack install lens`)
- try building again
- if this doesn't work, try commenting out `extra-deps` in `stack.yaml` and then building## Running
In `src/app/Main.hs`, there is a `program` variable which you may modify to encode any IMP program you like. There is currently no parser yet written for this implementation, but there are many convenient abbreviations (viz `src/IMP/Grammar.hs`).
Run `src/app/Main.hs` via```sh
stack run
```The output will look something like
```
[IMP-Interpreter]
[program]
int n, sum ; n = 100 ; sum = 0 ; while (! n <= 0) { sum = sum + n ; n = n + -1 ; }
[output]
Success (fromList [(n,0),(sum,5050)])
```where the `[program]` section prints the `program` variable in `src/app/Main.hs`, and the `[output]` section prints the resulting state after interpreting the program.
## Testing
In `src/test/Spec.hs`, there is a test suite of a few programs and their expected outputs (inspired by the examples given [here](https://github.com/kframework/k/tree/master/k-distribution/tutorial/1_k/2_imp/lesson_5/tests)).
Run the test suite via```sh
stack test
```If all the tests are successful, you'll get an output that looks something like:
```
✓ sum
✓ collatz
✓ primes
```If there are errors (i.e. differences between the expected output and the actual output) then you'll get an error message like:
```
✓ sum
✗ collatz
[!] m: expected 2 but found 3
✓ primes
```where `m` is name of the variable in `collatze` that after interpreting `collatze` was expected to have value `2` but actually had value `3`.
## Organization
This package contains one module, `IMP`, with two submodules:
- `IMP.Grammar`: datatypes for the grammar of the IMP language, along with convenient abbreviations and smart constructors
- `IMP.Semantics`: implementation of interpretation for the IMP language, based around the transformed monad `Interpretation` that keeps track of the interpretation state and allows for failure.