Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fdero/verse
Compiler and Interpreter of the Verse programming language
https://github.com/fdero/verse
compiler compiler-design interpreter language programming-language programming-languages
Last synced: about 2 months ago
JSON representation
Compiler and Interpreter of the Verse programming language
- Host: GitHub
- URL: https://github.com/fdero/verse
- Owner: fDero
- License: mit
- Created: 2022-12-24T12:26:01.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2024-02-18T22:13:08.000Z (11 months ago)
- Last Synced: 2024-02-18T23:23:20.617Z (11 months ago)
- Topics: compiler, compiler-design, interpreter, language, programming-language, programming-languages
- Language: C++
- Homepage:
- Size: 99.6 KB
- Stars: 12
- Watchers: 1
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![license: MIT](https://img.shields.io/badge/license-MIT-blue)
![version: pre-release](https://img.shields.io/badge/version-pre--release-red)# Verse
Verse is an interpreter for the Verse programming language. In the future, the goal is to evolve this project into an all-in-one bundle made of an interpreter, a compiler, and a debugger.
Verse is designed to be compiled directly to machine code, and offers all the features a low level language would, while still being able to be interpreted like languages like Python or Ruby (enhancing portability, and reducing wasted time by removing the need to perform a full compilation of your code-base just to run unit-tests).### Installation (Building from source)
In order to install verse, you have to build it from source. By default, the build process tries to use `clang++`, but you can change that
to make it use `g++` instead if you so desire. Either way `c++20` or higher is required.
```bash
$$ git clone https://www.github.com/fDero/Verse
$$ cd Verse
$$ make build
```### Hello World
To make your first hello-world program in verse, all it takes is to create a file with the `.verse` extension (in this case, it will be called `hello.verse`)
containing the following code:
```go
func main(){
println("Hello world!");
}
```Once you have the file set up, to run it just use the `verse -r hello.verse` command in console.
```bash
$$ verse -r hello.verse
$$ Hello world!
```### Types
Verse is a strictly typed language, it has a C-style type system with `Int`, `Float`, `Bool`, `Char`, `String` as primitive types.
```go
func main(){
var x : Int = 6;
var y : Float = 9.4;
var f : Bool = false;
var c : Char = 'z';
var s : String = "hello world";
}
```### Recursion
Verse supports recursion just like any other language, and a good way to show it is with the classic fibonacci example, consider the following code:
```go
func fibo(n : Int){
if (n < 2) {
return 1;
}
else {
return fibo(n-1) + fibo(n-2);
}
}func main(){
println(fibo(6));
}
```
assuming the file is called `fibo.verse`, then it can be executed just like we did earlier with the hello-world example, using the `verse -r` command.
```bash
$$ verse -r fibo.verse
$$ 21
```