diff options
| author | Cody <cody@codyq.dev> | 2022-12-15 13:23:48 -0600 | 
|---|---|---|
| committer | Cody <cody@codyq.dev> | 2022-12-15 13:23:48 -0600 | 
| commit | bddb011df4999f7ffeeddf6a4b66e2da6ab19ea0 (patch) | |
| tree | 874d175f352f1a4688e7e62d1f9222a192ae9bff /tour/literals.sloth | |
| download | sloth-bddb011df4999f7ffeeddf6a4b66e2da6ab19ea0.tar.gz | |
Initial language designs & lexer from crafting interpreters
The very initial language designs I came up with for Sloth. Likely
contains inconsistencies and definitely contains things that will be
changed in the future. This is basically just a dump of every idea I've
had for the language thus far.
As for the lexer right now it is heavily based on the one from the
Crafting Interpretrs book and doesn't yet parse Sloth grammar.
Diffstat (limited to 'tour/literals.sloth')
| -rw-r--r-- | tour/literals.sloth | 47 | 
1 files changed, 47 insertions, 0 deletions
| diff --git a/tour/literals.sloth b/tour/literals.sloth new file mode 100644 index 0000000..67e9071 --- /dev/null +++ b/tour/literals.sloth @@ -0,0 +1,47 @@ +# Literals +let number = 85; #TODO: Decide on default integer type +let 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; + +let number: BigInt = BigInt::from(73);     #TODO: naming +let number: BigFloat = BigFloat::from(73); #TODO: naming + +let chars: char = ' '; + +let strings: String = "Normal string"; +let strings: String = "Formated strings ${number}"; +let strings: String = """String literals"""; + +let regex: Regex = /[0-9A-F]/; + +let list: List<i32> = [1, 2, 3, 2]; +let sets: Set<i32> = {1, 2, 3, 2}; + +let maps = {  +    "foo": 48, +    "bar": 97,  +}; + +let maps: Map<String, i32> = {  +    "foo": 48, +    "bar": 97,  +}; + +# `value?` Can be used to bubble up an Option or Result +# `value!` Can be used to panic on None or Error + +maps["foo"]   # Option<i32> +maps["foo"]!  # 48 +maps["foo"]?  # 48 - Caller of function is responsible for None case +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}; | 
