From 900bd3d64ac4c5c4c1511ab8388da3f2ed77849f Mon Sep 17 00:00:00 2001 From: Cody Date: Thu, 15 Dec 2022 14:18:13 -0600 Subject: Replace `let` keyword with `val` and `var` Thanks for pointing out that using `let` and `let mut` was stupid for a scripting language @mworzala --- src/lexer.rs | 6 ++++-- src/main.rs | 6 ++++-- tour/functions.sloth | 8 ++++---- tour/literals.sloth | 42 +++++++++++++++++++++--------------------- tour/types.sloth | 12 ++++++------ tour/variables.sloth | 12 ++++++------ 6 files changed, 45 insertions(+), 41 deletions(-) diff --git a/src/lexer.rs b/src/lexer.rs index 602b5e1..e850cb0 100644 --- a/src/lexer.rs +++ b/src/lexer.rs @@ -49,7 +49,8 @@ pub enum TokenType { Identifier(String), // Keywords - Let, + Val, + Var, Fn, If, @@ -245,7 +246,8 @@ impl<'a> Iterator for Lexer<'a> { } match value.as_str() { - "let" => TokenType::Let, + "val" => TokenType::Val, + "var" => TokenType::Var, "fn" => TokenType::Fn, "if" => TokenType::If, "else" => TokenType::Else, diff --git a/src/main.rs b/src/main.rs index 65e6ee9..5334746 100644 --- a/src/main.rs +++ b/src/main.rs @@ -12,7 +12,9 @@ use lexer::Lexer; const SOURCE: &str = r#" -if 5 >= 7 { +val variable = 5; + +if variable >= 7 { print "Hello World"; } @@ -21,6 +23,6 @@ if 5 >= 7 { fn main() { let lexer = Lexer::new(SOURCE); for token in lexer { - print!("{} ", token.lexeme); + print!("({}) ", token.lexeme); } } diff --git a/tour/functions.sloth b/tour/functions.sloth index e6c8b89..529d108 100644 --- a/tour/functions.sloth +++ b/tour/functions.sloth @@ -1,13 +1,13 @@ # Types can be inferred. # If inferrence fails it will be set to "any" unless strict mode is on pub fn add(lhs, rhs) { - let result = lhs + rhs; + val result = lhs + rhs; return result; } # ...or manually specified pub fn mul(lhs: i32, rhs: i32) -> i32 { - let result = lhs * rhs; + val result = lhs * rhs; return result; } @@ -16,14 +16,14 @@ pub fn mul(lhs: i32, rhs: i32) -> i32 { ## lhs: Left hand side of subtraction ## rhs: Right hand side of subtraction pub fn sub(lhs: i32, rhs: i32) -> i32 { - let result = lhs - rhs; + val result = lhs - rhs; return result; } ## Fizzbuzz implementation from 1 through 100 fn fizzbuzz() { for x in 1..=100 { - let message = match (x % 5, x % 3) { + val message = match (x % 5, x % 3) { (0, 0) => "FizzBuzz", (0, _) => "Fizz", (_, 0) => "Buzz", diff --git a/tour/literals.sloth b/tour/literals.sloth index 67e9071..4aa4533 100644 --- a/tour/literals.sloth +++ b/tour/literals.sloth @@ -1,32 +1,32 @@ # Literals -let number = 85; #TODO: Decide on default integer type -let number = 85.0; # f64 is the default float type +val number = 85; #TODO: Decide on default integer type +val number = 85.0; # f64 is the default float type -let number: u16 = 27; # If you want more control over memory usage you can specify a integer type -let number: u16 = 27u16; -let number: u16 = 0x1B; -let number: u16 = 0x1Bu16; +val number: u16 = 27; # If you want more control over memory usage you can specify a integer type +val number: u16 = 27u16; +val number: u16 = 0x1B; +val number: u16 = 0x1Bu16; -let number: BigInt = BigInt::from(73); #TODO: naming -let number: BigFloat = BigFloat::from(73); #TODO: naming +val number: BigInt = BigInt::from(73); #TODO: naming +val number: BigFloat = BigFloat::from(73); #TODO: naming -let chars: char = ' '; +val chars: char = ' '; -let strings: String = "Normal string"; -let strings: String = "Formated strings ${number}"; -let strings: String = """String literals"""; +val strings: String = "Normal string"; +val strings: String = "Formated strings ${number}"; +val strings: String = """String literals"""; -let regex: Regex = /[0-9A-F]/; +val regex: Regex = /[0-9A-F]/; -let list: List = [1, 2, 3, 2]; -let sets: Set = {1, 2, 3, 2}; +val list: List = [1, 2, 3, 2]; +val sets: Set = {1, 2, 3, 2}; -let maps = { +val maps = { "foo": 48, "bar": 97, }; -let maps: Map = { +val maps: Map = { "foo": 48, "bar": 97, }; @@ -41,7 +41,7 @@ maps.keys() # ["foo", "bar"] maps.values() # [48, 97] # Spreading -let lhs = [1, 2, 3]; -let rhs = [4, 5, 6]; -let combined_list = [..lhs, ..rhs, 2, 4, 6]; -let combined_sets = {..lhs, ..rhs, 2, 4, 6}; +val lhs = [1, 2, 3]; +val rhs = [4, 5, 6]; +val combined_list = [..lhs, ..rhs, 2, 4, 6]; +val combined_sets = {..lhs, ..rhs, 2, 4, 6}; diff --git a/tour/types.sloth b/tour/types.sloth index a47fd3a..c7ef2f5 100644 --- a/tour/types.sloth +++ b/tour/types.sloth @@ -6,7 +6,7 @@ type Person = { grades: Map, }; -let cody = Person { +val cody = Person { name: "Cody Q", age: 17, hobbies: { @@ -59,12 +59,12 @@ impl Color { (value * 255) as u8 } - let h = (hue * 6).floor() as i32; + val h = (hue * 6).floor() as i32; - let f = hue * 6 - h; - let p = value * (1 - saturation); - let q = value * (1 - f * saturation); - let t = value * (1 - (1 - f) * saturation); + val f = hue * 6 - h; + val p = value * (1 - saturation); + val q = value * (1 - f * saturation); + val t = value * (1 - (1 - f) * saturation); return match h { 0 => Color(c(value), c(t), c(p)), diff --git a/tour/variables.sloth b/tour/variables.sloth index d105716..c3a9137 100644 --- a/tour/variables.sloth +++ b/tour/variables.sloth @@ -1,12 +1,12 @@ -# Variables can be declared using the `let` keyword, however they will be deeply -# immutable. If you would like to make the variable mutable you can use `let mut` +# Variables can be declared using the `var` keyword, however they will be mutable. +# If you would like to make the variable immutable you can use `val` # # Variables can not be exported and can not be referrenced accross modules. -let x = 0; -let mut y = 0; +var x = 0; +val y = 0; -x = 5; # Invalid -y = 5; # Valid +x = 5; # Valid +y = 5; # Invalid # Constants can be declared using the `const` keyword, unlike variables they can # be exported and accessed across modules. -- cgit v1.2.3