Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matteodelseppia/haruko
A toy Clojure-inspired programming language written in Scala and compiled for the JVM
https://github.com/matteodelseppia/haruko
asm ast clojure compiler java jvm lisp scala
Last synced: about 2 months ago
JSON representation
A toy Clojure-inspired programming language written in Scala and compiled for the JVM
- Host: GitHub
- URL: https://github.com/matteodelseppia/haruko
- Owner: matteodelseppia
- Created: 2024-03-11T17:48:05.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-05-31T09:32:19.000Z (8 months ago)
- Last Synced: 2024-10-12T10:21:07.192Z (3 months ago)
- Topics: asm, ast, clojure, compiler, java, jvm, lisp, scala
- Language: Scala
- Homepage:
- Size: 181 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Haruko Language
Haruko is a toy programming language I've implemented to learn more about the JVM and Java Bytecode. It features a Clojure-inspired syntax and compiles byetecode for the JVM. This repository contains the Haruko compiler and one example program containing functions like `pow` or `merge-sort`.
## Requirements
- **Scala 2.13**: Make sure Scala 2.13 is installed on your system. You can download it from the [official Scala website](https://www.scala-lang.org/download/2.13.10.html).
- **Java 21**: Ensure that Java 21 or higher is installed. You can download it from the [official Oracle website](https://www.oracle.com/java/technologies/javase/jdk21-archive-downloads.html).## Running the Compiler
To compile and run a `.ha` file, use the following command:
```sh
java -jar haruko.jar file.ha
```## Example Program
Here is an example file `tests.ha` that demonstrates various functions in Haruko:
```clojure
(defn gcd
(a b)
(if (lt a b)
(gcd b a)
(do
(let rem (mod a b))
(if (neq rem 0)
(gcd b rem)
b ))))(defn fib
(n)
(if (lt n 2)
n
(add (fib (dec n)) (fib (sub n 2)))))(defn factorial
(n)
(if (eq n 0)
1
(mul n (factorial (dec n)))))(defn power
(base exponent)
(if (eq exponent 0)
1
(mul base (power base (dec exponent)))))(defn sum-of-squares
(n)
(if (eq n 0)
0
(add (power n 2) (sum-of-squares (sub n 1)))))(defn say-hello
()
(prln "Welcome to haruko-lang!"))(defn return-1
()
1)(defn test-compose
()
(-> (return-1)
(inc)
(dec)
(power 3)
(inc)
(pow 0)
(add 5)
(sum-of-squares)
(cat " = 91")
(prln)))(defn test-nested
()
(do
(let x 2)
(let y 3)
(if (gt x y)
(do
(let z 4)
(let w 5)
(add z w))
(do
(let z 5)
(let w 6)
(pow z w)))))(defn return-123-list
()
(list$ 1 2 3 4 5 6))(defn return-1357-list
()
(list$ 1 3 5 7 9 11))(defn merge
(lst1 lst2 result)
(do
(if (empty lst1)
(app result lst2)
(if (empty lst2)
(app result lst1)
(do
(let head1 (head lst1))
(let head2 (head lst2))
(if (lt head1 head2)
(merge (tail lst1) lst2 (app result head1))
(merge lst1 (tail lst2) (app result head2))))))))(defn middle
(lst)
(-> lst (len) (div 2)))(defn merge-sort
(lst)
(if (or (empty lst) (eq 1 (len lst)))
lst
(do
(let half-index (middle lst))
(let left (slice lst 0 half-index))
(let right (slice lst half-index (len lst)))
(let res-left (merge-sort left))
(let res-right (merge-sort right))
(merge res-left res-right (list$)))))(say-hello)
(prln (cat "GCD of 147, 105: " (gcd 147 105)))
(prln (cat "10th Fibonacci: " (fib 10)))
(prln (cat "Factorial of 5: " (factorial 5)))
(prln (cat "2^5: " (power 2 5)))
(prln (cat "Sum of squares up to 5: " (sum-of-squares 5)))
(prln (cat "PI^3: " (power 3.1415926535 3)))
(test-compose)
(prln$ "should print 15625:" (-> (test-nested)))
(def lst (list$ 43 1 34 3 23 4 24 5))
(prln$ "List before merge sort: " lst)
(prln$ "List after merge sort: " (merge-sort lst))
```To execute this example, save it as `tests.ha` and run:
```sh
java -jar haruko.jar tests.ha
```