Vigscript is an interpreted language coded in Rust, to explore the Rust language.
Disclaimer: There are no releases at the moment. You have to build it yourself.
- Clone the repo:
git clone git@github.com:Vigintillionn/vigscript.git
- Make sure you have rust installed
- Cd into the folder
cd vigscript
- Build the cargo with
cargo build
- The executable is found in
target/debug/
- You can move the executeable to your path if you wish
A file can simply be interpreted by running the executeable with an argument, the file's path. ./vigscript main.vig
The parser can only parse files with the extension .vig
You could also use the repl, using ./vigscript
with no argument. Right now it evaluates line per line, not allowing you to indent statements like and if
or func
statement. This will be fixed in the future
I don't know. It's a terrible language, which is totally not optimised but have fun.
An example can be found in the example
directory.
I wanted to combine the syntax of some of my favorite languages. You will probably recognize a lot.
Disclaimer: The syntax is subject to change in the future.
Vigscript, just like rust, makes variables immutable by default. There are 2 ways of making a variable:
let x = 5;
let y;
const PI = 3.14;
The let keyword is allowed to be null, but will afterwards only be able to be assigned once. As the variable will be immutable.
A constant variable must always have a variable and should be written in UPPERCASE.
If you wish to create a mutable variable, the mut
keyword must be used.
Variable declarations must always end with a ;
. An assignment may not end with one, as it is handled as an expression.
let x = 5;
x = 10 // Not OK
let mut x = 5;
x = 10 // OK
let mut x;
let mut y;
x = y = 3
Strings can be created with
let x = "hello";
You may join two strings with the +
operator
let x = "hello";
let y = "world";
let z = x + " " + y; // hello world
All numbers are floating points numbers by default. This is subject to change in the future
let x = 5;
Standard mathematical operations can be done using numbers. This includes +
, -
, /
, *
and %
.
Booleans are just your standard boolean values. All values not equal to false
or null
are treated as true
in conditions.
let x = true;
let y = false;
Objects are just like other languages. Currently the member acces expression is not functioning like intended but is a priority to be fixed.
let obj = {
bar: {
foo: 5
},
fizz: 10
};
print!(obj::bar)
Members are accessed with the member access operator ::
.
If statemens are very intuitive:
let foo = 5;
if foo == 5 {
if foo > 3 {
print!("success")
} else {
print!("failure")
}
}
At the moment you may only loop over an array like so:
let arr = [1, 3, 5, 7];
for let i in arr {
print!(i)
}
The variable i
, in this case, will take on the value of the next index for each iteration. The above snipper will print in the console 1, 3, 5, 7
.
Functions are also very intuitive
func add(a, b) {
print!(a + b)
}
add(2, 3)
A function may have any number - or zero - parameters. The function can be called like most languages. If you wish to return a value in a function you can do with the ret
keyword. The ret
keyword is treated as a statement and must thus be ended with a ;
.
func add(a, b) {
ret a + b;
}
print!(add(2, 3)) // Prints 5
If the last statement of the function is an expression the result of that expression will be returned, if the function hasn't returned earlier.
func add(a, b) {
a + b
}
print!(add(2, 3)) // Prints 5
Vigscript comes with a number of native functions which will later be extended upon. Disclaimer: If I get to it, these native functions will be moved to the standard library
Native functions can be recognized by the trailing !
.
The print!
function will simply print it's arguments to the console.
print!(3, 5) // 3 5
Vigscript also comes with a number of helpers. Some of these will however later on be moved to native methods, once they are implemented.
The array helper is used to do various operations with an array.
Using the new method you can create a new array with a set amount of elements.
let arr = Array::new(5);
print!(arr) // [Null, Null, Null, Null, Null]
Using the from method you can pass in a set amount of arguments which will be added as elements to the array.
let arr = Array::from(1, 3, 5, 7);
print!(arr) // [1, 3, 5, 7]
The has method will return a boolean if the array contains said element.
let arr = [1, 3, 5, 7];
print!(Array::has(arr, 5)) // true
Note This method has almost identical behaviour as the in
keyword but the in
keyword will return the value if it was found and null
if it hasn't been found. Example:
let arr = [1, 3, 5, 7];
print!(5 in arr) // 5
print!(2 in arr) // null
print!(Array::has(arr, 5)) // true
print!(Array::has(arr, 2)) // false
The concat method will join two arrays into one array.
let arr1 = [1, 3, 5, 6];
let arr2 = [6, 7, 8];
let res = Array::concat(arr1, arr2);
print!(res) // [1, 3, 5, 6, 6, 7, 8]
The Date helper consists of various (one) methods that interact with the current data
Returns the current epoch timestamp in milliseconds
print!(Date::now()) // 1700518585000