diff --git a/crates/cli/tests/benchmarks/AStar.roc b/crates/cli/tests/benchmarks/AStar.roc index 8783c03af8a..20856b8d7f7 100644 --- a/crates/cli/tests/benchmarks/AStar.roc +++ b/crates/cli/tests/benchmarks/AStar.roc @@ -23,8 +23,8 @@ initial_model = \start -> { cheapest_open : (position -> F64), Model position -> Result position {} where position implements Hash & Eq cheapest_open = \cost_fn, model -> model.open_set - |> Set.toList - |> List.keepOks( + |> Set.to_list + |> List.keep_oks( \position -> when Dict.get(model.costs, position) is Err(_) -> Err({}) @@ -33,7 +33,7 @@ cheapest_open = \cost_fn, model -> |> Quicksort.sort_by(.cost) |> List.first |> Result.map(.position) - |> Result.mapErr(\_ -> {}) + |> Result.map_err(\_ -> {}) reconstruct_path : Dict position position, position -> List position where position implements Hash & Eq reconstruct_path = \came_from, goal -> @@ -52,7 +52,7 @@ update_cost = \current, neighbor, model -> distance_to = reconstruct_path(new_came_from, neighbor) |> List.len - |> Num.toFrac + |> Num.to_frac new_model = { model & diff --git a/crates/cli/tests/benchmarks/Base64.roc b/crates/cli/tests/benchmarks/Base64.roc index 65a7ecb9c6f..1e0a9623f87 100644 --- a/crates/cli/tests/benchmarks/Base64.roc +++ b/crates/cli/tests/benchmarks/Base64.roc @@ -16,7 +16,7 @@ from_bytes = \bytes -> # base 64 encoding from a string from_str : Str -> Result Str [InvalidInput] from_str = \str -> - from_bytes(Str.toUtf8(str)) + from_bytes(Str.to_utf8(str)) # base64-encode bytes to the original to_bytes : Str -> Result (List U8) [InvalidInput] @@ -27,7 +27,7 @@ to_str : Str -> Result Str [InvalidInput] to_str = \str -> when to_bytes(str) is Ok(bytes) -> - when Str.fromUtf8(bytes) is + when Str.from_utf8(bytes) is Ok(v) -> Ok(v) diff --git a/crates/cli/tests/benchmarks/Base64/Decode.roc b/crates/cli/tests/benchmarks/Base64/Decode.roc index e85d08728a5..e33e7028e05 100644 --- a/crates/cli/tests/benchmarks/Base64/Decode.roc +++ b/crates/cli/tests/benchmarks/Base64/Decode.roc @@ -14,12 +14,12 @@ loop_help = \{ remaining, string } -> if remaining >= 3 then Bytes.Decode.map3(Bytes.Decode.u8, Bytes.Decode.u8, Bytes.Decode.u8, \x, y, z -> a : U32 - a = Num.intCast(x) + a = Num.int_cast(x) b : U32 - b = Num.intCast(y) + b = Num.int_cast(y) c : U32 - c = Num.intCast(z) - combined = Num.bitwiseOr(Num.bitwiseOr(Num.shiftLeftBy(a, 16), Num.shiftLeftBy(b, 8)), c) + c = Num.int_cast(z) + combined = Num.bitwise_or(Num.bitwise_or(Num.shift_left_by(a, 16), Num.shift_left_by(b, 8)), c) Loop({ remaining: remaining - 3, @@ -31,10 +31,10 @@ loop_help = \{ remaining, string } -> Bytes.Decode.map2(Bytes.Decode.u8, Bytes.Decode.u8, \x, y -> a : U32 - a = Num.intCast(x) + a = Num.int_cast(x) b : U32 - b = Num.intCast(y) - combined = Num.bitwiseOr(Num.shiftLeftBy(a, 16), Num.shiftLeftBy(b, 8)) + b = Num.int_cast(y) + combined = Num.bitwise_or(Num.shift_left_by(a, 16), Num.shift_left_by(b, 8)) Done(Str.concat(string, bits_to_chars(combined, 1)))) else @@ -42,13 +42,13 @@ loop_help = \{ remaining, string } -> Bytes.Decode.map(Bytes.Decode.u8, \x -> a : U32 - a = Num.intCast(x) + a = Num.int_cast(x) - Done(Str.concat(string, bits_to_chars(Num.shiftLeftBy(a, 16), 2)))) + Done(Str.concat(string, bits_to_chars(Num.shift_left_by(a, 16), 2)))) bits_to_chars : U32, Int * -> Str bits_to_chars = \bits, missing -> - when Str.fromUtf8(bits_to_chars_help(bits, missing)) is + when Str.from_utf8(bits_to_chars_help(bits, missing)) is Ok(str) -> str Err(_) -> "" @@ -63,23 +63,23 @@ bits_to_chars_help = \bits, missing -> # with `0b111111` (which is 2^6 - 1 or 63) (so, 6 1s) to remove unwanted bits on the left. # any 6-bit number is a valid base64 digit, so this is actually safe p = - Num.shiftRightZfBy(bits, 18) - |> Num.intCast + Num.shift_right_zf_by(bits, 18) + |> Num.int_cast |> unsafe_to_char q = - Num.bitwiseAnd(Num.shiftRightZfBy(bits, 12), lowest6_bits_mask) - |> Num.intCast + Num.bitwise_and(Num.shift_right_zf_by(bits, 12), lowest6_bits_mask) + |> Num.int_cast |> unsafe_to_char r = - Num.bitwiseAnd(Num.shiftRightZfBy(bits, 6), lowest6_bits_mask) - |> Num.intCast + Num.bitwise_and(Num.shift_right_zf_by(bits, 6), lowest6_bits_mask) + |> Num.int_cast |> unsafe_to_char s = - Num.bitwiseAnd(bits, lowest6_bits_mask) - |> Num.intCast + Num.bitwise_and(bits, lowest6_bits_mask) + |> Num.int_cast |> unsafe_to_char equals : U8 diff --git a/crates/cli/tests/benchmarks/Base64/Encode.roc b/crates/cli/tests/benchmarks/Base64/Encode.roc index 49165122032..c29f0680388 100644 --- a/crates/cli/tests/benchmarks/Base64/Encode.roc +++ b/crates/cli/tests/benchmarks/Base64/Encode.roc @@ -8,7 +8,7 @@ InvalidChar : U8 to_bytes : Str -> List U8 to_bytes = \str -> str - |> Str.toUtf8 + |> Str.to_utf8 |> encode_chunks |> Bytes.Encode.sequence |> Bytes.Encode.encode @@ -73,18 +73,18 @@ encode_characters = \a, b, c, d -> n2 = unsafe_convert_char(b) x : U32 - x = Num.intCast(n1) + x = Num.int_cast(n1) y : U32 - y = Num.intCast(n2) + y = Num.int_cast(n2) if d == equals then if c == equals then - n = Num.bitwiseOr(Num.shiftLeftBy(x, 18), Num.shiftLeftBy(y, 12)) + n = Num.bitwise_or(Num.shift_left_by(x, 18), Num.shift_left_by(y, 12)) # masking higher bits is not needed, Encode.unsignedInt8 ignores higher bits b1 : U8 - b1 = Num.intCast(Num.shiftRightBy(n, 16)) + b1 = Num.int_cast(Num.shift_right_by(n, 16)) Ok(Bytes.Encode.u8(b1)) else if !(is_valid_char(c)) then @@ -93,12 +93,12 @@ encode_characters = \a, b, c, d -> n3 = unsafe_convert_char(c) z : U32 - z = Num.intCast(n3) + z = Num.int_cast(n3) - n = Num.bitwiseOr(Num.bitwiseOr(Num.shiftLeftBy(x, 18), Num.shiftLeftBy(y, 12)), Num.shiftLeftBy(z, 6)) + n = Num.bitwise_or(Num.bitwise_or(Num.shift_left_by(x, 18), Num.shift_left_by(y, 12)), Num.shift_left_by(z, 6)) combined : U16 - combined = Num.intCast(Num.shiftRightBy(n, 8)) + combined = Num.int_cast(Num.shift_right_by(n, 8)) Ok(Bytes.Encode.u16(BE, combined)) else if !(is_valid_char(d)) then @@ -108,22 +108,22 @@ encode_characters = \a, b, c, d -> n4 = unsafe_convert_char(d) z : U32 - z = Num.intCast(n3) + z = Num.int_cast(n3) w : U32 - w = Num.intCast(n4) + w = Num.int_cast(n4) n = - Num.bitwiseOr( - Num.bitwiseOr(Num.shiftLeftBy(x, 18), Num.shiftLeftBy(y, 12)), - Num.bitwiseOr(Num.shiftLeftBy(z, 6), w), + Num.bitwise_or( + Num.bitwise_or(Num.shift_left_by(x, 18), Num.shift_left_by(y, 12)), + Num.bitwise_or(Num.shift_left_by(z, 6), w), ) b3 : U8 - b3 = Num.intCast(n) + b3 = Num.int_cast(n) combined : U16 - combined = Num.intCast(Num.shiftRightBy(n, 8)) + combined = Num.int_cast(Num.shift_right_by(n, 8)) Ok(Bytes.Encode.sequence([Bytes.Encode.u16(BE, combined), Bytes.Encode.u8(b3)])) diff --git a/crates/cli/tests/benchmarks/Bytes/Decode.roc b/crates/cli/tests/benchmarks/Bytes/Decode.roc index 79d96828c6c..75490628d80 100644 --- a/crates/cli/tests/benchmarks/Bytes/Decode.roc +++ b/crates/cli/tests/benchmarks/Bytes/Decode.roc @@ -7,105 +7,111 @@ DecodeProblem : [OutOfBytes] ByteDecoder a := State -> [Good State a, Bad DecodeProblem] decode : List U8, ByteDecoder a -> Result a DecodeProblem -decode = \bytes, @ByteDecoder decoder -> - when decoder { bytes, cursor: 0 } is - Good _ value -> - Ok value +decode = \bytes, @ByteDecoder(decoder) -> + when decoder({ bytes, cursor: 0 }) is + Good(_, value) -> + Ok(value) - Bad e -> - Err e + Bad(e) -> + Err(e) succeed : a -> ByteDecoder a -succeed = \value -> @ByteDecoder \state -> Good state value +succeed = \value -> @ByteDecoder(\state -> Good(state, value)) map : ByteDecoder a, (a -> b) -> ByteDecoder b -map = \@ByteDecoder decoder, transform -> - @ByteDecoder +map = \@ByteDecoder(decoder), transform -> + @ByteDecoder( \state -> - when decoder state is - Good state1 value -> - Good state1 (transform value) + when decoder(state) is + Good(state1, value) -> + Good(state1, transform(value)) - Bad e -> - Bad e + Bad(e) -> + Bad(e), + ) map2 : ByteDecoder a, ByteDecoder b, (a, b -> c) -> ByteDecoder c -map2 = \@ByteDecoder decoder1, @ByteDecoder decoder2, transform -> - @ByteDecoder +map2 = \@ByteDecoder(decoder1), @ByteDecoder(decoder2), transform -> + @ByteDecoder( \state1 -> - when decoder1 state1 is - Good state2 a -> - when decoder2 state2 is - Good state3 b -> - Good state3 (transform a b) + when decoder1(state1) is + Good(state2, a) -> + when decoder2(state2) is + Good(state3, b) -> + Good(state3, transform(a, b)) - Bad e -> - Bad e + Bad(e) -> + Bad(e) - Bad e -> - Bad e + Bad(e) -> + Bad(e), + ) map3 : ByteDecoder a, ByteDecoder b, ByteDecoder c, (a, b, c -> d) -> ByteDecoder d -map3 = \@ByteDecoder decoder1, @ByteDecoder decoder2, @ByteDecoder decoder3, transform -> - @ByteDecoder +map3 = \@ByteDecoder(decoder1), @ByteDecoder(decoder2), @ByteDecoder(decoder3), transform -> + @ByteDecoder( \state1 -> - when decoder1 state1 is - Good state2 a -> - when decoder2 state2 is - Good state3 b -> - when decoder3 state3 is - Good state4 c -> - Good state4 (transform a b c) + when decoder1(state1) is + Good(state2, a) -> + when decoder2(state2) is + Good(state3, b) -> + when decoder3(state3) is + Good(state4, c) -> + Good(state4, transform(a, b, c)) - Bad e -> - Bad e + Bad(e) -> + Bad(e) - Bad e -> - Bad e + Bad(e) -> + Bad(e) - Bad e -> - Bad e + Bad(e) -> + Bad(e), + ) after : ByteDecoder a, (a -> ByteDecoder b) -> ByteDecoder b -after = \@ByteDecoder decoder, transform -> - @ByteDecoder +after = \@ByteDecoder(decoder), transform -> + @ByteDecoder( \state -> - when decoder state is - Good state1 value -> - (@ByteDecoder decoder1) = transform value + when decoder(state) is + Good(state1, value) -> + @ByteDecoder(decoder1) = transform(value) - decoder1 state1 + decoder1(state1) - Bad e -> - Bad e + Bad(e) -> + Bad(e), + ) u8 : ByteDecoder U8 -u8 = @ByteDecoder +u8 = @ByteDecoder( \state -> - when List.get state.bytes state.cursor is - Ok b -> - Good { state & cursor: state.cursor + 1 } b + when List.get(state.bytes, state.cursor) is + Ok(b) -> + Good({ state & cursor: state.cursor + 1 }, b) - Err _ -> - Bad OutOfBytes + Err(_) -> + Bad(OutOfBytes), +) Step state b : [Loop state, Done b] loop : (state -> ByteDecoder (Step state a)), state -> ByteDecoder a loop = \stepper, initial -> - @ByteDecoder + @ByteDecoder( \state -> - loopHelp stepper initial state + loop_help(stepper, initial, state), + ) -loopHelp = \stepper, accum, state -> - (@ByteDecoder stepper1) = stepper accum +loop_help = \stepper, accum, state -> + @ByteDecoder(stepper1) = stepper(accum) - when stepper1 state is - Good newState (Done value) -> - Good newState value + when stepper1(state) is + Good(new_state, Done(value)) -> + Good(new_state, value) - Good newState (Loop newAccum) -> - loopHelp stepper newAccum newState + Good(new_state, Loop(new_accum)) -> + loop_help(stepper, new_accum, new_state) - Bad e -> - Bad e + Bad(e) -> + Bad(e) diff --git a/crates/cli/tests/benchmarks/Bytes/Encode.roc b/crates/cli/tests/benchmarks/Bytes/Encode.roc index 2c70aff7fac..7242638143e 100644 --- a/crates/cli/tests/benchmarks/Bytes/Encode.roc +++ b/crates/cli/tests/benchmarks/Bytes/Encode.roc @@ -5,130 +5,132 @@ Endianness : [BE, LE] ByteEncoder : [Signed8 I8, Unsigned8 U8, Signed16 Endianness I16, Unsigned16 Endianness U16, Sequence U64 (List ByteEncoder), Bytes (List U8)] u8 : U8 -> ByteEncoder -u8 = \value -> Unsigned8 value +u8 = \value -> Unsigned8(value) empty : ByteEncoder empty = foo : List ByteEncoder foo = [] - Sequence 0 foo + Sequence(0, foo) u16 : Endianness, U16 -> ByteEncoder -u16 = \endianness, value -> Unsigned16 endianness value +u16 = \endianness, value -> Unsigned16(endianness, value) bytes : List U8 -> ByteEncoder -bytes = \bs -> Bytes bs +bytes = \bs -> Bytes(bs) sequence : List ByteEncoder -> ByteEncoder sequence = \encoders -> - Sequence (getWidths encoders 0) encoders + Sequence(get_widths(encoders, 0), encoders) -getWidth : ByteEncoder -> U64 -getWidth = \encoder -> +get_width : ByteEncoder -> U64 +get_width = \encoder -> when encoder is - Signed8 _ -> 1 - Unsigned8 _ -> 1 - Signed16 _ _ -> 2 - Unsigned16 _ _ -> 2 + Signed8(_) -> 1 + Unsigned8(_) -> 1 + Signed16(_, _) -> 2 + Unsigned16(_, _) -> 2 # Signed32 _ -> 4 # Unsigned32 _ -> 4 # Signed64 _ -> 8 # Unsigned64 _ -> 8 # Signed128 _ -> 16 # Unsigned128 _ -> 16 - Sequence w _ -> w - Bytes bs -> List.len bs + Sequence(w, _) -> w + Bytes(bs) -> List.len(bs) -getWidths : List ByteEncoder, U64 -> U64 -getWidths = \encoders, initial -> - List.walk encoders initial \accum, encoder -> accum + getWidth encoder +get_widths : List ByteEncoder, U64 -> U64 +get_widths = \encoders, initial -> + List.walk(encoders, initial, \accum, encoder -> accum + get_width(encoder)) encode : ByteEncoder -> List U8 encode = \encoder -> - output = List.repeat 0 (getWidth encoder) + output = List.repeat(0, get_width(encoder)) - encodeHelp encoder 0 output + encode_help(encoder, 0, output) |> .output -encodeHelp : ByteEncoder, U64, List U8 -> { output : List U8, offset : U64 } -encodeHelp = \encoder, offset, output -> +encode_help : ByteEncoder, U64, List U8 -> { output : List U8, offset : U64 } +encode_help = \encoder, offset, output -> when encoder is - Unsigned8 value -> + Unsigned8(value) -> { - output: List.set output offset value, + output: List.set(output, offset, value), offset: offset + 1, } - Signed8 value -> + Signed8(value) -> cast : U8 - cast = Num.intCast value + cast = Num.int_cast(value) { - output: List.set output offset cast, + output: List.set(output, offset, cast), offset: offset + 1, } - Unsigned16 endianness value -> + Unsigned16(endianness, value) -> a : U8 - a = Num.intCast (Num.shiftRightBy value 8) + a = Num.int_cast(Num.shift_right_by(value, 8)) b : U8 - b = Num.intCast value + b = Num.int_cast(value) - newOutput = + new_output = when endianness is BE -> output - |> List.set (offset + 0) a - |> List.set (offset + 1) b + |> List.set((offset + 0), a) + |> List.set((offset + 1), b) LE -> output - |> List.set (offset + 0) b - |> List.set (offset + 1) a + |> List.set((offset + 0), b) + |> List.set((offset + 1), a) { - output: newOutput, + output: new_output, offset: offset + 2, } - Signed16 endianness value -> + Signed16(endianness, value) -> a : U8 - a = Num.intCast (Num.shiftRightBy value 8) + a = Num.int_cast(Num.shift_right_by(value, 8)) b : U8 - b = Num.intCast value + b = Num.int_cast(value) - newOutput = + new_output = when endianness is BE -> output - |> List.set (offset + 0) a - |> List.set (offset + 1) b + |> List.set((offset + 0), a) + |> List.set((offset + 1), b) LE -> output - |> List.set (offset + 0) b - |> List.set (offset + 1) a + |> List.set((offset + 0), b) + |> List.set((offset + 1), a) { - output: newOutput, + output: new_output, offset: offset + 1, } - Bytes bs -> - List.walk - bs - { output, offset } + Bytes(bs) -> + List.walk( + bs, + { output, offset }, \accum, byte -> { offset: accum.offset + 1, - output: List.set accum.output offset byte, - } - - Sequence _ encoders -> - List.walk - encoders - { output, offset } + output: List.set(accum.output, offset, byte), + }, + ) + + Sequence(_, encoders) -> + List.walk( + encoders, + { output, offset }, \accum, single -> - encodeHelp single accum.offset accum.output + encode_help(single, accum.offset, accum.output), + ) diff --git a/crates/cli/tests/benchmarks/Issue2279Help.roc b/crates/cli/tests/benchmarks/Issue2279Help.roc index 7e6c53d6bd0..b71a3ceca0a 100644 --- a/crates/cli/tests/benchmarks/Issue2279Help.roc +++ b/crates/cli/tests/benchmarks/Issue2279Help.roc @@ -2,4 +2,4 @@ module [text, as_text] text = "Hello, world!" -as_text = Num.toStr +as_text = Num.to_str diff --git a/crates/cli/tests/benchmarks/Quicksort.roc b/crates/cli/tests/benchmarks/Quicksort.roc index 681bb02863d..3b03df6dfbc 100644 --- a/crates/cli/tests/benchmarks/Quicksort.roc +++ b/crates/cli/tests/benchmarks/Quicksort.roc @@ -2,13 +2,13 @@ module [sort_by, sort_with, show] show : List I64 -> Str show = \list -> - if List.isEmpty(list) then + if List.is_empty(list) then "[]" else content = list - |> List.map(Num.toStr) - |> Str.joinWith(", ") + |> List.map(Num.to_str) + |> Str.join_with(", ") "[$(content)]" @@ -30,7 +30,7 @@ quicksort_help = \list, order, low, high -> when partition(low, high, list, order) is Pair(partition_index, partitioned) -> partitioned - |> quicksort_help(order, low, Num.subSaturated(partition_index, 1)) + |> quicksort_help(order, low, Num.sub_saturated(partition_index, 1)) |> quicksort_help(order, (partition_index + 1), high) else list diff --git a/crates/cli/tests/benchmarks/cFold.roc b/crates/cli/tests/benchmarks/cFold.roc index 5bfe918807f..ce81b336974 100644 --- a/crates/cli/tests/benchmarks/cFold.roc +++ b/crates/cli/tests/benchmarks/cFold.roc @@ -19,9 +19,9 @@ main! = \{} -> optimized = eval(const_folding(reassoc(e))) unoptimized - |> Num.toStr + |> Num.to_str |> Str.concat(" & ") - |> Str.concat(Num.toStr(optimized)) + |> Str.concat(Num.to_str(optimized)) |> Host.put_line! Err(GetIntError) -> diff --git a/crates/cli/tests/benchmarks/closure.roc b/crates/cli/tests/benchmarks/closure.roc index c7d96bf4f70..49febbab5c8 100644 --- a/crates/cli/tests/benchmarks/closure.roc +++ b/crates/cli/tests/benchmarks/closure.roc @@ -6,7 +6,7 @@ main! = \{} -> |> Result.try(closure2) |> Result.try(closure3) |> Result.try(closure4) - |> Result.withDefault({}) + |> Result.with_default({}) # --- closure1 : {} -> Result {} [] @@ -14,7 +14,7 @@ closure1 = \_ -> Ok(foo(to_unit_borrowed, "a long string such that it's malloced")) |> Result.map(\_ -> {}) -to_unit_borrowed = \x -> Str.countUtf8Bytes(x) +to_unit_borrowed = \x -> Str.count_utf8_bytes(x) foo = \f, x -> f(x) diff --git a/crates/cli/tests/benchmarks/deriv.roc b/crates/cli/tests/benchmarks/deriv.roc index be43ef8670b..3f0f46fa663 100644 --- a/crates/cli/tests/benchmarks/deriv.roc +++ b/crates/cli/tests/benchmarks/deriv.roc @@ -41,7 +41,7 @@ Expr : [Val I64, Var Str, Add Expr Expr, Mul Expr Expr, Pow Expr Expr, Ln Expr] divmod : I64, I64 -> Result { div : I64, mod : I64 } [DivByZero] divmod = \l, r -> - when Pair(Num.divTruncChecked(l, r), Num.remChecked(l, r)) is + when Pair(Num.div_trunc_checked(l, r), Num.rem_checked(l, r)) is Pair(Ok(div), Ok(mod)) -> Ok({ div, mod }) _ -> Err(DivByZero) @@ -162,8 +162,8 @@ deriv! : I64, Expr => Expr deriv! = \i, f -> fprime = d("x", f) line = - Num.toStr((i + 1)) + Num.to_str((i + 1)) |> Str.concat(" count: ") - |> Str.concat(Num.toStr(count(fprime))) + |> Str.concat(Num.to_str(count(fprime))) Host.put_line!(line) fprime diff --git a/crates/cli/tests/benchmarks/nQueens.roc b/crates/cli/tests/benchmarks/nQueens.roc index 51098b25d65..26336e659ec 100644 --- a/crates/cli/tests/benchmarks/nQueens.roc +++ b/crates/cli/tests/benchmarks/nQueens.roc @@ -14,7 +14,7 @@ main! = \{} -> when input_result is Ok(n) -> queens(n) # original koka 13 - |> Num.toStr + |> Num.to_str |> Host.put_line! Err(GetIntError) -> diff --git a/crates/cli/tests/benchmarks/platform/PlatformTasks.roc b/crates/cli/tests/benchmarks/platform/PlatformTasks.roc new file mode 100644 index 00000000000..5db7e79c88b --- /dev/null +++ b/crates/cli/tests/benchmarks/platform/PlatformTasks.roc @@ -0,0 +1,9 @@ +hosted PlatformTasks + exposes [put_line, put_int, get_int] + imports [] + +put_line : Str -> Task {} * + +put_int : I64 -> Task {} * + +get_int : Task { value : I64, is_error : Bool } * diff --git a/crates/cli/tests/benchmarks/platform/main.roc b/crates/cli/tests/benchmarks/platform/main.roc index 53f8267272b..d16225ec963 100644 --- a/crates/cli/tests/benchmarks/platform/main.roc +++ b/crates/cli/tests/benchmarks/platform/main.roc @@ -6,4 +6,4 @@ platform "benchmarks" provides [main_for_host!] main_for_host! : {} => {} -main_for_host! = \{} -> main! {} +main_for_host! = \{} -> main!({}) diff --git a/crates/cli/tests/benchmarks/quicksortApp.roc b/crates/cli/tests/benchmarks/quicksortApp.roc index dc4c94d78a8..db856331f87 100644 --- a/crates/cli/tests/benchmarks/quicksortApp.roc +++ b/crates/cli/tests/benchmarks/quicksortApp.roc @@ -5,7 +5,7 @@ import Quicksort main! : {} => {} main! = \{} -> - { value, is_error } = Host.get_int! {} + { value, is_error } = Host.get_int!({}) input_result = if is_error then Err(GetIntError) diff --git a/crates/cli/tests/benchmarks/rBTreeCk.roc b/crates/cli/tests/benchmarks/rBTreeCk.roc index a8e7f14c64b..8144b81f113 100644 --- a/crates/cli/tests/benchmarks/rBTreeCk.roc +++ b/crates/cli/tests/benchmarks/rBTreeCk.roc @@ -57,7 +57,7 @@ main! = \{} -> val = fold(\_, v, r -> if v then r + 1 else r, head, 0) val - |> Num.toStr + |> Num.to_str |> Host.put_line! Nil -> diff --git a/crates/cli/tests/benchmarks/rBTreeInsert.roc b/crates/cli/tests/benchmarks/rBTreeInsert.roc index 29b82155070..05b62ccee73 100644 --- a/crates/cli/tests/benchmarks/rBTreeInsert.roc +++ b/crates/cli/tests/benchmarks/rBTreeInsert.roc @@ -12,7 +12,7 @@ main! = \{} -> |> Host.put_line! show : RedBlackTree I64 {} -> Str -show = \tree -> show_rb_tree(tree, Num.toStr, \{} -> "{}") +show = \tree -> show_rb_tree(tree, Num.to_str, \{} -> "{}") show_rb_tree : RedBlackTree k v, (k -> Str), (v -> Str) -> Str show_rb_tree = \tree, show_key, show_value -> diff --git a/crates/cli/tests/benchmarks/testAStar.roc b/crates/cli/tests/benchmarks/testAStar.roc index 734caf31e58..23f1d1f9df5 100644 --- a/crates/cli/tests/benchmarks/testAStar.roc +++ b/crates/cli/tests/benchmarks/testAStar.roc @@ -24,10 +24,10 @@ example1 = step : I64 -> Set I64 step = \n -> when n is - 1 -> Set.fromList([2, 3]) - 2 -> Set.fromList([4]) - 3 -> Set.fromList([4]) - _ -> Set.fromList([]) + 1 -> Set.from_list([2, 3]) + 2 -> Set.from_list([4]) + 3 -> Set.from_list([4]) + _ -> Set.from_list([]) cost : I64, I64 -> F64 cost = \_, _ -> 1 diff --git a/crates/cli/tests/benchmarks/testBase64.roc b/crates/cli/tests/benchmarks/testBase64.roc index 44d255f4238..86d76bdcdc7 100644 --- a/crates/cli/tests/benchmarks/testBase64.roc +++ b/crates/cli/tests/benchmarks/testBase64.roc @@ -5,7 +5,7 @@ import pf.Host main! : {} => {} main! = \{} -> - when Base64.from_bytes(Str.toUtf8("Hello World")) is + when Base64.from_bytes(Str.to_utf8("Hello World")) is Err(_) -> Host.put_line!("sadness") Ok(encoded) -> Host.put_line!(Str.concat("encoded: ", encoded)) diff --git a/crates/cli/tests/cli_tests.rs b/crates/cli/tests/cli_tests.rs index 4ea728099ea..053a00b4eac 100644 --- a/crates/cli/tests/cli_tests.rs +++ b/crates/cli/tests/cli_tests.rs @@ -188,7 +188,8 @@ mod cli_tests { } #[test] - #[cfg_attr(windows, ignore)] + // #[cfg_attr(windows, ignore)] + #[ignore] fn false_interpreter() { let cli_build = ExecCli::new( CMD_BUILD, @@ -852,7 +853,7 @@ mod cli_tests { ), ); - let expected_output = "(@Community {friends: [{2}, {2}, {0, 1}], people: [(@Person {age: 27, favoriteColor: Blue, firstName: \"John\", hasBeard: Bool.true, lastName: \"Smith\"}), (@Person {age: 47, favoriteColor: Green, firstName: \"Debby\", hasBeard: Bool.false, lastName: \"Johnson\"}), (@Person {age: 33, favoriteColor: (RGB (255, 255, 0)), firstName: \"Jane\", hasBeard: Bool.false, lastName: \"Doe\"})]})\n"; + let expected_output = "(@Community {friends: [{2}, {2}, {0, 1}], people: [(@Person {age: 27, favorite_color: Blue, first_name: \"John\", has_beard: Bool.true, last_name: \"Smith\"}), (@Person {age: 47, favorite_color: Green, first_name: \"Debby\", has_beard: Bool.false, last_name: \"Johnson\"}), (@Person {age: 33, favorite_color: (RGB (255, 255, 0)), first_name: \"Jane\", has_beard: Bool.false, last_name: \"Doe\"})]})\n"; cli_build.full_check_build_and_run( expected_output, @@ -963,7 +964,7 @@ mod cli_tests { ), ); - let expected_output = "notEffectful: hardcoded\neffectful: from stdin\n"; + let expected_output = "not_effectful: hardcoded\neffectful: from stdin\n"; cli_build.check_build_and_run( expected_output, diff --git a/crates/cli/tests/platform-switching/c-platform/host.c b/crates/cli/tests/platform-switching/c-platform/host.c index 2b0baf8e15c..021d20c974f 100644 --- a/crates/cli/tests/platform-switching/c-platform/host.c +++ b/crates/cli/tests/platform-switching/c-platform/host.c @@ -85,12 +85,12 @@ size_t roc_str_len(struct RocStr str) { } } -extern void roc__mainForHost_1_exposed_generic(struct RocStr *string); +extern void roc__main_for_host_1_exposed_generic(struct RocStr *string); int main() { struct RocStr str; - roc__mainForHost_1_exposed_generic(&str); + roc__main_for_host_1_exposed_generic(&str); // Determine str_len and the str_bytes pointer, // taking into account the small string optimization. diff --git a/crates/cli/tests/platform-switching/c-platform/main.roc b/crates/cli/tests/platform-switching/c-platform/main.roc index 35c286a30ef..7687aa43d39 100644 --- a/crates/cli/tests/platform-switching/c-platform/main.roc +++ b/crates/cli/tests/platform-switching/c-platform/main.roc @@ -3,7 +3,7 @@ platform "echo-in-c" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Str -mainForHost = main +main_for_host : Str +main_for_host = main diff --git a/crates/cli/tests/platform-switching/rust-platform/build.rs b/crates/cli/tests/platform-switching/rust-platform/build.rs index fdb4c2891f2..32b0e6cadab 100644 --- a/crates/cli/tests/platform-switching/rust-platform/build.rs +++ b/crates/cli/tests/platform-switching/rust-platform/build.rs @@ -2,7 +2,7 @@ // // ``` // = note: Undefined symbols for architecture arm64: -// "_roc__mainForHost_1_exposed_generic", referenced from: +// "_roc__main_for_host_1_exposed_generic", referenced from: // _main in rustplatform-df9e357e0cc989a6.rustplatform.863be87f3956573-cgu.0.rcgu.o // ld: symbol(s) not found for architecture arm64 // clang-16: error: linker command failed with exit code 1 (use -v to see invocation) diff --git a/crates/cli/tests/platform-switching/rust-platform/main.roc b/crates/cli/tests/platform-switching/rust-platform/main.roc index 13dd322d6b9..0fe1dd7353d 100644 --- a/crates/cli/tests/platform-switching/rust-platform/main.roc +++ b/crates/cli/tests/platform-switching/rust-platform/main.roc @@ -3,7 +3,7 @@ platform "echo-in-rust" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Str -mainForHost = main +main_for_host : Str +main_for_host = main diff --git a/crates/cli/tests/platform-switching/rust-platform/src/lib.rs b/crates/cli/tests/platform-switching/rust-platform/src/lib.rs index 1f910821130..55ed67ba974 100644 --- a/crates/cli/tests/platform-switching/rust-platform/src/lib.rs +++ b/crates/cli/tests/platform-switching/rust-platform/src/lib.rs @@ -6,7 +6,7 @@ use roc_std::RocStr; use std::io::Write; extern "C" { - #[link_name = "roc__mainForHost_1_exposed_generic"] + #[link_name = "roc__main_for_host_1_exposed_generic"] fn roc_main(_: &mut RocStr); } diff --git a/crates/cli/tests/platform-switching/web-assembly-platform/host.zig b/crates/cli/tests/platform-switching/web-assembly-platform/host.zig index 04c8eb716b8..c8a54aff9e1 100644 --- a/crates/cli/tests/platform-switching/web-assembly-platform/host.zig +++ b/crates/cli/tests/platform-switching/web-assembly-platform/host.zig @@ -35,14 +35,14 @@ export fn roc_dealloc(c_ptr: *anyopaque, alignment: u32) callconv(.C) void { // NOTE roc_panic and roc_dbg is provided in the JS file, so it can throw an exception -extern fn roc__mainForHost_1_exposed(*RocStr) void; +extern fn roc__main_for_host_1_exposed(*RocStr) void; extern fn js_display_roc_string(str_bytes: ?[*]u8, str_len: usize) void; pub export fn main() u8 { // actually call roc to populate the callresult var callresult = RocStr.empty(); - roc__mainForHost_1_exposed(&callresult); + roc__main_for_host_1_exposed(&callresult); // display the result using JavaScript js_display_roc_string(callresult.asU8ptrMut(), callresult.len()); diff --git a/crates/cli/tests/platform-switching/web-assembly-platform/main.roc b/crates/cli/tests/platform-switching/web-assembly-platform/main.roc index 08830392cda..ad7de7c8986 100644 --- a/crates/cli/tests/platform-switching/web-assembly-platform/main.roc +++ b/crates/cli/tests/platform-switching/web-assembly-platform/main.roc @@ -3,7 +3,7 @@ platform "echo-in-web-assembly" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Str -mainForHost = main +main_for_host : Str +main_for_host = main diff --git a/crates/cli/tests/platform-switching/zig-platform/host.zig b/crates/cli/tests/platform-switching/zig-platform/host.zig index ce8fdd1e2b5..37a1298119d 100644 --- a/crates/cli/tests/platform-switching/zig-platform/host.zig +++ b/crates/cli/tests/platform-switching/zig-platform/host.zig @@ -102,7 +102,7 @@ comptime { const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__mainForHost_1_exposed_generic(*RocStr) void; +extern fn roc__main_for_host_1_exposed_generic(*RocStr) void; const Unit = extern struct {}; @@ -111,7 +111,7 @@ pub export fn main() u8 { // actually call roc to populate the callresult var callresult = RocStr.empty(); - roc__mainForHost_1_exposed_generic(&callresult); + roc__main_for_host_1_exposed_generic(&callresult); // stdout the result stdout.print("{s}", .{callresult.asSlice()}) catch unreachable; diff --git a/crates/cli/tests/platform-switching/zig-platform/main.roc b/crates/cli/tests/platform-switching/zig-platform/main.roc index a52fe9a4801..f42048abe8c 100644 --- a/crates/cli/tests/platform-switching/zig-platform/main.roc +++ b/crates/cli/tests/platform-switching/zig-platform/main.roc @@ -3,7 +3,7 @@ platform "echo-in-zig" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Str -mainForHost = main +main_for_host : Str +main_for_host = main diff --git a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__expects_test_failure.snap b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__expects_test_failure.snap index e0bd3cb0fd2..69e6dceddcb 100644 --- a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__expects_test_failure.snap +++ b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__expects_test_failure.snap @@ -1,6 +1,7 @@ --- source: crates/cli/tests/cli_tests.rs expression: cli_test_out.normalize_stdout_and_stderr() +snapshot_kind: text --- ── EXPECT FAILED in tests/test-projects/expects/expects.roc ──────────────────── @@ -31,7 +32,7 @@ a = 1 This expectation failed: 11│> expect -12│> a = makeA +12│> a = make_a 13│> b = 2i64 14│> 15│> a == b diff --git a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_arity_mismatch.snap b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_arity_mismatch.snap index b43bfdcbe5e..f3bc460c4df 100644 --- a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_arity_mismatch.snap +++ b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_arity_mismatch.snap @@ -6,10 +6,10 @@ snapshot_kind: text ── TOO MANY ARGS in tests/test-projects/module_params/arity_mismatch.roc ─────── -The getUser function expects 1 argument, but it got 2 instead: +The get_user function expects 1 argument, but it got 2 instead: -12│ $(Api.getUser 1 2) - ^^^^^^^^^^^ +12│ $(Api.get_user(1, 2)) + ^^^^^^^^^^^^ Are there any missing commas? Or missing parentheses? @@ -18,18 +18,18 @@ Are there any missing commas? Or missing parentheses? This value is not a function, but it was given 1 argument: -13│ $(Api.baseUrl 1) - ^^^^^^^^^^^ +13│ $(Api.base_url(1)) + ^^^^^^^^^^^^ Are there any missing commas? Or missing parentheses? ── TOO FEW ARGS in tests/test-projects/module_params/arity_mismatch.roc ──────── -The getPostComment function expects 2 arguments, but it got only 1: +The get_post_comment function expects 2 arguments, but it got only 1: -16│ $(Api.getPostComment 1) - ^^^^^^^^^^^^^^^^^^ +16│ $(Api.get_post_comment(1)) + ^^^^^^^^^^^^^^^^^^^^ Roc does not allow functions to be partially applied. Use a closure to make partial application explicit. diff --git a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_bad_ann.snap b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_bad_ann.snap index 6abc4bcf2bd..70259aade42 100644 --- a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_bad_ann.snap +++ b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_bad_ann.snap @@ -6,34 +6,35 @@ snapshot_kind: text ── TYPE MISMATCH in tests/test-projects/module_params/BadAnn.roc ─────────────── -Something is off with the body of the fnAnnotatedAsValue definition: +Something is off with the body of the +fn_annotated_as_value definition: -3│ fnAnnotatedAsValue : Str -4│> fnAnnotatedAsValue = \postId, commentId -> -5│> "/posts/$(postId)/comments/$(Num.toStr commentId)" +3│ fn_annotated_as_value : Str +4│> fn_annotated_as_value = \post_id, comment_id -> +5│> "/posts/$(post_id)/comments/$(Num.to_str(comment_id))" The body is an anonymous function of type: Str, Num * -> Str -But the type annotation on fnAnnotatedAsValue says it should be: +But the type annotation on fn_annotated_as_value says it should be: Str ── TYPE MISMATCH in tests/test-projects/module_params/BadAnn.roc ─────────────── -Something is off with the body of the missingArg definition: +Something is off with the body of the missing_arg definition: -7│ missingArg : Str -> Str -8│> missingArg = \postId, _ -> -9│> "/posts/$(postId)/comments" +7│ missing_arg : Str -> Str +8│> missing_arg = \post_id, _ -> +9│> "/posts/$(post_id)/comments" The body is an anonymous function of type: (Str, ? -> Str) -But the type annotation on missingArg says it should be: +But the type annotation on missing_arg says it should be: (Str -> Str) diff --git a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_unexpected_fn.snap b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_unexpected_fn.snap index 55ed00e6a1a..61baf2e53ec 100644 --- a/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_unexpected_fn.snap +++ b/crates/cli/tests/snapshots/cli_tests__cli_tests__test_platform_simple_zig__module_params_unexpected_fn.snap @@ -8,9 +8,8 @@ snapshot_kind: text This argument to this string interpolation has an unexpected type: -10│ """ -11│> $(Api.getPost) -12│ """ +10│ "$(Api.get_post)" + ^^^^^^^^^^^^ The argument is an anonymous function of type: diff --git a/crates/cli/tests/test-projects/algorithms/fibonacci-platform/host.zig b/crates/cli/tests/test-projects/algorithms/fibonacci-platform/host.zig index 47e33d8bbd4..cd3d86499e3 100644 --- a/crates/cli/tests/test-projects/algorithms/fibonacci-platform/host.zig +++ b/crates/cli/tests/test-projects/algorithms/fibonacci-platform/host.zig @@ -11,8 +11,8 @@ const mem = std.mem; const Allocator = mem.Allocator; // NOTE the LLVM backend expects this signature -// extern fn roc__mainForHost_1_exposed(i64, *i64) void; -extern fn roc__mainForHost_1_exposed(i64) i64; +// extern fn roc__main_for_host_1_exposed(i64, *i64) void; +extern fn roc__main_for_host_1_exposed(i64) i64; const Align = 2 * @alignOf(usize); extern fn malloc(size: usize) callconv(.C) ?*align(Align) anyopaque; @@ -110,7 +110,7 @@ comptime { pub export fn main() u8 { const stdout = std.io.getStdOut().writer(); - const result = roc__mainForHost_1_exposed(10); + const result = roc__main_for_host_1_exposed(10); stdout.print("{d}\n", .{result}) catch unreachable; diff --git a/crates/cli/tests/test-projects/algorithms/fibonacci-platform/main.roc b/crates/cli/tests/test-projects/algorithms/fibonacci-platform/main.roc index daaf2ff5c85..722540f8092 100644 --- a/crates/cli/tests/test-projects/algorithms/fibonacci-platform/main.roc +++ b/crates/cli/tests/test-projects/algorithms/fibonacci-platform/main.roc @@ -3,7 +3,7 @@ platform "fibonacci" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : I64 -> I64 -mainForHost = \a -> main a +main_for_host : I64 -> I64 +main_for_host = \a -> main(a) diff --git a/crates/cli/tests/test-projects/algorithms/fibonacci.roc b/crates/cli/tests/test-projects/algorithms/fibonacci.roc index cee96929eb5..b8f574b38ca 100644 --- a/crates/cli/tests/test-projects/algorithms/fibonacci.roc +++ b/crates/cli/tests/test-projects/algorithms/fibonacci.roc @@ -1,10 +1,10 @@ app [main] { pf: platform "fibonacci-platform/main.roc" } -main = \n -> fib n 0 1 +main = \n -> fib(n, 0, 1) # the clever implementation requires join points fib = \n, a, b -> if n == 0 then a else - fib (n - 1) b (a + b) + fib((n - 1), b, (a + b)) diff --git a/crates/cli/tests/test-projects/algorithms/quicksort-platform/host.zig b/crates/cli/tests/test-projects/algorithms/quicksort-platform/host.zig index 06b015c6907..7e2ad538dd3 100644 --- a/crates/cli/tests/test-projects/algorithms/quicksort-platform/host.zig +++ b/crates/cli/tests/test-projects/algorithms/quicksort-platform/host.zig @@ -9,7 +9,7 @@ const expect = testing.expect; const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__mainForHost_1_exposed(input: RocList) callconv(.C) RocList; +extern fn roc__main_for_host_1_exposed(input: RocList) callconv(.C) RocList; const Align = 2 * @alignOf(usize); extern fn malloc(size: usize) callconv(.C) ?*align(Align) anyopaque; @@ -128,7 +128,7 @@ pub export fn main() u8 { const roc_list = RocList{ .elements = numbers, .length = NUM_NUMS, .capacity = NUM_NUMS }; // actually call roc to populate the callresult - const callresult: RocList = roc__mainForHost_1_exposed(roc_list); + const callresult: RocList = roc__main_for_host_1_exposed(roc_list); // stdout the result const length = @min(20, callresult.length); diff --git a/crates/cli/tests/test-projects/algorithms/quicksort-platform/main.roc b/crates/cli/tests/test-projects/algorithms/quicksort-platform/main.roc index 37c5db99abe..8b2426b83a9 100644 --- a/crates/cli/tests/test-projects/algorithms/quicksort-platform/main.roc +++ b/crates/cli/tests/test-projects/algorithms/quicksort-platform/main.roc @@ -3,7 +3,7 @@ platform "quicksort" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : List I64 -> List I64 -mainForHost = \list -> quicksort list +main_for_host : List I64 -> List I64 +main_for_host = \list -> quicksort(list) diff --git a/crates/cli/tests/test-projects/algorithms/quicksort.roc b/crates/cli/tests/test-projects/algorithms/quicksort.roc index 7e62e4bbd0e..5a24537938e 100644 --- a/crates/cli/tests/test-projects/algorithms/quicksort.roc +++ b/crates/cli/tests/test-projects/algorithms/quicksort.roc @@ -1,54 +1,54 @@ app [quicksort] { pf: platform "quicksort-platform/main.roc" } -quicksort = \originalList -> - n = List.len originalList +quicksort = \original_list -> + n = List.len(original_list) - quicksortHelp originalList 0 (n - 1) + quicksort_help(original_list, 0, (n - 1)) -quicksortHelp : List (Num a), U64, U64 -> List (Num a) -quicksortHelp = \list, low, high -> +quicksort_help : List (Num a), U64, U64 -> List (Num a) +quicksort_help = \list, low, high -> if low < high then - when partition low high list is - Pair partitionIndex partitioned -> + when partition(low, high, list) is + Pair(partition_index, partitioned) -> partitioned - |> quicksortHelp low (partitionIndex - 1) - |> quicksortHelp (partitionIndex + 1) high + |> quicksort_help(low, (partition_index - 1)) + |> quicksort_help((partition_index + 1), high) else list partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] -partition = \low, high, initialList -> - when List.get initialList high is - Ok pivot -> - when partitionHelp low low initialList high pivot is - Pair newI newList -> - Pair newI (swap newI high newList) - - Err _ -> - Pair low initialList - -partitionHelp : U64, U64, List (Num c), U64, Num c -> [Pair U64 (List (Num c))] -partitionHelp = \i, j, list, high, pivot -> +partition = \low, high, initial_list -> + when List.get(initial_list, high) is + Ok(pivot) -> + when partition_help(low, low, initial_list, high, pivot) is + Pair(new_i, new_list) -> + Pair(new_i, swap(new_i, high, new_list)) + + Err(_) -> + Pair(low, initial_list) + +partition_help : U64, U64, List (Num c), U64, Num c -> [Pair U64 (List (Num c))] +partition_help = \i, j, list, high, pivot -> if j < high then - when List.get list j is - Ok value -> + when List.get(list, j) is + Ok(value) -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap i j list) high pivot + partition_help((i + 1), (j + 1), swap(i, j, list), high, pivot) else - partitionHelp i (j + 1) list high pivot + partition_help(i, (j + 1), list, high, pivot) - Err _ -> - Pair i list + Err(_) -> + Pair(i, list) else - Pair i list + Pair(i, list) swap : U64, U64, List a -> List a swap = \i, j, list -> - when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + when Pair(List.get(list, i), List.get(list, j)) is + Pair(Ok(at_i), Ok(at_j)) -> list - |> List.set i atJ - |> List.set j atI + |> List.set(i, at_j) + |> List.set(j, at_i) _ -> # to prevent a decrement on list diff --git a/crates/cli/tests/test-projects/effectful/Community.roc b/crates/cli/tests/test-projects/effectful/Community.roc index e19906a8f66..5fcada82f98 100644 --- a/crates/cli/tests/test-projects/effectful/Community.roc +++ b/crates/cli/tests/test-projects/effectful/Community.roc @@ -1,10 +1,10 @@ module [ Community, empty, - addPerson, - addFriend, + add_person, + add_friend, Person, - walkFriendNames, + walk_friend_names, ] ## Datatype representing a community for demonstration purposes in inspect-gui.roc and inspect-logging.roc @@ -16,11 +16,11 @@ Community := { implements [Inspect] Person := { - firstName : Str, - lastName : Str, + first_name : Str, + last_name : Str, age : U8, - hasBeard : Bool, - favoriteColor : Color, + has_beard : Bool, + favorite_color : Color, } implements [Inspect] @@ -31,52 +31,52 @@ Color : [ RGB (U8, U8, U8), ] -empty = @Community { people: [], friends: [] } +empty = @Community({ people: [], friends: [] }) -addPerson = \@Community { people, friends }, person -> - @Community { - people: List.append people (@Person person), - friends: List.append friends (Set.empty {}), - } +add_person = \@Community({ people, friends }), person -> + @Community({ + people: List.append(people, @Person(person)), + friends: List.append(friends, Set.empty({})), + }) -addFriend = \@Community { people, friends }, from, to -> - when (List.get friends from, List.get friends to) is - (Ok fromSet, Ok toSet) -> - @Community { +add_friend = \@Community({ people, friends }), from, to -> + when (List.get(friends, from), List.get(friends, to)) is + (Ok(from_set), Ok(to_set)) -> + @Community({ people, friends: friends - |> List.set from (Set.insert fromSet to) - |> List.set to (Set.insert toSet from), - } + |> List.set(from, Set.insert(from_set, to)) + |> List.set(to, Set.insert(to_set, from)), + }) _ -> - @Community { people, friends } + @Community({ people, friends }) -walkFriendNames : Community, state, (state, Str, Set Str -> state) -> state -walkFriendNames = \@Community { people, friends }, s0, nextFn -> +walk_friend_names : Community, state, (state, Str, Set Str -> state) -> state +walk_friend_names = \@Community({ people, friends }), s0, next_fn -> (out, _) = - List.walk friends (s0, 0) \(s1, id), friendSet -> - (@Person person) = - when List.get people id is - Ok v -> v - Err _ -> crash "Unknown Person" - personName = - person.firstName - |> Str.concat " " - |> Str.concat person.lastName + List.walk(friends, (s0, 0), \(s1, id), friend_set -> + @Person(person) = + when List.get(people, id) is + Ok(v) -> v + Err(_) -> crash("Unknown Person") + person_name = + person.first_name + |> Str.concat(" ") + |> Str.concat(person.last_name) - friendNames = - Set.walk friendSet (Set.empty {}) \friendsSet, friendId -> - (@Person friend) = - when List.get people friendId is - Ok v -> v - Err _ -> crash "Unknown Person" - friendName = - friend.firstName - |> Str.concat " " - |> Str.concat friend.lastName - Set.insert friendsSet friendName + friend_names = + Set.walk(friend_set, Set.empty({}), \friends_set, friend_id -> + @Person(friend) = + when List.get(people, friend_id) is + Ok(v) -> v + Err(_) -> crash("Unknown Person") + friend_name = + friend.first_name + |> Str.concat(" ") + |> Str.concat(friend.last_name) + Set.insert(friends_set, friend_name)) - (nextFn s1 personName friendNames, id + 1) + (next_fn(s1, person_name, friend_names), id + 1)) out diff --git a/crates/cli/tests/test-projects/effectful/combine-tasks.roc b/crates/cli/tests/test-projects/effectful/combine-tasks.roc index f801791df43..576275e925c 100644 --- a/crates/cli/tests/test-projects/effectful/combine-tasks.roc +++ b/crates/cli/tests/test-projects/effectful/combine-tasks.roc @@ -3,19 +3,19 @@ app [main] { pf: platform "https://github.com/roc-lang/basic-cli/releases/downlo import pf.Stdout main = - multipleIn = + multiple_in = { sequential <- - a: Task.ok 123, - b: Task.ok "abc", - c: Task.ok [123], - _d: Task.ok ["abc"], - _: Task.ok (Dict.single "a" "b"), + a: Task.ok(123), + b: Task.ok("abc"), + c: Task.ok([123]), + _d: Task.ok(["abc"]), + _: Task.ok(Dict.single("a", "b")), }! - Stdout.line! "For multiple tasks: $(Inspect.toStr multipleIn)" + Stdout.line!("For multiple tasks: $(Inspect.to_str(multiple_in))") sequential : Task a err, Task b err, (a, b -> c) -> Task c err -sequential = \firstTask, secondTask, mapper -> - first = firstTask! - second = secondTask! - Task.ok (mapper first second) +sequential = \first_task, second_task, mapper -> + first = first_task! + second = second_task! + Task.ok(mapper(first, second)) diff --git a/crates/cli/tests/test-projects/effectful/echo.roc b/crates/cli/tests/test-projects/effectful/echo.roc index c3c51c1dfcd..047d3783dd9 100644 --- a/crates/cli/tests/test-projects/effectful/echo.roc +++ b/crates/cli/tests/test-projects/effectful/echo.roc @@ -3,33 +3,33 @@ app [main!] { pf: platform "../test-platform-effects-zig/main.roc" } import pf.Effect main! : {} => {} -main! = \{} -> tick! {} +main! = \{} -> tick!({}) tick! = \{} -> - line = Effect.getLine! {} + line = Effect.get_line!({}) - if !(Str.isEmpty line) then - Effect.putLine! (echo line) + if !(Str.is_empty(line)) then + Effect.put_line!(echo(line)) else - Effect.putLine! "Received no input." + Effect.put_line!("Received no input.") echo : Str -> Str echo = \shout -> - silence = \length -> List.repeat ' ' length + silence = \length -> List.repeat(' ', length) shout - |> Str.toUtf8 - |> List.mapWithIndex \_, i -> - length = (List.len (Str.toUtf8 shout) - i) - phrase = (List.splitAt (Str.toUtf8 shout) length).before + |> Str.to_utf8 + |> List.map_with_index(\_, i -> + length = (List.len(Str.to_utf8(shout)) - i) + phrase = (List.split_at(Str.to_utf8(shout), length)).before - List.concat (silence (if i == 0 then 2 * length else length)) phrase + List.concat(silence((if i == 0 then 2 * length else length)), phrase)) |> List.join - |> Str.fromUtf8 - |> Result.withDefault "" + |> Str.from_utf8 + |> Result.with_default("") expect message = "hello!" - echoedMessage = echo message + echoed_message = echo(message) - echoedMessage == " hello! hello hell hel he h" + echoed_message == " hello! hello hell hel he h" diff --git a/crates/cli/tests/test-projects/effectful/for_each_try.roc b/crates/cli/tests/test-projects/effectful/for_each_try.roc index a6a219c4282..e7f67091631 100644 --- a/crates/cli/tests/test-projects/effectful/for_each_try.roc +++ b/crates/cli/tests/test-projects/effectful/for_each_try.roc @@ -4,20 +4,19 @@ import pf.Effect main! : {} => {} main! = \{} -> - good = [0, 2, 4] |> List.forEachTry! validate! - expect good == Ok {} + good = [0, 2, 4] |> List.for_each_try!(validate!) + expect good == Ok({}) - bad = [6, 8, 9, 10] |> List.forEachTry! validate! - expect bad == Err 9 + bad = [6, 8, 9, 10] |> List.for_each_try!(validate!) + expect bad == Err(9) {} validate! : U32 => Result {} U32 validate! = \x -> - if Num.isEven x then - Effect.putLine! "✅ $(Num.toStr x)" - Ok {} - + if Num.is_even(x) then + Effect.put_line!("✅ $(Num.to_str(x))") + Ok({}) else - Effect.putLine! "$(Num.toStr x) is not even! ABORT!" - Err x + Effect.put_line!("$(Num.to_str(x)) is not even! ABORT!") + Err(x) diff --git a/crates/cli/tests/test-projects/effectful/form.roc b/crates/cli/tests/test-projects/effectful/form.roc index dd0a9b773fa..0f57f2a82bb 100644 --- a/crates/cli/tests/test-projects/effectful/form.roc +++ b/crates/cli/tests/test-projects/effectful/form.roc @@ -4,24 +4,24 @@ import pf.Effect main! : {} => {} main! = \{} -> - first = ask! "What's your first name?" - last = ask! "What's your last name?" + first = ask!("What's your first name?") + last = ask!("What's your last name?") - Effect.putLine! "\nHi, $(first) $(last)!\n" + Effect.put_line!("\nHi, $(first) $(last)!\n") - when Str.toU8 (ask! "How old are you?") is - Err InvalidNumStr -> - Effect.putLine! "Enter a valid number" + when Str.to_u8(ask!("How old are you?")) is + Err(InvalidNumStr) -> + Effect.put_line!("Enter a valid number") - Ok age if age >= 18 -> - Effect.putLine! "\nNice! You can vote!" + Ok(age) if age >= 18 -> + Effect.put_line!("\nNice! You can vote!") - Ok age -> - Effect.putLine! "\nYou'll be able to vote in $(Num.toStr (18 - age)) years" + Ok(age) -> + Effect.put_line!("\nYou'll be able to vote in $(Num.to_str((18 - age))) years") - Effect.putLine! "\nBye! 👋" + Effect.put_line!("\nBye! 👋") ask! : Str => Str ask! = \question -> - Effect.putLine! question - Effect.getLine! {} + Effect.put_line!(question) + Effect.get_line!({}) diff --git a/crates/cli/tests/test-projects/effectful/hello.roc b/crates/cli/tests/test-projects/effectful/hello.roc index 998ab4f8638..8a856861502 100644 --- a/crates/cli/tests/test-projects/effectful/hello.roc +++ b/crates/cli/tests/test-projects/effectful/hello.roc @@ -4,4 +4,4 @@ import pf.Effect main! : {} => {} main! = \{} -> - Effect.putLine! "I'm an effect 👻" + Effect.put_line!("I'm an effect 👻") diff --git a/crates/cli/tests/test-projects/effectful/ignore_result.roc b/crates/cli/tests/test-projects/effectful/ignore_result.roc index 828d24a73bd..9d9627fd12f 100644 --- a/crates/cli/tests/test-projects/effectful/ignore_result.roc +++ b/crates/cli/tests/test-projects/effectful/ignore_result.roc @@ -4,5 +4,5 @@ import pf.Effect main! : {} => {} main! = \{} -> - _ = Effect.getLine! {} - Effect.putLine! "I asked for input and I ignored it. Deal with it! 😎" + _ = Effect.get_line!({}) + Effect.put_line!("I asked for input and I ignored it. Deal with it! 😎") diff --git a/crates/cli/tests/test-projects/effectful/inspect-logging.roc b/crates/cli/tests/test-projects/effectful/inspect-logging.roc index eaa0cdd458f..06380f091e1 100644 --- a/crates/cli/tests/test-projects/effectful/inspect-logging.roc +++ b/crates/cli/tests/test-projects/effectful/inspect-logging.roc @@ -8,28 +8,28 @@ import Community main! = \{} -> Community.empty - |> Community.addPerson { - firstName: "John", - lastName: "Smith", + |> Community.add_person({ + first_name: "John", + last_name: "Smith", age: 27, - hasBeard: Bool.true, - favoriteColor: Blue, - } - |> Community.addPerson { - firstName: "Debby", - lastName: "Johnson", + has_beard: Bool.true, + favorite_color: Blue, + }) + |> Community.add_person({ + first_name: "Debby", + last_name: "Johnson", age: 47, - hasBeard: Bool.false, - favoriteColor: Green, - } - |> Community.addPerson { - firstName: "Jane", - lastName: "Doe", + has_beard: Bool.false, + favorite_color: Green, + }) + |> Community.add_person({ + first_name: "Jane", + last_name: "Doe", age: 33, - hasBeard: Bool.false, - favoriteColor: RGB (255, 255, 0), - } - |> Community.addFriend 0 2 - |> Community.addFriend 1 2 - |> Inspect.toStr - |> Effect.putLine! + has_beard: Bool.false, + favorite_color: RGB((255, 255, 0)), + }) + |> Community.add_friend(0, 2) + |> Community.add_friend(1, 2) + |> Inspect.to_str + |> Effect.put_line! diff --git a/crates/cli/tests/test-projects/effectful/loops.roc b/crates/cli/tests/test-projects/effectful/loops.roc index 170b1652f39..cb3b77199b1 100644 --- a/crates/cli/tests/test-projects/effectful/loops.roc +++ b/crates/cli/tests/test-projects/effectful/loops.roc @@ -5,12 +5,12 @@ import pf.Effect main! : {} => {} main! = \{} -> friends = ["Lu", "Marce", "Joaquin", "Chloé", "Mati", "Pedro"] - printAll! friends + print_all!(friends) -printAll! : List Str => {} -printAll! = \friends -> +print_all! : List Str => {} +print_all! = \friends -> when friends is [] -> {} [first, .. as remaining] -> - Effect.putLine! first - printAll! remaining + Effect.put_line!(first) + print_all!(remaining) diff --git a/crates/cli/tests/test-projects/effectful/on_err.roc b/crates/cli/tests/test-projects/effectful/on_err.roc index a8c4df24d8a..84370a40cdf 100644 --- a/crates/cli/tests/test-projects/effectful/on_err.roc +++ b/crates/cli/tests/test-projects/effectful/on_err.roc @@ -5,20 +5,20 @@ import pf.Effect main! : {} => {} main! = \{} -> _ = - authenticate! {} - |> Result.onErr! \BadPass -> - Effect.putLine! "LOG: Failed login attempt" - Ok "Bad password" + authenticate!({}) + |> Result.on_err!(\BadPass -> + Effect.put_line!("LOG: Failed login attempt") + Ok("Bad password")) {} authenticate! : {} => Result Str [BadPass] authenticate! = \{} -> - Effect.putLine! "Enter your password:" + Effect.put_line!("Enter your password:") - password = Effect.getLine! {} + password = Effect.get_line!({}) if password == "password" then - Ok "You are in" + Ok("You are in") else - Err BadPass + Err(BadPass) diff --git a/crates/cli/tests/test-projects/effectful/print-line.roc b/crates/cli/tests/test-projects/effectful/print-line.roc index b691400c452..64a55709344 100644 --- a/crates/cli/tests/test-projects/effectful/print-line.roc +++ b/crates/cli/tests/test-projects/effectful/print-line.roc @@ -5,15 +5,15 @@ import pf.Effect main! : {} => {} main! = \{} -> ["Welcome!", "What's your name?"] - |> List.forEach! Effect.putLine! + |> List.for_each!(Effect.put_line!) - line = Effect.getLine! {} + line = Effect.get_line!({}) if line == "secret" then - Effect.putLine! "You found the secret" - Effect.putLine! "Congratulations!" + Effect.put_line!("You found the secret") + Effect.put_line!("Congratulations!") else {} - Effect.putLine! "You entered: $(line)" - Effect.putLine! "It is known" + Effect.put_line!("You entered: $(line)") + Effect.put_line!("It is known") diff --git a/crates/cli/tests/test-projects/effectful/suffixed_record_field.roc b/crates/cli/tests/test-projects/effectful/suffixed_record_field.roc index f329cdbcb5a..c417a2388cb 100644 --- a/crates/cli/tests/test-projects/effectful/suffixed_record_field.roc +++ b/crates/cli/tests/test-projects/effectful/suffixed_record_field.roc @@ -3,20 +3,20 @@ app [main!] { pf: platform "../test-platform-effects-zig/main.roc" } import pf.Effect Fx : { - getLine!: {} => Str, + get_line! : {} => Str, } main! : {} => {} main! = \{} -> - notEffectful : Fx - notEffectful = { - getLine!: \{} -> "hardcoded" + not_effectful : Fx + not_effectful = { + get_line!: \{} -> "hardcoded", } effectful : Fx effectful = { - getLine!: Effect.getLine! + get_line!: Effect.get_line!, } - Effect.putLine! "notEffectful: $(notEffectful.getLine! {})" - Effect.putLine! "effectful: $(effectful.getLine! {})" + Effect.put_line!("not_effectful: $(not_effectful.get_line!({}))") + Effect.put_line!("effectful: $(effectful.get_line!({}))") diff --git a/crates/cli/tests/test-projects/effectful/untyped_passed_fx.roc b/crates/cli/tests/test-projects/effectful/untyped_passed_fx.roc index 98c4ad1fc90..5e2ef0f030a 100644 --- a/crates/cli/tests/test-projects/effectful/untyped_passed_fx.roc +++ b/crates/cli/tests/test-projects/effectful/untyped_passed_fx.roc @@ -4,9 +4,9 @@ import pf.Effect main! : {} => {} main! = \{} -> - logged! "hello" (\{} -> Effect.putLine! "Hello, World!") + logged!("hello", \{} -> Effect.put_line!("Hello, World!")) logged! = \name, fx! -> - Effect.putLine! "Before $(name)" - fx! {} - Effect.putLine! "After $(name)" + Effect.put_line!("Before $(name)") + fx!({}) + Effect.put_line!("After $(name)") diff --git a/crates/cli/tests/test-projects/expects/expects.roc b/crates/cli/tests/test-projects/expects/expects.roc index 0e9a57c0df9..7a64bc80741 100644 --- a/crates/cli/tests/test-projects/expects/expects.roc +++ b/crates/cli/tests/test-projects/expects/expects.roc @@ -1,6 +1,6 @@ app [main] { pf: platform "../test-platform-simple-zig/main.roc" } -makeA = +make_a = a = 1 expect a == 2 @@ -9,29 +9,29 @@ makeA = a expect - a = makeA + a = make_a b = 2i64 a == b -polyDbg = \x -> - dbg x +poly_dbg = \x -> + dbg(x) x main = str = "this will for sure be a large string so when we split it it will use seamless slices which affect printing" - words = Str.splitOn str " " + words = Str.split_on(str, " ") expect words == [] x = 42 - dbg x + dbg(x) - dbg "Fjoer en ferdjer frieten oan dyn geve lea" + dbg("Fjoer en ferdjer frieten oan dyn geve lea") - dbg "this is line 24" + dbg("this is line 24") - r = { x: polyDbg "abc", y: polyDbg 10u8, z: polyDbg (A (B C)) } + r = { x: poly_dbg("abc"), y: poly_dbg(10u8), z: poly_dbg(A(B(C))) } when r is _ -> "Program finished!\n" diff --git a/crates/cli/tests/test-projects/expects_transitive/Direct.roc b/crates/cli/tests/test-projects/expects_transitive/Direct.roc index 9e9d22ba723..d7d50ccad16 100644 --- a/crates/cli/tests/test-projects/expects_transitive/Direct.roc +++ b/crates/cli/tests/test-projects/expects_transitive/Direct.roc @@ -1,12 +1,12 @@ module [ - addAndStringify, + add_and_stringify, ] import Transitive -addAndStringify = \num1, num2 -> - Num.toStr (Transitive.add num1 num2) +add_and_stringify = \num1, num2 -> + Num.to_str(Transitive.add(num1, num2)) -expect addAndStringify 1 2 == "3" +expect add_and_stringify(1, 2) == "3" -expect addAndStringify 3 4 == "7" +expect add_and_stringify(3, 4) == "7" diff --git a/crates/cli/tests/test-projects/expects_transitive/Transitive.roc b/crates/cli/tests/test-projects/expects_transitive/Transitive.roc index 925c95d0e7c..db77221bae4 100644 --- a/crates/cli/tests/test-projects/expects_transitive/Transitive.roc +++ b/crates/cli/tests/test-projects/expects_transitive/Transitive.roc @@ -4,4 +4,4 @@ module [ add = \num1, num2 -> (num1 + num2) -expect add 1 2 == 3 +expect add(1, 2) == 3 diff --git a/crates/cli/tests/test-projects/false-interpreter/Context.roc b/crates/cli/tests/test-projects/false-interpreter/Context.roc index 99a4af99c8f..f0525deba20 100644 --- a/crates/cli/tests/test-projects/false-interpreter/Context.roc +++ b/crates/cli/tests/test-projects/false-interpreter/Context.roc @@ -1,4 +1,4 @@ -module [Context, Data, with!, getChar!, Option, pushStack, popStack, toStr, inWhileScope] +module [Context, Data, with!, get_char!, Option, push_stack, pop_stack, to_str, in_while_scope] import pf.File import Variable exposing [Variable] @@ -9,100 +9,100 @@ Option a : [Some a, None] Data : [Lambda (List U8), Number I32, Var Variable] # While loops are special and have their own Scope specific state. WhileState : { cond : List U8, body : List U8, state : [InCond, InBody] } -Scope : { data : Option File.Handle, index : U64, buf : List U8, whileInfo : Option WhileState } +Scope : { data : Option File.Handle, index : U64, buf : List U8, while_info : Option WhileState } State : [Executing, InComment, InLambda U64 (List U8), InString (List U8), InNumber I32, InSpecialChar, LoadChar] Context : { scopes : List Scope, stack : List Data, vars : List Data, state : State } -pushStack : Context, Data -> Context -pushStack = \ctx, data -> - { ctx & stack: List.append ctx.stack data } +push_stack : Context, Data -> Context +push_stack = \ctx, data -> + { ctx & stack: List.append(ctx.stack, data) } # I think an open tag union should just work here. # Instead at a call sites, I need to match on the error and then return the same error. # Otherwise it hits unreachable code in ir.rs -popStack : Context -> Result (Context, Data) [EmptyStack] -popStack = \ctx -> - when List.last ctx.stack is - Ok val -> - poppedCtx = { ctx & stack: List.dropAt ctx.stack (List.len ctx.stack - 1) } +pop_stack : Context -> Result (Context, Data) [EmptyStack] +pop_stack = \ctx -> + when List.last(ctx.stack) is + Ok(val) -> + popped_ctx = { ctx & stack: List.drop_at(ctx.stack, (List.len(ctx.stack) - 1)) } - Ok (poppedCtx, val) + Ok((popped_ctx, val)) - Err ListWasEmpty -> - Err EmptyStack + Err(ListWasEmpty) -> + Err(EmptyStack) -toStrData : Data -> Str -toStrData = \data -> +to_str_data : Data -> Str +to_str_data = \data -> when data is - Lambda _ -> "[]" - Number n -> Num.toStr (Num.intCast n) - Var v -> Variable.toStr v + Lambda(_) -> "[]" + Number(n) -> Num.to_str(Num.int_cast(n)) + Var(v) -> Variable.to_str(v) -toStrState : State -> Str -toStrState = \state -> +to_str_state : State -> Str +to_str_state = \state -> when state is Executing -> "Executing" InComment -> "InComment" - InString _ -> "InString" - InNumber _ -> "InNumber" - InLambda _ _ -> "InLambda" + InString(_) -> "InString" + InNumber(_) -> "InNumber" + InLambda(_, _) -> "InLambda" InSpecialChar -> "InSpecialChar" LoadChar -> "LoadChar" -toStr : Context -> Str -toStr = \{ scopes, stack, state, vars } -> - depth = Num.toStr (List.len scopes) - stateStr = toStrState state - stackStr = Str.joinWith (List.map stack toStrData) " " - varsStr = Str.joinWith (List.map vars toStrData) " " +to_str : Context -> Str +to_str = \{ scopes, stack, state, vars } -> + depth = Num.to_str(List.len(scopes)) + state_str = to_str_state(state) + stack_str = Str.join_with(List.map(stack, to_str_data), " ") + vars_str = Str.join_with(List.map(vars, to_str_data), " ") - "\n============\nDepth: $(depth)\nState: $(stateStr)\nStack: [$(stackStr)]\nVars: [$(varsStr)]\n============\n" + "\n============\nDepth: $(depth)\nState: $(state_str)\nStack: [$(stack_str)]\nVars: [$(vars_str)]\n============\n" with! : Str, (Context => a) => a with! = \path, callback! -> - File.withOpen! path \handle -> + File.with_open!(path, \handle -> # I cant define scope here and put it in the list in callback. It breaks alias anaysis. # Instead I have to inline this. # root_scope = { data: Some handle, index: 0, buf: [], whileInfo: None } - callback! { scopes: [{ data: Some handle, index: 0, buf: [], whileInfo: None }], state: Executing, stack: [], vars: List.repeat (Number 0) Variable.totalCount } + callback!({ scopes: [{ data: Some(handle), index: 0, buf: [], while_info: None }], state: Executing, stack: [], vars: List.repeat(Number(0), Variable.total_count) })) # I am pretty sure there is a syntax to destructure and keep a reference to the whole, but Im not sure what it is. -getChar! : Context => Result (U8, Context) [EndOfData, NoScope] -getChar! = \ctx -> - when List.last ctx.scopes is - Ok scope -> - (val, newScope) = getCharScope!? scope - Ok (val, { ctx & scopes: List.set ctx.scopes (List.len ctx.scopes - 1) newScope }) - - Err ListWasEmpty -> - Err NoScope - -getCharScope! : Scope => Result (U8, Scope) [EndOfData, NoScope] -getCharScope! = \scope -> - when List.get scope.buf scope.index is - Ok val -> - Ok (val, { scope & index: scope.index + 1 }) - - Err OutOfBounds -> +get_char! : Context => Result (U8, Context) [EndOfData, NoScope] +get_char! = \ctx -> + when List.last(ctx.scopes) is + Ok(scope) -> + (val, new_scope) = get_char_scope!?(scope) + Ok((val, { ctx & scopes: List.set(ctx.scopes, (List.len(ctx.scopes) - 1), new_scope) })) + + Err(ListWasEmpty) -> + Err(NoScope) + +get_char_scope! : Scope => Result (U8, Scope) [EndOfData, NoScope] +get_char_scope! = \scope -> + when List.get(scope.buf, scope.index) is + Ok(val) -> + Ok((val, { scope & index: scope.index + 1 })) + + Err(OutOfBounds) -> when scope.data is - Some h -> - bytes = File.chunk! h - when List.first bytes is - Ok val -> + Some(h) -> + bytes = File.chunk!(h) + when List.first(bytes) is + Ok(val) -> # This starts at 1 because the first character is already being returned. - Ok (val, { scope & buf: bytes, index: 1 }) + Ok((val, { scope & buf: bytes, index: 1 })) - Err ListWasEmpty -> - Err EndOfData + Err(ListWasEmpty) -> + Err(EndOfData) None -> - Err EndOfData + Err(EndOfData) -inWhileScope : Context -> Bool -inWhileScope = \ctx -> - when List.last ctx.scopes is - Ok scope -> - scope.whileInfo != None +in_while_scope : Context -> Bool +in_while_scope = \ctx -> + when List.last(ctx.scopes) is + Ok(scope) -> + scope.while_info != None - Err ListWasEmpty -> + Err(ListWasEmpty) -> Bool.false diff --git a/crates/cli/tests/test-projects/false-interpreter/Variable.roc b/crates/cli/tests/test-projects/false-interpreter/Variable.roc index f71f8cd577d..7bcf7db8a83 100644 --- a/crates/cli/tests/test-projects/false-interpreter/Variable.roc +++ b/crates/cli/tests/test-projects/false-interpreter/Variable.roc @@ -1,33 +1,33 @@ -module [Variable, fromUtf8, toIndex, totalCount, toStr] +module [Variable, from_utf8, to_index, total_count, to_str] # Variables in False can only be single letters. Thus, the valid variables are "a" to "z". # This opaque type deals with ensure we always have valid variables. Variable := U8 -totalCount : U64 -totalCount = +total_count : U64 +total_count = 0x7A # "z" - 0x61 # "a" + 1 -toStr : Variable -> Str -toStr = \@Variable char -> - when Str.fromUtf8 [char] is - Ok str -> str +to_str : Variable -> Str +to_str = \@Variable(char) -> + when Str.from_utf8([char]) is + Ok(str) -> str _ -> "_" -fromUtf8 : U8 -> Result Variable [InvalidVariableUtf8] -fromUtf8 = \char -> +from_utf8 : U8 -> Result Variable [InvalidVariableUtf8] +from_utf8 = \char -> if char >= 0x61 # "a" && char <= 0x7A # "z" then - Ok (@Variable char) + Ok(@Variable(char)) else - Err InvalidVariableUtf8 + Err(InvalidVariableUtf8) -toIndex : Variable -> U64 -toIndex = \@Variable char -> - Num.intCast (char - 0x61) # "a" +to_index : Variable -> U64 +to_index = \@Variable(char) -> + Num.int_cast((char - 0x61)) # "a" diff --git a/crates/cli/tests/test-projects/false-interpreter/main.roc b/crates/cli/tests/test-projects/false-interpreter/main.roc index 062e0f491e8..5553f4011ba 100644 --- a/crates/cli/tests/test-projects/false-interpreter/main.roc +++ b/crates/cli/tests/test-projects/false-interpreter/main.roc @@ -16,454 +16,454 @@ InterpreterErrors : [BadUtf8, DivByZero, EmptyStack, InvalidBooleanValue, Invali main! : Str => {} main! = \filename -> - when interpretFile! filename is - Ok {} -> + when interpret_file!(filename) is + Ok({}) -> {} - Err (StringErr e) -> - Stdout.line! "Ran into problem:\n$(e)\n" + Err(StringErr(e)) -> + Stdout.line!("Ran into problem:\n$(e)\n") -interpretFile! : Str => Result {} [StringErr Str] -interpretFile! = \filename -> - Context.with! filename \ctx -> - result = interpretCtx! ctx +interpret_file! : Str => Result {} [StringErr Str] +interpret_file! = \filename -> + Context.with!(filename, \ctx -> + result = interpret_ctx!(ctx) when result is - Ok _ -> - Ok {} + Ok(_) -> + Ok({}) - Err BadUtf8 -> - Err (StringErr "Failed to convert string from Utf8 bytes") + Err(BadUtf8) -> + Err(StringErr("Failed to convert string from Utf8 bytes")) - Err DivByZero -> - Err (StringErr "Division by zero") + Err(DivByZero) -> + Err(StringErr("Division by zero")) - Err EmptyStack -> - Err (StringErr "Tried to pop a value off of the stack when it was empty") + Err(EmptyStack) -> + Err(StringErr("Tried to pop a value off of the stack when it was empty")) - Err InvalidBooleanValue -> - Err (StringErr "Ran into an invalid boolean that was neither false (0) or true (-1)") + Err(InvalidBooleanValue) -> + Err(StringErr("Ran into an invalid boolean that was neither false (0) or true (-1)")) - Err (InvalidChar char) -> - Err (StringErr "Ran into an invalid character with ascii code: $(char)") + Err(InvalidChar(char)) -> + Err(StringErr("Ran into an invalid character with ascii code: $(char)")) - Err MaxInputNumber -> - Err (StringErr "Like the original false compiler, the max input number is 320,000") + Err(MaxInputNumber) -> + Err(StringErr("Like the original false compiler, the max input number is 320,000")) - Err NoLambdaOnStack -> - Err (StringErr "Tried to run a lambda when no lambda was on the stack") + Err(NoLambdaOnStack) -> + Err(StringErr("Tried to run a lambda when no lambda was on the stack")) - Err NoNumberOnStack -> - Err (StringErr "Tried to run a number when no number was on the stack") + Err(NoNumberOnStack) -> + Err(StringErr("Tried to run a number when no number was on the stack")) - Err NoVariableOnStack -> - Err (StringErr "Tried to load a variable when no variable was on the stack") + Err(NoVariableOnStack) -> + Err(StringErr("Tried to load a variable when no variable was on the stack")) - Err NoScope -> - Err (StringErr "Tried to run code when not in any scope") + Err(NoScope) -> + Err(StringErr("Tried to run code when not in any scope")) - Err OutOfBounds -> - Err (StringErr "Tried to load from an offset that was outside of the stack") + Err(OutOfBounds) -> + Err(StringErr("Tried to load from an offset that was outside of the stack")) - Err UnexpectedEndOfData -> - Err (StringErr "Hit end of data while still parsing something") + Err(UnexpectedEndOfData) -> + Err(StringErr("Hit end of data while still parsing something"))) -interpretCtx! : Context => Result Context InterpreterErrors -interpretCtx! = \ctx -> - when interpretCtxLoop! ctx is - Ok (Step next) -> - interpretCtx! next +interpret_ctx! : Context => Result Context InterpreterErrors +interpret_ctx! = \ctx -> + when interpret_ctx_loop!(ctx) is + Ok(Step(next)) -> + interpret_ctx!(next) - Ok (Done next) -> - Ok next + Ok(Done(next)) -> + Ok(next) - Err e -> - Err e + Err(e) -> + Err(e) -interpretCtxLoop! : Context => Result [Step Context, Done Context] InterpreterErrors -interpretCtxLoop! = \ctx -> +interpret_ctx_loop! : Context => Result [Step Context, Done Context] InterpreterErrors +interpret_ctx_loop! = \ctx -> when ctx.state is - Executing if Context.inWhileScope ctx -> + Executing if Context.in_while_scope(ctx) -> # Deal with the current while loop potentially looping. - last = (List.len ctx.scopes - 1) + last = (List.len(ctx.scopes) - 1) - scope = List.get ctx.scopes last |> Result.mapErr? \_ -> NoScope - when scope.whileInfo is - Some { state: InCond, body, cond } -> + scope = List.get(ctx.scopes, last) |> Result.map_err?(\_ -> NoScope) + when scope.while_info is + Some({ state: InCond, body, cond }) -> # Just ran condition. Check the top of stack to see if body should run. - (popCtx, n) = popNumber? ctx + (pop_ctx, n) = pop_number?(ctx) if n == 0 then - newScope = { scope & whileInfo: None } + new_scope = { scope & while_info: None } - Ok (Step { popCtx & scopes: List.set ctx.scopes last newScope }) + Ok(Step({ pop_ctx & scopes: List.set(ctx.scopes, last, new_scope) })) else - newScope = { scope & whileInfo: Some { state: InBody, body, cond } } + new_scope = { scope & while_info: Some({ state: InBody, body, cond }) } - Ok (Step { popCtx & scopes: List.append (List.set ctx.scopes last newScope) { data: None, buf: body, index: 0, whileInfo: None } }) + Ok(Step({ pop_ctx & scopes: List.append(List.set(ctx.scopes, last, new_scope), { data: None, buf: body, index: 0, while_info: None }) })) - Some { state: InBody, body, cond } -> + Some({ state: InBody, body, cond }) -> # Just rand the body. Run the condition again. - newScope = { scope & whileInfo: Some { state: InCond, body, cond } } + new_scope = { scope & while_info: Some({ state: InCond, body, cond }) } - Ok (Step { ctx & scopes: List.append (List.set ctx.scopes last newScope) { data: None, buf: cond, index: 0, whileInfo: None } }) + Ok(Step({ ctx & scopes: List.append(List.set(ctx.scopes, last, new_scope), { data: None, buf: cond, index: 0, while_info: None }) })) None -> - Err NoScope + Err(NoScope) Executing -> - # Stdout.line! (Context.toStr ctx) - result = Context.getChar! ctx + # Stdout.line! (Context.to_str ctx) + result = Context.get_char!(ctx) when result is - Ok (val, newCtx) -> - execCtx = stepExecCtx!? newCtx val - Ok (Step execCtx) + Ok((val, new_ctx)) -> + exec_ctx = step_exec_ctx!?(new_ctx, val) + Ok(Step(exec_ctx)) - Err NoScope -> - Err NoScope + Err(NoScope) -> + Err(NoScope) - Err EndOfData -> + Err(EndOfData) -> # Computation complete for this scope. # Drop a scope. - dropCtx = { ctx & scopes: List.dropAt ctx.scopes (List.len ctx.scopes - 1) } + drop_ctx = { ctx & scopes: List.drop_at(ctx.scopes, (List.len(ctx.scopes) - 1)) } # If no scopes left, all execution complete. - if List.isEmpty dropCtx.scopes then - Ok (Done dropCtx) + if List.is_empty(drop_ctx.scopes) then + Ok(Done(drop_ctx)) else - Ok (Step dropCtx) + Ok(Step(drop_ctx)) InComment -> - (val, newCtx) = Context.getChar! ctx |> Result.mapErr? endUnexpected + (val, new_ctx) = Context.get_char!(ctx) |> Result.map_err?(end_unexpected) if val == 0x7D then # `}` end of comment - Ok (Step { newCtx & state: Executing }) + Ok(Step({ new_ctx & state: Executing })) else - Ok (Step { newCtx & state: InComment }) + Ok(Step({ new_ctx & state: InComment })) - InNumber accum -> - (val, newCtx) = Context.getChar! ctx |> Result.mapErr? endUnexpected - if isDigit val then + InNumber(accum) -> + (val, new_ctx) = Context.get_char!(ctx) |> Result.map_err?(end_unexpected) + if is_digit(val) then # still in the number # i32 multiplication is kinda broken because it implicitly seems to want to upcast to i64. # so like should be (i32, i32) -> i32, but seems to be (i32, i32) -> i64 # so this is make i64 mul by 10 then convert back to i32. - nextAccum = (10 * Num.intCast accum) + Num.intCast (val - 0x30) + next_accum = (10 * Num.int_cast(accum)) + Num.int_cast((val - 0x30)) - Ok (Step { newCtx & state: InNumber (Num.intCast nextAccum) }) + Ok(Step({ new_ctx & state: InNumber(Num.int_cast(next_accum)) })) else # outside of number now, this needs to be executed. - pushCtx = Context.pushStack newCtx (Number accum) + push_ctx = Context.push_stack(new_ctx, Number(accum)) - execCtx = stepExecCtx!? { pushCtx & state: Executing } val - Ok (Step execCtx) + exec_ctx = step_exec_ctx!?({ push_ctx & state: Executing }, val) + Ok(Step(exec_ctx)) - InString bytes -> - (val, newCtx) = Context.getChar! ctx |> Result.mapErr? endUnexpected + InString(bytes) -> + (val, new_ctx) = Context.get_char!(ctx) |> Result.map_err?(end_unexpected) if val == 0x22 then # `"` end of string - when Str.fromUtf8 bytes is - Ok str -> - Stdout.raw! str - Ok (Step { newCtx & state: Executing }) + when Str.from_utf8(bytes) is + Ok(str) -> + Stdout.raw!(str) + Ok(Step({ new_ctx & state: Executing })) - Err _ -> - Err BadUtf8 + Err(_) -> + Err(BadUtf8) else - Ok (Step { newCtx & state: InString (List.append bytes val) }) + Ok(Step({ new_ctx & state: InString(List.append(bytes, val)) })) - InLambda depth bytes -> - (val, newCtx) = Context.getChar! ctx |> Result.mapErr? endUnexpected + InLambda(depth, bytes) -> + (val, new_ctx) = Context.get_char!(ctx) |> Result.map_err?(end_unexpected) if val == 0x5B then # start of a nested lambda `[` - Ok (Step { newCtx & state: InLambda (depth + 1) (List.append bytes val) }) + Ok(Step({ new_ctx & state: InLambda((depth + 1), List.append(bytes, val)) })) else if val == 0x5D then # `]` end of current lambda if depth == 0 then # end of all lambdas - Ok (Step (Context.pushStack { newCtx & state: Executing } (Lambda bytes))) + Ok(Step(Context.push_stack({ new_ctx & state: Executing }, Lambda(bytes)))) else # end of nested lambda - Ok (Step { newCtx & state: InLambda (depth - 1) (List.append bytes val) }) + Ok(Step({ new_ctx & state: InLambda((depth - 1), List.append(bytes, val)) })) else - Ok (Step { newCtx & state: InLambda depth (List.append bytes val) }) + Ok(Step({ new_ctx & state: InLambda(depth, List.append(bytes, val)) })) InSpecialChar -> - val = Context.getChar! { ctx & state: Executing } |> Result.mapErr? endUnexpected + val = Context.get_char!({ ctx & state: Executing }) |> Result.map_err?(end_unexpected) when val is - (0xB8, newCtx) -> - (popCtx, index) = popNumber? newCtx + (0xB8, new_ctx) -> + (pop_ctx, index) = pop_number?(new_ctx) # I think Num.abs is too restrictive, it should be able to produce a natural number, but it seem to be restricted to signed numbers. - size = List.len popCtx.stack - 1 - offset = Num.intCast size - index + size = List.len(pop_ctx.stack) - 1 + offset = Num.int_cast(size) - index if offset >= 0 then - stackVal = List.get? popCtx.stack (Num.intCast offset) - Ok (Step (Context.pushStack popCtx stackVal)) + stack_val = List.get?(pop_ctx.stack, Num.int_cast(offset)) + Ok(Step(Context.push_stack(pop_ctx, stack_val))) else - Err OutOfBounds + Err(OutOfBounds) - (0x9F, newCtx) -> + (0x9F, new_ctx) -> # This is supposed to flush io buffers. We don't buffer, so it does nothing - Ok (Step newCtx) + Ok(Step(new_ctx)) (x, _) -> - data = Num.toStr (Num.intCast x) + data = Num.to_str(Num.int_cast(x)) - Err (InvalidChar data) + Err(InvalidChar(data)) LoadChar -> - (x, newCtx) = Context.getChar! { ctx & state: Executing } |> Result.mapErr? endUnexpected - Ok (Step (Context.pushStack newCtx (Number (Num.intCast x)))) + (x, new_ctx) = Context.get_char!({ ctx & state: Executing }) |> Result.map_err?(end_unexpected) + Ok(Step(Context.push_stack(new_ctx, Number(Num.int_cast(x))))) # If it weren't for reading stdin or writing to stdout, this could return a result. -stepExecCtx! : Context, U8 => Result Context InterpreterErrors -stepExecCtx! = \ctx, char -> +step_exec_ctx! : Context, U8 => Result Context InterpreterErrors +step_exec_ctx! = \ctx, char -> when char is 0x21 -> # `!` execute lambda - (popCtx, bytes) = popLambda? ctx - Ok { popCtx & scopes: List.append popCtx.scopes { data: None, buf: bytes, index: 0, whileInfo: None } } + (pop_ctx, bytes) = pop_lambda?(ctx) + Ok({ pop_ctx & scopes: List.append(pop_ctx.scopes, { data: None, buf: bytes, index: 0, while_info: None }) }) 0x3F -> # `?` if - (popCtx1, bytes) = popLambda? ctx - (popCtx2, n1) = popNumber? popCtx1 + (pop_ctx1, bytes) = pop_lambda?(ctx) + (pop_ctx2, n1) = pop_number?(pop_ctx1) if n1 == 0 then - Ok popCtx2 + Ok(pop_ctx2) else - Ok { popCtx2 & scopes: List.append popCtx2.scopes { data: None, buf: bytes, index: 0, whileInfo: None } } + Ok({ pop_ctx2 & scopes: List.append(pop_ctx2.scopes, { data: None, buf: bytes, index: 0, while_info: None }) }) 0x23 -> # `#` while - (popCtx1, body) = popLambda? ctx - (popCtx2, cond) = popLambda? popCtx1 - last = (List.len popCtx2.scopes - 1) + (pop_ctx1, body) = pop_lambda?(ctx) + (pop_ctx2, cond) = pop_lambda?(pop_ctx1) + last = (List.len(pop_ctx2.scopes) - 1) - scope = List.get popCtx2.scopes last |> Result.mapErr? \_ -> NoScope + scope = List.get(pop_ctx2.scopes, last) |> Result.map_err?(\_ -> NoScope) # set the current scope to be in a while loop. - scopes = List.set popCtx2.scopes last { scope & whileInfo: Some { cond: cond, body: body, state: InCond } } + scopes = List.set(pop_ctx2.scopes, last, { scope & while_info: Some({ cond: cond, body: body, state: InCond }) }) # push a scope to execute the condition. - Ok { popCtx2 & scopes: List.append scopes { data: None, buf: cond, index: 0, whileInfo: None } } + Ok({ pop_ctx2 & scopes: List.append(scopes, { data: None, buf: cond, index: 0, while_info: None }) }) 0x24 -> # `$` dup # Switching this to List.last and changing the error to ListWasEmpty leads to a compiler bug. # Complains about the types eq not matching. - when List.get ctx.stack (List.len ctx.stack - 1) is - Ok dupItem -> Ok (Context.pushStack ctx dupItem) - Err OutOfBounds -> Err EmptyStack + when List.get(ctx.stack, (List.len(ctx.stack) - 1)) is + Ok(dup_item) -> Ok(Context.push_stack(ctx, dup_item)) + Err(OutOfBounds) -> Err(EmptyStack) 0x25 -> # `%` drop - when Context.popStack ctx is + when Context.pop_stack(ctx) is # Dropping with an empty stack, all results here are fine - Ok (popCtx, _) -> Ok popCtx - Err _ -> Ok ctx + Ok((pop_ctx, _)) -> Ok(pop_ctx) + Err(_) -> Ok(ctx) 0x5C -> # `\` swap - (popCtx1, n1) = Context.popStack? ctx - (popCtx2, n2) = Context.popStack? popCtx1 - Ok (Context.pushStack (Context.pushStack popCtx2 n1) n2) + (pop_ctx1, n1) = Context.pop_stack?(ctx) + (pop_ctx2, n2) = Context.pop_stack?(pop_ctx1) + Ok(Context.push_stack(Context.push_stack(pop_ctx2, n1), n2)) 0x40 -> # `@` rot result2 = - (popCtx1, n1) = Context.popStack? ctx - (popCtx2, n2) = Context.popStack? popCtx1 - (popCtx3, n3) = Context.popStack? popCtx2 - Ok (Context.pushStack (Context.pushStack (Context.pushStack popCtx3 n2) n1) n3) + (pop_ctx1, n1) = Context.pop_stack?(ctx) + (pop_ctx2, n2) = Context.pop_stack?(pop_ctx1) + (pop_ctx3, n3) = Context.pop_stack?(pop_ctx2) + Ok(Context.push_stack(Context.push_stack(Context.push_stack(pop_ctx3, n2), n1), n3)) when result2 is - Ok a -> - Ok a + Ok(a) -> + Ok(a) # Being explicit with error type is required to stop the need to propogate the error parameters to Context.popStack - Err EmptyStack -> - Err EmptyStack + Err(EmptyStack) -> + Err(EmptyStack) 0xC3 -> # `ø` pick or `ß` flush # these are actually 2 bytes, 0xC3 0xB8 or 0xC3 0x9F # requires special parsing - Ok { ctx & state: InSpecialChar } + Ok({ ctx & state: InSpecialChar }) 0x4F -> # `O` also treat this as pick for easier script writing - (popCtx, index) = popNumber? ctx + (pop_ctx, index) = pop_number?(ctx) # I think Num.abs is too restrictive, it should be able to produce a natural number, but it seem to be restricted to signed numbers. - size = List.len popCtx.stack - 1 - offset = Num.intCast size - index + size = List.len(pop_ctx.stack) - 1 + offset = Num.int_cast(size) - index if offset >= 0 then - stackVal = List.get? popCtx.stack (Num.intCast offset) - Ok (Context.pushStack popCtx stackVal) + stack_val = List.get?(pop_ctx.stack, Num.int_cast(offset)) + Ok(Context.push_stack(pop_ctx, stack_val)) else - Err OutOfBounds + Err(OutOfBounds) 0x42 -> # `B` also treat this as flush for easier script writing # This is supposed to flush io buffers. We don't buffer, so it does nothing - Ok ctx + Ok(ctx) 0x27 -> # `'` load next char - Ok { ctx & state: LoadChar } + Ok({ ctx & state: LoadChar }) 0x2B -> # `+` add - binaryOp ctx Num.addWrap + binary_op(ctx, Num.add_wrap) 0x2D -> # `-` sub - binaryOp ctx Num.subWrap + binary_op(ctx, Num.sub_wrap) 0x2A -> # `*` mul - binaryOp ctx Num.mulWrap + binary_op(ctx, Num.mul_wrap) 0x2F -> # `/` div # Due to possible division by zero error, this must be handled specially. - (popCtx1, numR) = popNumber? ctx - (popCtx2, numL) = popNumber? popCtx1 - res = Num.divTruncChecked? numL numR - Ok (Context.pushStack popCtx2 (Number res)) + (pop_ctx1, num_r) = pop_number?(ctx) + (pop_ctx2, num_l) = pop_number?(pop_ctx1) + res = Num.div_trunc_checked?(num_l, num_r) + Ok(Context.push_stack(pop_ctx2, Number(res))) 0x26 -> # `&` bitwise and - binaryOp ctx Num.bitwiseAnd + binary_op(ctx, Num.bitwise_and) 0x7C -> # `|` bitwise or - binaryOp ctx Num.bitwiseOr + binary_op(ctx, Num.bitwise_or) 0x3D -> # `=` equals - binaryOp ctx \a, b -> + binary_op(ctx, \a, b -> if a == b then -1 else - 0 + 0) 0x3E -> # `>` greater than - binaryOp ctx \a, b -> + binary_op(ctx, \a, b -> if a > b then -1 else - 0 + 0) 0x5F -> # `_` negate - unaryOp ctx Num.neg + unary_op(ctx, Num.neg) 0x7E -> # `~` bitwise not - unaryOp ctx (\x -> Num.bitwiseXor x -1) # xor with -1 should be bitwise not + unary_op(ctx, \x -> Num.bitwise_xor(x, -1)) # xor with -1 should be bitwise not 0x2C -> # `,` write char - (popCtx, num) = popNumber? ctx - str = Str.fromUtf8 [Num.intCast num] |> Result.mapErr? \_ -> BadUtf8 - Stdout.raw! str - Ok popCtx + (pop_ctx, num) = pop_number?(ctx) + str = Str.from_utf8([Num.int_cast(num)]) |> Result.map_err?(\_ -> BadUtf8) + Stdout.raw!(str) + Ok(pop_ctx) 0x2E -> # `.` write int - (popCtx, num) = popNumber? ctx - Stdout.raw! (Num.toStr (Num.intCast num)) - Ok popCtx + (pop_ctx, num) = pop_number?(ctx) + Stdout.raw!(Num.to_str(Num.int_cast(num))) + Ok(pop_ctx) 0x5E -> # `^` read char as int - in = Stdin.char! {} + in = Stdin.char!({}) if in == 255 then # max char sent on EOF. Change to -1 - Ok (Context.pushStack ctx (Number -1)) + Ok(Context.push_stack(ctx, Number(-1))) else - Ok (Context.pushStack ctx (Number (Num.intCast in))) + Ok(Context.push_stack(ctx, Number(Num.int_cast(in)))) 0x3A -> # `:` store to variable - (popCtx1, var) = popVariable? ctx - (popCtx2, n1) = Context.popStack? popCtx1 - Ok { popCtx2 & vars: List.set popCtx2.vars (Variable.toIndex var) n1 } + (pop_ctx1, var) = pop_variable?(ctx) + (pop_ctx2, n1) = Context.pop_stack?(pop_ctx1) + Ok({ pop_ctx2 & vars: List.set(pop_ctx2.vars, Variable.to_index(var), n1) }) 0x3B -> # `;` load from variable - (popCtx, var) = popVariable? ctx - elem = List.get? popCtx.vars (Variable.toIndex var) - Ok (Context.pushStack popCtx elem) + (pop_ctx, var) = pop_variable?(ctx) + elem = List.get?(pop_ctx.vars, Variable.to_index(var)) + Ok(Context.push_stack(pop_ctx, elem)) 0x22 -> # `"` string start - Ok { ctx & state: InString [] } + Ok({ ctx & state: InString([]) }) 0x5B -> # `"` string start - Ok { ctx & state: InLambda 0 [] } + Ok({ ctx & state: InLambda(0, []) }) 0x7B -> # `{` comment start - Ok { ctx & state: InComment } + Ok({ ctx & state: InComment }) - x if isDigit x -> + x if is_digit(x) -> # number start - Ok { ctx & state: InNumber (Num.intCast (x - 0x30)) } + Ok({ ctx & state: InNumber(Num.int_cast((x - 0x30))) }) - x if isWhitespace x -> - Ok ctx + x if is_whitespace(x) -> + Ok(ctx) x -> - when Variable.fromUtf8 x is + when Variable.from_utf8(x) is # letters are variable names - Ok var -> - Ok (Context.pushStack ctx (Var var)) - - Err _ -> - data = Num.toStr (Num.intCast x) - - Err (InvalidChar data) - -unaryOp : Context, (I32 -> I32) -> Result Context InterpreterErrors -unaryOp = \ctx, op -> - (popCtx, num) = popNumber? ctx - Ok (Context.pushStack popCtx (Number (op num))) - -binaryOp : Context, (I32, I32 -> I32) -> Result Context InterpreterErrors -binaryOp = \ctx, op -> - (popCtx1, numR) = popNumber? ctx - (popCtx2, numL) = popNumber? popCtx1 - Ok (Context.pushStack popCtx2 (Number (op numL numR))) - -popNumber : Context -> Result (Context, I32) InterpreterErrors -popNumber = \ctx -> - when Context.popStack? ctx is - (popCtx, Number num) -> Ok (popCtx, num) - _ -> Err NoNumberOnStack - -popLambda : Context -> Result (Context, List U8) InterpreterErrors -popLambda = \ctx -> - when Context.popStack? ctx is - (popCtx, Lambda bytes) -> Ok (popCtx, bytes) - _ -> Err NoLambdaOnStack - -popVariable : Context -> Result (Context, Variable) InterpreterErrors -popVariable = \ctx -> - when Context.popStack? ctx is - (popCtx, Var var) -> Ok (popCtx, var) - _ -> Err NoVariableOnStack - -isDigit : U8 -> Bool -isDigit = \char -> + Ok(var) -> + Ok(Context.push_stack(ctx, Var(var))) + + Err(_) -> + data = Num.to_str(Num.int_cast(x)) + + Err(InvalidChar(data)) + +unary_op : Context, (I32 -> I32) -> Result Context InterpreterErrors +unary_op = \ctx, op -> + (pop_ctx, num) = pop_number?(ctx) + Ok(Context.push_stack(pop_ctx, Number(op(num)))) + +binary_op : Context, (I32, I32 -> I32) -> Result Context InterpreterErrors +binary_op = \ctx, op -> + (pop_ctx1, num_r) = pop_number?(ctx) + (pop_ctx2, num_l) = pop_number?(pop_ctx1) + Ok(Context.push_stack(pop_ctx2, Number(op(num_l, num_r)))) + +pop_number : Context -> Result (Context, I32) InterpreterErrors +pop_number = \ctx -> + when Context.pop_stack?(ctx) is + (pop_ctx, Number(num)) -> Ok((pop_ctx, num)) + _ -> Err(NoNumberOnStack) + +pop_lambda : Context -> Result (Context, List U8) InterpreterErrors +pop_lambda = \ctx -> + when Context.pop_stack?(ctx) is + (pop_ctx, Lambda(bytes)) -> Ok((pop_ctx, bytes)) + _ -> Err(NoLambdaOnStack) + +pop_variable : Context -> Result (Context, Variable) InterpreterErrors +pop_variable = \ctx -> + when Context.pop_stack?(ctx) is + (pop_ctx, Var(var)) -> Ok((pop_ctx, var)) + _ -> Err(NoVariableOnStack) + +is_digit : U8 -> Bool +is_digit = \char -> char >= 0x30 # `0` && char <= 0x39 # `0` -isWhitespace : U8 -> Bool -isWhitespace = \char -> +is_whitespace : U8 -> Bool +is_whitespace = \char -> char == 0xA # new line || char @@ -473,7 +473,7 @@ isWhitespace = \char -> || char == 0x9 # tab -endUnexpected = \err -> +end_unexpected = \err -> when err is NoScope -> NoScope diff --git a/crates/cli/tests/test-projects/false-interpreter/platform/File.roc b/crates/cli/tests/test-projects/false-interpreter/platform/File.roc index ccb0cffe128..8d9ea0db35d 100644 --- a/crates/cli/tests/test-projects/false-interpreter/platform/File.roc +++ b/crates/cli/tests/test-projects/false-interpreter/platform/File.roc @@ -1,30 +1,30 @@ -module [line!, withOpen!, chunk!, Handle] +module [line!, with_open!, chunk!, Handle] import pf.Host Handle := U64 line! : Handle => Str -line! = \@Handle handle -> - Host.getFileLine! handle +line! = \@Handle(handle) -> + Host.get_file_line!(handle) chunk! : Handle => List U8 -chunk! = \@Handle handle -> - Host.getFileBytes! handle +chunk! = \@Handle(handle) -> + Host.get_file_bytes!(handle) open! : Str => Handle open! = \path -> - Host.openFile! path + Host.open_file!(path) |> @Handle close! : Handle => {} -close! = \@Handle handle -> - Host.closeFile! handle - -withOpen! : Str, (Handle => a) => a -withOpen! = \path, callback! -> - handle = open! path - result = callback! handle - close! handle +close! = \@Handle(handle) -> + Host.close_file!(handle) + +with_open! : Str, (Handle => a) => a +with_open! = \path, callback! -> + handle = open!(path) + result = callback!(handle) + close!(handle) result diff --git a/crates/cli/tests/test-projects/false-interpreter/platform/Host.roc b/crates/cli/tests/test-projects/false-interpreter/platform/Host.roc index c1662d998c5..ef6aaaa5d70 100644 --- a/crates/cli/tests/test-projects/false-interpreter/platform/Host.roc +++ b/crates/cli/tests/test-projects/false-interpreter/platform/Host.roc @@ -1,19 +1,19 @@ hosted Host - exposes [openFile!, closeFile!, getFileLine!, getFileBytes!, putLine!, putRaw!, getLine!, getChar!] + exposes [open_file!, close_file!, get_file_line!, get_file_bytes!, put_line!, put_raw!, get_line!, get_char!] imports [] -openFile! : Str => U64 +open_file! : Str => U64 -closeFile! : U64 => {} +close_file! : U64 => {} -getFileLine! : U64 => Str +get_file_line! : U64 => Str -getFileBytes! : U64 => List U8 +get_file_bytes! : U64 => List U8 -putLine! : Str => {} +put_line! : Str => {} -putRaw! : Str => {} +put_raw! : Str => {} -getLine! : {} => Str +get_line! : {} => Str -getChar! : {} => U8 +get_char! : {} => U8 diff --git a/crates/cli/tests/test-projects/false-interpreter/platform/Stdin.roc b/crates/cli/tests/test-projects/false-interpreter/platform/Stdin.roc index fc33e16ad6d..b9ad5d2eac6 100644 --- a/crates/cli/tests/test-projects/false-interpreter/platform/Stdin.roc +++ b/crates/cli/tests/test-projects/false-interpreter/platform/Stdin.roc @@ -4,8 +4,8 @@ import pf.Host line! : {} => Str line! = \{} -> - Host.getLine! {} + Host.get_line!({}) char! : {} => U8 char! = \{} -> - Host.getChar! {} + Host.get_char!({}) diff --git a/crates/cli/tests/test-projects/false-interpreter/platform/Stdout.roc b/crates/cli/tests/test-projects/false-interpreter/platform/Stdout.roc index 9e56cc6ae11..c4c7656b5a5 100644 --- a/crates/cli/tests/test-projects/false-interpreter/platform/Stdout.roc +++ b/crates/cli/tests/test-projects/false-interpreter/platform/Stdout.roc @@ -4,8 +4,8 @@ import pf.Host line! : Str => {} line! = \text -> - Host.putLine! text + Host.put_line!(text) raw! : Str => {} raw! = \text -> - Host.putRaw! text + Host.put_raw!(text) diff --git a/crates/cli/tests/test-projects/false-interpreter/platform/main.roc b/crates/cli/tests/test-projects/false-interpreter/platform/main.roc index 62d643ed6de..b39ab41e9fc 100644 --- a/crates/cli/tests/test-projects/false-interpreter/platform/main.roc +++ b/crates/cli/tests/test-projects/false-interpreter/platform/main.roc @@ -3,7 +3,7 @@ platform "false-interpreter" exposes [] packages {} imports [] - provides [mainForHost!] + provides [main_for_host!] -mainForHost! : Str => {} -mainForHost! = \file -> main! file +main_for_host! : Str => {} +main_for_host! = \file -> main!(file) diff --git a/crates/cli/tests/test-projects/false-interpreter/platform/src/lib.rs b/crates/cli/tests/test-projects/false-interpreter/platform/src/lib.rs index 616dd27a397..4bf8ce1d4b4 100644 --- a/crates/cli/tests/test-projects/false-interpreter/platform/src/lib.rs +++ b/crates/cli/tests/test-projects/false-interpreter/platform/src/lib.rs @@ -19,7 +19,7 @@ fn file_handles() -> &'static Mutex>> { } extern "C" { - #[link_name = "roc__mainForHost_1_exposed_generic"] + #[link_name = "roc__main_for_host_1_exposed_generic"] fn roc_main(void: *const c_void, args: *mut RocStr); } diff --git a/crates/cli/tests/test-projects/fixtures/format/formatted.roc b/crates/cli/tests/test-projects/fixtures/format/formatted.roc index 34dd7401faa..58f252bab69 100644 --- a/crates/cli/tests/test-projects/fixtures/format/formatted.roc +++ b/crates/cli/tests/test-projects/fixtures/format/formatted.roc @@ -1,4 +1,4 @@ app [main] { pf: "platform/main.roc" } main : Str -main = Dep1.value1 {} +main = Dep1.value1({}) diff --git a/crates/cli/tests/test-projects/fixtures/format/formatted_directory/Formatted.roc b/crates/cli/tests/test-projects/fixtures/format/formatted_directory/Formatted.roc index 34dd7401faa..58f252bab69 100644 --- a/crates/cli/tests/test-projects/fixtures/format/formatted_directory/Formatted.roc +++ b/crates/cli/tests/test-projects/fixtures/format/formatted_directory/Formatted.roc @@ -1,4 +1,4 @@ app [main] { pf: "platform/main.roc" } main : Str -main = Dep1.value1 {} +main = Dep1.value1({}) diff --git a/crates/cli/tests/test-projects/fixtures/format/not-formatted.roc b/crates/cli/tests/test-projects/fixtures/format/not-formatted.roc index 757a5e90edb..4a82e9b28cb 100644 --- a/crates/cli/tests/test-projects/fixtures/format/not-formatted.roc +++ b/crates/cli/tests/test-projects/fixtures/format/not-formatted.roc @@ -1,4 +1,4 @@ -app [main] { pf: "platform/main.roc" } +app [main] { pf: "platform/main.roc" } main : Str -main = Dep1.value1 {} +main = Dep1.value1({}) diff --git a/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/Dep1.roc b/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/Dep1.roc index a975704b4f1..bc291f49f3e 100644 --- a/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/Dep1.roc +++ b/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/Dep1.roc @@ -3,4 +3,4 @@ module [value1] import Dep2 value1 : {} -> Str -value1 = \_ -> Dep2.value2 {} +value1 = \_ -> Dep2.value2({}) diff --git a/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/main.roc b/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/main.roc index 00fb7fd1513..24ea147fc02 100644 --- a/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/main.roc +++ b/crates/cli/tests/test-projects/fixtures/multi-dep-thunk/main.roc @@ -3,4 +3,4 @@ app [main] { pf: platform "../../test-platform-simple-zig/main.roc" } import Dep1 main : Str -main = Dep1.value1 {} +main = Dep1.value1({}) diff --git a/crates/cli/tests/test-projects/known_bad/UnusedImport.roc b/crates/cli/tests/test-projects/known_bad/UnusedImport.roc index f7c19c024e4..4cf48d545d6 100644 --- a/crates/cli/tests/test-projects/known_bad/UnusedImport.roc +++ b/crates/cli/tests/test-projects/known_bad/UnusedImport.roc @@ -1,7 +1,7 @@ -module [plainText, emText] +module [plain_text, em_text] import Symbol exposing [Ident] -plainText = \str -> PlainText str +plain_text = \str -> PlainText(str) -emText = \str -> EmText str +em_text = \str -> EmText(str) diff --git a/crates/cli/tests/test-projects/known_bad/UnusedImportButWithALongFileNameForTesting.roc b/crates/cli/tests/test-projects/known_bad/UnusedImportButWithALongFileNameForTesting.roc index f7c19c024e4..4cf48d545d6 100644 --- a/crates/cli/tests/test-projects/known_bad/UnusedImportButWithALongFileNameForTesting.roc +++ b/crates/cli/tests/test-projects/known_bad/UnusedImportButWithALongFileNameForTesting.roc @@ -1,7 +1,7 @@ -module [plainText, emText] +module [plain_text, em_text] import Symbol exposing [Ident] -plainText = \str -> PlainText str +plain_text = \str -> PlainText(str) -emText = \str -> EmText str +em_text = \str -> EmText(str) diff --git a/crates/cli/tests/test-projects/module_imports_pkg/ImportsUnknownPkg.roc b/crates/cli/tests/test-projects/module_imports_pkg/ImportsUnknownPkg.roc index dbe6b03e87c..62bd9a5b5f3 100644 --- a/crates/cli/tests/test-projects/module_imports_pkg/ImportsUnknownPkg.roc +++ b/crates/cli/tests/test-projects/module_imports_pkg/ImportsUnknownPkg.roc @@ -1,7 +1,7 @@ -module [valueFromPkg] +module [value_from_pkg] import cli.Foo -valueFromPkg = Foo.foo +value_from_pkg = Foo.foo -expect valueFromPkg == "Foo" +expect value_from_pkg == "Foo" diff --git a/crates/cli/tests/test-projects/module_imports_pkg/Module.roc b/crates/cli/tests/test-projects/module_imports_pkg/Module.roc index 8b4b21aef21..28c245d4c86 100644 --- a/crates/cli/tests/test-projects/module_imports_pkg/Module.roc +++ b/crates/cli/tests/test-projects/module_imports_pkg/Module.roc @@ -1,7 +1,7 @@ -module [valueFromPkg] +module [value_from_pkg] import pkg.Foo -valueFromPkg = Foo.foo +value_from_pkg = Foo.foo -expect valueFromPkg == "Foo" +expect value_from_pkg == "Foo" diff --git a/crates/cli/tests/test-projects/module_imports_pkg/app.roc b/crates/cli/tests/test-projects/module_imports_pkg/app.roc index dc81319d256..7e663b62003 100644 --- a/crates/cli/tests/test-projects/module_imports_pkg/app.roc +++ b/crates/cli/tests/test-projects/module_imports_pkg/app.roc @@ -5,4 +5,4 @@ app [main] { import Module main = - Module.valueFromPkg + Module.value_from_pkg diff --git a/crates/cli/tests/test-projects/module_params/Api.roc b/crates/cli/tests/test-projects/module_params/Api.roc index cd3a7792d05..cd407b71229 100644 --- a/crates/cli/tests/test-projects/module_params/Api.roc +++ b/crates/cli/tests/test-projects/module_params/Api.roc @@ -1,69 +1,69 @@ -module { appId, protocol } -> [ - baseUrl, - getUser, - getPost, - getPosts, - getPostComments, - getCompanies, - baseUrlAliased, - getPostAliased, - getUserSafe, - getPostComment, +module { app_id, protocol } -> [ + base_url, + get_user, + get_post, + get_posts, + get_post_comments, + get_companies, + base_url_aliased, + get_post_aliased, + get_user_safe, + get_post_comment, ] ## value def referencing params -baseUrl : Str -baseUrl = - protocol "api.example.com/$(appId)" +base_url : Str +base_url = + protocol("api.example.com/$(app_id)") ## function def referencing params -getUser : U32 -> Str -getUser = \userId -> +get_user : U32 -> Str +get_user = \user_id -> # purposefully not using baseUrl to test top-level fn referencing param - protocol "api.example.com/$(appId)/users/$(Num.toStr userId)" + protocol("api.example.com/$(app_id)/users/$(Num.to_str(user_id))") ## function def referencing top-level value -getPost : U32 -> Str -getPost = \postId -> - "$(baseUrl)/posts/$(Num.toStr postId)" +get_post : U32 -> Str +get_post = \post_id -> + "$(base_url)/posts/$(Num.to_str(post_id))" ## function def passing top-level function -getPosts : List U32 -> List Str -getPosts = \ids -> - List.map ids getPost +get_posts : List U32 -> List Str +get_posts = \ids -> + List.map(ids, get_post) ## function def calling top-level function -getPostComments : U32 -> Str -getPostComments = \postId -> - "$(getPost postId)/comments" +get_post_comments : U32 -> Str +get_post_comments = \post_id -> + "$(get_post(post_id))/comments" ## function def passing nested function -getCompanies : List U32 -> List Str -getCompanies = \ids -> - getCompany = \id -> - protocol "api.example.com/$(appId)/companies/$(Num.toStr id)" +get_companies : List U32 -> List Str +get_companies = \ids -> + get_company = \id -> + protocol("api.example.com/$(app_id)/companies/$(Num.to_str(id))") - List.map ids getCompany + List.map(ids, get_company) ## aliasing top-level value -baseUrlAliased : Str -baseUrlAliased = - baseUrl +base_url_aliased : Str +base_url_aliased = + base_url ## aliasing top-level fn -getPostAliased : U32 -> Str -getPostAliased = - getPost +get_post_aliased : U32 -> Str +get_post_aliased = + get_post ## top-level value returning functions -getUserSafe : U32 -> Str -getUserSafe = - if Str.startsWith appId "prod_" then - \id -> "$(getUser id)?safe=true" +get_user_safe : U32 -> Str +get_user_safe = + if Str.starts_with(app_id, "prod_") then + \id -> "$(get_user(id))?safe=true" else - getUser + get_user ## two-argument function -getPostComment : U32, U32 -> Str -getPostComment = \postId, commentId -> - "$(getPost postId)/comments/$(Num.toStr commentId)" +get_post_comment : U32, U32 -> Str +get_post_comment = \post_id, comment_id -> + "$(get_post(post_id))/comments/$(Num.to_str(comment_id))" diff --git a/crates/cli/tests/test-projects/module_params/BadAnn.roc b/crates/cli/tests/test-projects/module_params/BadAnn.roc index 2ccfce872e8..1c67aef6089 100644 --- a/crates/cli/tests/test-projects/module_params/BadAnn.roc +++ b/crates/cli/tests/test-projects/module_params/BadAnn.roc @@ -1,9 +1,9 @@ -module { appId } -> [fnAnnotatedAsValue, missingArg] +module { app_id } -> [fn_annotated_as_value, missing_arg] -fnAnnotatedAsValue : Str -fnAnnotatedAsValue = \postId, commentId -> - "/posts/$(postId)/comments/$(Num.toStr commentId)" +fn_annotated_as_value : Str +fn_annotated_as_value = \post_id, comment_id -> + "/posts/$(post_id)/comments/$(Num.to_str(comment_id))" -missingArg : Str -> Str -missingArg = \postId, _ -> - "/posts/$(postId)/comments" +missing_arg : Str -> Str +missing_arg = \post_id, _ -> + "/posts/$(post_id)/comments" diff --git a/crates/cli/tests/test-projects/module_params/ImportInExpect.roc b/crates/cli/tests/test-projects/module_params/ImportInExpect.roc index 477d23f50af..02bc3a38e68 100644 --- a/crates/cli/tests/test-projects/module_params/ImportInExpect.roc +++ b/crates/cli/tests/test-projects/module_params/ImportInExpect.roc @@ -3,12 +3,12 @@ module [] https = \url -> "https://$(url)" expect - import Api { appId: "one", protocol: https } - Api.baseUrl == "https://api.example.com/one" + import Api { app_id: "one", protocol: https } + Api.base_url == "https://api.example.com/one" expect - import Api { appId: "two", protocol: https } - Api.getUser 1 == "https://api.example.com/two/users/1" + import Api { app_id: "two", protocol: https } + Api.get_user(1) == "https://api.example.com/two/users/1" expect import NoParams diff --git a/crates/cli/tests/test-projects/module_params/Menu.roc b/crates/cli/tests/test-projects/module_params/Menu.roc index e16090caf54..52afd5dd11d 100644 --- a/crates/cli/tests/test-projects/module_params/Menu.roc +++ b/crates/cli/tests/test-projects/module_params/Menu.roc @@ -1,7 +1,7 @@ module { echo } -> [menu] menu = \name -> - indirect name + indirect(name) indirect = \name -> - echo "Hi, $(name)!" + echo("Hi, $(name)!") diff --git a/crates/cli/tests/test-projects/module_params/MultilineParams.roc b/crates/cli/tests/test-projects/module_params/MultilineParams.roc index 7c8906376c4..7371b4cdc7b 100644 --- a/crates/cli/tests/test-projects/module_params/MultilineParams.roc +++ b/crates/cli/tests/test-projects/module_params/MultilineParams.roc @@ -1,4 +1,4 @@ -module { sendHttpReq, getEnvVar } -> [hi] +module { send_http_req, get_env_var } -> [hi] hi : Str hi = diff --git a/crates/cli/tests/test-projects/module_params/app.roc b/crates/cli/tests/test-projects/module_params/app.roc index 5f4a38c3a2c..692fee536a9 100644 --- a/crates/cli/tests/test-projects/module_params/app.roc +++ b/crates/cli/tests/test-projects/module_params/app.roc @@ -2,58 +2,58 @@ app [main] { pf: platform "../test-platform-simple-zig/main.roc", } -import Api { appId: "one", protocol: https } as App1 -import Api { appId: "two", protocol: http } as App2 -import Api { appId: "prod_1", protocol: http } as Prod +import Api { app_id: "one", protocol: https } as App1 +import Api { app_id: "two", protocol: http } as App2 +import Api { app_id: "prod_1", protocol: http } as Prod https = \url -> "https://$(url)" http = \url -> "http://$(url)" -usersApp1 = +users_app1 = # pass top-level fn in a module with params - List.map [1, 2, 3] App1.getUser + List.map([1, 2, 3], App1.get_user) main = - app3Id = "three" + app3_id = "three" - import Api { appId: app3Id, protocol: https } as App3 + import Api { app_id: app3_id, protocol: https } as App3 - getUserApp3Nested = \userId -> + get_user_app3_nested = \user_id -> # use captured params def - App3.getUser userId + App3.get_user(user_id) - usersApp3Passed = + users_app3_passed = # pass top-level fn in a nested def - List.map [1, 2, 3] App3.getUser + List.map([1, 2, 3], App3.get_user) """ - App1.baseUrl: $(App1.baseUrl) - App2.baseUrl: $(App2.baseUrl) - App3.baseUrl: $(App3.baseUrl) - App1.getUser 1: $(App1.getUser 1) - App2.getUser 2: $(App2.getUser 2) - App3.getUser 3: $(App3.getUser 3) - App1.getPost 1: $(App1.getPost 1) - App2.getPost 2: $(App2.getPost 2) - App3.getPost 3: $(App3.getPost 3) - App1.getPosts [1, 2]: $(Inspect.toStr (App1.getPosts [1, 2])) - App2.getPosts [3, 4]: $(Inspect.toStr (App2.getPosts [3, 4])) - App2.getPosts [5, 6]: $(Inspect.toStr (App2.getPosts [5, 6])) - App1.getPostComments 1: $(App1.getPostComments 1) - App2.getPostComments 2: $(App2.getPostComments 2) - App2.getPostComments 3: $(App2.getPostComments 3) - App1.getCompanies [1, 2]: $(Inspect.toStr (App1.getCompanies [1, 2])) - App2.getCompanies [3, 4]: $(Inspect.toStr (App2.getCompanies [3, 4])) - App2.getCompanies [5, 6]: $(Inspect.toStr (App2.getCompanies [5, 6])) - App1.getPostAliased 1: $(App1.getPostAliased 1) - App2.getPostAliased 2: $(App2.getPostAliased 2) - App3.getPostAliased 3: $(App3.getPostAliased 3) - App1.baseUrlAliased: $(App1.baseUrlAliased) - App2.baseUrlAliased: $(App2.baseUrlAliased) - App3.baseUrlAliased: $(App3.baseUrlAliased) - App1.getUserSafe 1: $(App1.getUserSafe 1) - Prod.getUserSafe 2: $(Prod.getUserSafe 2) - usersApp1: $(Inspect.toStr usersApp1) - getUserApp3Nested 3: $(getUserApp3Nested 3) - usersApp3Passed: $(Inspect.toStr usersApp3Passed) + App1.baseUrl: $(App1.base_url) + App2.baseUrl: $(App2.base_url) + App3.baseUrl: $(App3.base_url) + App1.getUser 1: $(App1.get_user(1)) + App2.getUser 2: $(App2.get_user(2)) + App3.getUser 3: $(App3.get_user(3)) + App1.getPost 1: $(App1.get_post(1)) + App2.getPost 2: $(App2.get_post(2)) + App3.getPost 3: $(App3.get_post(3)) + App1.getPosts [1, 2]: $(Inspect.to_str(App1.get_posts([1, 2]))) + App2.getPosts [3, 4]: $(Inspect.to_str(App2.get_posts([3, 4]))) + App2.getPosts [5, 6]: $(Inspect.to_str(App2.get_posts([5, 6]))) + App1.getPostComments 1: $(App1.get_post_comments(1)) + App2.getPostComments 2: $(App2.get_post_comments(2)) + App2.getPostComments 3: $(App2.get_post_comments(3)) + App1.getCompanies [1, 2]: $(Inspect.to_str(App1.get_companies([1, 2]))) + App2.getCompanies [3, 4]: $(Inspect.to_str(App2.get_companies([3, 4]))) + App2.getCompanies [5, 6]: $(Inspect.to_str(App2.get_companies([5, 6]))) + App1.getPostAliased 1: $(App1.get_post_aliased(1)) + App2.getPostAliased 2: $(App2.get_post_aliased(2)) + App3.getPostAliased 3: $(App3.get_post_aliased(3)) + App1.baseUrlAliased: $(App1.base_url_aliased) + App2.baseUrlAliased: $(App2.base_url_aliased) + App3.baseUrlAliased: $(App3.base_url_aliased) + App1.getUserSafe 1: $(App1.get_user_safe(1)) + Prod.getUserSafe 2: $(Prod.get_user_safe(2)) + usersApp1: $(Inspect.to_str(users_app1)) + getUserApp3Nested 3: $(get_user_app3_nested(3)) + usersApp3Passed: $(Inspect.to_str(users_app3_passed)) """ diff --git a/crates/cli/tests/test-projects/module_params/arity_mismatch.roc b/crates/cli/tests/test-projects/module_params/arity_mismatch.roc index 2c7cc3679db..a2f600ed348 100644 --- a/crates/cli/tests/test-projects/module_params/arity_mismatch.roc +++ b/crates/cli/tests/test-projects/module_params/arity_mismatch.roc @@ -2,16 +2,16 @@ app [main] { pf: platform "../test-platform-simple-zig/main.roc", } -import Api { appId: "one", protocol: https } +import Api { app_id: "one", protocol: https } https = \url -> "https://$(url)" main = """ # too many args - $(Api.getUser 1 2) - $(Api.baseUrl 1) + $(Api.get_user(1, 2)) + $(Api.base_url(1)) # too few args - $(Api.getPostComment 1) + $(Api.get_post_comment(1)) """ diff --git a/crates/cli/tests/test-projects/module_params/bad_ann.roc b/crates/cli/tests/test-projects/module_params/bad_ann.roc index d0529076b7e..a9c977e1272 100644 --- a/crates/cli/tests/test-projects/module_params/bad_ann.roc +++ b/crates/cli/tests/test-projects/module_params/bad_ann.roc @@ -2,7 +2,7 @@ app [main] { pf: platform "../test-platform-simple-zig/main.roc", } -import BadAnn { appId: "one" } +import BadAnn { app_id: "one" } main = "" diff --git a/crates/cli/tests/test-projects/module_params/different_types.roc b/crates/cli/tests/test-projects/module_params/different_types.roc index 2f0412e4651..d144467f04a 100644 --- a/crates/cli/tests/test-projects/module_params/different_types.roc +++ b/crates/cli/tests/test-projects/module_params/different_types.roc @@ -9,6 +9,6 @@ import Alias { passed: Stdin.line } as In import Alias { passed: Stdout.line } as Out main = - Out.exposed! "Write something:" + Out.exposed!("Write something:") input = In.exposed! - Out.exposed! input + Out.exposed!(input) diff --git a/crates/cli/tests/test-projects/module_params/effect_module.roc b/crates/cli/tests/test-projects/module_params/effect_module.roc index 8728f52e556..9e745eb553b 100644 --- a/crates/cli/tests/test-projects/module_params/effect_module.roc +++ b/crates/cli/tests/test-projects/module_params/effect_module.roc @@ -1,3 +1,3 @@ module { stdout! } -> [log!] -log! = \msg, level -> stdout! "$(level):$(msg)" +log! = \msg, level -> stdout!("$(level):$(msg)") diff --git a/crates/cli/tests/test-projects/module_params/issue_7116.roc b/crates/cli/tests/test-projects/module_params/issue_7116.roc index 891ad5a9aef..dc2d64363bd 100644 --- a/crates/cli/tests/test-projects/module_params/issue_7116.roc +++ b/crates/cli/tests/test-projects/module_params/issue_7116.roc @@ -2,10 +2,10 @@ app [main] { cli: platform "https://github.com/roc-lang/basic-cli/releases/download/0.17.0/lZFLstMUCUvd5bjnnpYromZJXkQUrdhbva4xdBInicE.tar.br", } -import Alias { passed: Task.ok {} } +import Alias { passed: Task.ok({}) } main = - Task.loop! {} loop + Task.loop!({}, loop) loop = \{} -> - Task.map Alias.exposed \x -> Done x + Task.map(Alias.exposed, \x -> Done(x)) diff --git a/crates/cli/tests/test-projects/module_params/multiline_params.roc b/crates/cli/tests/test-projects/module_params/multiline_params.roc index f12c466b449..fb6c4dea3fa 100644 --- a/crates/cli/tests/test-projects/module_params/multiline_params.roc +++ b/crates/cli/tests/test-projects/module_params/multiline_params.roc @@ -3,8 +3,8 @@ app [main] { } import MultilineParams { - sendHttpReq: \_ -> crash "todo", - getEnvVar: \_ -> crash "todo", + send_http_req: \_ -> crash("todo"), + get_env_var: \_ -> crash("todo"), } main = diff --git a/crates/cli/tests/test-projects/module_params/pass_task.roc b/crates/cli/tests/test-projects/module_params/pass_task.roc index 5d3d17f176f..9d80f5b0ea1 100644 --- a/crates/cli/tests/test-projects/module_params/pass_task.roc +++ b/crates/cli/tests/test-projects/module_params/pass_task.roc @@ -1,7 +1,7 @@ app [main] { pf: platform "https://github.com/roc-lang/basic-cli/releases/download/0.17.0/lZFLstMUCUvd5bjnnpYromZJXkQUrdhbva4xdBInicE.tar.br" } import pf.Stdout -import Menu { echo: \str -> Stdout.line str } +import Menu { echo: \str -> Stdout.line(str) } main = - Menu.menu "Agus" + Menu.menu("Agus") diff --git a/crates/cli/tests/test-projects/module_params/unexpected_fn.roc b/crates/cli/tests/test-projects/module_params/unexpected_fn.roc index 1867f57238e..6c3a49a5d9c 100644 --- a/crates/cli/tests/test-projects/module_params/unexpected_fn.roc +++ b/crates/cli/tests/test-projects/module_params/unexpected_fn.roc @@ -2,11 +2,9 @@ app [main] { pf: platform "../test-platform-simple-zig/main.roc", } -import Api { appId: "one", protocol: https } +import Api { app_id: "one", protocol: https } https = \url -> "https://$(url)" main = - """ - $(Api.getPost) - """ + "$(Api.get_post)" diff --git a/crates/cli/tests/test-projects/multiple_exposed/main.roc b/crates/cli/tests/test-projects/multiple_exposed/main.roc index f2f40e7eaf3..2c49df47b7a 100644 --- a/crates/cli/tests/test-projects/multiple_exposed/main.roc +++ b/crates/cli/tests/test-projects/multiple_exposed/main.roc @@ -1,20 +1,20 @@ app [exposed1, exposed2, add1, sub1] { pf: platform "platform/main.roc" } -exposed1 = \n -> fib n 0 1 +exposed1 = \n -> fib(n, 0, 1) fib = \n, a, b -> if n == 0 then a else - fib (n - 1) b (a + b) + fib((n - 1), b, (a + b)) -exposed2 = \n -> fact n 1 +exposed2 = \n -> fact(n, 1) fact = \n, x -> if n == 0 then x else - fact (n - 1) (n * x) + fact((n - 1), (n * x)) add1 = \n -> n + 1 sub1 = \n -> n - 1 diff --git a/crates/cli/tests/test-projects/multiple_exposed/platform/host.zig b/crates/cli/tests/test-projects/multiple_exposed/platform/host.zig index 5ab48472ced..c3885f6223b 100644 --- a/crates/cli/tests/test-projects/multiple_exposed/platform/host.zig +++ b/crates/cli/tests/test-projects/multiple_exposed/platform/host.zig @@ -10,8 +10,8 @@ const maxInt = std.math.maxInt; const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__exposedForHost1_1_exposed(i64) i64; -extern fn roc__exposedForHost2_1_exposed(i64) i64; +extern fn roc__exposed_for_host1_1_exposed(i64) i64; +extern fn roc__exposed_for_host2_1_exposed(i64) i64; const Align = 2 * @alignOf(usize); extern fn malloc(size: usize) callconv(.C) ?*align(Align) anyopaque; @@ -109,8 +109,8 @@ comptime { pub export fn main() u8 { const stdout = std.io.getStdOut().writer(); - const result = roc__exposedForHost1_1_exposed(10); - const result2 = roc__exposedForHost2_1_exposed(10); + const result = roc__exposed_for_host1_1_exposed(10); + const result2 = roc__exposed_for_host2_1_exposed(10); stdout.print("{d}\n", .{result}) catch unreachable; stdout.print("{d}\n", .{result2}) catch unreachable; diff --git a/crates/cli/tests/test-projects/multiple_exposed/platform/main.roc b/crates/cli/tests/test-projects/multiple_exposed/platform/main.roc index 4b5f5a0277c..04c89821e52 100644 --- a/crates/cli/tests/test-projects/multiple_exposed/platform/main.roc +++ b/crates/cli/tests/test-projects/multiple_exposed/platform/main.roc @@ -3,10 +3,10 @@ platform "multiple_exposed" exposes [] packages {} imports [] - provides [exposedForHost1, exposedForHost2] + provides [exposed_for_host1, exposed_for_host2] -exposedForHost1 : I64 -> I64 -exposedForHost1 = \a -> exposed1 a |> sub1 |> add1 +exposed_for_host1 : I64 -> I64 +exposed_for_host1 = \a -> exposed1(a) |> sub1 |> add1 -exposedForHost2 : I64 -> I64 -exposedForHost2 = \a -> exposed2 a |> add1 |> sub1 +exposed_for_host2 : I64 -> I64 +exposed_for_host2 = \a -> exposed2(a) |> add1 |> sub1 diff --git a/crates/cli/tests/test-projects/platform_requires_pkg/platform/host.zig b/crates/cli/tests/test-projects/platform_requires_pkg/platform/host.zig index 0d8574224a5..441240d1692 100644 --- a/crates/cli/tests/test-projects/platform_requires_pkg/platform/host.zig +++ b/crates/cli/tests/test-projects/platform_requires_pkg/platform/host.zig @@ -101,7 +101,7 @@ comptime { const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__mainForHost_1_exposed_generic(*RocStr) void; +extern fn roc__main_for_host_1_exposed_generic(*RocStr) void; const Unit = extern struct {}; @@ -110,7 +110,7 @@ pub export fn main() u8 { // actually call roc to populate the callresult var callresult = RocStr.empty(); - roc__mainForHost_1_exposed_generic(&callresult); + roc__main_for_host_1_exposed_generic(&callresult); // stdout the result stdout.print("{s}", .{callresult.asSlice()}) catch unreachable; diff --git a/crates/cli/tests/test-projects/platform_requires_pkg/platform/main.roc b/crates/cli/tests/test-projects/platform_requires_pkg/platform/main.roc index b8c40ae927d..56565e7ec6b 100644 --- a/crates/cli/tests/test-projects/platform_requires_pkg/platform/main.roc +++ b/crates/cli/tests/test-projects/platform_requires_pkg/platform/main.roc @@ -5,10 +5,10 @@ platform "test" foo: "../foo/main.roc", } imports [] - provides [mainForHost] + provides [main_for_host] import foo.Foo -mainForHost : Str -mainForHost = +main_for_host : Str +main_for_host = "$(main) $(Foo.foo)" diff --git a/crates/cli/tests/test-projects/test-platform-effects-zig/Effect.roc b/crates/cli/tests/test-projects/test-platform-effects-zig/Effect.roc index 8b1ab6d69fa..c719a7886cc 100644 --- a/crates/cli/tests/test-projects/test-platform-effects-zig/Effect.roc +++ b/crates/cli/tests/test-projects/test-platform-effects-zig/Effect.roc @@ -1,7 +1,7 @@ hosted Effect - exposes [putLine!, getLine!] + exposes [put_line!, get_line!] imports [] -putLine! : Str => {} +put_line! : Str => {} -getLine! : {} => Str +get_line! : {} => Str diff --git a/crates/cli/tests/test-projects/test-platform-effects-zig/app-stub.roc b/crates/cli/tests/test-projects/test-platform-effects-zig/app-stub.roc index 09149a4d3c5..b5f3d90d2a0 100644 --- a/crates/cli/tests/test-projects/test-platform-effects-zig/app-stub.roc +++ b/crates/cli/tests/test-projects/test-platform-effects-zig/app-stub.roc @@ -5,6 +5,6 @@ import pf.Effect # just a stubbed app for building the test platform main! = \{} -> - Effect.putLine! "" + Effect.put_line!("") {} diff --git a/crates/cli/tests/test-projects/test-platform-effects-zig/host.zig b/crates/cli/tests/test-projects/test-platform-effects-zig/host.zig index 4380a947223..93247117dd2 100644 --- a/crates/cli/tests/test-projects/test-platform-effects-zig/host.zig +++ b/crates/cli/tests/test-projects/test-platform-effects-zig/host.zig @@ -10,8 +10,8 @@ const maxInt = std.math.maxInt; const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__mainForHost_1_exposed_generic([*]u8) void; -extern fn roc__mainForHost_1_exposed_size() i64; +extern fn roc__main_for_host_1_exposed_generic([*]u8) void; +extern fn roc__main_for_host_1_exposed_size() i64; const Align = 2 * @alignOf(usize); extern fn malloc(size: usize) callconv(.C) ?*align(Align) anyopaque; @@ -111,7 +111,7 @@ pub export fn main() u8 { const allocator = std.heap.page_allocator; // NOTE the return size can be zero, which will segfault. Always allocate at least 8 bytes - const size = @max(8, @as(usize, @intCast(roc__mainForHost_1_exposed_size()))); + const size = @max(8, @as(usize, @intCast(roc__main_for_host_1_exposed_size()))); const raw_output = allocator.alignedAlloc(u8, @alignOf(u64), @as(usize, @intCast(size))) catch unreachable; const output = @as([*]u8, @ptrCast(raw_output)); @@ -119,16 +119,16 @@ pub export fn main() u8 { allocator.free(raw_output); } - roc__mainForHost_1_exposed_generic(output); + roc__main_for_host_1_exposed_generic(output); return 0; } -pub export fn roc_fx_getLine() str.RocStr { - return roc_fx_getLine_help() catch return str.RocStr.empty(); +pub export fn roc_fx_get_line() str.RocStr { + return roc_fx_get_line_help() catch return str.RocStr.empty(); } -fn roc_fx_getLine_help() !RocStr { +fn roc_fx_get_line_help() !RocStr { const stdin = std.io.getStdIn().reader(); var buf: [400]u8 = undefined; @@ -137,7 +137,7 @@ fn roc_fx_getLine_help() !RocStr { return str.RocStr.init(@as([*]const u8, @ptrCast(line)), line.len); } -pub export fn roc_fx_putLine(rocPath: *str.RocStr) i64 { +pub export fn roc_fx_put_line(rocPath: *str.RocStr) i64 { const stdout = std.io.getStdOut().writer(); for (rocPath.asSlice()) |char| { @@ -155,8 +155,8 @@ const GetInt = extern struct { is_error: bool, }; -pub export fn roc_fx_getInt() GetInt { - if (roc_fx_getInt_help()) |value| { +pub export fn roc_fx_get_int() GetInt { + if (roc_fx_get_int_help()) |value| { const get_int = GetInt{ .is_error = false, .value = value, .error_code = 0 }; return get_int; } else |err| switch (err) { @@ -171,7 +171,7 @@ pub export fn roc_fx_getInt() GetInt { return 0; } -fn roc_fx_getInt_help() !i64 { +fn roc_fx_get_int_help() !i64 { const stdin = std.io.getStdIn().reader(); var buf: [40]u8 = undefined; diff --git a/crates/cli/tests/test-projects/test-platform-effects-zig/main.roc b/crates/cli/tests/test-projects/test-platform-effects-zig/main.roc index bcaccafe040..beaf945cd5c 100644 --- a/crates/cli/tests/test-projects/test-platform-effects-zig/main.roc +++ b/crates/cli/tests/test-projects/test-platform-effects-zig/main.roc @@ -3,7 +3,7 @@ platform "effects" exposes [] packages {} imports [] - provides [mainForHost!] + provides [main_for_host!] -mainForHost! : {} => {} -mainForHost! = \{} -> main! {} +main_for_host! : {} => {} +main_for_host! = \{} -> main!({}) diff --git a/crates/cli/tests/test-projects/test-platform-simple-zig/host.zig b/crates/cli/tests/test-projects/test-platform-simple-zig/host.zig index d621b10bf34..4da7370c432 100644 --- a/crates/cli/tests/test-projects/test-platform-simple-zig/host.zig +++ b/crates/cli/tests/test-projects/test-platform-simple-zig/host.zig @@ -9,7 +9,7 @@ const expect = testing.expect; const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__mainForHost_1_exposed_generic(*RocStr) void; +extern fn roc__main_for_host_1_exposed_generic(*RocStr) void; const Align = 2 * @alignOf(usize); extern fn malloc(size: usize) callconv(.C) ?*align(Align) anyopaque; @@ -96,7 +96,7 @@ pub export fn main() i32 { // actually call roc to populate the callresult var callresult = RocStr.empty(); - roc__mainForHost_1_exposed_generic(&callresult); + roc__main_for_host_1_exposed_generic(&callresult); // stdout the result stdout.print("{s}\n", .{callresult.asSlice()}) catch unreachable; diff --git a/crates/cli/tests/test-projects/test-platform-simple-zig/main.roc b/crates/cli/tests/test-projects/test-platform-simple-zig/main.roc index e141577dcb2..45ca32d1a2b 100644 --- a/crates/cli/tests/test-projects/test-platform-simple-zig/main.roc +++ b/crates/cli/tests/test-projects/test-platform-simple-zig/main.roc @@ -3,7 +3,7 @@ platform "" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Str -mainForHost = main +main_for_host : Str +main_for_host = main diff --git a/crates/cli/tests/test-projects/tui/main.roc b/crates/cli/tests/test-projects/tui/main.roc index b882363b8b3..35f3cc08c09 100644 --- a/crates/cli/tests/test-projects/tui/main.roc +++ b/crates/cli/tests/test-projects/tui/main.roc @@ -7,6 +7,6 @@ Model : Str main : Program Model main = { init: \{} -> "Hello World", - update: \model, new -> Str.concat model new, - view: \model -> Str.concat model "!", + update: \model, new -> Str.concat(model, new), + view: \model -> Str.concat(model, "!"), } diff --git a/crates/cli/tests/test-projects/tui/platform/host.zig b/crates/cli/tests/test-projects/tui/platform/host.zig index b3e6da41e58..370ca907d42 100644 --- a/crates/cli/tests/test-projects/tui/platform/host.zig +++ b/crates/cli/tests/test-projects/tui/platform/host.zig @@ -12,18 +12,18 @@ const Allocator = mem.Allocator; const Program = extern struct { init: RocStr, update: Unit, view: Unit }; -extern fn roc__mainForHost_1_exposed() Program; -extern fn roc__mainForHost_size() i64; +extern fn roc__main_for_host_1_exposed() Program; +extern fn roc__main_for_host_size() i64; const ConstModel = [*]const u8; const MutModel = [*]u8; -extern fn roc__mainForHost_0_caller([*]u8, [*]u8, MutModel) void; -extern fn roc__mainForHost_0_size() i64; -extern fn roc__mainForHost_0_result_size() i64; +extern fn roc__main_for_host_0_caller([*]u8, [*]u8, MutModel) void; +extern fn roc__main_for_host_0_size() i64; +extern fn roc__main_for_host_0_result_size() i64; fn allocate_model(allocator: *Allocator) MutModel { - const size = roc__mainForHost_0_result_size(); + const size = roc__main_for_host_0_result_size(); const raw_output = allocator.alignedAlloc(u8, @alignOf(u64), @as(usize, @intCast(size))) catch unreachable; const output = @as([*]u8, @ptrCast(raw_output)); @@ -34,33 +34,33 @@ fn init(allocator: *Allocator) ConstModel { const closure: [*]u8 = undefined; const output = allocate_model(allocator); - roc__mainForHost_0_caller(closure, closure, output); + roc__main_for_host_0_caller(closure, closure, output); return output; } -extern fn roc__mainForHost_1_caller(ConstModel, *const RocStr, [*]u8, MutModel) void; -extern fn roc__mainForHost_1_size() i64; -extern fn roc__mainForHost_1_result_size() i64; +extern fn roc__main_for_host_1_caller(ConstModel, *const RocStr, [*]u8, MutModel) void; +extern fn roc__main_for_host_1_size() i64; +extern fn roc__main_for_host_1_result_size() i64; fn update(allocator: *Allocator, model: ConstModel, msg: RocStr) ConstModel { const closure: [*]u8 = undefined; const output = allocate_model(allocator); - roc__mainForHost_1_caller(model, &msg, closure, output); + roc__main_for_host_1_caller(model, &msg, closure, output); return output; } -extern fn roc__mainForHost_2_caller(ConstModel, [*]u8, *RocStr) void; -extern fn roc__mainForHost_2_size() i64; -extern fn roc__mainForHost_2_result_size() i64; +extern fn roc__main_for_host_2_caller(ConstModel, [*]u8, *RocStr) void; +extern fn roc__main_for_host_2_size() i64; +extern fn roc__main_for_host_2_result_size() i64; fn view(input: ConstModel) RocStr { const closure: [*]u8 = undefined; var output: RocStr = undefined; - roc__mainForHost_2_caller(input, closure, &output); + roc__main_for_host_2_caller(input, closure, &output); return output; } @@ -171,7 +171,7 @@ comptime { const Unit = extern struct {}; pub export fn main() callconv(.C) u8 { - const program = roc__mainForHost_1_exposed(); + const program = roc__main_for_host_1_exposed(); call_the_closure(program); @@ -206,7 +206,7 @@ fn call_the_closure(program: Program) void { return; } -pub export fn roc_fx_putInt(int: i64) i64 { +pub export fn roc_fx_put_int(int: i64) i64 { const stdout = std.io.getStdOut().writer(); stdout.print("{d}", .{int}) catch unreachable; @@ -216,7 +216,7 @@ pub export fn roc_fx_putInt(int: i64) i64 { return 0; } -export fn roc_fx_putLine(rocPath: str.RocStr) callconv(.C) void { +export fn roc_fx_put_line(rocPath: str.RocStr) callconv(.C) void { const stdout = std.io.getStdOut().writer(); for (rocPath.asSlice()) |char| { @@ -234,14 +234,14 @@ const GetInt = extern struct { comptime { if (@sizeOf(usize) == 8) { - @export(roc_fx_getInt_64bit, .{ .name = "roc_fx_getInt" }); + @export(roc_fx_get_int_64bit, .{ .name = "roc_fx_get_int" }); } else { - @export(roc_fx_getInt_32bit, .{ .name = "roc_fx_getInt" }); + @export(roc_fx_get_int_32bit, .{ .name = "roc_fx_get_int" }); } } -fn roc_fx_getInt_64bit() callconv(.C) GetInt { - if (roc_fx_getInt_help()) |value| { +fn roc_fx_get_int_64bit() callconv(.C) GetInt { + if (roc_fx_get_int_help()) |value| { const get_int = GetInt{ .is_error = false, .value = value, .error_code = false }; return get_int; } else |err| switch (err) { @@ -256,8 +256,8 @@ fn roc_fx_getInt_64bit() callconv(.C) GetInt { return 0; } -fn roc_fx_getInt_32bit(output: *GetInt) callconv(.C) void { - if (roc_fx_getInt_help()) |value| { +fn roc_fx_get_int_32bit(output: *GetInt) callconv(.C) void { + if (roc_fx_get_int_help()) |value| { const get_int = GetInt{ .is_error = false, .value = value, .error_code = false }; output.* = get_int; } else |err| switch (err) { @@ -272,7 +272,7 @@ fn roc_fx_getInt_32bit(output: *GetInt) callconv(.C) void { return; } -fn roc_fx_getInt_help() !i64 { +fn roc_fx_get_int_help() !i64 { const stdin = std.io.getStdIn().reader(); var buf: [40]u8 = undefined; diff --git a/crates/cli/tests/test-projects/tui/platform/main.roc b/crates/cli/tests/test-projects/tui/platform/main.roc index f4f2386d262..d7a0c963249 100644 --- a/crates/cli/tests/test-projects/tui/platform/main.roc +++ b/crates/cli/tests/test-projects/tui/platform/main.roc @@ -3,7 +3,7 @@ platform "tui" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : { init : ({} -> Model) as Init, update : (Model, Str -> Model) as Update, view : (Model -> Str) as View } -mainForHost = main +main_for_host : { init : ({} -> Model) as Init, update : (Model, Str -> Model) as Update, view : (Model -> Str) as View } +main_for_host = main diff --git a/crates/compiler/alias_analysis/src/lib.rs b/crates/compiler/alias_analysis/src/lib.rs index abbbe813fa4..925efc3bf29 100644 --- a/crates/compiler/alias_analysis/src/lib.rs +++ b/crates/compiler/alias_analysis/src/lib.rs @@ -28,7 +28,7 @@ pub const MOD_APP: ModName = ModName(b"UserApp"); pub const STATIC_STR_NAME: ConstName = ConstName(&Symbol::STR_ALIAS_ANALYSIS_STATIC.to_ne_bytes()); pub const STATIC_LIST_NAME: ConstName = ConstName(b"THIS IS A STATIC LIST"); -const DEFAULT_ENTRY_POINT_NAME: &[u8] = b"mainForHost"; +const DEFAULT_ENTRY_POINT_NAME: &[u8] = b"main_for_host"; pub fn func_name_bytes(proc: &Proc) -> [u8; SIZE] { let bytes = func_name_bytes_help( diff --git a/crates/compiler/builtins/bitcode/src/dec.zig b/crates/compiler/builtins/bitcode/src/dec.zig index 53a4cb3df77..f93eca695ff 100644 --- a/crates/compiler/builtins/bitcode/src/dec.zig +++ b/crates/compiler/builtins/bitcode/src/dec.zig @@ -144,7 +144,7 @@ pub const RocDec = extern struct { return (c -% 48) <= 9; } - pub fn toStr(self: RocDec) RocStr { + pub fn to_str(self: RocDec) RocStr { // Special case if (self.num == 0) { return RocStr.init("0.0", 3); @@ -1031,97 +1031,97 @@ test "fromStr: .123.1" { try expectEqual(dec, null); } -test "toStr: 100.00" { +test "to_str: 100.00" { var dec: RocDec = .{ .num = 100000000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "100.0"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 123.45" { +test "to_str: 123.45" { var dec: RocDec = .{ .num = 123450000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "123.45"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: -123.45" { +test "to_str: -123.45" { var dec: RocDec = .{ .num = -123450000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "-123.45"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 123.0" { +test "to_str: 123.0" { var dec: RocDec = .{ .num = 123000000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "123.0"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: -123.0" { +test "to_str: -123.0" { var dec: RocDec = .{ .num = -123000000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "-123.0"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 0.45" { +test "to_str: 0.45" { var dec: RocDec = .{ .num = 450000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "0.45"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: -0.45" { +test "to_str: -0.45" { var dec: RocDec = .{ .num = -450000000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "-0.45"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 0.00045" { +test "to_str: 0.00045" { var dec: RocDec = .{ .num = 450000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "0.00045"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: -0.00045" { +test "to_str: -0.00045" { var dec: RocDec = .{ .num = -450000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "-0.00045"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: -111.123456" { +test "to_str: -111.123456" { var dec: RocDec = .{ .num = -111123456000000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "-111.123456"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 123.1111111" { +test "to_str: 123.1111111" { var dec: RocDec = .{ .num = 123111111100000000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "123.1111111"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 123.1111111111111 (big str)" { +test "to_str: 123.1111111111111 (big str)" { var dec: RocDec = .{ .num = 123111111111111000000 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); errdefer res_roc_str.decref(); defer res_roc_str.decref(); @@ -1129,9 +1129,9 @@ test "toStr: 123.1111111111111 (big str)" { try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 123.111111111111444444 (max number of decimal places)" { +test "to_str: 123.111111111111444444 (max number of decimal places)" { var dec: RocDec = .{ .num = 123111111111111444444 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); errdefer res_roc_str.decref(); defer res_roc_str.decref(); @@ -1139,9 +1139,9 @@ test "toStr: 123.111111111111444444 (max number of decimal places)" { try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 12345678912345678912.111111111111111111 (max number of digits)" { +test "to_str: 12345678912345678912.111111111111111111 (max number of digits)" { var dec: RocDec = .{ .num = 12345678912345678912111111111111111111 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); errdefer res_roc_str.decref(); defer res_roc_str.decref(); @@ -1149,9 +1149,9 @@ test "toStr: 12345678912345678912.111111111111111111 (max number of digits)" { try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: std.math.maxInt" { +test "to_str: std.math.maxInt" { var dec: RocDec = .{ .num = std.math.maxInt(i128) }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); errdefer res_roc_str.decref(); defer res_roc_str.decref(); @@ -1159,9 +1159,9 @@ test "toStr: std.math.maxInt" { try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: std.math.minInt" { +test "to_str: std.math.minInt" { var dec: RocDec = .{ .num = std.math.minInt(i128) }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); errdefer res_roc_str.decref(); defer res_roc_str.decref(); @@ -1169,9 +1169,9 @@ test "toStr: std.math.minInt" { try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); } -test "toStr: 0" { +test "to_str: 0" { var dec: RocDec = .{ .num = 0 }; - var res_roc_str = dec.toStr(); + var res_roc_str = dec.to_str(); const res_slice: []const u8 = "0.0"[0..]; try expectEqualSlices(u8, res_slice, res_roc_str.asSlice()); @@ -1443,8 +1443,8 @@ pub fn fromStr(arg: RocStr) callconv(.C) num_.NumParseResult(i128) { } } -pub fn toStr(arg: RocDec) callconv(.C) RocStr { - return @call(.always_inline, RocDec.toStr, .{arg}); +pub fn to_str(arg: RocDec) callconv(.C) RocStr { + return @call(.always_inline, RocDec.to_str, .{arg}); } pub fn fromF64C(arg: f64) callconv(.C) i128 { diff --git a/crates/compiler/builtins/bitcode/src/main.zig b/crates/compiler/builtins/bitcode/src/main.zig index f1b3ccfaa13..52a02c75c7d 100644 --- a/crates/compiler/builtins/bitcode/src/main.zig +++ b/crates/compiler/builtins/bitcode/src/main.zig @@ -50,7 +50,7 @@ comptime { exportDecFn(dec.toF64, "to_f64"); exportDecFn(dec.toI128, "to_i128"); exportDecFn(dec.fromI128, "from_i128"); - exportDecFn(dec.toStr, "to_str"); + exportDecFn(dec.to_str, "to_str"); for (INTEGERS) |T| { dec.exportFromInt(T, ROC_BUILTINS ++ ".dec.from_int."); diff --git a/crates/compiler/builtins/roc/Bool.roc b/crates/compiler/builtins/roc/Bool.roc index d53d80e55ca..fccfc10d6cf 100644 --- a/crates/compiler/builtins/roc/Bool.roc +++ b/crates/compiler/builtins/roc/Bool.roc @@ -1,9 +1,9 @@ -module [Bool, Eq, true, false, and, or, not, isEq, isNotEq] +module [Bool, Eq, true, false, and, or, not, is_eq, is_not_eq] ## Defines a type that can be compared for total equality. ## ## Total equality means that all values of the type can be compared to each -## other, and two values `a`, `b` are identical if and only if `isEq a b` is +## other, and two values `a`, `b` are identical if and only if `isEq(a, b)` is ## `Bool.true`. ## ## Not all types support total equality. For example, [`F32`](../Num#F32) and [`F64`](../Num#F64) can @@ -14,9 +14,9 @@ Eq implements ## Returns `Bool.true` if the input values are equal. This is ## equivalent to the logic ## [XNOR](https://en.wikipedia.org/wiki/Logical_equality) gate. The infix - ## operator `==` can be used as shorthand for `Bool.isEq`. + ## operator `==` can be used as shorthand for `Bool.is_eq`. ## - ## **Note** that when `isEq` is determined by the Roc compiler, values are + ## **Note** that when `is_eq` is determined by the Roc compiler, values are ## compared using structural equality. The rules for this are as follows: ## ## 1. Tags are equal if their name and also contents are equal. @@ -24,25 +24,25 @@ Eq implements ## 3. The collections [Str], [List], [Dict], and [Set] are equal iff they ## are the same length and their elements are equal. ## 4. [Num] values are equal if their numbers are equal. However, if both - ## inputs are *NaN* then `isEq` returns `Bool.false`. Refer to `Num.isNaN` + ## inputs are *NaN* then `is_eq` returns `Bool.false`. Refer to `Num.is_nan` ## for more detail. ## 5. Functions cannot be compared for structural equality, therefore Roc - ## cannot derive `isEq` for types that contain functions. - isEq : a, a -> Bool where a implements Eq + ## cannot derive `is_eq` for types that contain functions. + is_eq : a, a -> Bool where a implements Eq ## Represents the boolean true and false using an opaque type. ## `Bool` implements the `Eq` ability. -Bool := [True, False] implements [Eq { isEq: boolIsEq }] +Bool := [True, False] implements [Eq { is_eq: bool_is_eq }] -boolIsEq = \@Bool b1, @Bool b2 -> structuralEq b1 b2 +bool_is_eq = \@Bool(b1), @Bool(b2) -> structural_eq(b1, b2) ## The boolean true value. true : Bool -true = @Bool True +true = @Bool(True) ## The boolean false value. false : Bool -false = @Bool False +false = @Bool(False) ## Returns `Bool.true` when both inputs are `Bool.true`. This is equivalent to ## the logic [AND](https://en.wikipedia.org/wiki/Logical_conjunction) @@ -50,7 +50,7 @@ false = @Bool False ## `Bool.and`. ## ## ```roc -## expect (Bool.and Bool.true Bool.true) == Bool.true +## expect Bool.and(Bool.true, Bool.true) == Bool.true ## expect (Bool.true && Bool.true) == Bool.true ## expect (Bool.false && Bool.true) == Bool.false ## expect (Bool.true && Bool.false) == Bool.false @@ -63,10 +63,10 @@ false = @Bool False ## other function. However, in some languages `&&` and `||` are special-cased. ## In these languages the compiler will skip evaluating the expression after the ## first operator under certain circumstances. For example an expression like -## `enablePets && likesDogs user` would compile to. +## `enable_pets && likes_dogs(user)` would compile to. ## ```roc -## if enablePets then -## likesDogs user +## if enable_pets then +## likes_dogs(user) ## else ## Bool.false ## ``` @@ -79,7 +79,7 @@ and : Bool, Bool -> Bool ## the logic [OR](https://en.wikipedia.org/wiki/Logical_disjunction) gate. ## The infix operator `||` can also be used as shorthand for `Bool.or`. ## ```roc -## expect (Bool.or Bool.false Bool.true) == Bool.true +## expect Bool.or(Bool.false, Bool.true) == Bool.true ## expect (Bool.true || Bool.true) == Bool.true ## expect (Bool.false || Bool.true) == Bool.true ## expect (Bool.true || Bool.false) == Bool.true @@ -97,30 +97,30 @@ or : Bool, Bool -> Bool ## equivalent to the logic [NOT](https://en.wikipedia.org/wiki/Negation) ## gate. The operator `!` can also be used as shorthand for `Bool.not`. ## ```roc -## expect (Bool.not Bool.false) == Bool.true -## expect (!Bool.false) == Bool.true +## expect Bool.not(Bool.false) == Bool.true +## expect !Bool.false == Bool.true ## ``` not : Bool -> Bool -## This will call the function `Bool.isEq` on the inputs, and then `Bool.not` +## This will call the function `Bool.is_eq` on the inputs, and then `Bool.not` ## on the result. The is equivalent to the logic ## [XOR](https://en.wikipedia.org/wiki/Exclusive_or) gate. The infix operator -## `!=` can also be used as shorthand for `Bool.isNotEq`. +## `!=` can also be used as shorthand for `Bool.is_not_eq`. ## -## **Note** that `isNotEq` does not accept arguments whose types contain +## **Note** that `is_not_eq` does not accept arguments whose types contain ## functions. ## ```roc -## expect (Bool.isNotEq Bool.false Bool.true) == Bool.true +## expect Bool.is_not_eq(Bool.false, Bool.true) == Bool.true ## expect (Bool.false != Bool.false) == Bool.false ## expect "Apples" != "Oranges" ## ``` -isNotEq : a, a -> Bool where a implements Eq -isNotEq = \a, b -> structuralNotEq a b +is_not_eq : a, a -> Bool where a implements Eq +is_not_eq = \a, b -> structural_not_eq(a, b) -# INTERNAL COMPILER USE ONLY: used to lower calls to `isEq` to structural +# INTERNAL COMPILER USE ONLY: used to lower calls to `is_eq` to structural # equality via the `Eq` low-level for derived types. -structuralEq : a, a -> Bool +structural_eq : a, a -> Bool -# INTERNAL COMPILER USE ONLY: used to lower calls to `isNotEq` to structural +# INTERNAL COMPILER USE ONLY: used to lower calls to `is_not_eq` to structural # inequality via the `NotEq` low-level for derived types. -structuralNotEq : a, a -> Bool +structural_not_eq : a, a -> Bool diff --git a/crates/compiler/builtins/roc/Box.roc b/crates/compiler/builtins/roc/Box.roc index 4812a4e0cde..482ebe75be4 100644 --- a/crates/compiler/builtins/roc/Box.roc +++ b/crates/compiler/builtins/roc/Box.roc @@ -9,13 +9,13 @@ module [box, unbox] ## optimization for advanced use cases with large values. A platform may require ## that some values are boxed. ## ```roc -## expect Box.unbox (Box.box "Stack Faster") == "Stack Faster" +## expect Box.unbox(Box.box("Stack Faster")) == "Stack Faster" ## ``` box : a -> Box a ## Returns a boxed value. ## ```roc -## expect Box.unbox (Box.box "Stack Faster") == "Stack Faster" +## expect Box.unbox(Box.box("Stack Faster") == "Stack Faster" ## ``` unbox : Box a -> a diff --git a/crates/compiler/builtins/roc/Decode.roc b/crates/compiler/builtins/roc/Decode.roc index 71e330c4b1b..ce7d996af5f 100644 --- a/crates/compiler/builtins/roc/Decode.roc +++ b/crates/compiler/builtins/roc/Decode.roc @@ -24,10 +24,10 @@ module [ record, tuple, custom, - decodeWith, - fromBytesPartial, - fromBytes, - mapResult, + decode_with, + from_bytes_partial, + from_bytes, + map_result, ] import List @@ -55,13 +55,13 @@ DecodeError : [TooShort] ## Return type of a [Decoder]. ## ## This can be useful when creating a [custom](#custom) decoder or when -## using [fromBytesPartial](#fromBytesPartial). For example writing unit tests, +## using [from_bytes_partial](#from_bytes_partial). For example writing unit tests, ## such as; ## ```roc ## expect ## input = "\"hello\", " |> Str.toUtf8 -## actual = Decode.fromBytesPartial input Json.json -## expected = Ok "hello" +## actual = Decode.from_bytes_partial(input, Json.json) +## expected = Ok("hello") ## ## actual.result == expected ## ``` @@ -95,51 +95,51 @@ DecoderFormatting implements string : Decoder Str fmt where fmt implements DecoderFormatting list : Decoder elem fmt -> Decoder (List elem) fmt where fmt implements DecoderFormatting - ## `record state stepField finalizer` decodes a record field-by-field. + ## `record(state, step_field, finalizer)` decodes a record field-by-field. ## - ## `stepField` returns a decoder for the given field in the record, or + ## `step_field` returns a decoder for the given field in the record, or ## `Skip` if the field is not a part of the decoded record. ## ## `finalizer` should produce the record value from the decoded `state`. record : state, (state, Str -> [Keep (Decoder state fmt), Skip]), (state, fmt -> Result val DecodeError) -> Decoder val fmt where fmt implements DecoderFormatting - ## `tuple state stepElem finalizer` decodes a tuple element-by-element. + ## `tuple(state, step_elem, finalizer)` decodes a tuple element-by-element. ## - ## `stepElem` returns a decoder for the nth index in the tuple, or + ## `step_elem` returns a decoder for the nth index in the tuple, or ## `TooLong` if the index is larger than the expected size of the tuple. The - ## index passed to `stepElem` is 0-indexed. + ## index passed to `step_elem` is 0-indexed. ## ## `finalizer` should produce the tuple value from the decoded `state`. tuple : state, (state, U64 -> [Next (Decoder state fmt), TooLong]), (state -> Result val DecodeError) -> Decoder val fmt where fmt implements DecoderFormatting ## Build a custom [Decoder] function. For example the implementation of -## `decodeBool` could be defined as follows; +## `decode_bool` could be defined as follows; ## ## ```roc -## decodeBool = Decode.custom \bytes, @Json {} -> +## decode_bool = Decode.custom \bytes, @Json({}) -> ## when bytes is -## ['f', 'a', 'l', 's', 'e', ..] -> { result: Ok Bool.false, rest: List.dropFirst bytes 5 } -## ['t', 'r', 'u', 'e', ..] -> { result: Ok Bool.true, rest: List.dropFirst bytes 4 } -## _ -> { result: Err TooShort, rest: bytes } +## ['f', 'a', 'l', 's', 'e', ..] -> { result: Ok(Bool.false), rest: List.drop_first(bytes, 5) } +## ['t', 'r', 'u', 'e', ..] -> { result: Ok Bool.true, rest: List.drop_first(bytes, 4) } +## _ -> { result: Err(TooShort), rest: bytes } ## ``` custom : (List U8, fmt -> DecodeResult val) -> Decoder val fmt where fmt implements DecoderFormatting -custom = \decode -> @Decoder decode +custom = \decode -> @Decoder(decode) ## Decode a `List U8` utf-8 bytes using a specific [Decoder] function -decodeWith : List U8, Decoder val fmt, fmt -> DecodeResult val where fmt implements DecoderFormatting -decodeWith = \bytes, @Decoder decode, fmt -> decode bytes fmt +decode_with : List U8, Decoder val fmt, fmt -> DecodeResult val where fmt implements DecoderFormatting +decode_with = \bytes, @Decoder(decode), fmt -> decode(bytes, fmt) ## Decode a `List U8` utf-8 bytes and return a [DecodeResult](#DecodeResult) ## ```roc ## expect ## input = "\"hello\", " |> Str.toUtf8 -## actual = Decode.fromBytesPartial input Json.json -## expected = Ok "hello" +## actual = Decode.from_bytes_partial(input Json.json) +## expected = Ok("hello") ## ## actual.result == expected ## ``` -fromBytesPartial : List U8, fmt -> DecodeResult val where val implements Decoding, fmt implements DecoderFormatting -fromBytesPartial = \bytes, fmt -> decodeWith bytes decoder fmt +from_bytes_partial : List U8, fmt -> DecodeResult val where val implements Decoding, fmt implements DecoderFormatting +from_bytes_partial = \bytes, fmt -> decode_with(bytes, decoder, fmt) ## Decode a `List U8` utf-8 bytes and return a [Result] with no leftover bytes ## expected. If successful returns `Ok val`, however, if there are bytes @@ -147,22 +147,22 @@ fromBytesPartial = \bytes, fmt -> decodeWith bytes decoder fmt ## ```roc ## expect ## input = "\"hello\", " |> Str.toUtf8 -## actual = Decode.fromBytes input Json.json -## expected = Ok "hello" +## actual = Decode.from_bytes(input, Json.json) +## expected = Ok("hello") ## ## actual == expected ## ``` -fromBytes : List U8, fmt -> Result val [Leftover (List U8)]DecodeError where val implements Decoding, fmt implements DecoderFormatting -fromBytes = \bytes, fmt -> - when fromBytesPartial bytes fmt is +from_bytes : List U8, fmt -> Result val [Leftover (List U8)]DecodeError where val implements Decoding, fmt implements DecoderFormatting +from_bytes = \bytes, fmt -> + when from_bytes_partial(bytes, fmt) is { result, rest } -> - if List.isEmpty rest then + if List.is_empty(rest) then when result is - Ok val -> Ok val - Err TooShort -> Err TooShort + Ok(val) -> Ok(val) + Err(TooShort) -> Err(TooShort) else - Err (Leftover rest) + Err(Leftover(rest)) ## Transform the `val` of a [DecodeResult] -mapResult : DecodeResult a, (a -> b) -> DecodeResult b -mapResult = \{ result, rest }, mapper -> { result: Result.map result mapper, rest } +map_result : DecodeResult a, (a -> b) -> DecodeResult b +map_result = \{ result, rest }, mapper -> { result: Result.map(result, mapper), rest } diff --git a/crates/compiler/builtins/roc/Dict.roc b/crates/compiler/builtins/roc/Dict.roc index c5e99c8b787..a1a94ac11aa 100644 --- a/crates/compiler/builtins/roc/Dict.roc +++ b/crates/compiler/builtins/roc/Dict.roc @@ -1,32 +1,32 @@ module [ Dict, empty, - withCapacity, + with_capacity, single, clear, capacity, reserve, - releaseExcessCapacity, + release_excess_capacity, len, - isEmpty, + is_empty, get, contains, insert, remove, update, walk, - walkUntil, - keepIf, - dropIf, - toList, - fromList, + walk_until, + keep_if, + drop_if, + to_list, + from_list, keys, values, - insertAll, - keepShared, - removeAll, + insert_all, + keep_shared, + remove_all, map, - joinMap, + join_map, ] import Bool exposing [Bool, Eq] @@ -52,13 +52,13 @@ import Inspect exposing [Inspect, Inspector, InspectFormatter] ## Here's an example of a dictionary which uses a city's name as the key, and ## its population as the associated value. ## ```roc -## populationByCity = -## Dict.empty {} -## |> Dict.insert "London" 8_961_989 -## |> Dict.insert "Philadelphia" 1_603_797 -## |> Dict.insert "Shanghai" 24_870_895 -## |> Dict.insert "Delhi" 16_787_941 -## |> Dict.insert "Amsterdam" 872_680 +## population_by_city = +## Dict.empty({}) +## |> Dict.insert("London", 8_961_989) +## |> Dict.insert("Philadelphia", 1_603_797) +## |> Dict.insert("Shanghai", 24_870_895) +## |> Dict.insert("Delhi", 16_787_941) +## |> Dict.insert("Amsterdam", 872_680) ## ``` ## ## Accessing keys or values ## @@ -73,8 +73,8 @@ import Inspect exposing [Inspect, Inspector, InspectFormatter] ## ## We can remove an element from the dictionary, like so: ## ```roc -## populationByCity -## |> Dict.remove "Philadelphia" +## population_by_city +## |> Dict.remove("Philadelphia") ## |> Dict.keys ## == ## ["London", "Amsterdam", "Shanghai", "Delhi"] @@ -95,138 +95,142 @@ import Inspect exposing [Inspect, Inspector, InspectFormatter] Dict k v := { buckets : List Bucket, data : List (k, v), - maxBucketCapacity : U64, - maxLoadFactor : F32, + max_bucket_capacity : U64, + max_load_factor : F32, shifts : U8, } where k implements Hash & Eq implements [ Eq { - isEq, + is_eq, }, Hash { - hash: hashDict, + hash: hash_dict, }, Inspect { - toInspector: toInspectorDict, + to_inspector: to_inspector_dict, }, ] -isEq : Dict k v, Dict k v -> Bool where v implements Eq -isEq = \xs, ys -> - if len xs != len ys then +is_eq : Dict k v, Dict k v -> Bool where v implements Eq +is_eq = \xs, ys -> + if len(xs) != len(ys) then Bool.false else - walkUntil xs Bool.true \_, k, xVal -> - when get ys k is - Ok yVal if yVal == xVal -> - Continue Bool.true - - _ -> - Break Bool.false + walk_until( + xs, + Bool.true, + \_, k, x_val -> + when get(ys, k) is + Ok(y_val) if y_val == x_val -> + Continue(Bool.true) + + _ -> + Break(Bool.false), + ) -hashDict : hasher, Dict k v -> hasher where v implements Hash, hasher implements Hasher -hashDict = \hasher, dict -> Hash.hashUnordered hasher (toList dict) List.walk +hash_dict : hasher, Dict k v -> hasher where v implements Hash, hasher implements Hasher +hash_dict = \hasher, dict -> Hash.hash_unordered(hasher, to_list(dict), List.walk) -toInspectorDict : Dict k v -> Inspector f where k implements Inspect & Hash & Eq, v implements Inspect, f implements InspectFormatter -toInspectorDict = \dict -> - Inspect.custom \fmt -> - Inspect.apply (Inspect.dict dict walk Inspect.toInspector Inspect.toInspector) fmt +to_inspector_dict : Dict k v -> Inspector f where k implements Inspect & Hash & Eq, v implements Inspect, f implements InspectFormatter +to_inspector_dict = \dict -> + Inspect.custom(\fmt -> + Inspect.apply(Inspect.dict(dict, walk, Inspect.to_inspector, Inspect.to_inspector), fmt)) ## Return an empty dictionary. ## ```roc -## emptyDict = Dict.empty {} +## empty_dict = Dict.empty({}) ## ``` empty : {} -> Dict * * empty = \{} -> - @Dict { + @Dict({ buckets: [], data: [], - maxBucketCapacity: 0, - maxLoadFactor: defaultMaxLoadFactor, - shifts: initialShifts, - } + max_bucket_capacity: 0, + max_load_factor: default_max_load_factor, + shifts: initial_shifts, + }) ## Return a dictionary with space allocated for a number of entries. This ## may provide a performance optimization if you know how many entries will be ## inserted. -withCapacity : U64 -> Dict * * -withCapacity = \requested -> - empty {} - |> reserve requested +with_capacity : U64 -> Dict * * +with_capacity = \requested -> + empty({}) + |> reserve(requested) ## Enlarge the dictionary for at least capacity additional elements reserve : Dict k v, U64 -> Dict k v -reserve = \@Dict { buckets, data, maxBucketCapacity: originalMaxBucketCapacity, maxLoadFactor, shifts }, requested -> - currentSize = List.len data - requestedSize = Num.addWrap currentSize requested - size = Num.min requestedSize maxSize - - requestedShifts = calcShiftsForSize size maxLoadFactor - if (List.isEmpty buckets) || requestedShifts > shifts then - (buckets0, maxBucketCapacity) = allocBucketsFromShift requestedShifts maxLoadFactor - buckets1 = fillBucketsFromData buckets0 data requestedShifts - @Dict { +reserve = \@Dict({ buckets, data, max_bucket_capacity: original_max_bucket_capacity, max_load_factor, shifts }), requested -> + current_size = List.len(data) + requested_size = Num.add_wrap(current_size, requested) + size = Num.min(requested_size, max_size) + + requested_shifts = calc_shifts_for_size(size, max_load_factor) + if List.is_empty(buckets) || requested_shifts > shifts then + (buckets0, max_bucket_capacity) = alloc_buckets_from_shift(requested_shifts, max_load_factor) + buckets1 = fill_buckets_from_data(buckets0, data, requested_shifts) + @Dict({ buckets: buckets1, - data: List.reserve data (Num.subSaturated size currentSize), - maxBucketCapacity, - maxLoadFactor, - shifts: requestedShifts, - } + data: List.reserve(data, Num.sub_saturated(size, current_size)), + max_bucket_capacity, + max_load_factor, + shifts: requested_shifts, + }) else - @Dict { buckets, data, maxBucketCapacity: originalMaxBucketCapacity, maxLoadFactor, shifts } + @Dict({ buckets, data, max_bucket_capacity: original_max_bucket_capacity, max_load_factor, shifts }) ## Shrink the memory footprint of a dictionary such that capacity is as small as possible. ## This function will require regenerating the metadata if the size changes. ## There will still be some overhead due to dictionary metadata always being a power of 2. -releaseExcessCapacity : Dict k v -> Dict k v -releaseExcessCapacity = \@Dict { buckets, data, maxBucketCapacity: originalMaxBucketCapacity, maxLoadFactor, shifts } -> - size = List.len data +release_excess_capacity : Dict k v -> Dict k v +release_excess_capacity = \@Dict({ buckets, data, max_bucket_capacity: original_max_bucket_capacity, max_load_factor, shifts }) -> + size = List.len(data) # NOTE: If we want, we technically could increase the load factor here to potentially minimize size more. - minShifts = calcShiftsForSize size maxLoadFactor - if minShifts < shifts then - (buckets0, maxBucketCapacity) = allocBucketsFromShift minShifts maxLoadFactor - buckets1 = fillBucketsFromData buckets0 data minShifts - @Dict { + min_shifts = calc_shifts_for_size(size, max_load_factor) + if min_shifts < shifts then + (buckets0, max_bucket_capacity) = alloc_buckets_from_shift(min_shifts, max_load_factor) + buckets1 = fill_buckets_from_data(buckets0, data, min_shifts) + @Dict({ buckets: buckets1, - data: List.releaseExcessCapacity data, - maxBucketCapacity, - maxLoadFactor, - shifts: minShifts, - } + data: List.release_excess_capacity(data), + max_bucket_capacity, + max_load_factor, + shifts: min_shifts, + }) else - @Dict { buckets, data, maxBucketCapacity: originalMaxBucketCapacity, maxLoadFactor, shifts } + @Dict({ buckets, data, max_bucket_capacity: original_max_bucket_capacity, max_load_factor, shifts }) ## Returns the max number of elements the dictionary can hold before requiring a rehash. ## ```roc -## foodDict = -## Dict.empty {} -## |> Dict.insert "apple" "fruit" +## food_dict = +## Dict.empty({}) +## |> Dict.insert("apple", "fruit") ## -## capacityOfDict = Dict.capacity foodDict +## capacity_of_dict = Dict.capacity(food_dict) ## ``` capacity : Dict * * -> U64 -capacity = \@Dict { maxBucketCapacity } -> - maxBucketCapacity +capacity = \@Dict({ max_bucket_capacity }) -> + max_bucket_capacity ## Returns a dictionary containing the key and value provided as input. ## ```roc ## expect -## Dict.single "A" "B" -## |> Bool.isEq (Dict.insert (Dict.empty {}) "A" "B") +## Dict.single("A", "B") +## |> Bool.is_eq(Dict.empty({}) |> Dict.insert("A", "B")) ## ``` single : k, v -> Dict k v single = \k, v -> - insert (empty {}) k v + insert(empty({}), k, v) ## Returns dictionary with the keys and values specified by the input [List]. ## ```roc ## expect -## Dict.single 1 "One" -## |> Dict.insert 2 "Two" -## |> Dict.insert 3 "Three" -## |> Dict.insert 4 "Four" -## |> Bool.isEq (Dict.fromList [(1, "One"), (2, "Two"), (3, "Three"), (4, "Four")]) +## Dict.single(1, "One") +## |> Dict.insert(2, "Two") +## |> Dict.insert(3, "Three") +## |> Dict.insert(4, "Four") +## |> Bool.is_eq(Dict.from_list([(1, "One"), (2, "Two"), (3, "Three"), (4, "Four")])) ## ``` ## ## ## Performance Details @@ -234,93 +238,101 @@ single = \k, v -> ## This will build up from an empty dictionary to minimize totally memory use. ## If the list has few duplicate keys, it would be faster to allocate a dictionary ## with the same capacity of the list and walk it calling [Dict.insert] -fromList : List (k, v) -> Dict k v -fromList = \data -> - List.walk data (empty {}) (\dict, (k, v) -> insert dict k v) +from_list : List (k, v) -> Dict k v +from_list = \data -> + List.walk(data, empty({}), \dict, (k, v) -> insert(dict, k, v)) ## Returns the number of values in the dictionary. ## ```roc ## expect -## Dict.empty {} -## |> Dict.insert "One" "A Song" -## |> Dict.insert "Two" "Candy Canes" -## |> Dict.insert "Three" "Boughs of Holly" +## Dict.empty({}) +## |> Dict.insert("One", "A Song") +## |> Dict.insert("Two", "Candy Canes") +## |> Dict.insert("Three", "Boughs of Holly") ## |> Dict.len -## |> Bool.isEq 3 +## |> Bool.is_eq(3) ## ``` len : Dict * * -> U64 -len = \@Dict { data } -> - List.len data +len = \@Dict({ data }) -> + List.len(data) ## Check if the dictionary is empty. ## ```roc -## Dict.isEmpty (Dict.empty {} |> Dict.insert "key" 42) +## Dict.is_empty(Dict.empty({}) |> Dict.insert("key", 42)) ## -## Dict.isEmpty (Dict.empty {}) +## Dict.is_empty(Dict.empty({})) ## ``` -isEmpty : Dict * * -> Bool -isEmpty = \@Dict { data } -> - List.isEmpty data +is_empty : Dict * * -> Bool +is_empty = \@Dict({ data }) -> + List.is_empty(data) ## Clears all elements from a dictionary keeping around the allocation if it isn't huge. ## ```roc ## songs = -## Dict.empty {} -## |> Dict.insert "One" "A Song" -## |> Dict.insert "Two" "Candy Canes" -## |> Dict.insert "Three" "Boughs of Holly" +## Dict.empty({}) +## |> Dict.insert("One", "A Song") +## |> Dict.insert("Two", "Candy Canes") +## |> Dict.insert("Three", "Boughs of Holly") ## -## clearSongs = Dict.clear songs +## clear_songs = Dict.clear(songs) ## -## expect Dict.len clearSongs == 0 +## expect Dict.len(clear_songs) == 0 ## ``` clear : Dict k v -> Dict k v -clear = \@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts } -> - @Dict { - buckets: List.map buckets \_ -> emptyBucket, - # use takeFirst to keep around the capacity - data: List.takeFirst data 0, - maxBucketCapacity, - maxLoadFactor, +clear = \@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }) -> + @Dict({ + buckets: List.map(buckets, \_ -> empty_bucket), + # use take_first to keep around the capacity + data: List.take_first(data, 0), + max_bucket_capacity, + max_load_factor, shifts, - } + }) ## Convert each value in the dictionary to something new, by calling a conversion ## function on each of them which receives both the key and the old value. Then return a ## new dictionary containing the same keys and the converted values. map : Dict k a, (k, a -> b) -> Dict k b map = \dict, transform -> - init = withCapacity (capacity dict) + init = with_capacity(capacity(dict)) - walk dict init \answer, k, v -> - insert answer k (transform k v) + walk( + dict, + init, + \answer, k, v -> + insert(answer, k, transform(k, v)), + ) ## Like [Dict.map], except the transformation function wraps the return value ## in a dictionary. At the end, all the dictionaries get joined together -## (using [Dict.insertAll]) into one dictionary. +## (using [Dict.insert_all]) into one dictionary. ## -## You may know a similar function named `concatMap` in other languages. -joinMap : Dict a b, (a, b -> Dict x y) -> Dict x y -joinMap = \dict, transform -> - init = withCapacity (capacity dict) # Might be a pessimization - - walk dict init \answer, k, v -> - insertAll answer (transform k v) +## You may know a similar function named `concat_map` in other languages. +join_map : Dict a b, (a, b -> Dict x y) -> Dict x y +join_map = \dict, transform -> + init = with_capacity(capacity(dict)) # Might be a pessimization + + walk( + dict, + init, + \answer, k, v -> + insert_all(answer, transform(k, v)), + ) ## Iterate through the keys and values in the dictionary and call the provided ## function with signature `state, k, v -> state` for each value, with an ## initial `state` value provided for the first call. ## ```roc ## expect -## Dict.empty {} -## |> Dict.insert "Apples" 12 -## |> Dict.insert "Orange" 24 -## |> Dict.walk 0 (\count, _, qty -> count + qty) -## |> Bool.isEq 36 +## Dict.empty({}) +## |> Dict.insert("Apples", 12) +## |> Dict.insert("Orange", 24) +## |> Dict.walk(0, (\count, _, qty -> count + qty)) +## |> Bool.is_eq(36) ## ``` walk : Dict k v, state, (state, k, v -> state) -> state -walk = \@Dict { data }, initialState, transform -> - List.walk data initialState (\state, (k, v) -> transform state k v) +walk = \@Dict({ data }), initial_state, transform -> + List.walk(data, initial_state, \state, (k, v) -> transform(state, k, v)) ## Same as [Dict.walk], except you can stop walking early. ## @@ -335,284 +347,285 @@ walk = \@Dict { data }, initialState, transform -> ## if returning `Break` earlier than the last element is expected to be common. ## ```roc ## people = -## Dict.empty {} -## |> Dict.insert "Alice" 17 -## |> Dict.insert "Bob" 18 -## |> Dict.insert "Charlie" 19 +## Dict.empty({}) +## |> Dict.insert("Alice", 17) +## |> Dict.insert("Bob", 18) +## |> Dict.insert("Charlie", 19) ## -## isAdult = \_, _, age -> -## if age >= 18 then -## Break Bool.true -## else -## Continue Bool.false +## is_adult = \_, _, age -> +## if age >= 18 then +## Break(Bool.true) +## else +## Continue(Bool.false) ## -## someoneIsAnAdult = Dict.walkUntil people Bool.false isAdult +## someone_is_an_adult = Dict.walk_until(people, Bool.false, is_adult) ## -## expect someoneIsAnAdult == Bool.true +## expect someone_is_an_adult == Bool.true ## ``` -walkUntil : Dict k v, state, (state, k, v -> [Continue state, Break state]) -> state -walkUntil = \@Dict { data }, initialState, transform -> - List.walkUntil data initialState (\state, (k, v) -> transform state k v) +walk_until : Dict k v, state, (state, k, v -> [Continue state, Break state]) -> state +walk_until = \@Dict({ data }), initial_state, transform -> + List.walk_until(data, initial_state, \state, (k, v) -> transform(state, k, v)) ## Run the given function on each key-value pair of a dictionary, and return ## a dictionary with just the pairs for which the function returned `Bool.true`. ## ```roc -## expect Dict.empty {} -## |> Dict.insert "Alice" 17 -## |> Dict.insert "Bob" 18 -## |> Dict.insert "Charlie" 19 -## |> Dict.keepIf \(_k, v) -> v >= 18 +## expect Dict.empty({}) +## |> Dict.insert("Alice", 17) +## |> Dict.insert("Bob", 18) +## |> Dict.insert("Charlie", 19) +## |> Dict.keep_if(\(_k, v) -> v >= 18) ## |> Dict.len -## |> Bool.isEq 2 +## |> Bool.is_eq(2) ## ``` -keepIf : Dict k v, ((k, v) -> Bool) -> Dict k v -keepIf = \dict, predicate -> - keepIfHelp dict predicate 0 (Dict.len dict) +keep_if : Dict k v, ((k, v) -> Bool) -> Dict k v +keep_if = \dict, predicate -> + keep_if_help(dict, predicate, 0, Dict.len(dict)) -keepIfHelp : Dict k v, ((k, v) -> Bool), U64, U64 -> Dict k v -keepIfHelp = \@Dict dict, predicate, index, length -> +keep_if_help : Dict k v, ((k, v) -> Bool), U64, U64 -> Dict k v +keep_if_help = \@Dict(dict), predicate, index, length -> if index < length then - (key, value) = listGetUnsafe dict.data index - if predicate (key, value) then - keepIfHelp (@Dict dict) predicate (index |> Num.addWrap 1) length + (key, value) = list_get_unsafe(dict.data, index) + if predicate((key, value)) then + keep_if_help(@Dict(dict), predicate, Num.add_wrap(index, 1), length) else - keepIfHelp (Dict.remove (@Dict dict) key) predicate index (length |> Num.subWrap 1) + keep_if_help(Dict.remove(@Dict(dict), key), predicate, index, Num.sub_wrap(length, 1)) else - @Dict dict + @Dict(dict) ## Run the given function on each key-value pair of a dictionary, and return ## a dictionary with just the pairs for which the function returned `Bool.false`. ## ```roc -## expect Dict.empty {} -## |> Dict.insert "Alice" 17 -## |> Dict.insert "Bob" 18 -## |> Dict.insert "Charlie" 19 -## |> Dict.dropIf \(_k, v) -> v >= 18 +## expect Dict.empty({}) +## |> Dict.insert("Alice", 17) +## |> Dict.insert("Bob", 18) +## |> Dict.insert("Charlie", 19) +## |> Dict.drop_if(\(_k, v) -> v >= 18) ## |> Dict.len -## |> Bool.isEq 1 +## |> Bool.is_eq(1) ## ``` -dropIf : Dict k v, ((k, v) -> Bool) -> Dict k v -dropIf = \dict, predicate -> - Dict.keepIf dict (\e -> Bool.not (predicate e)) +drop_if : Dict k v, ((k, v) -> Bool) -> Dict k v +drop_if = \dict, predicate -> + Dict.keep_if(dict, \e -> Bool.not(predicate(e))) ## Get the value for a given key. If there is a value for the specified key it ## will return [Ok value], otherwise return [Err KeyNotFound]. ## ```roc ## dictionary = -## Dict.empty {} -## |> Dict.insert 1 "Apple" -## |> Dict.insert 2 "Orange" +## Dict.empty({}) +## |> Dict.insert(1,s "Apple") +## |> Dict.insert(2,s "Orange") ## -## expect Dict.get dictionary 1 == Ok "Apple" -## expect Dict.get dictionary 2000 == Err KeyNotFound +## expect Dict.get(dictionary, 1) == Ok("Apple") +## expect Dict.get(dictionary, 2000) == Err(KeyNotFound) ## ``` get : Dict k v, k -> Result v [KeyNotFound] get = \dict, key -> - find dict key + find(dict, key) |> .result ## Check if the dictionary has a value for a specified key. ## ```roc ## expect -## Dict.empty {} -## |> Dict.insert 1234 "5678" -## |> Dict.contains 1234 -## |> Bool.isEq Bool.true +## Dict.empty({}) +## |> Dict.insert(1234, "5678") +## |> Dict.contains(1234) +## |> Bool.is_eq(Bool.true) ## ``` contains : Dict k v, k -> Bool contains = \dict, key -> - find dict key + find(dict, key) |> .result - |> Result.isOk + |> Result.is_ok ## Insert a value into the dictionary at a specified key. ## ```roc ## expect -## Dict.empty {} -## |> Dict.insert "Apples" 12 -## |> Dict.get "Apples" -## |> Bool.isEq (Ok 12) +## Dict.empty({}) +## |> Dict.insert("Apples", 12) +## |> Dict.get("Apples") +## |> Bool.is_eq(Ok(12)) ## ``` insert : Dict k v, k, v -> Dict k v insert = \dict, key, value -> - (@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }) = - if len dict < capacity dict then + @Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }) = + if len(dict) < capacity(dict) then dict else - increaseSize dict - - hash = hashKey key - distAndFingerprint = distAndFingerprintFromHash hash - bucketIndex = bucketIndexFromHash hash shifts - - insertHelper buckets data bucketIndex distAndFingerprint key value maxBucketCapacity maxLoadFactor shifts - -insertHelper : List Bucket, List (k, v), U64, U32, k, v, U64, F32, U8 -> Dict k v -insertHelper = \buckets0, data0, bucketIndex0, distAndFingerprint0, key, value, maxBucketCapacity, maxLoadFactor, shifts -> - loaded = listGetUnsafe buckets0 bucketIndex0 - if distAndFingerprint0 == loaded.distAndFingerprint then - (foundKey, _) = listGetUnsafe data0 (Num.toU64 loaded.dataIndex) - if foundKey == key then - data1 = List.set data0 (Num.toU64 loaded.dataIndex) (key, value) - @Dict { buckets: buckets0, data: data1, maxBucketCapacity, maxLoadFactor, shifts } + increase_size(dict) + + hash = hash_key(key) + dist_and_fingerprint = dist_and_fingerprint_from_hash(hash) + bucket_index = bucket_index_from_hash(hash, shifts) + + # TODO: put these args in a record for organization? + insert_helper(buckets, data, bucket_index, dist_and_fingerprint, key, value, max_bucket_capacity, max_load_factor, shifts) + +insert_helper : List Bucket, List (k, v), U64, U32, k, v, U64, F32, U8 -> Dict k v +insert_helper = \buckets0, data0, bucket_index0, dist_and_fingerprint0, key, value, max_bucket_capacity, max_load_factor, shifts -> + loaded = list_get_unsafe(buckets0, bucket_index0) + if dist_and_fingerprint0 == loaded.dist_and_fingerprint then + (found_key, _) = list_get_unsafe(data0, Num.to_u64(loaded.data_index)) + if found_key == key then + data1 = List.set(data0, Num.to_u64(loaded.data_index), (key, value)) + @Dict({ buckets: buckets0, data: data1, max_bucket_capacity, max_load_factor, shifts }) else - bucketIndex1 = nextBucketIndex bucketIndex0 (List.len buckets0) - distAndFingerprint1 = incrementDist distAndFingerprint0 - insertHelper buckets0 data0 bucketIndex1 distAndFingerprint1 key value maxBucketCapacity maxLoadFactor shifts - else if distAndFingerprint0 > loaded.distAndFingerprint then - data1 = List.append data0 (key, value) - dataIndex = (List.len data1) |> Num.subWrap 1 - buckets1 = placeAndShiftUp buckets0 { distAndFingerprint: distAndFingerprint0, dataIndex: Num.toU32 dataIndex } bucketIndex0 - @Dict { buckets: buckets1, data: data1, maxBucketCapacity, maxLoadFactor, shifts } + bucket_index1 = next_bucket_index(bucket_index0, List.len(buckets0)) + dist_and_fingerprint1 = increment_dist(dist_and_fingerprint0) + insert_helper(buckets0, data0, bucket_index1, dist_and_fingerprint1, key, value, max_bucket_capacity, max_load_factor, shifts) + else if dist_and_fingerprint0 > loaded.dist_and_fingerprint then + data1 = List.append(data0, (key, value)) + data_index = List.len(data1) |> Num.sub_wrap(1) + buckets1 = place_and_shift_up(buckets0, { dist_and_fingerprint: dist_and_fingerprint0, data_index: Num.to_u32(data_index) }, bucket_index0) + @Dict({ buckets: buckets1, data: data1, max_bucket_capacity, max_load_factor, shifts }) else - bucketIndex1 = nextBucketIndex bucketIndex0 (List.len buckets0) - distAndFingerprint1 = incrementDist distAndFingerprint0 - insertHelper buckets0 data0 bucketIndex1 distAndFingerprint1 key value maxBucketCapacity maxLoadFactor shifts + bucket_index1 = next_bucket_index(bucket_index0, List.len(buckets0)) + dist_and_fingerprint1 = increment_dist(dist_and_fingerprint0) + insert_helper(buckets0, data0, bucket_index1, dist_and_fingerprint1, key, value, max_bucket_capacity, max_load_factor, shifts) ## Remove a value from the dictionary for a specified key. ## ```roc ## expect -## Dict.empty {} -## |> Dict.insert "Some" "Value" -## |> Dict.remove "Some" +## Dict.empty({}) +## |> Dict.insert("Some", "Value") +## |> Dict.remove("Some") ## |> Dict.len -## |> Bool.isEq 0 +## |> Bool.is_eq(0) ## ``` remove : Dict k v, k -> Dict k v -remove = \@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }, key -> - if !(List.isEmpty data) then - (bucketIndex0, distAndFingerprint0) = nextWhileLess buckets key shifts - (bucketIndex1, distAndFingerprint1) = removeHelper buckets bucketIndex0 distAndFingerprint0 data key - - bucket = listGetUnsafe buckets bucketIndex1 - if distAndFingerprint1 != bucket.distAndFingerprint then - @Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts } +remove = \@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }), key -> + if !(List.is_empty(data)) then + (bucket_index0, dist_and_fingerprint0) = next_while_less(buckets, key, shifts) + (bucket_index1, dist_and_fingerprint1) = remove_helper(buckets, bucket_index0, dist_and_fingerprint0, data, key) + + bucket = list_get_unsafe(buckets, bucket_index1) + if dist_and_fingerprint1 != bucket.dist_and_fingerprint then + @Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }) else - removeBucket (@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }) bucketIndex1 + remove_bucket(@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }), bucket_index1) else - @Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts } - -removeHelper : List Bucket, U64, U32, List (k, *), k -> (U64, U32) where k implements Eq -removeHelper = \buckets, bucketIndex, distAndFingerprint, data, key -> - bucket = listGetUnsafe buckets bucketIndex - if distAndFingerprint == bucket.distAndFingerprint then - (foundKey, _) = listGetUnsafe data (Num.toU64 bucket.dataIndex) - if foundKey == key then - (bucketIndex, distAndFingerprint) + @Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }) + +remove_helper : List Bucket, U64, U32, List (k, *), k -> (U64, U32) where k implements Eq +remove_helper = \buckets, bucket_index, dist_and_fingerprint, data, key -> + bucket = list_get_unsafe(buckets, bucket_index) + if dist_and_fingerprint == bucket.dist_and_fingerprint then + (found_key, _) = list_get_unsafe(data, Num.to_u64(bucket.data_index)) + if found_key == key then + (bucket_index, dist_and_fingerprint) else - removeHelper buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key + remove_helper(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) else - (bucketIndex, distAndFingerprint) + (bucket_index, dist_and_fingerprint) ## Insert or remove a value for a specified key. This function enables a ## performance optimization for the use case of providing a default when a value ## is missing. This is more efficient than doing both a `Dict.get` and then a ## `Dict.insert` call, and supports being piped. ## ```roc -## alterValue : Result Bool [Missing] -> Result Bool [Missing] -## alterValue = \possibleValue -> -## when possibleValue is -## Err Missing -> Ok Bool.false -## Ok value -> if value then Err Missing else Ok Bool.true +## alter_value : Result Bool [Missing] -> Result Bool [Missing] +## alter_value = \possible_value -> +## when possible_value is +## Err Missing -> Ok(Bool.false) +## Ok value -> if value then Err(Missing) else Ok(Bool.true) ## -## expect Dict.update (Dict.empty {}) "a" alterValue == Dict.single "a" Bool.false -## expect Dict.update (Dict.single "a" Bool.false) "a" alterValue == Dict.single "a" Bool.true -## expect Dict.update (Dict.single "a" Bool.true) "a" alterValue == Dict.empty {} +## expect Dict.update(Dict.empty({}), "a", alter_value) == Dict.single("a", Bool.false) +## expect Dict.update(Dict.single("a", Bool.false), "a", alter_value) == Dict.single("a", Bool.true) +## expect Dict.update(Dict.single("a", Bool.true), "a", alter_value) == Dict.empty({}) ## ``` update : Dict k v, k, (Result v [Missing] -> Result v [Missing]) -> Dict k v -update = \@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }, key, alter -> - { bucketIndex, result } = find (@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }) key +update = \@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }), key, alter -> + { bucket_index, result } = find(@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }), key) when result is - Ok value -> - when alter (Ok value) is - Ok newValue -> - bucket = listGetUnsafe buckets bucketIndex - newData = List.set data (Num.toU64 bucket.dataIndex) (key, newValue) - @Dict { buckets, data: newData, maxBucketCapacity, maxLoadFactor, shifts } - - Err Missing -> - removeBucket (@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }) bucketIndex - - Err KeyNotFound -> - when alter (Err Missing) is - Ok newValue -> - if List.len data >= maxBucketCapacity then + Ok(value) -> + when alter(Ok(value)) is + Ok(new_value) -> + bucket = list_get_unsafe(buckets, bucket_index) + new_data = List.set(data, Num.to_u64(bucket.data_index), (key, new_value)) + @Dict({ buckets, data: new_data, max_bucket_capacity, max_load_factor, shifts }) + + Err(Missing) -> + remove_bucket(@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }), bucket_index) + + Err(KeyNotFound) -> + when alter(Err(Missing)) is + Ok(new_value) -> + if List.len(data) >= max_bucket_capacity then # Need to reallocate let regular insert handle that. - insert (@Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts }) key newValue + insert(@Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }), key, new_value) else # Can skip work by jumping staight to the found bucket. # That will be the location we want to insert in. - hash = hashKey key - baseDistAndFingerprint = distAndFingerprintFromHash hash - baseBucketIndex = bucketIndexFromHash hash shifts + hash = hash_key(key) + base_dist_and_fingerprint = dist_and_fingerprint_from_hash(hash) + base_bucket_index = bucket_index_from_hash(hash, shifts) # Due to the unrolling of loops in find along with loop optimizations, - # The bucketIndex is not guaranteed to be correct here. + # The bucket_index is not guaranteed to be correct here. # It is only correct if we have traversed past the number of find unrolls. - dist = circularDist baseBucketIndex bucketIndex (List.len buckets) - if dist <= findManualUnrolls then - insertHelper buckets data baseBucketIndex baseDistAndFingerprint key newValue maxBucketCapacity maxLoadFactor shifts + dist = circular_dist(base_bucket_index, bucket_index, List.len(buckets)) + if dist <= find_manual_unrolls then + insert_helper(buckets, data, base_bucket_index, base_dist_and_fingerprint, key, new_value, max_bucket_capacity, max_load_factor, shifts) else - distAndFingerprint = incrementDistN baseDistAndFingerprint (Num.toU32 dist) - insertHelper buckets data bucketIndex distAndFingerprint key newValue maxBucketCapacity maxLoadFactor shifts + dist_and_fingerprint = increment_dist_n(base_dist_and_fingerprint, Num.to_u32(dist)) + insert_helper(buckets, data, bucket_index, dist_and_fingerprint, key, new_value, max_bucket_capacity, max_load_factor, shifts) - Err Missing -> - @Dict { buckets, data, maxBucketCapacity, maxLoadFactor, shifts } + Err(Missing) -> + @Dict({ buckets, data, max_bucket_capacity, max_load_factor, shifts }) -circularDist = \start, end, size -> +circular_dist = \start, end, size -> correction = if start > end then size else 0 end - |> Num.subWrap start - |> Num.addWrap correction + |> Num.sub_wrap(start) + |> Num.add_wrap(correction) ## Returns the keys and values of a dictionary as a [List]. -## This requires allocating a temporary list, prefer using [Dict.toList] or [Dict.walk] instead. +## This requires allocating a temporary list, prefer using [Dict.to_list] or [Dict.walk] instead. ## ```roc ## expect -## Dict.single 1 "One" -## |> Dict.insert 2 "Two" -## |> Dict.insert 3 "Three" -## |> Dict.insert 4 "Four" -## |> Dict.toList -## |> Bool.isEq [(1, "One"), (2, "Two"), (3, "Three"), (4, "Four")] +## Dict.single(1, "One") +## |> Dict.insert(2, "Two") +## |> Dict.insert(3, "Three") +## |> Dict.insert(4, "Four") +## |> Dict.to_list +## |> Bool.is_eq([(1, "One"), (2, "Two"), (3, "Three"), (4, "Four")]) ## ``` -toList : Dict k v -> List (k, v) -toList = \@Dict { data } -> +to_list : Dict k v -> List (k, v) +to_list = \@Dict({ data }) -> data ## Returns the keys of a dictionary as a [List]. -## This requires allocating a temporary [List], prefer using [Dict.toList] or [Dict.walk] instead. +## This requires allocating a temporary [List], prefer using [Dict.to_list] or [Dict.walk] instead. ## ```roc ## expect -## Dict.single 1 "One" -## |> Dict.insert 2 "Two" -## |> Dict.insert 3 "Three" -## |> Dict.insert 4 "Four" +## Dict.single(1, "One") +## |> Dict.insert(2, "Two") +## |> Dict.insert(3, "Three") +## |> Dict.insert(4, "Four") ## |> Dict.keys -## |> Bool.isEq [1,2,3,4] +## |> Bool.is_eq([1,2,3,4]) ## ``` keys : Dict k v -> List k -keys = \@Dict { data } -> - List.map data (\(k, _) -> k) +keys = \@Dict({ data }) -> + List.map(data, \(k, _) -> k) ## Returns the values of a dictionary as a [List]. -## This requires allocating a temporary [List], prefer using [Dict.toList] or [Dict.walk] instead. +## This requires allocating a temporary [List], prefer using [Dict.to_list] or [Dict.walk] instead. ## ```roc ## expect -## Dict.single 1 "One" -## |> Dict.insert 2 "Two" -## |> Dict.insert 3 "Three" -## |> Dict.insert 4 "Four" +## Dict.single(1, "One") +## |> Dict.insert(2, "Two") +## |> Dict.insert(3, "Three") +## |> Dict.insert(4, "Four") ## |> Dict.values -## |> Bool.isEq ["One","Two","Three","Four"] +## |> Bool.is_eq(["One","Two","Three","Four"]) ## ``` values : Dict k v -> List v -values = \@Dict { data } -> - List.map data (\(_, v) -> v) +values = \@Dict({ data }) -> + List.map(data, \(_, v) -> v) ## Combine two dictionaries by keeping the [union](https://en.wikipedia.org/wiki/Union_(set_theory)) ## of all the key-value pairs. This means that all the key-value pairs in @@ -621,69 +634,70 @@ values = \@Dict { data } -> ## retained, and the value in the first input will be removed. ## ```roc ## first = -## Dict.single 1 "Not Me" -## |> Dict.insert 2 "And Me" +## Dict.single(1, "Not Me") +## |> Dict.insert(2, "And Me") ## ## second = -## Dict.single 1 "Keep Me" -## |> Dict.insert 3 "Me Too" -## |> Dict.insert 4 "And Also Me" +## Dict.single(1, "Keep Me") +## |> Dict.insert(3, "Me Too") +## |> Dict.insert(4, "And Also Me") ## ## expected = -## Dict.single 1 "Keep Me" -## |> Dict.insert 2 "And Me" -## |> Dict.insert 3 "Me Too" -## |> Dict.insert 4 "And Also Me" +## Dict.single(1, "Keep Me") +## |> Dict.insert(2, "And Me") +## |> Dict.insert(3, "Me Too") +## |> Dict.insert(4, "And Also Me") ## ## expect -## Dict.insertAll first second == expected +## Dict.insert_all(first, second) == expected ## ``` -insertAll : Dict k v, Dict k v -> Dict k v -insertAll = \xs, ys -> - if len ys > len xs then - insertAll ys xs +insert_all : Dict k v, Dict k v -> Dict k v +insert_all = \xs, ys -> + if len(ys) > len(xs) then + insert_all(ys, xs) else - walk ys xs insert + walk(ys, xs, insert) ## Combine two dictionaries by keeping the [intersection](https://en.wikipedia.org/wiki/Intersection_(set_theory)) ## of all the key-value pairs. This means that we keep only those pairs ## that are in both dictionaries. Both the key and value must match to be kept. ## ```roc ## first = -## Dict.single 1 "Keep Me" -## |> Dict.insert 2 "And Me" -## |> Dict.insert 3 "Not this one" +## Dict.single(1, "Keep Me") +## |> Dict.insert(2, "And Me") +## |> Dict.insert(3, "Not this one") ## ## second = -## Dict.single 1 "Keep Me" -## |> Dict.insert 2 "And Me" -## |> Dict.insert 3 "This has a different value" -## |> Dict.insert 4 "Or Me" +## Dict.single(1, "Keep Me") +## |> Dict.insert(2, "And Me") +## |> Dict.insert(3, "This has a different value") +## |> Dict.insert(4, "Or Me") ## ## expected = -## Dict.single 1 "Keep Me" -## |> Dict.insert 2 "And Me" +## Dict.single(1, "Keep Me") +## |> Dict.insert(2, "And Me") ## -## expect Dict.keepShared first second == expected +## expect Dict.keep_shared(first, second) == expected ## ``` -keepShared : Dict k v, Dict k v -> Dict k v where v implements Eq -keepShared = \xs0, ys0 -> +keep_shared : Dict k v, Dict k v -> Dict k v where v implements Eq +keep_shared = \xs0, ys0 -> (xs1, ys1) = - if len ys0 < len xs0 then + if len(ys0) < len(xs0) then (ys0, xs0) else (xs0, ys0) - walk - xs1 - (withCapacity (len xs1)) - (\state, k, v -> - when get ys1 k is - Ok yv if v == yv -> - insert state k v + + walk( + xs1, + with_capacity(len(xs1)), + \state, k, v -> + when get(ys1, k) is + Ok(yv) if v == yv -> + insert(state, k, v) _ -> - state - ) + state, + ) ## Remove the key-value pairs in the first input that are also in the second ## using the [set difference](https://en.wikipedia.org/wiki/Complement_(set_theory)#Relative_complement) @@ -691,384 +705,388 @@ keepShared = \xs0, ys0 -> ## are in the first dictionary and whose keys are not in the second. ## ```roc ## first = -## Dict.single 1 "Keep Me" -## |> Dict.insert 2 "And Me" -## |> Dict.insert 3 "Remove Me" +## Dict.single(1, "Keep Me") +## |> Dict.insert(2, "And Me") +## |> Dict.insert(3, "Remove Me") ## ## second = -## Dict.single 3 "Remove Me" -## |> Dict.insert 4 "I do nothing..." +## Dict.single(3, "Remove Me") +## |> Dict.insert(4, "I do nothing...") ## ## expected = -## Dict.single 1 "Keep Me" -## |> Dict.insert 2 "And Me" +## Dict.single(1, "Keep Me") +## |> Dict.insert(2, "And Me") ## -## expect Dict.removeAll first second == expected +## expect Dict.remove_all(first, second) == expected ## ``` -removeAll : Dict k v, Dict k v -> Dict k v -removeAll = \xs, ys -> - walk ys xs (\state, k, _ -> remove state k) +remove_all : Dict k v, Dict k v -> Dict k v +remove_all = \xs, ys -> + walk(ys, xs, \state, k, _ -> remove(state, k)) # Below here is a list of generic helpers and internal data types for Dict Bucket : { - distAndFingerprint : U32, # upper 3 byte: distance to original bucket. lower byte: fingerprint from hash - dataIndex : U32, # index into the data list. + dist_and_fingerprint : U32, # upper 3 byte: distance to original bucket. lower byte: fingerprint from hash + data_index : U32, # index into the data list. } -emptyBucket = { distAndFingerprint: 0, dataIndex: 0 } -distInc = Num.shiftLeftBy 1u32 8 # skip 1 byte fingerprint -fingerprintMask = Num.subWrap distInc 1 # mask for 1 byte of fingerprint -defaultMaxLoadFactor = 0.8 -initialShifts = 64 |> Num.subWrap 3 # 2^(64-shifts) number of buckets -maxSize = Num.shiftLeftBy 1u64 32 -maxBucketCount = maxSize +empty_bucket = { dist_and_fingerprint: 0, data_index: 0 } +dist_inc = Num.shift_left_by(1u32, 8) # skip 1 byte fingerprint +fingerprint_mask = Num.sub_wrap(dist_inc, 1) # mask for 1 byte of fingerprint +default_max_load_factor = 0.8 +initial_shifts = Num.sub_wrap(64, 3) # 2^(64-shifts) number of buckets +max_size = Num.shift_left_by(1u64, 32) +max_bucket_count = max_size -incrementDist = \distAndFingerprint -> - Num.addWrap distAndFingerprint distInc +increment_dist = \dist_and_fingerprint -> + Num.add_wrap(dist_and_fingerprint, dist_inc) -incrementDistN = \distAndFingerprint, n -> - Num.addWrap distAndFingerprint (Num.mulWrap n distInc) +increment_dist_n = \dist_and_fingerprint, n -> + Num.add_wrap(dist_and_fingerprint, Num.mul_wrap(n, dist_inc)) -decrementDist = \distAndFingerprint -> - distAndFingerprint |> Num.subWrap distInc +decrement_dist = \dist_and_fingerprint -> + Num.sub_wrap(dist_and_fingerprint, dist_inc) -find : Dict k v, k -> { bucketIndex : U64, result : Result v [KeyNotFound] } -find = \@Dict { buckets, data, shifts }, key -> - hash = hashKey key - distAndFingerprint = distAndFingerprintFromHash hash - bucketIndex = bucketIndexFromHash hash shifts +find : Dict k v, k -> { bucket_index : U64, result : Result v [KeyNotFound] } +find = \@Dict({ buckets, data, shifts }), key -> + hash = hash_key(key) + dist_and_fingerprint = dist_and_fingerprint_from_hash(hash) + bucket_index = bucket_index_from_hash(hash, shifts) - if !(List.isEmpty data) then + if !(List.is_empty(data)) then # TODO: this is true in the C++ code, confirm it in Roc as well. # unrolled loop. *Always* check a few directly, then enter the loop. This is faster. - findFirstUnroll buckets bucketIndex distAndFingerprint data key + find_first_unroll(buckets, bucket_index, dist_and_fingerprint, data, key) else - { bucketIndex, result: Err KeyNotFound } + { bucket_index, result: Err(KeyNotFound) } -findManualUnrolls = 2 +find_manual_unrolls = 2 -findFirstUnroll : List Bucket, U64, U32, List (k, v), k -> { bucketIndex : U64, result : Result v [KeyNotFound] } where k implements Eq -findFirstUnroll = \buckets, bucketIndex, distAndFingerprint, data, key -> +find_first_unroll : List Bucket, U64, U32, List (k, v), k -> { bucket_index : U64, result : Result v [KeyNotFound] } where k implements Eq +find_first_unroll = \buckets, bucket_index, dist_and_fingerprint, data, key -> # TODO: once we have short circuit evaluation, use it here and other similar locations in this file. # Avoid the nested if with else block inconvenience. - bucket = listGetUnsafe buckets bucketIndex - if distAndFingerprint == bucket.distAndFingerprint then - (foundKey, value) = listGetUnsafe data (Num.toU64 bucket.dataIndex) - if foundKey == key then - { bucketIndex, result: Ok value } + bucket = list_get_unsafe(buckets, bucket_index) + if dist_and_fingerprint == bucket.dist_and_fingerprint then + (found_key, value) = list_get_unsafe(data, Num.to_u64(bucket.data_index)) + if found_key == key then + { bucket_index, result: Ok(value) } else - findSecondUnroll buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key + find_second_unroll(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) else - findSecondUnroll buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key - -findSecondUnroll : List Bucket, U64, U32, List (k, v), k -> { bucketIndex : U64, result : Result v [KeyNotFound] } where k implements Eq -findSecondUnroll = \buckets, bucketIndex, distAndFingerprint, data, key -> - bucket = listGetUnsafe buckets bucketIndex - if distAndFingerprint == bucket.distAndFingerprint then - (foundKey, value) = listGetUnsafe data (Num.toU64 bucket.dataIndex) - if foundKey == key then - { bucketIndex, result: Ok value } + find_second_unroll(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) + +find_second_unroll : List Bucket, U64, U32, List (k, v), k -> { bucket_index : U64, result : Result v [KeyNotFound] } where k implements Eq +find_second_unroll = \buckets, bucket_index, dist_and_fingerprint, data, key -> + bucket = list_get_unsafe(buckets, bucket_index) + if dist_and_fingerprint == bucket.dist_and_fingerprint then + (found_key, value) = list_get_unsafe(data, Num.to_u64(bucket.data_index)) + if found_key == key then + { bucket_index, result: Ok(value) } else - findHelper buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key + find_helper(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) else - findHelper buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key - -findHelper : List Bucket, U64, U32, List (k, v), k -> { bucketIndex : U64, result : Result v [KeyNotFound] } where k implements Eq -findHelper = \buckets, bucketIndex, distAndFingerprint, data, key -> - bucket = listGetUnsafe buckets bucketIndex - if distAndFingerprint == bucket.distAndFingerprint then - (foundKey, value) = listGetUnsafe data (Num.toU64 bucket.dataIndex) - if foundKey == key then - { bucketIndex, result: Ok value } + find_helper(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) + +find_helper : List Bucket, U64, U32, List (k, v), k -> { bucket_index : U64, result : Result v [KeyNotFound] } where k implements Eq +find_helper = \buckets, bucket_index, dist_and_fingerprint, data, key -> + bucket = list_get_unsafe(buckets, bucket_index) + if dist_and_fingerprint == bucket.dist_and_fingerprint then + (found_key, value) = list_get_unsafe(data, Num.to_u64(bucket.data_index)) + if found_key == key then + { bucket_index, result: Ok(value) } else - findHelper buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key - else if distAndFingerprint > bucket.distAndFingerprint then - { bucketIndex, result: Err KeyNotFound } + find_helper(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) + else if dist_and_fingerprint > bucket.dist_and_fingerprint then + { bucket_index, result: Err(KeyNotFound) } else - findHelper buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) data key + find_helper(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint), data, key) -removeBucket : Dict k v, U64 -> Dict k v -removeBucket = \@Dict { buckets: buckets0, data: data0, maxBucketCapacity, maxLoadFactor, shifts }, bucketIndex0 -> - dataIndexToRemove = (listGetUnsafe buckets0 bucketIndex0).dataIndex - dataIndexToRemoveU64 = Num.toU64 dataIndexToRemove +remove_bucket : Dict k v, U64 -> Dict k v +remove_bucket = \@Dict({ buckets: buckets0, data: data0, max_bucket_capacity, max_load_factor, shifts }), bucket_index0 -> + data_index_to_remove = list_get_unsafe(buckets0, bucket_index0) |> .data_index + data_index_to_remove_u64 = Num.to_u64(data_index_to_remove) - (buckets1, bucketIndex1) = removeBucketHelper buckets0 bucketIndex0 - buckets2 = List.set buckets1 bucketIndex1 emptyBucket + (buckets1, bucket_index1) = remove_bucket_helper(buckets0, bucket_index0) + buckets2 = List.set(buckets1, bucket_index1, empty_bucket) - lastDataIndex = List.len data0 |> Num.subWrap 1 - if dataIndexToRemoveU64 != lastDataIndex then + last_data_index = List.len(data0) |> Num.sub_wrap(1) + if data_index_to_remove_u64 != last_data_index then # Swap removed item to the end - data1 = List.swap data0 dataIndexToRemoveU64 lastDataIndex - (key, _) = listGetUnsafe data1 dataIndexToRemoveU64 + data1 = List.swap(data0, data_index_to_remove_u64, last_data_index) + (key, _) = list_get_unsafe(data1, data_index_to_remove_u64) # Update the data index of the new value. - hash = hashKey key - bucketIndex2 = bucketIndexFromHash hash shifts - - bucketIndex3 = scanForIndex buckets2 bucketIndex2 (Num.toU32 lastDataIndex) - swapBucket = listGetUnsafe buckets2 bucketIndex3 - @Dict { - buckets: List.set buckets2 bucketIndex3 { swapBucket & dataIndex: dataIndexToRemove }, - data: List.dropLast data1 1, - maxBucketCapacity, - maxLoadFactor, + hash = hash_key(key) + bucket_index2 = bucket_index_from_hash(hash, shifts) + + bucket_index3 = scan_for_index(buckets2, bucket_index2, Num.to_u32(last_data_index)) + swap_bucket = list_get_unsafe(buckets2, bucket_index3) + + @Dict({ + buckets: List.set(buckets2, bucket_index3, { swap_bucket & data_index: data_index_to_remove }), + data: List.drop_last(data1, 1), + max_bucket_capacity, + max_load_factor, shifts, - } + }) else - @Dict { + @Dict({ buckets: buckets2, - data: List.dropLast data0 1, - maxBucketCapacity, - maxLoadFactor, + data: List.drop_last(data0, 1), + max_bucket_capacity, + max_load_factor, shifts, - } + }) -scanForIndex : List Bucket, U64, U32 -> U64 -scanForIndex = \buckets, bucketIndex, dataIndex -> - bucket = listGetUnsafe buckets bucketIndex - if bucket.dataIndex != dataIndex then - scanForIndex buckets (nextBucketIndex bucketIndex (List.len buckets)) dataIndex +scan_for_index : List Bucket, U64, U32 -> U64 +scan_for_index = \buckets, bucket_index, data_index -> + bucket = list_get_unsafe(buckets, bucket_index) + if bucket.data_index != data_index then + scan_for_index(buckets, next_bucket_index(bucket_index, List.len(buckets)), data_index) else - bucketIndex + bucket_index -removeBucketHelper : List Bucket, U64 -> (List Bucket, U64) -removeBucketHelper = \buckets, bucketIndex -> - nextIndex = nextBucketIndex bucketIndex (List.len buckets) - nextBucket = listGetUnsafe buckets nextIndex +remove_bucket_helper : List Bucket, U64 -> (List Bucket, U64) +remove_bucket_helper = \buckets, bucket_index -> + next_index = next_bucket_index(bucket_index, List.len(buckets)) + next_bucket = list_get_unsafe(buckets, next_index) # shift down until either empty or an element with correct spot is found - if nextBucket.distAndFingerprint >= Num.mulWrap distInc 2 then - List.set buckets bucketIndex { nextBucket & distAndFingerprint: decrementDist nextBucket.distAndFingerprint } - |> removeBucketHelper nextIndex + if next_bucket.dist_and_fingerprint >= Num.mul_wrap(dist_inc, 2) then + List.set(buckets, bucket_index, { next_bucket & dist_and_fingerprint: decrement_dist(next_bucket.dist_and_fingerprint) }) + |> remove_bucket_helper(next_index) else - (buckets, bucketIndex) - -increaseSize : Dict k v -> Dict k v -increaseSize = \@Dict { data, maxBucketCapacity, maxLoadFactor, shifts } -> - if maxBucketCapacity != maxBucketCount then - newShifts = shifts |> Num.subWrap 1 - (buckets0, newMaxBucketCapacity) = allocBucketsFromShift newShifts maxLoadFactor - buckets1 = fillBucketsFromData buckets0 data newShifts - @Dict { + (buckets, bucket_index) + +increase_size : Dict k v -> Dict k v +increase_size = \@Dict({ data, max_bucket_capacity, max_load_factor, shifts }) -> + if max_bucket_capacity != max_bucket_count then + new_shifts = shifts |> Num.sub_wrap(1) + (buckets0, new_max_bucket_capacity) = alloc_buckets_from_shift(new_shifts, max_load_factor) + buckets1 = fill_buckets_from_data(buckets0, data, new_shifts) + @Dict({ buckets: buckets1, data, - maxBucketCapacity: newMaxBucketCapacity, - maxLoadFactor, - shifts: newShifts, - } + max_bucket_capacity: new_max_bucket_capacity, + max_load_factor, + shifts: new_shifts, + }) else - crash "Dict hit limit of $(Num.toStr maxBucketCount) elements. Unable to grow more." + crash("Dict hit limit of $(Num.to_str(max_bucket_count)) elements. Unable to grow more.") -allocBucketsFromShift : U8, F32 -> (List Bucket, U64) -allocBucketsFromShift = \shifts, maxLoadFactor -> - bucketCount = calcNumBuckets shifts - if bucketCount == maxBucketCount then +alloc_buckets_from_shift : U8, F32 -> (List Bucket, U64) +alloc_buckets_from_shift = \shifts, max_load_factor -> + bucket_count = calc_num_buckets(shifts) + if bucket_count == max_bucket_count then # reached the maximum, make sure we can use each bucket - (List.repeat emptyBucket maxBucketCount, maxBucketCount) + (List.repeat(empty_bucket, max_bucket_count), max_bucket_count) else - maxBucketCapacity = - bucketCount - |> Num.toF32 - |> Num.mul maxLoadFactor + max_bucket_capacity = + bucket_count + |> Num.to_f32 + |> Num.mul(max_load_factor) |> Num.floor - (List.repeat emptyBucket bucketCount, maxBucketCapacity) -calcShiftsForSize : U64, F32 -> U8 -calcShiftsForSize = \size, maxLoadFactor -> - calcShiftsForSizeHelper initialShifts size maxLoadFactor + (List.repeat(empty_bucket, bucket_count), max_bucket_capacity) + +calc_shifts_for_size : U64, F32 -> U8 +calc_shifts_for_size = \size, max_load_factor -> + calc_shifts_for_size_helper(initial_shifts, size, max_load_factor) -calcShiftsForSizeHelper = \shifts, size, maxLoadFactor -> - maxBucketCapacity = +calc_shifts_for_size_helper = \shifts, size, max_load_factor -> + max_bucket_capacity = shifts - |> calcNumBuckets - |> Num.toF32 - |> Num.mul maxLoadFactor + |> calc_num_buckets + |> Num.to_f32 + |> Num.mul(max_load_factor) |> Num.floor - if shifts > 0 && maxBucketCapacity < size then - calcShiftsForSizeHelper (shifts |> Num.subWrap 1) size maxLoadFactor + if shifts > 0 && max_bucket_capacity < size then + calc_shifts_for_size_helper(Num.sub_wrap(shifts, 1), size, max_load_factor) else shifts -calcNumBuckets = \shifts -> - Num.min - (Num.shiftLeftBy 1 (64 |> Num.subWrap shifts)) - maxBucketCount - -fillBucketsFromData = \buckets0, data, shifts -> - List.walkWithIndex data buckets0 \buckets1, (key, _), dataIndex -> - (bucketIndex, distAndFingerprint) = nextWhileLess buckets1 key shifts - placeAndShiftUp buckets1 { distAndFingerprint, dataIndex: Num.toU32 dataIndex } bucketIndex - -nextWhileLess : List Bucket, k, U8 -> (U64, U32) where k implements Hash & Eq -nextWhileLess = \buckets, key, shifts -> - hash = hashKey key - distAndFingerprint = distAndFingerprintFromHash hash - bucketIndex = bucketIndexFromHash hash shifts - - nextWhileLessHelper buckets bucketIndex distAndFingerprint - -nextWhileLessHelper = \buckets, bucketIndex, distAndFingerprint -> - loaded = listGetUnsafe buckets bucketIndex - if distAndFingerprint < loaded.distAndFingerprint then - nextWhileLessHelper buckets (nextBucketIndex bucketIndex (List.len buckets)) (incrementDist distAndFingerprint) +calc_num_buckets = \shifts -> + Num.min(Num.shift_left_by(1, Num.sub_wrap(64, shifts)), max_bucket_count) + +fill_buckets_from_data = \buckets0, data, shifts -> + List.walk_with_index( + data, + buckets0, + \buckets1, (key, _), data_index -> + (bucket_index, dist_and_fingerprint) = next_while_less(buckets1, key, shifts) + place_and_shift_up(buckets1, { dist_and_fingerprint, data_index: Num.to_u32(data_index) }, bucket_index), + ) + +next_while_less : List Bucket, k, U8 -> (U64, U32) where k implements Hash & Eq +next_while_less = \buckets, key, shifts -> + hash = hash_key(key) + dist_and_fingerprint = dist_and_fingerprint_from_hash(hash) + bucket_index = bucket_index_from_hash(hash, shifts) + + next_while_less_helper(buckets, bucket_index, dist_and_fingerprint) + +next_while_less_helper = \buckets, bucket_index, dist_and_fingerprint -> + loaded = list_get_unsafe(buckets, bucket_index) + if dist_and_fingerprint < loaded.dist_and_fingerprint then + next_while_less_helper(buckets, next_bucket_index(bucket_index, List.len(buckets)), increment_dist(dist_and_fingerprint)) else - (bucketIndex, distAndFingerprint) - -placeAndShiftUp = \buckets0, bucket, bucketIndex -> - loaded = listGetUnsafe buckets0 bucketIndex - if loaded.distAndFingerprint != 0 then - buckets1 = List.set buckets0 bucketIndex bucket - placeAndShiftUp - buckets1 - { loaded & distAndFingerprint: incrementDist loaded.distAndFingerprint } - (nextBucketIndex bucketIndex (List.len buckets1)) + (bucket_index, dist_and_fingerprint) + +place_and_shift_up = \buckets0, bucket, bucket_index -> + loaded = list_get_unsafe(buckets0, bucket_index) + if loaded.dist_and_fingerprint != 0 then + buckets1 = List.set(buckets0, bucket_index, bucket) + place_and_shift_up( + buckets1, + { loaded & dist_and_fingerprint: increment_dist(loaded.dist_and_fingerprint) }, + next_bucket_index(bucket_index, List.len(buckets1)), + ) else - List.set buckets0 bucketIndex bucket + List.set(buckets0, bucket_index, bucket) -nextBucketIndex = \bucketIndex, maxBuckets -> +next_bucket_index = \bucket_index, max_buckets -> # I just ported this impl directly. # I am a bit confused why it is using an if over a mask. # Maybe compilers are smart enough to optimize this well. # Maybe the unlikely annotation is super important - if Num.addWrap bucketIndex 1 != maxBuckets then - Num.addWrap bucketIndex 1 + if Num.add_wrap(bucket_index, 1) != max_buckets then + Num.add_wrap(bucket_index, 1) else 0 -hashKey = \key -> - createLowLevelHasher PseudoRandSeed - |> Hash.hash key +hash_key = \key -> + create_low_level_hasher(PseudoRandSeed) + |> Hash.hash(key) |> complete -distAndFingerprintFromHash : U64 -> U32 -distAndFingerprintFromHash = \hash -> +dist_and_fingerprint_from_hash : U64 -> U32 +dist_and_fingerprint_from_hash = \hash -> hash - |> Num.toU32 - |> Num.bitwiseAnd fingerprintMask - |> Num.bitwiseOr distInc + |> Num.to_u32 + |> Num.bitwise_and(fingerprint_mask) + |> Num.bitwise_or(dist_inc) -bucketIndexFromHash : U64, U8 -> U64 -bucketIndexFromHash = \hash, shifts -> - hash - |> Num.shiftRightZfBy shifts +bucket_index_from_hash : U64, U8 -> U64 +bucket_index_from_hash = \hash, shifts -> + Num.shift_right_zf_by(hash, shifts) expect val = - empty {} - |> insert "foo" "bar" - |> get "foo" + empty({}) + |> insert("foo", "bar") + |> get("foo") - val == Ok "bar" + val == Ok("bar") expect dict1 = - empty {} - |> insert 1 "bar" - |> insert 2 "baz" + empty({}) + |> insert(1, "bar") + |> insert(2, "baz") dict2 = - empty {} - |> insert 2 "baz" - |> insert 1 "bar" + empty({}) + |> insert(2, "baz") + |> insert(1, "bar") dict1 == dict2 expect dict1 = - empty {} - |> insert 1 "bar" - |> insert 2 "baz" + empty({}) + |> insert(1, "bar") + |> insert(2, "baz") dict2 = - empty {} - |> insert 1 "bar" - |> insert 2 "baz!" + empty({}) + |> insert(1, "bar") + |> insert(2, "baz!") dict1 != dict2 expect inner1 = - empty {} - |> insert 1 "bar" - |> insert 2 "baz" + empty({}) + |> insert(1, "bar") + |> insert(2, "baz") inner2 = - empty {} - |> insert 2 "baz" - |> insert 1 "bar" + empty({}) + |> insert(2, "baz") + |> insert(1, "bar") outer = - empty {} - |> insert inner1 "wrong" - |> insert inner2 "right" + empty({}) + |> insert(inner1, "wrong") + |> insert(inner2, "right") - get outer inner1 == Ok "right" + get(outer, inner1) == Ok("right") expect inner1 = - empty {} - |> insert 1 "bar" - |> insert 2 "baz" + empty({}) + |> insert(1, "bar") + |> insert(2, "baz") inner2 = - empty {} - |> insert 2 "baz" - |> insert 1 "bar" + empty({}) + |> insert(2, "baz") + |> insert(1, "bar") outer1 = - empty {} - |> insert inner1 "val" + empty({}) + |> insert(inner1, "val") outer2 = - empty {} - |> insert inner2 "val" + empty({}) + |> insert(inner2, "val") outer1 == outer2 expect val = - empty {} - |> insert "foo" "bar" - |> insert "foo" "baz" - |> get "foo" + empty({}) + |> insert("foo", "bar") + |> insert("foo", "baz") + |> get("foo") - val == Ok "baz" + val == Ok("baz") expect val = - empty {} - |> insert "foo" "bar" - |> get "bar" + empty({}) + |> insert("foo", "bar") + |> get("bar") - val == Err KeyNotFound + val == Err(KeyNotFound) expect - empty {} - |> insert "foo" {} - |> contains "foo" + empty({}) + |> insert("foo", {}) + |> contains("foo") expect dict = - empty {} - |> insert "foo" {} - |> insert "bar" {} - |> insert "baz" {} + empty({}) + |> insert("foo", {}) + |> insert("bar", {}) + |> insert("baz", {}) - contains dict "baz" && Bool.not (contains dict "other") + contains(dict, "baz") && !(contains(dict, "other")) expect dict = - fromList [(1u8, 1u8), (2, 2), (3, 3)] - |> remove 1 - |> remove 3 + from_list([(1u8, 1u8), (2, 2), (3, 3)]) + |> remove(1) + |> remove(3) - keys dict == [2] + keys(dict) == [2] expect list = - fromList [(1u8, 1u8), (2u8, 2u8), (3, 3)] - |> remove 1 - |> insert 0 0 - |> remove 3 + from_list([(1u8, 1u8), (2u8, 2u8), (3, 3)]) + |> remove(1) + |> insert(0, 0) + |> remove(3) |> keys list == [0, 2] @@ -1076,19 +1094,19 @@ expect # Reach capacity, no rehash. expect val = - empty {} - |> insert "a" 0 - |> insert "b" 1 - |> insert "c" 2 - |> insert "d" 3 - |> insert "e" 4 - |> insert "f" 5 - |> insert "g" 6 - |> insert "h" 7 - |> insert "i" 8 - |> insert "j" 9 - |> insert "k" 10 - |> insert "l" 11 + empty({}) + |> insert("a", 0) + |> insert("b", 1) + |> insert("c", 2) + |> insert("d", 3) + |> insert("e", 4) + |> insert("f", 5) + |> insert("g", 6) + |> insert("h", 7) + |> insert("i", 8) + |> insert("j", 9) + |> insert("k", 10) + |> insert("l", 11) |> capacity val == 12 @@ -1096,50 +1114,50 @@ expect # Reach capacity, all elements still exist expect dict = - empty {} - |> insert "a" 0 - |> insert "b" 1 - |> insert "c" 2 - |> insert "d" 3 - |> insert "e" 4 - |> insert "f" 5 - |> insert "g" 6 - |> insert "h" 7 - |> insert "i" 8 - |> insert "j" 9 - |> insert "k" 10 - |> insert "l" 11 - - (get dict "a" == Ok 0) - && (get dict "b" == Ok 1) - && (get dict "c" == Ok 2) - && (get dict "d" == Ok 3) - && (get dict "e" == Ok 4) - && (get dict "f" == Ok 5) - && (get dict "g" == Ok 6) - && (get dict "h" == Ok 7) - && (get dict "i" == Ok 8) - && (get dict "j" == Ok 9) - && (get dict "k" == Ok 10) - && (get dict "l" == Ok 11) + empty({}) + |> insert("a", 0) + |> insert("b", 1) + |> insert("c", 2) + |> insert("d", 3) + |> insert("e", 4) + |> insert("f", 5) + |> insert("g", 6) + |> insert("h", 7) + |> insert("i", 8) + |> insert("j", 9) + |> insert("k", 10) + |> insert("l", 11) + + (get(dict, "a") == Ok(0)) + && (get(dict, "b") == Ok(1)) + && (get(dict, "c") == Ok(2)) + && (get(dict, "d") == Ok(3)) + && (get(dict, "e") == Ok(4)) + && (get(dict, "f") == Ok(5)) + && (get(dict, "g") == Ok(6)) + && (get(dict, "h") == Ok(7)) + && (get(dict, "i") == Ok(8)) + && (get(dict, "j") == Ok(9)) + && (get(dict, "k") == Ok(10)) + && (get(dict, "l") == Ok(11)) # Force rehash. expect val = - empty {} - |> insert "a" 0 - |> insert "b" 1 - |> insert "c" 2 - |> insert "d" 3 - |> insert "e" 4 - |> insert "f" 5 - |> insert "g" 6 - |> insert "h" 7 - |> insert "i" 8 - |> insert "j" 9 - |> insert "k" 10 - |> insert "l" 11 - |> insert "m" 12 + empty({}) + |> insert("a", 0) + |> insert("b", 1) + |> insert("c", 2) + |> insert("d", 3) + |> insert("e", 4) + |> insert("f", 5) + |> insert("g", 6) + |> insert("h", 7) + |> insert("i", 8) + |> insert("j", 9) + |> insert("k", 10) + |> insert("l", 11) + |> insert("m", 12) |> capacity val == 25 @@ -1147,87 +1165,99 @@ expect # Force rehash, all elements still exist expect dict = - empty {} - |> insert "a" 0 - |> insert "b" 1 - |> insert "c" 2 - |> insert "d" 3 - |> insert "e" 4 - |> insert "f" 5 - |> insert "g" 6 - |> insert "h" 7 - |> insert "i" 8 - |> insert "j" 9 - |> insert "k" 10 - |> insert "l" 11 - |> insert "m" 12 - - (get dict "a" == Ok 0) - && (get dict "b" == Ok 1) - && (get dict "c" == Ok 2) - && (get dict "d" == Ok 3) - && (get dict "e" == Ok 4) - && (get dict "f" == Ok 5) - && (get dict "g" == Ok 6) - && (get dict "h" == Ok 7) - && (get dict "i" == Ok 8) - && (get dict "j" == Ok 9) - && (get dict "k" == Ok 10) - && (get dict "l" == Ok 11) - && (get dict "m" == Ok 12) + empty({}) + |> insert("a", 0) + |> insert("b", 1) + |> insert("c", 2) + |> insert("d", 3) + |> insert("e", 4) + |> insert("f", 5) + |> insert("g", 6) + |> insert("h", 7) + |> insert("i", 8) + |> insert("j", 9) + |> insert("k", 10) + |> insert("l", 11) + |> insert("m", 12) + + (get(dict, "a") == Ok(0)) + && (get(dict, "b") == Ok(1)) + && (get(dict, "c") == Ok(2)) + && (get(dict, "d") == Ok(3)) + && (get(dict, "e") == Ok(4)) + && (get(dict, "f") == Ok(5)) + && (get(dict, "g") == Ok(6)) + && (get(dict, "h") == Ok(7)) + && (get(dict, "i") == Ok(8)) + && (get(dict, "j") == Ok(9)) + && (get(dict, "k") == Ok(10)) + && (get(dict, "l") == Ok(11)) + && (get(dict, "m") == Ok(12)) expect - empty {} - |> insert "Some" "Value" - |> remove "Some" + empty({}) + |> insert("Some", "Value") + |> remove("Some") |> len - |> Bool.isEq 0 + |> Bool.is_eq(0) # All BadKey's hash to the same location. # This is needed to test some robinhood logic. BadKey := U64 implements [ Eq, Hash { - hash: hashBadKey, + hash: hash_bad_key, }, ] -hashBadKey : hasher, BadKey -> hasher where hasher implements Hasher -hashBadKey = \hasher, _ -> Hash.hash hasher 0 +hash_bad_key : hasher, BadKey -> hasher where hasher implements Hasher +hash_bad_key = \hasher, _ -> Hash.hash(hasher, 0) expect - badKeys = [ - @BadKey 0, - @BadKey 1, - @BadKey 2, - @BadKey 3, - @BadKey 4, - @BadKey 5, - @BadKey 6, - @BadKey 5, - @BadKey 4, - @BadKey 3, - @BadKey 3, - @BadKey 3, - @BadKey 10, + bad_keys = [ + @BadKey(0), + @BadKey(1), + @BadKey(2), + @BadKey(3), + @BadKey(4), + @BadKey(5), + @BadKey(6), + @BadKey(5), + @BadKey(4), + @BadKey(3), + @BadKey(3), + @BadKey(3), + @BadKey(10), ] dict = - List.walk badKeys (Dict.empty {}) \acc, k -> - Dict.update acc k \val -> - when val is - Ok p -> Ok (p |> Num.addWrap 1) - Err Missing -> Ok 0 + List.walk( + bad_keys, + Dict.empty({}), + \acc, k -> + Dict.update( + acc, + k, + \val -> + when val is + Ok(p) -> Ok(Num.add_wrap(p, 1)) + Err(Missing) -> Ok(0), + ), + ) - allInsertedCorrectly = - List.walk badKeys Bool.true \acc, k -> - acc && Dict.contains dict k + all_inserted_correctly = + List.walk( + bad_keys, + Bool.true, + \acc, k -> + acc && Dict.contains(dict, k), + ) - allInsertedCorrectly + all_inserted_correctly # Note, there are a number of places we should probably use set and replace unsafe. # unsafe primitive that does not perform a bounds check -listGetUnsafe : List a, U64 -> a +list_get_unsafe : List a, U64 -> a # We have decided not to expose the standard roc hashing algorithm. # This is to avoid external dependence and the need for versioning. @@ -1236,160 +1266,161 @@ listGetUnsafe : List a, U64 -> a # TODO: wyhash is slow for large keys, use something like cityhash if the keys are too long. # TODO: Add a builtin to distinguish big endian systems and change loading orders. # TODO: Switch out Wymum on systems with slow 128bit multiplication. -LowLevelHasher := { initializedSeed : U64, state : U64 } implements [ +LowLevelHasher := { initialized_seed : U64, state : U64 } implements [ Hasher { - addBytes, - addU8, - addU16, - addU32, - addU64, - addU128, + add_bytes, + add_u8, + add_u16, + add_u32, + add_u64, + add_u128, complete, }, ] # Returns a application specific pseudo random seed for Dict. # This avoids trivial DOS attacks. -pseudoSeed : {} -> U64 +pseudo_seed : {} -> U64 -createLowLevelHasher : [PseudoRandSeed, WithSeed U64] -> LowLevelHasher -createLowLevelHasher = \seedOpt -> +create_low_level_hasher : [PseudoRandSeed, WithSeed U64] -> LowLevelHasher +create_low_level_hasher = \seed_opt -> seed = - when seedOpt is - PseudoRandSeed -> pseudoSeed {} - WithSeed s -> s - @LowLevelHasher { initializedSeed: initSeed seed, state: seed } + when seed_opt is + PseudoRandSeed -> pseudo_seed({}) + WithSeed(s) -> s + @LowLevelHasher({ initialized_seed: init_seed(seed), state: seed }) -combineState : LowLevelHasher, { a : U64, b : U64, seed : U64, length : U64 } -> LowLevelHasher -combineState = \@LowLevelHasher { initializedSeed, state }, { a, b, seed, length } -> +combine_state : LowLevelHasher, { a : U64, b : U64, seed : U64, length : U64 } -> LowLevelHasher +combine_state = \@LowLevelHasher({ initialized_seed, state }), { a, b, seed, length } -> mum = a - |> Num.bitwiseXor wyp1 - |> wymum (Num.bitwiseXor b seed) + |> Num.bitwise_xor(wyp1) + |> wymum(Num.bitwise_xor(b, seed)) nexta = mum.lower - |> Num.bitwiseXor wyp0 - |> Num.bitwiseXor length + |> Num.bitwise_xor(wyp0) + |> Num.bitwise_xor(length) nextb = mum.upper - |> Num.bitwiseXor wyp1 - hash = wymix nexta nextb + |> Num.bitwise_xor(wyp1) + hash = wymix(nexta, nextb) - @LowLevelHasher { initializedSeed, state: wymix state hash } + @LowLevelHasher({ initialized_seed, state: wymix(state, hash) }) -initSeed = \seed -> +init_seed = \seed -> seed - |> Num.bitwiseXor wyp0 - |> wymix wyp1 - |> Num.bitwiseXor seed + |> Num.bitwise_xor(wyp0) + |> wymix(wyp1) + |> Num.bitwise_xor(seed) -complete = \@LowLevelHasher { state } -> state +complete = \@LowLevelHasher({ state }) -> state # These implementations hash each value individually with the seed and then mix # the resulting hash with the state. There are other options that may be faster # like using the output of the last hash as the seed to the current hash. # I am simply not sure the tradeoffs here. Theoretically this method is more sound. # Either way, the performance will be similar and we can change this later. -addU8 = \@LowLevelHasher { initializedSeed, state }, u8 -> - p0 = Num.toU64 u8 +add_u8 = \@LowLevelHasher({ initialized_seed, state }), u8 -> + p0 = Num.to_u64(u8) a = - Num.shiftLeftBy p0 16 - |> Num.bitwiseOr (Num.shiftLeftBy p0 8) - |> Num.bitwiseOr p0 + Num.shift_left_by(p0, 16) + |> Num.bitwise_or(Num.shift_left_by(p0, 8)) + |> Num.bitwise_or(p0) b = 0 - combineState (@LowLevelHasher { initializedSeed, state }) { a, b, seed: initializedSeed, length: 1 } + combine_state(@LowLevelHasher({ initialized_seed, state }), { a, b, seed: initialized_seed, length: 1 }) -addU16 = \@LowLevelHasher { initializedSeed, state }, u16 -> - p0 = Num.bitwiseAnd u16 0xFF |> Num.toU64 - p1 = Num.shiftRightZfBy u16 8 |> Num.toU64 +add_u16 = \@LowLevelHasher({ initialized_seed, state }), u16 -> + p0 = Num.bitwise_and(u16, 0xFF) |> Num.to_u64 + p1 = Num.shift_right_zf_by(u16, 8) |> Num.to_u64 a = - Num.shiftLeftBy p0 16 - |> Num.bitwiseOr (Num.shiftLeftBy p1 8) - |> Num.bitwiseOr p1 + Num.shift_left_by(p0, 16) + |> Num.bitwise_or(Num.shift_left_by(p1, 8)) + |> Num.bitwise_or(p1) b = 0 - combineState (@LowLevelHasher { initializedSeed, state }) { a, b, seed: initializedSeed, length: 2 } + combine_state(@LowLevelHasher({ initialized_seed, state }), { a, b, seed: initialized_seed, length: 2 }) -addU32 = \@LowLevelHasher { initializedSeed, state }, u32 -> - p0 = Num.toU64 u32 - a = Num.shiftLeftBy p0 32 |> Num.bitwiseOr p0 +add_u32 = \@LowLevelHasher({ initialized_seed, state }), u32 -> + p0 = Num.to_u64(u32) + a = Num.shift_left_by(p0, 32) |> Num.bitwise_or(p0) - combineState (@LowLevelHasher { initializedSeed, state }) { a, b: a, seed: initializedSeed, length: 4 } + combine_state(@LowLevelHasher({ initialized_seed, state }), { a, b: a, seed: initialized_seed, length: 4 }) -addU64 = \@LowLevelHasher { initializedSeed, state }, u64 -> - p0 = Num.bitwiseAnd 0xFFFF_FFFF u64 - p1 = Num.shiftRightZfBy u64 32 - a = Num.shiftLeftBy p0 32 |> Num.bitwiseOr p1 - b = Num.shiftLeftBy p1 32 |> Num.bitwiseOr p0 +add_u64 = \@LowLevelHasher({ initialized_seed, state }), u64 -> + p0 = Num.bitwise_and(0xFFFF_FFFF, u64) + p1 = Num.shift_right_zf_by(u64, 32) + a = Num.shift_left_by(p0, 32) |> Num.bitwise_or(p1) + b = Num.shift_left_by(p1, 32) |> Num.bitwise_or(p0) - combineState (@LowLevelHasher { initializedSeed, state }) { a, b, seed: initializedSeed, length: 8 } + combine_state(@LowLevelHasher({ initialized_seed, state }), { a, b, seed: initialized_seed, length: 8 }) -addU128 = \@LowLevelHasher { initializedSeed, state }, u128 -> - lower = u128 |> Num.toU64 - upper = Num.shiftRightZfBy u128 64 |> Num.toU64 - p0 = Num.bitwiseAnd 0xFFFF_FFFF lower - p1 = Num.shiftRightZfBy lower 32 |> Num.bitwiseAnd 0xFFFF_FFFF - p2 = Num.bitwiseAnd 0xFFFF_FFFF upper - p3 = Num.shiftRightZfBy upper 32 |> Num.bitwiseAnd 0xFFFF_FFFF - a = Num.shiftLeftBy p0 32 |> Num.bitwiseOr p2 - b = Num.shiftLeftBy p3 32 |> Num.bitwiseOr p1 +add_u128 = \@LowLevelHasher({ initialized_seed, state }), u128 -> + lower = u128 |> Num.to_u64 + upper = Num.shift_right_zf_by(u128, 64) |> Num.to_u64 + p0 = Num.bitwise_and(0xFFFF_FFFF, lower) + p1 = Num.shift_right_zf_by(lower, 32) |> Num.bitwise_and(0xFFFF_FFFF) + p2 = Num.bitwise_and(0xFFFF_FFFF, upper) + p3 = Num.shift_right_zf_by(upper, 32) |> Num.bitwise_and(0xFFFF_FFFF) + a = Num.shift_left_by(p0, 32) |> Num.bitwise_or(p2) + b = Num.shift_left_by(p3, 32) |> Num.bitwise_or(p1) - combineState (@LowLevelHasher { initializedSeed, state }) { a, b, seed: initializedSeed, length: 16 } + combine_state(@LowLevelHasher({ initialized_seed, state }), { a, b, seed: initialized_seed, length: 16 }) -addBytes : LowLevelHasher, List U8 -> LowLevelHasher -addBytes = \@LowLevelHasher { initializedSeed, state }, list -> - length = List.len list +add_bytes : LowLevelHasher, List U8 -> LowLevelHasher +add_bytes = \@LowLevelHasher({ initialized_seed, state }), list -> + length = List.len(list) abs = if length <= 16 then if length >= 4 then - x = Num.shiftRightZfBy length 3 |> Num.shiftLeftBy 2 - a = Num.bitwiseOr (wyr4 list 0 |> Num.shiftLeftBy 32) (wyr4 list x) + x = Num.shift_right_zf_by(length, 3) |> Num.shift_left_by(2) + a = Num.bitwise_or(wyr4(list, 0) |> Num.shift_left_by(32), wyr4(list, x)) b = - (wyr4 list (Num.subWrap length 4) |> Num.shiftLeftBy 32) - |> Num.bitwiseOr (wyr4 list (Num.subWrap length 4 |> Num.subWrap x)) + wyr4(list, Num.sub_wrap(length, 4)) + |> Num.shift_left_by(32) + |> Num.bitwise_or(wyr4(list, Num.sub_wrap(length, 4) |> Num.sub_wrap(x))) - { a, b, seed: initializedSeed } + { a, b, seed: initialized_seed } else if length > 0 then - { a: wyr3 list 0 length, b: 0, seed: initializedSeed } + { a: wyr3(list, 0, length), b: 0, seed: initialized_seed } else - { a: 0, b: 0, seed: initializedSeed } + { a: 0, b: 0, seed: initialized_seed } else if length <= 48 then - hashBytesHelper16 initializedSeed list 0 length + hash_bytes_helper16(initialized_seed, list, 0, length) else - hashBytesHelper48 initializedSeed initializedSeed initializedSeed list 0 length + hash_bytes_helper48(initialized_seed, initialized_seed, initialized_seed, list, 0, length) - combineState (@LowLevelHasher { initializedSeed, state }) { a: abs.a, b: abs.b, seed: abs.seed, length } + combine_state(@LowLevelHasher({ initialized_seed, state }), { a: abs.a, b: abs.b, seed: abs.seed, length }) -hashBytesHelper48 : U64, U64, U64, List U8, U64, U64 -> { a : U64, b : U64, seed : U64 } -hashBytesHelper48 = \seed, see1, see2, list, index, remaining -> - newSeed = wymix (Num.bitwiseXor (wyr8 list index) wyp1) (Num.bitwiseXor (wyr8 list (Num.addWrap index 8)) seed) - newSee1 = wymix (Num.bitwiseXor (wyr8 list (Num.addWrap index 16)) wyp2) (Num.bitwiseXor (wyr8 list (Num.addWrap index 24)) see1) - newSee2 = wymix (Num.bitwiseXor (wyr8 list (Num.addWrap index 32)) wyp3) (Num.bitwiseXor (wyr8 list (Num.addWrap index 40)) see2) - newRemaining = Num.subWrap remaining 48 - newIndex = Num.addWrap index 48 +hash_bytes_helper48 : U64, U64, U64, List U8, U64, U64 -> { a : U64, b : U64, seed : U64 } +hash_bytes_helper48 = \seed, see1, see2, list, index, remaining -> + new_seed = wymix(Num.bitwise_xor(wyr8(list, index), wyp1), Num.bitwise_xor(wyr8(list, Num.add_wrap(index, 8)), seed)) + new_see1 = wymix(Num.bitwise_xor(wyr8(list, Num.add_wrap(index, 16)), wyp2), Num.bitwise_xor(wyr8(list, Num.add_wrap(index, 24)), see1)) + new_see2 = wymix(Num.bitwise_xor(wyr8(list, Num.add_wrap(index, 32)), wyp3), Num.bitwise_xor(wyr8(list, Num.add_wrap(index, 40)), see2)) + new_remaining = Num.sub_wrap(remaining, 48) + new_index = Num.add_wrap(index, 48) - if newRemaining > 48 then - hashBytesHelper48 newSeed newSee1 newSee2 list newIndex newRemaining - else if newRemaining > 16 then - finalSeed = Num.bitwiseXor newSee2 (Num.bitwiseXor newSee1 newSeed) + if new_remaining > 48 then + hash_bytes_helper48(new_seed, new_see1, new_see2, list, new_index, new_remaining) + else if new_remaining > 16 then + final_seed = Num.bitwise_xor(new_see2, Num.bitwise_xor(new_see1, new_seed)) - hashBytesHelper16 finalSeed list newIndex newRemaining + hash_bytes_helper16(final_seed, list, new_index, new_remaining) else - finalSeed = Num.bitwiseXor newSee2 (Num.bitwiseXor newSee1 newSeed) + final_seed = Num.bitwise_xor(new_see2, Num.bitwise_xor(new_see1, new_seed)) - { a: wyr8 list (Num.subWrap newRemaining 16 |> Num.addWrap newIndex), b: wyr8 list (Num.subWrap newRemaining 8 |> Num.addWrap newIndex), seed: finalSeed } + { a: wyr8(list, (Num.sub_wrap(new_remaining, 16) |> Num.add_wrap(new_index))), b: wyr8(list, (Num.sub_wrap(new_remaining, 8) |> Num.add_wrap(new_index))), seed: final_seed } -hashBytesHelper16 : U64, List U8, U64, U64 -> { a : U64, b : U64, seed : U64 } -hashBytesHelper16 = \seed, list, index, remaining -> - newSeed = wymix (Num.bitwiseXor (wyr8 list index) wyp1) (Num.bitwiseXor (wyr8 list (Num.addWrap index 8)) seed) - newRemaining = Num.subWrap remaining 16 - newIndex = Num.addWrap index 16 +hash_bytes_helper16 : U64, List U8, U64, U64 -> { a : U64, b : U64, seed : U64 } +hash_bytes_helper16 = \seed, list, index, remaining -> + new_seed = wymix(Num.bitwise_xor(wyr8(list, index), wyp1), Num.bitwise_xor(wyr8(list, Num.add_wrap(index, 8)), seed)) + new_remaining = Num.sub_wrap(remaining, 16) + new_index = Num.add_wrap(index, 16) - if newRemaining <= 16 then - { a: wyr8 list (Num.subWrap newRemaining 16 |> Num.addWrap newIndex), b: wyr8 list (Num.subWrap newRemaining 8 |> Num.addWrap newIndex), seed: newSeed } + if new_remaining <= 16 then + { a: wyr8(list, (Num.sub_wrap(new_remaining, 16) |> Num.add_wrap(new_index))), b: wyr8(list, (Num.sub_wrap(new_remaining, 8) |> Num.add_wrap(new_index))), seed: new_seed } else - hashBytesHelper16 newSeed list newIndex newRemaining + hash_bytes_helper16(new_seed, list, new_index, new_remaining) wyp0 : U64 wyp0 = 0xa0761d6478bd642f @@ -1402,202 +1433,202 @@ wyp3 = 0x589965cc75374cc3 wymix : U64, U64 -> U64 wymix = \a, b -> - { lower, upper } = wymum a b + { lower, upper } = wymum(a, b) - Num.bitwiseXor lower upper + Num.bitwise_xor(lower, upper) wymum : U64, U64 -> { lower : U64, upper : U64 } wymum = \a, b -> - r = Num.mulWrap (Num.toU128 a) (Num.toU128 b) - lower = Num.toU64 r - upper = Num.shiftRightZfBy r 64 |> Num.toU64 + r = Num.mul_wrap(Num.to_u128(a), Num.to_u128(b)) + lower = Num.to_u64(r) + upper = Num.shift_right_zf_by(r, 64) |> Num.to_u64 # This is the more robust form, which we may look into later - # { lower: Num.bitwiseXor a lower, upper: Num.bitwiseXor b upper } + # { lower: Num.bitwise_xor(a, lower), upper: Num.bitwise_xor(b, upper) } { lower, upper } # Get the next 8 bytes as a U64 wyr8 : List U8, U64 -> U64 wyr8 = \list, index -> - # With seamless slices and Num.fromBytes, this should be possible to make faster and nicer. + # With seamless slices and Num.from_bytes, this should be possible to make faster and nicer. # It would also deal with the fact that on big endian systems we want to invert the order here. - # Without seamless slices, we would need fromBytes to take an index. - p1 = listGetUnsafe list index |> Num.toU64 - p2 = listGetUnsafe list (Num.addWrap index 1) |> Num.toU64 - p3 = listGetUnsafe list (Num.addWrap index 2) |> Num.toU64 - p4 = listGetUnsafe list (Num.addWrap index 3) |> Num.toU64 - p5 = listGetUnsafe list (Num.addWrap index 4) |> Num.toU64 - p6 = listGetUnsafe list (Num.addWrap index 5) |> Num.toU64 - p7 = listGetUnsafe list (Num.addWrap index 6) |> Num.toU64 - p8 = listGetUnsafe list (Num.addWrap index 7) |> Num.toU64 - a = Num.bitwiseOr p1 (Num.shiftLeftBy p2 8) - b = Num.bitwiseOr (Num.shiftLeftBy p3 16) (Num.shiftLeftBy p4 24) - c = Num.bitwiseOr (Num.shiftLeftBy p5 32) (Num.shiftLeftBy p6 40) - d = Num.bitwiseOr (Num.shiftLeftBy p7 48) (Num.shiftLeftBy p8 56) - - Num.bitwiseOr (Num.bitwiseOr a b) (Num.bitwiseOr c d) + # Without seamless slices, we would need from_bytes to take an index. + p1 = list_get_unsafe(list, index) |> Num.to_u64 + p2 = list_get_unsafe(list, Num.add_wrap(index, 1)) |> Num.to_u64 + p3 = list_get_unsafe(list, Num.add_wrap(index, 2)) |> Num.to_u64 + p4 = list_get_unsafe(list, Num.add_wrap(index, 3)) |> Num.to_u64 + p5 = list_get_unsafe(list, Num.add_wrap(index, 4)) |> Num.to_u64 + p6 = list_get_unsafe(list, Num.add_wrap(index, 5)) |> Num.to_u64 + p7 = list_get_unsafe(list, Num.add_wrap(index, 6)) |> Num.to_u64 + p8 = list_get_unsafe(list, Num.add_wrap(index, 7)) |> Num.to_u64 + a = Num.bitwise_or(p1, Num.shift_left_by(p2, 8)) + b = Num.bitwise_or(Num.shift_left_by(p3, 16), Num.shift_left_by(p4, 24)) + c = Num.bitwise_or(Num.shift_left_by(p5, 32), Num.shift_left_by(p6, 40)) + d = Num.bitwise_or(Num.shift_left_by(p7, 48), Num.shift_left_by(p8, 56)) + + Num.bitwise_or(Num.bitwise_or(a, b), Num.bitwise_or(c, d)) # Get the next 4 bytes as a U64 with some shifting. wyr4 : List U8, U64 -> U64 wyr4 = \list, index -> - p1 = listGetUnsafe list index |> Num.toU64 - p2 = listGetUnsafe list (Num.addWrap index 1) |> Num.toU64 - p3 = listGetUnsafe list (Num.addWrap index 2) |> Num.toU64 - p4 = listGetUnsafe list (Num.addWrap index 3) |> Num.toU64 - a = Num.bitwiseOr p1 (Num.shiftLeftBy p2 8) - b = Num.bitwiseOr (Num.shiftLeftBy p3 16) (Num.shiftLeftBy p4 24) + p1 = list_get_unsafe(list, index) |> Num.to_u64 + p2 = list_get_unsafe(list, Num.add_wrap(index, 1)) |> Num.to_u64 + p3 = list_get_unsafe(list, Num.add_wrap(index, 2)) |> Num.to_u64 + p4 = list_get_unsafe(list, Num.add_wrap(index, 3)) |> Num.to_u64 + a = Num.bitwise_or(p1, Num.shift_left_by(p2, 8)) + b = Num.bitwise_or(Num.shift_left_by(p3, 16), Num.shift_left_by(p4, 24)) - Num.bitwiseOr a b + Num.bitwise_or(a, b) # Get the next K bytes with some shifting. # K must be 3 or less. wyr3 : List U8, U64, U64 -> U64 wyr3 = \list, index, k -> # ((uint64_t)p[0])<<16)|(((uint64_t)p[k>>1])<<8)|p[k-1] - p1 = listGetUnsafe list index |> Num.toU64 - p2 = listGetUnsafe list (Num.shiftRightZfBy k 1 |> Num.addWrap index) |> Num.toU64 - p3 = listGetUnsafe list (Num.subWrap k 1 |> Num.addWrap index) |> Num.toU64 - a = Num.bitwiseOr (Num.shiftLeftBy p1 16) (Num.shiftLeftBy p2 8) + p1 = list_get_unsafe(list, index) |> Num.to_u64 + p2 = list_get_unsafe(list, Num.shift_right_zf_by(k, 1) |> Num.add_wrap(index)) |> Num.to_u64 + p3 = list_get_unsafe(list, Num.sub_wrap(k, 1) |> Num.add_wrap(index)) |> Num.to_u64 + a = Num.bitwise_or(Num.shift_left_by(p1, 16), Num.shift_left_by(p2, 8)) - Num.bitwiseOr a p3 + Num.bitwise_or(a, p3) -testSeed = WithSeed 0x526F_6352_616E_643F +test_seed = WithSeed(0x526F_6352_616E_643F) # TODO: would be great to have table driven expects for this. # Would also be great to have some sort of property based hasher -# where we can compare `addU*` functions to the `addBytes` function. +# where we can compare `add_u*` functions to the `add_bytes` function. expect hash = - createLowLevelHasher testSeed - |> addBytes [] + create_low_level_hasher(test_seed) + |> add_bytes([]) |> complete hash == 0xD59C59757DBBE6B3 expect hash = - createLowLevelHasher testSeed - |> addBytes [0x42] + create_low_level_hasher(test_seed) + |> add_bytes([0x42]) |> complete hash == 0x38CE03D0E61AF963 expect hash = - createLowLevelHasher testSeed - |> addU8 0x42 + create_low_level_hasher(test_seed) + |> add_u8(0x42) |> complete hash == 0x38CE03D0E61AF963 expect hash = - createLowLevelHasher testSeed - |> addBytes [0xFF, 0xFF] + create_low_level_hasher(test_seed) + |> add_bytes([0xFF, 0xFF]) |> complete hash == 0xE1CB2FA0D6A64113 expect hash = - createLowLevelHasher testSeed - |> addU16 0xFFFF + create_low_level_hasher(test_seed) + |> add_u16(0xFFFF) |> complete hash == 0xE1CB2FA0D6A64113 expect hash = - createLowLevelHasher testSeed - |> addBytes [0x36, 0xA7] + create_low_level_hasher(test_seed) + |> add_bytes([0x36, 0xA7]) |> complete hash == 0x26B8319EDAF81B15 expect hash = - createLowLevelHasher testSeed - |> addU16 0xA736 + create_low_level_hasher(test_seed) + |> add_u16(0xA736) |> complete hash == 0x26B8319EDAF81B15 expect hash = - createLowLevelHasher testSeed - |> addBytes [0x00, 0x00, 0x00, 0x00] + create_low_level_hasher(test_seed) + |> add_bytes([0x00, 0x00, 0x00, 0x00]) |> complete hash == 0xA187D7CA074F9EE7 expect hash = - createLowLevelHasher testSeed - |> addU32 0x0000_0000 + create_low_level_hasher(test_seed) + |> add_u32(0x0000_0000) |> complete hash == 0xA187D7CA074F9EE7 expect hash = - createLowLevelHasher testSeed - |> addBytes [0xA9, 0x2F, 0xEE, 0x21] + create_low_level_hasher(test_seed) + |> add_bytes([0xA9, 0x2F, 0xEE, 0x21]) |> complete hash == 0xA499EFE4C1454D09 expect hash = - createLowLevelHasher testSeed - |> addU32 0x21EE_2FA9 + create_low_level_hasher(test_seed) + |> add_u32(0x21EE_2FA9) |> complete hash == 0xA499EFE4C1454D09 expect hash = - createLowLevelHasher testSeed - |> addBytes [0x5D, 0x66, 0xB1, 0x8F, 0x68, 0x44, 0xC7, 0x03, 0xE1, 0xDD, 0x23, 0x34, 0xBB, 0x9A, 0x42, 0xA7] + create_low_level_hasher(test_seed) + |> add_bytes([0x5D, 0x66, 0xB1, 0x8F, 0x68, 0x44, 0xC7, 0x03, 0xE1, 0xDD, 0x23, 0x34, 0xBB, 0x9A, 0x42, 0xA7]) |> complete hash == 0xDD39A206AED64C73 expect hash = - createLowLevelHasher testSeed - |> addU128 0xA742_9ABB_3423_DDE1_03C7_4468_8FB1_665D + create_low_level_hasher(test_seed) + |> add_u128(0xA742_9ABB_3423_DDE1_03C7_4468_8FB1_665D) |> complete hash == 0xDD39A206AED64C73 expect hash = - createLowLevelHasher testSeed - |> Hash.hashStrBytes "abcdefghijklmnopqrstuvwxyz" + create_low_level_hasher(test_seed) + |> Hash.hash_str_bytes("abcdefghijklmnopqrstuvwxyz") |> complete hash == 0x51C59DF5B1D15F40 expect hash = - createLowLevelHasher testSeed - |> Hash.hashStrBytes "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789" + create_low_level_hasher(test_seed) + |> Hash.hash_str_bytes("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789") |> complete hash == 0xD8D0A129D97A4E95 expect hash = - createLowLevelHasher testSeed - |> Hash.hashStrBytes "1234567890123456789012345678901234567890123456789012345678901234567890" + create_low_level_hasher(test_seed) + |> Hash.hash_str_bytes("1234567890123456789012345678901234567890123456789012345678901234567890") |> complete hash == 0x8188065B44FB4AAA expect hash = - createLowLevelHasher testSeed - |> addBytes (List.repeat 0x77 100) + create_low_level_hasher(test_seed) + |> add_bytes(List.repeat(0x77, 100)) |> complete hash == 0x47A2A606EADF3378 @@ -1606,124 +1637,124 @@ expect # Apparently it won't pick the default integer. expect hash = - createLowLevelHasher testSeed - |> Hash.hashUnordered [8u8, 82u8, 3u8, 8u8, 24u8] List.walk + create_low_level_hasher(test_seed) + |> Hash.hash_unordered([8u8, 82u8, 3u8, 8u8, 24u8], List.walk) |> complete hash == 0xB2E8254C08F16B20 expect hash1 = - createLowLevelHasher testSeed - |> Hash.hashUnordered ([0u8, 1u8, 2u8, 3u8, 4u8]) List.walk + create_low_level_hasher(test_seed) + |> Hash.hash_unordered([0u8, 1u8, 2u8, 3u8, 4u8], List.walk) |> complete hash2 = - createLowLevelHasher testSeed - |> Hash.hashUnordered [4u8, 3u8, 2u8, 1u8, 0u8] List.walk + create_low_level_hasher(test_seed) + |> Hash.hash_unordered([4u8, 3u8, 2u8, 1u8, 0u8], List.walk) |> complete hash1 == hash2 expect hash1 = - createLowLevelHasher testSeed - |> Hash.hashUnordered [0u8, 1u8, 2u8, 3u8, 4u8] List.walk + create_low_level_hasher(test_seed) + |> Hash.hash_unordered([0u8, 1u8, 2u8, 3u8, 4u8], List.walk) |> complete hash2 = - createLowLevelHasher testSeed - |> Hash.hashUnordered [4u8, 3u8, 2u8, 1u8, 0u8, 0u8] List.walk + create_low_level_hasher(test_seed) + |> Hash.hash_unordered([4u8, 3u8, 2u8, 1u8, 0u8, 0u8], List.walk) |> complete hash1 != hash2 expect - empty {} + empty({}) |> len - |> Bool.isEq 0 + |> Bool.is_eq(0) expect - empty {} - |> insert "One" "A Song" - |> insert "Two" "Candy Canes" - |> insert "Three" "Boughs of Holly" + empty({}) + |> insert("One", "A Song") + |> insert("Two", "Candy Canes") + |> insert("Three", "Boughs of Holly") |> clear |> len - |> Bool.isEq 0 + |> Bool.is_eq(0) expect - Dict.empty {} - |> Dict.insert "Alice" 17 - |> Dict.insert "Bob" 18 - |> Dict.insert "Charlie" 19 - |> Dict.walkUntil Bool.false (\_, _, age -> if age >= 18 then Break Bool.true else Continue Bool.false) - |> Bool.isEq Bool.true + Dict.empty({}) + |> Dict.insert("Alice", 17) + |> Dict.insert("Bob", 18) + |> Dict.insert("Charlie", 19) + |> Dict.walk_until(Bool.false, \_, _, age -> if age >= 18 then Break(Bool.true) else Continue(Bool.false)) + |> Bool.is_eq(Bool.true) expect d1 = - Dict.empty {} - |> Dict.insert "Alice" 17 - |> Dict.insert "Bob" 18 - |> Dict.insert "Charlie" 19 - |> Dict.keepIf \(_k, v) -> v >= 18 + Dict.empty({}) + |> Dict.insert("Alice", 17) + |> Dict.insert("Bob", 18) + |> Dict.insert("Charlie", 19) + |> Dict.keep_if(\(_k, v) -> v >= 18) d2 = - Dict.empty {} - |> Dict.insert "Bob" 18 - |> Dict.insert "Charlie" 19 + Dict.empty({}) + |> Dict.insert("Bob", 18) + |> Dict.insert("Charlie", 19) d1 == d2 expect d1 = - Dict.empty {} - |> Dict.insert "Alice" 17 - |> Dict.insert "Bob" 18 - |> Dict.insert "Charlie" 19 - |> Dict.keepIf \(k, _v) -> Str.endsWith k "e" + Dict.empty({}) + |> Dict.insert("Alice", 17) + |> Dict.insert("Bob", 18) + |> Dict.insert("Charlie", 19) + |> Dict.keep_if(\(k, _v) -> Str.ends_with(k, "e")) d2 = - Dict.empty {} - |> Dict.insert "Alice" 17 - |> Dict.insert "Charlie" 19 + Dict.empty({}) + |> Dict.insert("Alice", 17) + |> Dict.insert("Charlie", 19) d1 == d2 expect - keysToDelete = [1, 2] + keys_to_delete = [1, 2] d1 = - Dict.empty {} - |> Dict.insert 0 0 - |> Dict.insert 1 1 - |> Dict.insert 2 2 - |> Dict.insert 3 3 - |> Dict.insert 4 4 - |> Dict.keepIf (\(k, _v) -> List.contains keysToDelete k |> Bool.not) + Dict.empty({}) + |> Dict.insert(0, 0) + |> Dict.insert(1, 1) + |> Dict.insert(2, 2) + |> Dict.insert(3, 3) + |> Dict.insert(4, 4) + |> Dict.keep_if(\(k, _v) -> !(List.contains(keys_to_delete, k))) d2 = - Dict.empty {} - |> Dict.insert 0 0 - |> Dict.insert 3 3 - |> Dict.insert 4 4 + Dict.empty({}) + |> Dict.insert(0, 0) + |> Dict.insert(3, 3) + |> Dict.insert(4, 4) d1 == d2 expect - keysToDelete = [2, 4] + keys_to_delete = [2, 4] d1 = - Dict.empty {} - |> Dict.insert 0 0 - |> Dict.insert 1 1 - |> Dict.insert 2 2 - |> Dict.insert 3 3 - |> Dict.insert 4 4 - |> Dict.keepIf (\(k, _v) -> List.contains keysToDelete k |> Bool.not) + Dict.empty({}) + |> Dict.insert(0, 0) + |> Dict.insert(1, 1) + |> Dict.insert(2, 2) + |> Dict.insert(3, 3) + |> Dict.insert(4, 4) + |> Dict.keep_if(\(k, _v) -> !(List.contains(keys_to_delete, k))) d2 = - Dict.empty {} - |> Dict.insert 0 0 - |> Dict.insert 1 1 - |> Dict.insert 3 3 + Dict.empty({}) + |> Dict.insert(0, 0) + |> Dict.insert(1, 1) + |> Dict.insert(3, 3) d1 == d2 diff --git a/crates/compiler/builtins/roc/Encode.roc b/crates/compiler/builtins/roc/Encode.roc index b63ad2f35ba..2a091c26979 100644 --- a/crates/compiler/builtins/roc/Encode.roc +++ b/crates/compiler/builtins/roc/Encode.roc @@ -1,7 +1,7 @@ module [ Encoder, Encoding, - toEncoder, + to_encoder, EncoderFormatting, u8, u16, @@ -23,9 +23,9 @@ module [ tag, tuple, custom, - appendWith, + append_with, append, - toBytes, + to_bytes, ] import Num exposing [ @@ -48,7 +48,7 @@ import Bool exposing [Bool] Encoder fmt := List U8, fmt -> List U8 where fmt implements EncoderFormatting Encoding implements - toEncoder : val -> Encoder fmt where val implements Encoding, fmt implements EncoderFormatting + to_encoder : val -> Encoder fmt where val implements Encoding, fmt implements EncoderFormatting EncoderFormatting implements u8 : U8 -> Encoder fmt where fmt implements EncoderFormatting @@ -76,41 +76,41 @@ EncoderFormatting implements ## ```roc ## expect ## # Appends the byte 42 -## customEncoder = Encode.custom (\bytes, _fmt -> List.append bytes 42) +## custom_encoder = Encode.custom(\bytes, _fmt -> List.append(bytes, 42)) ## -## actual = Encode.appendWith [] customEncoder Core.json +## actual = Encode.append_with([], custom_encoder, Core.json) ## expected = [42] # Expected result is a list with a single byte, 42 ## ## actual == expected ## ``` custom : (List U8, fmt -> List U8) -> Encoder fmt where fmt implements EncoderFormatting -custom = \encoder -> @Encoder encoder +custom = \encoder -> @Encoder(encoder) -appendWith : List U8, Encoder fmt, fmt -> List U8 where fmt implements EncoderFormatting -appendWith = \lst, @Encoder doEncoding, fmt -> doEncoding lst fmt +append_with : List U8, Encoder fmt, fmt -> List U8 where fmt implements EncoderFormatting +append_with = \lst, @Encoder(do_encoding), fmt -> do_encoding(lst, fmt) ## Appends the encoded representation of a value to an existing list of bytes. ## ## ```roc ## expect -## actual = Encode.append [] { foo: 43 } Core.json -## expected = Str.toUtf8 """{"foo":43}""" +## actual = Encode.append([], { foo: 43 }, Core.json) +## expected = Str.to_utf8("""{"foo":43}""") ## ## actual == expected ## ``` append : List U8, val, fmt -> List U8 where val implements Encoding, fmt implements EncoderFormatting -append = \lst, val, fmt -> appendWith lst (toEncoder val) fmt +append = \lst, val, fmt -> append_with(lst, to_encoder(val), fmt) ## Encodes a value to a list of bytes (`List U8`) according to the specified format. ## ## ```roc ## expect -## fooRec = { foo: 42 } +## foo_rec = { foo: 42 } ## -## actual = Encode.toBytes fooRec Core.json -## expected = Str.toUtf8 """{"foo":42}""" +## actual = Encode.to_bytes(foo_rec, Core.json) +## expected = Str.to_utf8("""{"foo":42}""") ## ## actual == expected ## ``` -toBytes : val, fmt -> List U8 where val implements Encoding, fmt implements EncoderFormatting -toBytes = \val, fmt -> appendWith [] (toEncoder val) fmt +to_bytes : val, fmt -> List U8 where val implements Encoding, fmt implements EncoderFormatting +to_bytes = \val, fmt -> append_with([], to_encoder(val), fmt) diff --git a/crates/compiler/builtins/roc/Hash.roc b/crates/compiler/builtins/roc/Hash.roc index 8dfa548c7dc..62f703581ed 100644 --- a/crates/compiler/builtins/roc/Hash.roc +++ b/crates/compiler/builtins/roc/Hash.roc @@ -2,23 +2,23 @@ module [ Hash, Hasher, hash, - addBytes, - addU8, - addU16, - addU32, - addU64, - addU128, - hashBool, - hashI8, - hashI16, - hashI32, - hashI64, - hashI128, - hashDec, + add_bytes, + add_u8, + add_u16, + add_u32, + add_u64, + add_u128, + hash_bool, + hash_i8, + hash_i16, + hash_i32, + hash_i64, + hash_i128, + hash_dec, complete, - hashStrBytes, - hashList, - hashUnordered, + hash_str_bytes, + hash_list, + hash_unordered, ] import Bool exposing [Bool] @@ -52,86 +52,90 @@ Hash implements ## cryptographically-secure hashing. Hasher implements ## Adds a list of bytes to the hasher. - addBytes : a, List U8 -> a where a implements Hasher + add_bytes : a, List U8 -> a where a implements Hasher ## Adds a single U8 to the hasher. - addU8 : a, U8 -> a where a implements Hasher + add_u8 : a, U8 -> a where a implements Hasher ## Adds a single U16 to the hasher. - addU16 : a, U16 -> a where a implements Hasher + add_u16 : a, U16 -> a where a implements Hasher ## Adds a single U32 to the hasher. - addU32 : a, U32 -> a where a implements Hasher + add_u32 : a, U32 -> a where a implements Hasher ## Adds a single U64 to the hasher. - addU64 : a, U64 -> a where a implements Hasher + add_u64 : a, U64 -> a where a implements Hasher ## Adds a single U128 to the hasher. - addU128 : a, U128 -> a where a implements Hasher + add_u128 : a, U128 -> a where a implements Hasher ## Completes the hasher, extracting a hash value from its ## accumulated hash state. complete : a -> U64 where a implements Hasher ## Adds a string into a [Hasher] by hashing its UTF-8 bytes. -hashStrBytes = \hasher, s -> - addBytes hasher (Str.toUtf8 s) +hash_str_bytes = \hasher, s -> + add_bytes(hasher, Str.to_utf8(s)) ## Adds a list of [Hash]able elements to a [Hasher] by hashing each element. -hashList = \hasher, lst -> - List.walk lst hasher \accumHasher, elem -> - hash accumHasher elem +hash_list = \hasher, lst -> + List.walk( + lst, + hasher, + \accum_hasher, elem -> + hash(accum_hasher, elem), + ) ## Adds a single [Bool] to a hasher. -hashBool : a, Bool -> a where a implements Hasher -hashBool = \hasher, b -> - asU8 = if b then 1 else 0 - addU8 hasher asU8 +hash_bool : a, Bool -> a where a implements Hasher +hash_bool = \hasher, b -> + as_u8 = if b then 1 else 0 + add_u8(hasher, as_u8) ## Adds a single I8 to a hasher. -hashI8 : a, I8 -> a where a implements Hasher -hashI8 = \hasher, n -> addU8 hasher (Num.toU8 n) +hash_i8 : a, I8 -> a where a implements Hasher +hash_i8 = \hasher, n -> add_u8(hasher, Num.to_u8(n)) ## Adds a single I16 to a hasher. -hashI16 : a, I16 -> a where a implements Hasher -hashI16 = \hasher, n -> addU16 hasher (Num.toU16 n) +hash_i16 : a, I16 -> a where a implements Hasher +hash_i16 = \hasher, n -> add_u16(hasher, Num.to_u16(n)) ## Adds a single I32 to a hasher. -hashI32 : a, I32 -> a where a implements Hasher -hashI32 = \hasher, n -> addU32 hasher (Num.toU32 n) +hash_i32 : a, I32 -> a where a implements Hasher +hash_i32 = \hasher, n -> add_u32(hasher, Num.to_u32(n)) ## Adds a single I64 to a hasher. -hashI64 : a, I64 -> a where a implements Hasher -hashI64 = \hasher, n -> addU64 hasher (Num.toU64 n) +hash_i64 : a, I64 -> a where a implements Hasher +hash_i64 = \hasher, n -> add_u64(hasher, Num.to_u64(n)) ## Adds a single I128 to a hasher. -hashI128 : a, I128 -> a where a implements Hasher -hashI128 = \hasher, n -> addU128 hasher (Num.toU128 n) +hash_i128 : a, I128 -> a where a implements Hasher +hash_i128 = \hasher, n -> add_u128(hasher, Num.to_u128(n)) ## Adds a single [Dec] to a hasher. -hashDec : a, Dec -> a where a implements Hasher -hashDec = \hasher, n -> hashI128 hasher (Num.withoutDecimalPoint n) +hash_dec : a, Dec -> a where a implements Hasher +hash_dec = \hasher, n -> hash_i128(hasher, Num.without_decimal_point(n)) ## Adds a container of [Hash]able elements to a [Hasher] by hashing each element. ## The container is iterated using the walk method passed in. ## The order of the elements does not affect the final hash. -hashUnordered = \hasher, container, walk -> - walk - container - 0 - (\accum, elem -> +hash_unordered = \hasher, container, walk -> + walk( + container, + 0, + \accum, elem -> x = # Note, we intentionally copy the hasher in every iteration. # Having the same base state is required for unordered hashing. hasher - |> hash elem + |> hash(elem) |> complete - nextAccum = Num.addWrap accum x + next_accum = Num.add_wrap(accum, x) - if nextAccum < accum then + if next_accum < accum then # we don't want to lose a bit of entropy on overflow, so add it back in. - Num.addWrap nextAccum 1 + Num.add_wrap(next_accum, 1) else - nextAccum - ) - |> \accum -> addU64 hasher accum + next_accum, + ) + |> \accum -> add_u64(hasher, accum) diff --git a/crates/compiler/builtins/roc/Inspect.roc b/crates/compiler/builtins/roc/Inspect.roc index 7d2dfa2e36f..f8839b33ca0 100644 --- a/crates/compiler/builtins/roc/Inspect.roc +++ b/crates/compiler/builtins/roc/Inspect.roc @@ -31,8 +31,8 @@ module [ dec, custom, apply, - toInspector, - toStr, + to_inspector, + to_str, ] import Bool exposing [Bool] @@ -81,24 +81,24 @@ InspectFormatter implements Inspector f := f -> f where f implements InspectFormatter custom : (f -> f) -> Inspector f where f implements InspectFormatter -custom = \fn -> @Inspector fn +custom = \fn -> @Inspector(fn) apply : Inspector f, f -> f where f implements InspectFormatter -apply = \@Inspector fn, fmt -> fn fmt +apply = \@Inspector(fn), fmt -> fn(fmt) Inspect implements - toInspector : val -> Inspector f where val implements Inspect, f implements InspectFormatter + to_inspector : val -> Inspector f where val implements Inspect, f implements InspectFormatter inspect : val -> f where val implements Inspect, f implements InspectFormatter inspect = \val -> - (@Inspector valFn) = toInspector val - valFn (init {}) + @Inspector(val_fn) = to_inspector(val) + val_fn(init({})) -toStr : val -> Str where val implements Inspect -toStr = \val -> +to_str : val -> Str where val implements Inspect +to_str = \val -> val |> inspect - |> toDbgStr + |> to_dbg_str # The current default formatter for inspect. # This just returns a simple string for debugging. @@ -106,246 +106,260 @@ toStr = \val -> DbgFormatter := { data : Str } implements [ InspectFormatter { - init: dbgInit, - list: dbgList, - set: dbgSet, - dict: dbgDict, - tag: dbgTag, - tuple: dbgTuple, - record: dbgRecord, - bool: dbgBool, - str: dbgStr, - opaque: dbgOpaque, - function: dbgFunction, - u8: dbgU8, - i8: dbgI8, - u16: dbgU16, - i16: dbgI16, - u32: dbgU32, - i32: dbgI32, - u64: dbgU64, - i64: dbgI64, - u128: dbgU128, - i128: dbgI128, - f32: dbgF32, - f64: dbgF64, - dec: dbgDec, + init: dbg_init, + list: dbg_list, + set: dbg_set, + dict: dbg_dict, + tag: dbg_tag, + tuple: dbg_tuple, + record: dbg_record, + bool: dbg_bool, + str: dbg_str, + opaque: dbg_opaque, + function: dbg_function, + u8: dbg_u8, + i8: dbg_i8, + u16: dbg_u16, + i16: dbg_i16, + u32: dbg_u32, + i32: dbg_i32, + u64: dbg_u64, + i64: dbg_i64, + u128: dbg_u128, + i128: dbg_i128, + f32: dbg_f32, + f64: dbg_f64, + dec: dbg_dec, }, ] -dbgInit : {} -> DbgFormatter -dbgInit = \{} -> @DbgFormatter { data: "" } - -dbgList : list, ElemWalker (DbgFormatter, Bool) list elem, (elem -> Inspector DbgFormatter) -> Inspector DbgFormatter -dbgList = \content, walkFn, toDbgInspector -> - custom \f0 -> - dbgWrite f0 "[" - |> \f1 -> - walkFn content (f1, Bool.false) \(f2, prependSep), elem -> +dbg_init : {} -> DbgFormatter +dbg_init = \{} -> @DbgFormatter({ data: "" }) + +dbg_list : list, ElemWalker (DbgFormatter, Bool) list elem, (elem -> Inspector DbgFormatter) -> Inspector DbgFormatter +dbg_list = \content, walk_fn, to_dbg_inspector -> + custom_list_dbg = \f0 -> + f1 = dbg_write(f0, "[") + (f5, _) = walk_fn( + content, + (f1, Bool.false), + \(f2, prepend_sep), elem -> f3 = - if prependSep then - dbgWrite f2 ", " + if prepend_sep then + dbg_write(f2, ", ") else f2 elem - |> toDbgInspector - |> apply f3 - |> \f4 -> (f4, Bool.true) - |> .0 - |> dbgWrite "]" - -dbgSet : set, ElemWalker (DbgFormatter, Bool) set elem, (elem -> Inspector DbgFormatter) -> Inspector DbgFormatter -dbgSet = \content, walkFn, toDbgInspector -> - custom \f0 -> - dbgWrite f0 "{" - |> \f1 -> - walkFn content (f1, Bool.false) \(f2, prependSep), elem -> + |> to_dbg_inspector + |> apply(f3) + |> \f4 -> (f4, Bool.true), + ) + + dbg_write(f5, "]") + + custom(custom_list_dbg) + +dbg_set : set, ElemWalker (DbgFormatter, Bool) set elem, (elem -> Inspector DbgFormatter) -> Inspector DbgFormatter +dbg_set = \content, walk_fn, to_dbg_inspector -> + custom_dbg_set = \f0 -> + f1 = dbg_write(f0, "{") + (f5, _) = walk_fn( + content, + (f1, Bool.false), + \(f2, prepend_sep), elem -> f3 = - if prependSep then - dbgWrite f2 ", " + if prepend_sep then + dbg_write(f2, ", ") else f2 elem - |> toDbgInspector - |> apply f3 - |> \f4 -> (f4, Bool.true) - |> .0 - |> dbgWrite "}" - -dbgDict : dict, KeyValWalker (DbgFormatter, Bool) dict key value, (key -> Inspector DbgFormatter), (value -> Inspector DbgFormatter) -> Inspector DbgFormatter -dbgDict = \d, walkFn, keyToInspector, valueToInspector -> - custom \f0 -> - dbgWrite f0 "{" - |> \f1 -> - walkFn d (f1, Bool.false) \(f2, prependSep), key, value -> + |> to_dbg_inspector + |> apply(f3) + |> \f4 -> (f4, Bool.true), + ) + + dbg_write(f5, "}") + + custom(custom_dbg_set) + +dbg_dict : dict, KeyValWalker (DbgFormatter, Bool) dict key value, (key -> Inspector DbgFormatter), (value -> Inspector DbgFormatter) -> Inspector DbgFormatter +dbg_dict = \d, walk_fn, key_to_inspector, value_to_inspector -> + custom_dbg_dict = \f0 -> + f1 = dbg_write(f0, "{") + (f5, _) = walk_fn( + d, + (f1, Bool.false), + \(f2, prepend_sep), key, value -> f3 = - if prependSep then - dbgWrite f2 ", " + if prepend_sep then + dbg_write(f2, ", ") else f2 - apply (keyToInspector key) f3 - |> dbgWrite ": " - |> \x -> apply (valueToInspector value) x - |> \f4 -> (f4, Bool.true) - |> .0 - |> dbgWrite "}" - -dbgTag : Str, List (Inspector DbgFormatter) -> Inspector DbgFormatter -dbgTag = \name, fields -> - if List.isEmpty fields then - custom \f0 -> - dbgWrite f0 name + apply(key_to_inspector(key), f3) + |> dbg_write(": ") + |> \x -> apply(value_to_inspector(value), x) + |> \f4 -> (f4, Bool.true), + ) + + dbg_write(f5, "}") + + custom(custom_dbg_dict) + +dbg_tag : Str, List (Inspector DbgFormatter) -> Inspector DbgFormatter +dbg_tag = \name, fields -> + if List.is_empty(fields) then + custom(\f0 -> dbg_write(f0, name)) else - custom \f0 -> - dbgWrite f0 "(" - |> dbgWrite name - |> \f1 -> - List.walk fields f1 \f2, inspector -> - dbgWrite f2 " " - |> \x -> apply inspector x - |> dbgWrite ")" - -dbgTuple : List (Inspector DbgFormatter) -> Inspector DbgFormatter -dbgTuple = \fields -> - custom \f0 -> - dbgWrite f0 "(" - |> \f1 -> - List.walk fields (f1, Bool.false) \(f2, prependSep), inspector -> + custom_dbg_tag = \f0 -> + f1 = + dbg_write(f0, "(") + |> dbg_write(name) + + f3 = List.walk( + fields, + f1, + \f2, inspector -> + dbg_write(f2, " ") + |> \x -> apply(inspector, x), + ) + + dbg_write(f3, ")") + + custom(custom_dbg_tag) + +dbg_tuple : List (Inspector DbgFormatter) -> Inspector DbgFormatter +dbg_tuple = \fields -> + custom_dbg_tuple = \f0 -> + f1 = dbg_write(f0, "(") + (f5, _) = List.walk( + fields, + (f1, Bool.false), + \(f2, prepend_sep), inspector -> f3 = - if prependSep then - dbgWrite f2 ", " + if prepend_sep then + dbg_write(f2, ", ") else f2 - apply inspector f3 - |> \f4 -> (f4, Bool.true) - |> .0 - |> dbgWrite ")" - -dbgRecord : List { key : Str, value : Inspector DbgFormatter } -> Inspector DbgFormatter -dbgRecord = \fields -> - custom \f0 -> - dbgWrite f0 "{" - |> \f1 -> - List.walk fields (f1, Bool.false) \(f2, prependSep), { key, value } -> + apply(inspector, f3) + |> \f4 -> (f4, Bool.true), + ) + + dbg_write(f5, ")") + + custom(custom_dbg_tuple) + +dbg_record : List { key : Str, value : Inspector DbgFormatter } -> Inspector DbgFormatter +dbg_record = \fields -> + custom_dbg_record = \f0 -> + f1 = dbg_write(f0, "{") + (f5, _) = List.walk( + fields, + (f1, Bool.false), + \(f2, prepend_sep), { key, value } -> f3 = - if prependSep then - dbgWrite f2 ", " + if prepend_sep then + dbg_write(f2, ", ") else f2 - dbgWrite f3 key - |> dbgWrite ": " - |> \x -> apply value x - |> \f4 -> (f4, Bool.true) - |> .0 - |> dbgWrite "}" - -dbgBool : Bool -> Inspector DbgFormatter -dbgBool = \b -> - if b then - custom \f0 -> - dbgWrite f0 "Bool.true" - else - custom \f0 -> - dbgWrite f0 "Bool.false" - -dbgStr : Str -> Inspector DbgFormatter -dbgStr = \s -> - custom \f0 -> - f0 - |> dbgWrite "\"" - |> \f1 -> - # escape invisible unicode characters as in fmt_str_body crates/compiler/fmt/src/expr.rs - escapeS = - Str.replaceEach s "\u(feff)" "\\u(feff)" - |> Str.replaceEach "\u(200b)" "\\u(200b)" - |> Str.replaceEach "\u(200c)" "\\u(200c)" - |> Str.replaceEach "\u(200d)" "\\u(200d)" - dbgWrite f1 escapeS - |> dbgWrite "\"" - -dbgOpaque : * -> Inspector DbgFormatter -dbgOpaque = \_ -> - custom \f0 -> - dbgWrite f0 "" - -dbgFunction : * -> Inspector DbgFormatter -dbgFunction = \_ -> - custom \f0 -> - dbgWrite f0 "" - -dbgU8 : U8 -> Inspector DbgFormatter -dbgU8 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgI8 : I8 -> Inspector DbgFormatter -dbgI8 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgU16 : U16 -> Inspector DbgFormatter -dbgU16 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgI16 : I16 -> Inspector DbgFormatter -dbgI16 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgU32 : U32 -> Inspector DbgFormatter -dbgU32 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgI32 : I32 -> Inspector DbgFormatter -dbgI32 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgU64 : U64 -> Inspector DbgFormatter -dbgU64 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgI64 : I64 -> Inspector DbgFormatter -dbgI64 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgU128 : U128 -> Inspector DbgFormatter -dbgU128 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgI128 : I128 -> Inspector DbgFormatter -dbgI128 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgF32 : F32 -> Inspector DbgFormatter -dbgF32 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgF64 : F64 -> Inspector DbgFormatter -dbgF64 = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgDec : Dec -> Inspector DbgFormatter -dbgDec = \num -> - custom \f0 -> - dbgWrite f0 (num |> Num.toStr) - -dbgWrite : DbgFormatter, Str -> DbgFormatter -dbgWrite = \@DbgFormatter { data }, added -> - @DbgFormatter { data: Str.concat data added } - -toDbgStr : DbgFormatter -> Str -toDbgStr = \@DbgFormatter { data } -> data + dbg_write(f3, key) + |> dbg_write(": ") + |> \x -> apply(value, x) + |> \f4 -> (f4, Bool.true), + ) + + dbg_write(f5, "}") + + custom(custom_dbg_record) + +dbg_bool : Bool -> Inspector DbgFormatter +dbg_bool = \b -> + text = if b then "Bool.true" else "Bool.false" + custom(\f0 -> dbg_write(f0, text)) + +dbg_str : Str -> Inspector DbgFormatter +dbg_str = \s -> + # escape invisible unicode characters as in fmt_str_body crates/compiler/fmt/src/expr.rs + escape_s = + Str.replace_each(s, "\u(feff)", "\\u(feff)") + |> Str.replace_each("\u(200b)", "\\u(200b)") + |> Str.replace_each("\u(200c)", "\\u(200c)") + |> Str.replace_each("\u(200d)", "\\u(200d)") + + custom_dbg_str = \f0 -> + dbg_write(f0, "\"") + |> dbg_write(escape_s) + |> dbg_write("\"") + + custom(custom_dbg_str) + +dbg_opaque : * -> Inspector DbgFormatter +dbg_opaque = \_ -> + custom(\f0 -> dbg_write(f0, "")) + +dbg_function : * -> Inspector DbgFormatter +dbg_function = \_ -> + custom(\f0 -> dbg_write(f0, "")) + +dbg_u8 : U8 -> Inspector DbgFormatter +dbg_u8 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_i8 : I8 -> Inspector DbgFormatter +dbg_i8 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_u16 : U16 -> Inspector DbgFormatter +dbg_u16 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_i16 : I16 -> Inspector DbgFormatter +dbg_i16 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_u32 : U32 -> Inspector DbgFormatter +dbg_u32 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_i32 : I32 -> Inspector DbgFormatter +dbg_i32 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_u64 : U64 -> Inspector DbgFormatter +dbg_u64 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_i64 : I64 -> Inspector DbgFormatter +dbg_i64 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_u128 : U128 -> Inspector DbgFormatter +dbg_u128 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_i128 : I128 -> Inspector DbgFormatter +dbg_i128 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_f32 : F32 -> Inspector DbgFormatter +dbg_f32 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_f64 : F64 -> Inspector DbgFormatter +dbg_f64 = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_dec : Dec -> Inspector DbgFormatter +dbg_dec = \num -> + custom(\f0 -> dbg_write(f0, Num.to_str(num))) + +dbg_write : DbgFormatter, Str -> DbgFormatter +dbg_write = \@DbgFormatter({ data }), added -> + @DbgFormatter({ data: Str.concat(data, added) }) + +to_dbg_str : DbgFormatter -> Str +to_dbg_str = \@DbgFormatter({ data }) -> data diff --git a/crates/compiler/builtins/roc/List.roc b/crates/compiler/builtins/roc/List.roc index 8d1875fecec..efba31324d3 100644 --- a/crates/compiler/builtins/roc/List.roc +++ b/crates/compiler/builtins/roc/List.roc @@ -1,79 +1,79 @@ module [ - isEmpty, + is_empty, get, set, replace, update, append, - appendIfOk, + append_if_ok, prepend, - prependIfOk, + prepend_if_ok, map, len, - withCapacity, - walkBackwards, + with_capacity, + walk_backwards, concat, first, single, repeat, reverse, join, - keepIf, + keep_if, contains, sum, walk, last, - keepOks, - keepErrs, - mapWithIndex, + keep_oks, + keep_errs, + map_with_index, map2, map3, product, - walkWithIndex, - walkUntil, - walkWithIndexUntil, - walkFrom, - walkFromUntil, + walk_with_index, + walk_until, + walk_with_index_until, + walk_from, + walk_from_until, range, - sortWith, + sort_with, swap, - dropAt, + drop_at, min, max, map4, - mapTry, - walkTry, - joinMap, + map_try, + walk_try, + join_map, any, - takeFirst, - takeLast, - dropFirst, - dropLast, - findFirst, - findLast, - findFirstIndex, - findLastIndex, + take_first, + take_last, + drop_first, + drop_last, + find_first, + find_last, + find_first_index, + find_last_index, sublist, intersperse, - splitAt, - splitOn, - splitOnList, - splitFirst, - splitLast, - startsWith, - endsWith, + split_at, + split_on, + split_on_list, + split_first, + split_last, + starts_with, + ends_with, all, - dropIf, - sortAsc, - sortDesc, + drop_if, + sort_asc, + sort_desc, reserve, - releaseExcessCapacity, - walkBackwardsUntil, - countIf, - chunksOf, - concatUtf8, - forEach!, - forEachTry!, + release_excess_capacity, + walk_backwards_until, + count_if, + chunks_of, + concat_utf8, + for_each!, + for_each_try!, walk!, ] @@ -95,8 +95,8 @@ import Num exposing [U64, Num, U8] ## is normally enabled, not having enough memory could result in the list appearing ## to be created just fine, but then crashing later.) ## -## > The theoretical maximum length for a list created in Roc is `Num.maxI32` on 32-bit systems -## > and `Num.maxI64` on 64-bit systems. Attempting to create a list bigger than that +## > The theoretical maximum length for a list created in Roc is `Num.max_i32` on 32-bit systems +## > and `Num.max_i64` on 64-bit systems. Attempting to create a list bigger than that ## > in Roc code will always fail, although in practice it is likely to fail ## > at much smaller lengths due to insufficient memory being available. ## @@ -130,34 +130,34 @@ import Num exposing [U64, Num, U8] ## ## Let's turn this example into a function. ## ```roc -## getRatings = \first -> +## get_ratings = \first -> ## ratings = [first, 4, 3] ## ## { foo: ratings, bar: ratings } ## -## getRatings 5 +## get_ratings(5) ## ``` -## At the end of the `getRatings` function, when the record gets returned, +## At the end of the `get_ratings` function, when the record gets returned, ## the original `ratings =` binding has gone out of scope and is no longer ## accessible. (Trying to reference `ratings` outside the scope of the -## `getRatings` function would be an error!) +## `get_ratings` function would be an error!) ## ## Since `ratings` represented a way to reference the list, and that way is no ## longer accessible, the list's refcount gets decremented when `ratings` goes ## out of scope. It will decrease from 3 back down to 2. ## -## Putting these together, when we call `getRatings 5`, what we get back is +## Putting these together, when we call `get_ratings(5)`, what we get back is ## a record with two fields, `foo`, and `bar`, each of which refers to the same ## list, and that list has a refcount of 2. ## -## Let's change the last line to be `(getRatings 5).bar` instead of `getRatings 5`: +## Let's change the last line to be `get_ratings(5).bar` instead of `get_ratings(5)`: ## ```roc -## getRatings = \first -> +## get_ratings = \first -> ## ratings = [first, 4, 3] ## ## { foo: ratings, bar: ratings } ## -## (getRatings 5).bar +## get_ratings(5).bar ## ``` ## Now, when this expression returns, only the `bar` field of the record will ## be returned. This will mean that the `foo` field becomes inaccessible, causing @@ -166,7 +166,7 @@ import Num exposing [U64, Num, U8] ## ## Finally let's suppose the final line were changed to this: ## ```roc -## List.first (getRatings 5).bar +## List.first(get_ratings(5).bar) ## ``` ## This call to [List.first] means that even the list in the `bar` field has become ## inaccessible. As such, this line will cause the list's refcount to get @@ -181,8 +181,8 @@ import Num exposing [U64, Num, U8] ## ```roc ## nums = [1, 2, 3, 4, 5, 6, 7] ## -## first = List.first nums -## last = List.last nums +## first = List.first(nums) +## last = List.last(nums) ## ## first ## ``` @@ -192,8 +192,8 @@ import Num exposing [U64, Num, U8] ## ```roc ## lists = [[1], [2, 3], [], [4, 5, 6, 7]] ## -## first = List.first lists -## last = List.last lists +## first = List.first(lists) +## last = List.last(lists) ## ## first ## ``` @@ -213,66 +213,66 @@ import Num exposing [U64, Num, U8] ## At the end, we once again call [List.first] on the list, but this time ## ## * Copying small lists (64 elements or fewer) is typically slightly faster than copying small persistent data structures. This is because, at small sizes, persistent data structures tend to be thin wrappers around flat arrays anyway. They don't have any copying advantage until crossing a certain minimum size threshold. -## * Even when copying is faster, other list operations may still be slightly slower with persistent data structures. For example, even if it were a persistent data structure, [List.map], [List.walk], and [List.keepIf] would all need to traverse every element in the list and build up the result from scratch. These operations are all -## * Roc's compiler optimizes many list operations into in-place mutations behind the scenes, depending on how the list is being used. For example, [List.map], [List.keepIf], and [List.set] can all be optimized to perform in-place mutations. +## * Even when copying is faster, other list operations may still be slightly slower with persistent data structures. For example, even if it were a persistent data structure, [List.map], [List.walk], and [List.keep_if] would all need to traverse every element in the list and build up the result from scratch. These operations are all +## * Roc's compiler optimizes many list operations into in-place mutations behind the scenes, depending on how the list is being used. For example, [List.map], [List.keep_if], and [List.set] can all be optimized to perform in-place mutations. ## * If possible, it is usually best for performance to use large lists in a way where the optimizer can turn them into in-place mutations. If this is not possible, a persistent data structure might be faster - but this is a rare enough scenario that it would not be good for the average Roc program's performance if this were the way [List] worked by default. Instead, you can look outside Roc's standard modules for an implementation of a persistent data structure - likely built using [List] under the hood! -# separator so List.isEmpty doesn't absorb the above into its doc comment +# separator so List.is_empty doesn't absorb the above into its doc comment ## Check if the list is empty. ## ```roc -## List.isEmpty [1, 2, 3] +## List.is_empty([1, 2, 3]) ## -## List.isEmpty [] +## List.is_empty([]) ## ``` -isEmpty : List * -> Bool -isEmpty = \list -> - List.len list == 0 +is_empty : List * -> Bool +is_empty = \list -> + List.len(list) == 0 # unsafe primitive that does not perform a bounds check # but will cause a reference count increment on the value it got out of the list -getUnsafe : List a, U64 -> a +get_unsafe : List a, U64 -> a ## Returns an element from a list at the given index. ## ## Returns `Err OutOfBounds` if the given index exceeds the List's length ## ```roc -## expect List.get [100, 200, 300] 1 == Ok 200 -## expect List.get [100, 200, 300] 5 == Err OutOfBounds +## expect List.get([100, 200, 300], 1) == Ok(200) +## expect List.get([100, 200, 300], 5) == Err(OutOfBounds) ## ``` get : List a, U64 -> Result a [OutOfBounds] get = \list, index -> - if index < List.len list then - Ok (List.getUnsafe list index) + if index < List.len(list) then + Ok(List.get_unsafe(list, index)) else - Err OutOfBounds + Err(OutOfBounds) # unsafe primitive that does not perform a bounds check # but will cause a reference count increment on the value it got out of the list -replaceUnsafe : List a, U64, a -> { list : List a, value : a } +replace_unsafe : List a, U64, a -> { list : List a, value : a } replace : List a, U64, a -> { list : List a, value : a } -replace = \list, index, newValue -> - if index < List.len list then - List.replaceUnsafe list index newValue +replace = \list, index, new_value -> + if index < List.len(list) then + List.replace_unsafe(list, index, new_value) else - { list, value: newValue } + { list, value: new_value } ## Replaces the element at the given index with a replacement. ## ```roc -## List.set ["a", "b", "c"] 1 "B" +## List.set(["a", "b", "c"], 1, "B") ## ``` ## If the given index is outside the bounds of the list, returns the original ## list unmodified. ## -## To drop the element at a given index, instead of replacing it, see [List.dropAt]. +## To drop the element at a given index, instead of replacing it, see [List.drop_at]. set : List a, U64, a -> List a set = \list, index, value -> - (List.replace list index value).list + (List.replace(list, index, value)).list ## Updates the element at the given index with the given function. ## ```roc -## List.update [1, 2, 3] 1 (\x -> x + 1) +## List.update([1, 2, 3], 1, (\x -> x + 1)) ## ``` ## If the given index is outside the bounds of the list, returns the original ## list unmodified. @@ -281,17 +281,17 @@ set = \list, index, value -> ## see [List.set] and [List.replace] update : List a, U64, (a -> a) -> List a update = \list, index, func -> - when List.get list index is - Err OutOfBounds -> list - Ok value -> - newValue = func value - (replaceUnsafe list index newValue).list + when List.get(list, index) is + Err(OutOfBounds) -> list + Ok(value) -> + new_value = func(value) + (replace_unsafe(list, index, new_value)).list # Update one element in bounds expect list : List U64 list = [1, 2, 3] - got = update list 1 (\x -> x + 42) + got = update(list, 1, \x -> x + 42) want = [1, 44, 3] got == want @@ -299,7 +299,7 @@ expect expect list : List U64 list = [1, 2, 3] - got = update list 5 (\x -> x + 42) + got = update(list, 5, \x -> x + 42) got == list # Update chain @@ -308,53 +308,53 @@ expect list = [1, 2, 3] got = list - |> update 0 (\x -> x + 10) - |> update 1 (\x -> x + 20) - |> update 2 (\x -> x + 30) + |> update(0, \x -> x + 10) + |> update(1, \x -> x + 20) + |> update(2, \x -> x + 30) want = [11, 22, 33] got == want ## Add a single element to the end of a list. ## ```roc -## List.append [1, 2, 3] 4 +## List.append([1, 2, 3], 4) ## ## [0, 1, 2] -## |> List.append 3 +## |> List.append(3) ## ``` append : List a, a -> List a append = \list, element -> list - |> List.reserve 1 - |> List.appendUnsafe element + |> List.reserve(1) + |> List.append_unsafe(element) ## If the given [Result] is `Ok`, add it to the end of a list. ## Otherwise, return the list unmodified. ## ## ```roc -## List.appendIfOk [1, 2, 3] (Ok 4) +## List.append_if_ok([1, 2, 3], Ok(4)) ## ## [0, 1, 2] -## |> List.appendIfOk (Err 3) +## |> List.append_if_ok(Err(3)) ## ``` -appendIfOk : List a, Result a * -> List a -appendIfOk = \list, result -> +append_if_ok : List a, Result a * -> List a +append_if_ok = \list, result -> when result is - Ok elem -> append list elem - Err _ -> list + Ok(elem) -> append(list, elem) + Err(_) -> list ## Writes the element after the current last element unconditionally. ## In other words, it is assumed that ## -## - the list is owned (i.e. can be updated in-place +## - the list is owned (i.e. can be updated in-place) ## - the list has at least one element of spare capacity -appendUnsafe : List a, a -> List a +append_unsafe : List a, a -> List a ## Add a single element to the beginning of a list. ## ```roc -## List.prepend [1, 2, 3] 0 +## List.prepend([1, 2, 3], 0) ## ## [2, 3, 4] -## |> List.prepend 1 +## |> List.prepend(1) ## ``` prepend : List a, a -> List a @@ -362,59 +362,59 @@ prepend : List a, a -> List a ## Otherwise, return the list unmodified. ## ## ```roc -## List.prepend [1, 2, 3] (Ok 0) +## List.prepend([1, 2, 3], Ok(0)) ## ## [2, 3, 4] -## |> List.prepend (Err 1) +## |> List.prepend(Err(1)) ## ``` -prependIfOk : List a, Result a * -> List a -prependIfOk = \list, result -> +prepend_if_ok : List a, Result a * -> List a +prepend_if_ok = \list, result -> when result is - Ok elem -> prepend list elem - Err _ -> list + Ok(elem) -> prepend(list, elem) + Err(_) -> list ## Returns the length of the list - the number of elements it contains. ## -## One [List] can store up to `Num.maxI64` elements on 64-bit targets and `Num.maxI32` on 32-bit targets like wasm. +## One [List] can store up to `Num.max_i64` elements on 64-bit targets and `Num.max_i32` on 32-bit targets like wasm. ## This means the #U64 this function returns can always be safely converted to #I64 or #I32, depending on the target. len : List * -> U64 ## Create a list with space for at least capacity elements -withCapacity : U64 -> List * +with_capacity : U64 -> List * ## Enlarge the list for at least capacity additional elements reserve : List a, U64 -> List a ## Shrink the memory footprint of a list such that it's capacity and length are equal. ## Note: This will also convert seamless slices to regular lists. -releaseExcessCapacity : List a -> List a +release_excess_capacity : List a -> List a ## Put two lists together. ## ```roc -## List.concat [1, 2, 3] [4, 5] +## List.concat([1, 2, 3], [4, 5]) ## ## [0, 1, 2] -## |> List.concat [3, 4] +## |> List.concat([3, 4]) ## ``` concat : List a, List a -> List a ## Returns the last element in the list, or `ListWasEmpty` if it was empty. ## ```roc -## expect List.last [1, 2, 3] == Ok 3 -## expect List.last [] == Err ListWasEmpty +## expect List.last([1, 2, 3]) == Ok(3) +## expect List.last([]) == Err(ListWasEmpty) ## ``` last : List a -> Result a [ListWasEmpty] last = \list -> - when List.get list (Num.subSaturated (List.len list) 1) is - Ok v -> Ok v - Err _ -> Err ListWasEmpty + when List.get(list, Num.sub_saturated(List.len(list), 1)) is + Ok(v) -> Ok(v) + Err(_) -> Err(ListWasEmpty) ## A list with a single element in it. ## ## This is useful in pipelines, like so: ## ```roc ## websites = -## Str.concat domain ".com" +## Str.concat(domain, ".com") ## |> List.single ## ``` single : a -> List a @@ -423,27 +423,27 @@ single = \x -> [x] ## Returns a list with the given length, where every element is the given value. repeat : a, U64 -> List a repeat = \value, count -> - repeatHelp value count (List.withCapacity count) + repeat_help(value, count, List.with_capacity(count)) -repeatHelp : a, U64, List a -> List a -repeatHelp = \value, count, accum -> +repeat_help : a, U64, List a -> List a +repeat_help = \value, count, accum -> if count > 0 then - repeatHelp value (Num.subWrap count 1) (List.appendUnsafe accum value) + repeat_help(value, Num.sub_wrap(count, 1), List.append_unsafe(accum, value)) else accum ## Returns the list with its elements reversed. ## ```roc -## expect List.reverse [1, 2, 3] == [3, 2, 1] +## expect List.reverse([1, 2, 3]) == [3, 2, 1] ## ``` reverse : List a -> List a reverse = \list -> - end = List.len list |> Num.subSaturated 1 - reverseHelp (List.clone list) 0 end + end = List.len(list) |> Num.sub_saturated(1) + reverse_help(List.clone(list), 0, end) -reverseHelp = \list, left, right -> +reverse_help = \list, left, right -> if left < right then - reverseHelp (List.swap list left right) (Num.addWrap left 1) (Num.subWrap right 1) + reverse_help(List.swap(list, left, right), Num.add_wrap(left, 1), Num.sub_wrap(right, 1)) else list @@ -452,20 +452,20 @@ clone : List a -> List a ## Join the given lists together into one list. ## ```roc -## expect List.join [[1], [2, 3], [], [4, 5]] == [1, 2, 3, 4, 5] -## expect List.join [[], []] == [] -## expect List.join [] == [] +## expect List.join([[1], [2, 3], [], [4, 5]]) == [1, 2, 3, 4, 5] +## expect List.join([[], []]) == [] +## expect List.join([]) == [] ## ``` join : List (List a) -> List a join = \lists -> - totalLength = - List.walk lists 0 (\state, list -> Num.addWrap state (List.len list)) + total_length = + List.walk(lists, 0, \state, list -> Num.add_wrap(state, List.len(list))) - List.walk lists (List.withCapacity totalLength) \state, list -> List.concat state list + List.walk(lists, List.with_capacity(total_length), \state, list -> List.concat(state, list)) contains : List a, a -> Bool where a implements Eq contains = \list, needle -> - List.any list (\x -> x == needle) + List.any(list, \x -> x == needle) ## Build a value using each element in the list. ## @@ -476,11 +476,11 @@ contains = \list, needle -> ## You can use it in a pipeline: ## ```roc ## [2, 4, 8] -## |> List.walk 0 Num.add +## |> List.walk(0, Num.add) ## ``` ## This returns 14 because: ## * `state` starts at 0 -## * Each `step` runs `Num.add state elem`, and the return value becomes the new `state`. +## * Each `step` runs `Num.add(state, elem)`, and the return value becomes the new `state`. ## ## Here is a table of how `state` changes as [List.walk] walks over the elements ## `[2, 4, 8]` using [Num.add] as its `step` function to determine the next `state`. @@ -495,74 +495,74 @@ contains = \list, needle -> ## The following returns -6: ## ```roc ## [1, 2, 3] -## |> List.walk 0 Num.sub +## |> List.walk(0, Num.sub) ## ``` ## Note that in other languages, `walk` is sometimes called `reduce`, -## `fold`, `foldLeft`, or `foldl`. +## `fold`, `fold_left`, or `foldl`. walk : List elem, state, (state, elem -> state) -> state walk = \list, init, func -> - walkHelp list init func 0 (List.len list) + walk_help(list, init, func, 0, List.len(list)) ## internal helper -walkHelp : List elem, s, (s, elem -> s), U64, U64 -> s -walkHelp = \list, state, f, index, length -> +walk_help : List elem, s, (s, elem -> s), U64, U64 -> s +walk_help = \list, state, f, index, length -> if index < length then - nextState = f state (List.getUnsafe list index) + next_state = f(state, List.get_unsafe(list, index)) - walkHelp list nextState f (Num.addWrap index 1) length + walk_help(list, next_state, f, Num.add_wrap(index, 1), length) else state ## Like [walk], but at each step the function also receives the index of the current element. -walkWithIndex : List elem, state, (state, elem, U64 -> state) -> state -walkWithIndex = \list, init, func -> - walkWithIndexHelp list init func 0 (List.len list) +walk_with_index : List elem, state, (state, elem, U64 -> state) -> state +walk_with_index = \list, init, func -> + walk_with_index_help(list, init, func, 0, List.len(list)) ## internal helper -walkWithIndexHelp : List elem, s, (s, elem, U64 -> s), U64, U64 -> s -walkWithIndexHelp = \list, state, f, index, length -> +walk_with_index_help : List elem, s, (s, elem, U64 -> s), U64, U64 -> s +walk_with_index_help = \list, state, f, index, length -> if index < length then - nextState = f state (List.getUnsafe list index) index + next_state = f(state, List.get_unsafe(list, index), index) - walkWithIndexHelp list nextState f (Num.addWrap index 1) length + walk_with_index_help(list, next_state, f, Num.add_wrap(index, 1), length) else state -## Like [walkUntil], but at each step the function also receives the index of the current element. -walkWithIndexUntil : List elem, state, (state, elem, U64 -> [Continue state, Break state]) -> state -walkWithIndexUntil = \list, state, f -> - when walkWithIndexUntilHelp list state f 0 (List.len list) is - Continue new -> new - Break new -> new +## Like [walk_until], but at each step the function also receives the index of the current element. +walk_with_index_until : List elem, state, (state, elem, U64 -> [Continue state, Break state]) -> state +walk_with_index_until = \list, state, f -> + when walk_with_index_until_help(list, state, f, 0, List.len(list)) is + Continue(new) -> new + Break(new) -> new ## internal helper -walkWithIndexUntilHelp : List elem, s, (s, elem, U64 -> [Continue s, Break b]), U64, U64 -> [Continue s, Break b] -walkWithIndexUntilHelp = \list, state, f, index, length -> +walk_with_index_until_help : List elem, s, (s, elem, U64 -> [Continue s, Break b]), U64, U64 -> [Continue s, Break b] +walk_with_index_until_help = \list, state, f, index, length -> if index < length then - when f state (List.getUnsafe list index) index is - Continue nextState -> - walkWithIndexUntilHelp list nextState f (Num.addWrap index 1) length + when f(state, List.get_unsafe(list, index), index) is + Continue(next_state) -> + walk_with_index_until_help(list, next_state, f, Num.add_wrap(index, 1), length) - Break b -> Break b + Break(b) -> Break(b) else - Continue state + Continue(state) -## Note that in other languages, `walkBackwards` is sometimes called `reduceRight`, -## `fold`, `foldRight`, or `foldr`. -walkBackwards : List elem, state, (state, elem -> state) -> state -walkBackwards = \list, state, func -> - walkBackwardsHelp list state func (len list) +## Note that in other languages, `walk_backwards` is sometimes called `reduce_right`, +## `fold`, `fold_right`, or `foldr`. +walk_backwards : List elem, state, (state, elem -> state) -> state +walk_backwards = \list, state, func -> + walk_backwards_help(list, state, func, len(list)) ## internal helper -walkBackwardsHelp : List elem, state, (state, elem -> state), U64 -> state -walkBackwardsHelp = \list, state, f, indexPlusOne -> - if indexPlusOne == 0 then +walk_backwards_help : List elem, state, (state, elem -> state), U64 -> state +walk_backwards_help = \list, state, f, index_plus_one -> + if index_plus_one == 0 then state else - index = Num.subWrap indexPlusOne 1 - nextState = f state (getUnsafe list index) + index = Num.sub_wrap(index_plus_one, 1) + next_state = f(state, get_unsafe(list, index)) - walkBackwardsHelp list nextState f index + walk_backwards_help(list, next_state, f, index) ## Same as [List.walk], except you can stop walking early. ## @@ -575,79 +575,79 @@ walkBackwardsHelp = \list, state, f, indexPlusOne -> ## ## As such, it is typically better for performance to use this over [List.walk] ## if returning `Break` earlier than the last element is expected to be common. -walkUntil : List elem, state, (state, elem -> [Continue state, Break state]) -> state -walkUntil = \list, initial, step -> - when List.iterate list initial step is - Continue new -> new - Break new -> new - -## Same as [List.walkUntil], but does it from the end of the list instead. -walkBackwardsUntil : List elem, state, (state, elem -> [Continue state, Break state]) -> state -walkBackwardsUntil = \list, initial, func -> - when List.iterateBackwards list initial func is - Continue new -> new - Break new -> new +walk_until : List elem, state, (state, elem -> [Continue state, Break state]) -> state +walk_until = \list, initial, step -> + when List.iterate(list, initial, step) is + Continue(new) -> new + Break(new) -> new + +## Same as [List.walk_until], but does it from the end of the list instead. +walk_backwards_until : List elem, state, (state, elem -> [Continue state, Break state]) -> state +walk_backwards_until = \list, initial, func -> + when List.iterate_backwards(list, initial, func) is + Continue(new) -> new + Break(new) -> new ## Walks to the end of the list from a specified starting index -walkFrom : List elem, U64, state, (state, elem -> state) -> state -walkFrom = \list, index, state, func -> +walk_from : List elem, U64, state, (state, elem -> state) -> state +walk_from = \list, index, state, func -> step : _, _ -> [Continue _, Break []] - step = \currentState, element -> Continue (func currentState element) + step = \current_state, element -> Continue(func(current_state, element)) - when List.iterHelp list state step index (List.len list) is - Continue new -> new + when List.iter_help(list, state, step, index, List.len(list)) is + Continue(new) -> new -## A combination of [List.walkFrom] and [List.walkUntil] -walkFromUntil : List elem, U64, state, (state, elem -> [Continue state, Break state]) -> state -walkFromUntil = \list, index, state, func -> - when List.iterHelp list state func index (List.len list) is - Continue new -> new - Break new -> new +## A combination of [List.walk_from] and [List.walk_until] +walk_from_until : List elem, U64, state, (state, elem -> [Continue state, Break state]) -> state +walk_from_until = \list, index, state, func -> + when List.iter_help(list, state, func, index, List.len(list)) is + Continue(new) -> new + Break(new) -> new sum : List (Num a) -> Num a sum = \list -> - List.walk list 0 Num.add + List.walk(list, 0, Num.add) product : List (Num a) -> Num a product = \list -> - List.walk list 1 Num.mul + List.walk(list, 1, Num.mul) ## Run the given predicate on each element of the list, returning `Bool.true` if ## any of the elements satisfy it. any : List a, (a -> Bool) -> Bool any = \list, predicate -> looper = \{}, element -> - if predicate element then - Break {} + if predicate(element) then + Break({}) else - Continue {} + Continue({}) - when List.iterate list {} looper is - Continue {} -> Bool.false - Break {} -> Bool.true + when List.iterate(list, {}, looper) is + Continue({}) -> Bool.false + Break({}) -> Bool.true ## Run the given predicate on each element of the list, returning `Bool.true` if ## all of the elements satisfy it. all : List a, (a -> Bool) -> Bool all = \list, predicate -> looper = \{}, element -> - if predicate element then - Continue {} + if predicate(element) then + Continue({}) else - Break {} + Break({}) - when List.iterate list {} looper is - Continue {} -> Bool.true - Break {} -> Bool.false + when List.iterate(list, {}, looper) is + Continue({}) -> Bool.true + Break({}) -> Bool.false ## Run the given function on each element of a list, and return all the ## elements for which the function returned `Bool.true`. ## ```roc -## List.keepIf [1, 2, 3, 4] (\num -> num > 2) +## List.keep_if([1, 2, 3, 4], (\num -> num > 2)) ## ``` ## ## Performance Details ## -## [List.keepIf] always returns a list that takes up exactly the same amount +## [List.keep_if] always returns a list that takes up exactly the same amount ## of memory as the original, even if its length decreases. This is because it ## can't know in advance exactly how much space it will need, and if it guesses a ## length that's too low, it would have to re-allocate. @@ -656,110 +656,111 @@ all = \list, predicate -> ## of the resulting list, you can do two passes over the list with [List.walk] - one ## to calculate the precise new size, and another to populate the new list.) ## -## If given a unique list, [List.keepIf] will mutate it in place to assemble the appropriate list. +## If given a unique list, [List.keep_if] will mutate it in place to assemble the appropriate list. ## If that happens, this function will not allocate any new memory on the heap. ## If all elements in the list end up being kept, Roc will return the original ## list unaltered. ## -keepIf : List a, (a -> Bool) -> List a -keepIf = \list, predicate -> - length = List.len list +keep_if : List a, (a -> Bool) -> List a +keep_if = \list, predicate -> + length = List.len(list) - keepIfHelp list predicate 0 0 length + keep_if_help(list, predicate, 0, 0, length) -keepIfHelp : List a, (a -> Bool), U64, U64, U64 -> List a -keepIfHelp = \list, predicate, kept, index, length -> +keep_if_help : List a, (a -> Bool), U64, U64, U64 -> List a +keep_if_help = \list, predicate, kept, index, length -> if index < length then - if predicate (List.getUnsafe list index) then - keepIfHelp (List.swap list kept index) predicate (Num.addWrap kept 1) (Num.addWrap index 1) length + if predicate(List.get_unsafe(list, index)) then + keep_if_help(List.swap(list, kept, index), predicate, Num.add_wrap(kept, 1), Num.add_wrap(index, 1), length) else - keepIfHelp list predicate kept (Num.addWrap index 1) length + keep_if_help(list, predicate, kept, Num.add_wrap(index, 1), length) else - List.takeFirst list kept + List.take_first(list, kept) ## Run the given function on each element of a list, and return all the ## elements for which the function returned `Bool.false`. ## ```roc -## List.dropIf [1, 2, 3, 4] (\num -> num > 2) +## List.drop_if([1, 2, 3, 4], (\num -> num > 2)) ## ``` ## ## Performance Details ## -## `List.dropIf` has the same performance characteristics as [List.keepIf]. +## `List.drop_if` has the same performance characteristics as [List.keep_if]. ## See its documentation for details on those characteristics! -dropIf : List a, (a -> Bool) -> List a -dropIf = \list, predicate -> - List.keepIf list (\e -> Bool.not (predicate e)) +drop_if : List a, (a -> Bool) -> List a +drop_if = \list, predicate -> + List.keep_if(list, \e -> Bool.not(predicate(e))) ## Run the given function on each element of a list, and return the ## number of elements for which the function returned `Bool.true`. ## ```roc -## expect List.countIf [1, -2, -3] Num.isNegative == 2 -## expect List.countIf [1, 2, 3] (\num -> num > 1 ) == 2 +## expect List.count_if([1, -2, -3], Num.is_negative) == 2 +## expect List.count_if([1, 2, 3], (\num -> num > 1)) == 2 ## ``` -countIf : List a, (a -> Bool) -> U64 -countIf = \list, predicate -> - walkState = \state, elem -> - if predicate elem then - Num.addWrap state 1 +count_if : List a, (a -> Bool) -> U64 +count_if = \list, predicate -> + walk_state = \state, elem -> + if predicate(elem) then + Num.add_wrap(state, 1) else state - List.walk list 0 walkState + List.walk(list, 0, walk_state) ## This works like [List.map], except only the transformed values that are ## wrapped in `Ok` are kept. Any that are wrapped in `Err` are dropped. ## ```roc -## expect List.keepOks ["1", "Two", "23", "Bird"] Str.toI32 == [1, 23] +## expect List.keep_oks(["1", "Two", "23", "Bird"], Str.to_i32) == [1, 23] ## -## expect List.keepOks [["a", "b"], [], ["c", "d", "e"], [] ] List.first == ["a", "c"] +## expect List.keep_oks([["a", "b"], [], ["c", "d", "e"], [] ], List.first) == ["a", "c"] ## -## fn = \str -> if Str.isEmpty str then Err StrWasEmpty else Ok str -## expect List.keepOks ["", "a", "bc", "", "d", "ef", ""] fn == ["a", "bc", "d", "ef"] +## fn = \str -> if Str.is_empty(str) then Err(StrWasEmpty) else Ok(str) +## expect List.keep_oks(["", "a", "bc", "", "d", "ef", ""], fn) == ["a", "bc", "d", "ef"] ## ``` -keepOks : List before, (before -> Result after *) -> List after -keepOks = \list, toResult -> +keep_oks : List before, (before -> Result after *) -> List after +keep_oks = \list, to_result -> walker = \accum, element -> - when toResult element is - Ok keep -> List.append accum keep - Err _drop -> accum + when to_result(element) is + Ok(keep) -> List.append(accum, keep) + Err(_drop) -> accum - List.walk list (List.withCapacity (List.len list)) walker + List.walk(list, List.with_capacity(List.len(list)), walker) ## This works like [List.map], except only the transformed values that are ## wrapped in `Err` are kept. Any that are wrapped in `Ok` are dropped. ## ```roc -## List.keepErrs [["a", "b"], [], [], ["c", "d", "e"]] List.last +## List.keep_errs([["a", "b"], [], [], ["c", "d", "e"]], List.last) ## -## fn = \str -> if Str.isEmpty str then Err StrWasEmpty else Ok (Str.len str) +## fn = \str -> if Str.is_empty(str) then Err(StrWasEmpty) else Okd(Str.len(str)) ## -## List.keepErrs ["", "a", "bc", "", "d", "ef", ""] +## List.keep_errs(["", "a", "bc", "", "d", "ef", ""], fn) ## ``` -keepErrs : List before, (before -> Result * after) -> List after -keepErrs = \list, toResult -> +keep_errs : List before, (before -> Result * after) -> List after +keep_errs = \list, to_result -> walker = \accum, element -> - when toResult element is - Ok _drop -> accum - Err keep -> List.append accum keep + when to_result(element) is + Ok(_drop) -> accum + Err(keep) -> List.append(accum, keep) - List.walk list (List.withCapacity (List.len list)) walker + List.walk(list, List.with_capacity(List.len(list)), walker) ## Convert each element in the list to something new, by calling a conversion ## function on each of them. Then return a new list of the converted values. ## ```roc -## expect List.map [1, 2, 3] (\num -> num + 1) == [2, 3, 4] +## expect List.map([1, 2, 3], (\num -> num + 1)) == [2, 3, 4] ## -## expect List.map ["", "a", "bc"] Str.isEmpty == [Bool.true, Bool.false, Bool.false] +## expect List.map(["", "a", "bc"], Str.is_empty) == [Bool.true, Bool.false, Bool.false] ## ``` map : List a, (a -> b) -> List b map = \list, mapper -> # TODO: allow checking the refcounting and running the map inplace. # Preferably allow it even if the types are different (must be same size with padding though). - length = List.len list - List.walk - list - (List.withCapacity length) + length = List.len(list) + List.walk( + list, + List.with_capacity(length), \state, elem -> - List.appendUnsafe state (mapper elem) + List.append_unsafe(state, mapper(elem)), + ) ## Run a transformation function on the first element of each list, ## and use that as the first element in the returned list. @@ -768,19 +769,19 @@ map = \list, mapper -> ## Some languages have a function named `zip`, which does something similar to ## calling [List.map2] passing two lists and `Pair`: ## ```roc -## zipped = List.map2 ["a", "b", "c"] [1, 2, 3] Pair +## zipped = List.map2(["a", "b", "c"], [1, 2, 3], Pair) ## ``` map2 : List a, List b, (a, b -> c) -> List c -map2 = \listA, listB, mapper -> - length = Num.min (List.len listA) (List.len listB) - map2Help listA listB (List.withCapacity length) mapper 0 length +map2 = \list_a, list_b, mapper -> + length = Num.min(List.len(list_a), List.len(list_b)) + map2_help(list_a, list_b, List.with_capacity(length), mapper, 0, length) -map2Help : List a, List b, List c, (a, b -> c), U64, U64 -> List c -map2Help = \listA, listB, out, mapper, index, length -> +map2_help : List a, List b, List c, (a, b -> c), U64, U64 -> List c +map2_help = \list_a, list_b, out, mapper, index, length -> if index < length then - mapped = mapper (List.getUnsafe listA index) (List.getUnsafe listB index) + mapped = mapper(List.get_unsafe(list_a, index), List.get_unsafe(list_b, index)) - map2Help listA listB (List.appendUnsafe out mapped) mapper (Num.addWrap index 1) length + map2_help(list_a, list_b, List.append_unsafe(out, mapped), mapper, Num.add_wrap(index, 1), length) else out @@ -788,18 +789,19 @@ map2Help = \listA, listB, out, mapper, index, length -> ## and use that as the first element in the returned list. ## Repeat until a list runs out of elements. map3 : List a, List b, List c, (a, b, c -> d) -> List d -map3 = \listA, listB, listC, mapper -> - length = Num.min - (Num.min (List.len listA) (List.len listB)) - (List.len listC) - map3Help listA listB listC (List.withCapacity length) mapper 0 length - -map3Help : List a, List b, List c, List d, (a, b, c -> d), U64, U64 -> List d -map3Help = \listA, listB, listC, out, mapper, index, length -> +map3 = \list_a, list_b, list_c, mapper -> + length = Num.min( + Num.min(List.len(list_a), List.len(list_b)), + List.len(list_c), + ) + map3_help(list_a, list_b, list_c, List.with_capacity(length), mapper, 0, length) + +map3_help : List a, List b, List c, List d, (a, b, c -> d), U64, U64 -> List d +map3_help = \list_a, list_b, list_c, out, mapper, index, length -> if index < length then - mapped = mapper (List.getUnsafe listA index) (List.getUnsafe listB index) (List.getUnsafe listC index) + mapped = mapper(List.get_unsafe(list_a, index), List.get_unsafe(list_b, index), List.get_unsafe(list_c, index)) - map3Help listA listB listC (List.appendUnsafe out mapped) mapper (Num.addWrap index 1) length + map3_help(list_a, list_b, list_c, List.append_unsafe(out, mapped), mapper, Num.add_wrap(index, 1), length) else out @@ -807,42 +809,43 @@ map3Help = \listA, listB, listC, out, mapper, index, length -> ## and use that as the first element in the returned list. ## Repeat until a list runs out of elements. map4 : List a, List b, List c, List d, (a, b, c, d -> e) -> List e -map4 = \listA, listB, listC, listD, mapper -> - length = Num.min - (Num.min (List.len listA) (List.len listB)) - (Num.min (List.len listC) (List.len listD)) - map4Help listA listB listC listD (List.withCapacity length) mapper 0 length - -map4Help : List a, List b, List c, List d, List e, (a, b, c, d -> e), U64, U64 -> List e -map4Help = \listA, listB, listC, listD, out, mapper, index, length -> +map4 = \list_a, list_b, list_c, list_d, mapper -> + length = Num.min( + Num.min(List.len(list_a), List.len(list_b)), + Num.min(List.len(list_c), List.len(list_d)), + ) + map4_help(list_a, list_b, list_c, list_d, List.with_capacity(length), mapper, 0, length) + +map4_help : List a, List b, List c, List d, List e, (a, b, c, d -> e), U64, U64 -> List e +map4_help = \list_a, list_b, list_c, list_d, out, mapper, index, length -> if index < length then - mapped = mapper (List.getUnsafe listA index) (List.getUnsafe listB index) (List.getUnsafe listC index) (List.getUnsafe listD index) + mapped = mapper(List.get_unsafe(list_a, index), List.get_unsafe(list_b, index), List.get_unsafe(list_c, index), List.get_unsafe(list_d, index)) - map4Help listA listB listC listD (List.append out mapped) mapper (Num.addWrap index 1) length + map4_help(list_a, list_b, list_c, list_d, List.append(out, mapped), mapper, Num.add_wrap(index, 1), length) else out ## This works like [List.map], except it also passes the index ## of the element to the conversion function. ## ```roc -## expect List.mapWithIndex [10, 20, 30] (\num, index -> num + index) == [10, 21, 32] +## expect List.map_with_index([10, 20, 30], (\num, index -> num + index)) == [10, 21, 32] ## ``` -mapWithIndex : List a, (a, U64 -> b) -> List b -mapWithIndex = \src, func -> - length = len src - dest = withCapacity length +map_with_index : List a, (a, U64 -> b) -> List b +map_with_index = \src, func -> + length = len(src) + dest = with_capacity(length) - mapWithIndexHelp src dest func 0 length + map_with_index_help(src, dest, func, 0, length) # Internal helper -mapWithIndexHelp : List a, List b, (a, U64 -> b), U64, U64 -> List b -mapWithIndexHelp = \src, dest, func, index, length -> +map_with_index_help : List a, List b, (a, U64 -> b), U64, U64 -> List b +map_with_index_help = \src, dest, func, index, length -> if index < length then - elem = getUnsafe src index - mappedElem = func elem index - newDest = List.appendUnsafe dest mappedElem + elem = get_unsafe(src, index) + mapped_elem = func(elem, index) + new_dest = List.append_unsafe(dest, mapped_elem) - mapWithIndexHelp src newDest func (Num.addWrap index 1) length + map_with_index_help(src, new_dest, func, Num.add_wrap(index, 1), length) else dest @@ -850,373 +853,373 @@ mapWithIndexHelp = \src, dest, func, index, length -> ## ## To include the `start` and `end` integers themselves, use `At` like so: ## ```roc -## List.range { start: At 2, end: At 5 } # returns [2, 3, 4, 5] +## List.range({ start: At 2, end: At 5 }) == [2, 3, 4, 5] ## ``` ## To exclude them, use `After` and `Before`, like so: ## ```roc -## List.range { start: After 2, end: Before 5 } # returns [3, 4] +## List.range({ start: After 2, end: Before 5 }) == [3, 4] ## ``` ## You can have the list end at a certain length rather than a certain integer: ## ```roc -## List.range { start: At 6, end: Length 4 } # returns [6, 7, 8, 9] +## List.range({ start: At 6, end: Length 4 }) == [6, 7, 8, 9] ## ``` ## If `step` is specified, each integer increases by that much. (`step: 1` is the default.) ## ```roc -## List.range { start: After 0, end: Before 9, step: 3 } # returns [3, 6] +## List.range({ start: After 0, end: Before 9, step: 3 }) == [3, 6] ## ``` ## List.range will also generate a reversed list if step is negative or end comes before start: ## ```roc -## List.range { start: At 5, end: At 2 } # returns [5, 4, 3, 2] +## List.range({ start: At 5, end: At 2 }) == [5, 4, 3, 2] ## ``` ## All of these options are compatible with the others. For example, you can use `At` or `After` ## with `start` regardless of what `end` and `step` are set to. range : _ range = \{ start, end, step ?? 0 } -> - { calcNext, stepIsPositive } = + { calc_next, step_is_positive } = if step == 0 then - when T start end is - T (At x) (At y) | T (At x) (Before y) | T (After x) (At y) | T (After x) (Before y) -> + when T(start, end) is + T(At(x), At(y)) | T(At(x), Before(y)) | T(After(x), At(y)) | T(After(x), Before(y)) -> if x < y then { - calcNext: \i -> Num.addChecked i 1, - stepIsPositive: Bool.true, + calc_next: \i -> Num.add_checked(i, 1), + step_is_positive: Bool.true, } else { - calcNext: \i -> Num.subChecked i 1, - stepIsPositive: Bool.false, + calc_next: \i -> Num.sub_checked(i, 1), + step_is_positive: Bool.false, } - T (At _) (Length _) | T (After _) (Length _) -> + T(At(_), Length(_)) | T(After(_), Length(_)) -> { - calcNext: \i -> Num.addChecked i 1, - stepIsPositive: Bool.true, + calc_next: \i -> Num.add_checked(i, 1), + step_is_positive: Bool.true, } else { - calcNext: \i -> Num.addChecked i step, - stepIsPositive: step > 0, + calc_next: \i -> Num.add_checked(i, step), + step_is_positive: step > 0, } - inclusiveStart = + inclusive_start = when start is - At x -> Ok x - After x -> calcNext x + At(x) -> Ok(x) + After(x) -> calc_next(x) when end is - At at -> - isValid = - if stepIsPositive then + At(at) -> + is_valid = + if step_is_positive then \i -> i <= at else \i -> i >= at - # TODO: switch to List.withCapacity - rangeHelp [] inclusiveStart calcNext isValid + # TODO: switch to List.with_capacity + range_help([], inclusive_start, calc_next, is_valid) - Before before -> - isValid = - if stepIsPositive then + Before(before) -> + is_valid = + if step_is_positive then \i -> i < before else \i -> i > before - # TODO: switch to List.withCapacity - rangeHelp [] inclusiveStart calcNext isValid + # TODO: switch to List.with_capacity + range_help([], inclusive_start, calc_next, is_valid) - Length l -> - rangeLengthHelp (List.withCapacity l) inclusiveStart l calcNext + Length(l) -> + range_length_help(List.with_capacity(l), inclusive_start, l, calc_next) -rangeHelp = \accum, i, calcNext, isValid -> +range_help = \accum, i, calc_next, is_valid -> when i is - Ok val -> - if isValid val then - # TODO: change this to List.appendUnsafe once capacity is set correctly - rangeHelp (List.append accum val) (calcNext val) calcNext isValid + Ok(val) -> + if is_valid(val) then + # TODO: change this to List.append_unsafe once capacity is set correctly + range_help(List.append(accum, val), calc_next(val), calc_next, is_valid) else accum - Err _ -> + Err(_) -> # We went past the end of the numeric range and there is no next. # return the generated list. accum -rangeLengthHelp = \accum, i, remaining, calcNext -> +range_length_help = \accum, i, remaining, calc_next -> if remaining == 0 then accum else when i is - Ok val -> - rangeLengthHelp (List.appendUnsafe accum val) (calcNext val) (Num.subWrap remaining 1) calcNext + Ok(val) -> + range_length_help(List.append_unsafe(accum, val), calc_next(val), Num.sub_wrap(remaining, 1), calc_next) - Err _ -> + Err(_) -> # We went past the end of the numeric range and there is no next. # The list is not the correct length yet, so we must crash. - crash "List.range: failed to generate enough elements to fill the range before overflowing the numeric type" + crash("List.range: failed to generate enough elements to fill the range before overflowing the numeric type") expect - List.range { start: At 0, end: At 4 } == [0, 1, 2, 3, 4] + List.range({ start: At(0), end: At(4) }) == [0, 1, 2, 3, 4] expect - List.range { start: After 0, end: At 4 } == [1, 2, 3, 4] + List.range({ start: After(0), end: At(4) }) == [1, 2, 3, 4] expect - List.range { start: At 0, end: At 4, step: 2 } == [0, 2, 4] + List.range({ start: At(0), end: At(4), step: 2 }) == [0, 2, 4] expect - List.range { start: At 0, end: Before 4 } == [0, 1, 2, 3] + List.range({ start: At(0), end: Before(4) }) == [0, 1, 2, 3] expect - List.range { start: After 0, end: Before 4 } == [1, 2, 3] + List.range({ start: After(0), end: Before(4) }) == [1, 2, 3] expect - List.range { start: At 0, end: Before 4, step: 2 } == [0, 2] + List.range({ start: At(0), end: Before(4), step: 2 }) == [0, 2] expect - List.range { start: At 4, end: Length 5 } == [4, 5, 6, 7, 8] + List.range({ start: At(4), end: Length(5) }) == [4, 5, 6, 7, 8] expect - List.range { start: At 4, end: Length 5, step: 10 } == [4, 14, 24, 34, 44] + List.range({ start: At(4), end: Length(5), step: 10 }) == [4, 14, 24, 34, 44] expect - List.range { start: At 4, end: Length 5, step: -3 } == [4, 1, -2, -5, -8] + List.range({ start: At(4), end: Length(5), step: -3 }) == [4, 1, -2, -5, -8] expect - List.range { start: After 250u8, end: At 255 } == [251, 252, 253, 254, 255] + List.range({ start: After(250u8), end: At(255) }) == [251, 252, 253, 254, 255] expect - List.range { start: After 250u8, end: At 255, step: 10 } == [] + List.range({ start: After(250u8), end: At(255), step: 10 }) == [] expect - List.range { start: After 250u8, end: At 245, step: 10 } == [] + List.range({ start: After(250u8), end: At(245), step: 10 }) == [] expect - List.range { start: At 4, end: At 0 } == [4, 3, 2, 1, 0] + List.range({ start: At(4), end: At(0) }) == [4, 3, 2, 1, 0] ## Sort with a custom comparison function -sortWith : List a, (a, a -> [LT, EQ, GT]) -> List a +sort_with : List a, (a, a -> [LT, EQ, GT]) -> List a ## Sorts a list of numbers in ascending order (lowest to highest). ## -## To sort in descending order (highest to lowest), use [List.sortDesc] instead. -sortAsc : List (Num a) -> List (Num a) -sortAsc = \list -> List.sortWith list Num.compare +## To sort in descending order (highest to lowest), use [List.sort_desc] instead. +sort_asc : List (Num a) -> List (Num a) +sort_asc = \list -> List.sort_with(list, Num.compare) ## Sorts a list of numbers in descending order (highest to lowest). ## -## To sort in ascending order (lowest to highest), use [List.sortAsc] instead. -sortDesc : List (Num a) -> List (Num a) -sortDesc = \list -> List.sortWith list (\a, b -> Num.compare b a) +## To sort in ascending order (lowest to highest), use [List.sort_asc] instead. +sort_desc : List (Num a) -> List (Num a) +sort_desc = \list -> List.sort_with(list, \a, b -> Num.compare(b, a)) swap : List a, U64, U64 -> List a ## Returns the first element in the list, or `ListWasEmpty` if it was empty. first : List a -> Result a [ListWasEmpty] first = \list -> - when List.get list 0 is - Ok v -> Ok v - Err _ -> Err ListWasEmpty + when List.get(list, 0) is + Ok(v) -> Ok(v) + Err(_) -> Err(ListWasEmpty) ## Returns the given number of elements from the beginning of the list. ## ```roc -## List.takeFirst [1, 2, 3, 4, 5, 6, 7, 8] 4 +## List.take_first([1, 2, 3, 4, 5, 6, 7, 8], 4) == [1, 2, 3, 4] ## ``` ## If there are fewer elements in the list than the requested number, ## returns the entire list. ## ```roc -## List.takeFirst [1, 2] 5 +## List.take_first([1, 2], 5) == [1, 2] ## ``` -## To *remove* elements from the beginning of the list, use `List.takeLast`. +## To *remove* elements from the beginning of the list, use `List.take_last`. ## ## To remove elements from both the beginning and end of the list, ## use `List.sublist`. ## -## To split the list into two lists, use `List.splitAt`. +## To split the list into two lists, use `List.split_at`. ## -takeFirst : List elem, U64 -> List elem -takeFirst = \list, outputLength -> - List.sublist list { start: 0, len: outputLength } +take_first : List elem, U64 -> List elem +take_first = \list, output_length -> + List.sublist(list, { start: 0, len: output_length }) ## Returns the given number of elements from the end of the list. ## ```roc -## List.takeLast [1, 2, 3, 4, 5, 6, 7, 8] 4 +## List.take_last([1, 2, 3, 4, 5, 6, 7, 8], 4) == [5, 6, 7, 8] ## ``` ## If there are fewer elements in the list than the requested number, ## returns the entire list. ## ```roc -## List.takeLast [1, 2] 5 +## List.take_last([1, 2], 5) == [1, 2] ## ``` -## To *remove* elements from the end of the list, use `List.takeFirst`. +## To *remove* elements from the end of the list, use `List.take_first`. ## ## To remove elements from both the beginning and end of the list, ## use `List.sublist`. ## -## To split the list into two lists, use `List.splitAt`. +## To split the list into two lists, use `List.split_at`. ## -takeLast : List elem, U64 -> List elem -takeLast = \list, outputLength -> - List.sublist list { start: Num.subSaturated (List.len list) outputLength, len: outputLength } +take_last : List elem, U64 -> List elem +take_last = \list, output_length -> + List.sublist(list, { start: Num.sub_saturated(List.len(list), output_length), len: output_length }) ## Drops n elements from the beginning of the list. -dropFirst : List elem, U64 -> List elem -dropFirst = \list, n -> - remaining = Num.subSaturated (List.len list) n +drop_first : List elem, U64 -> List elem +drop_first = \list, n -> + remaining = Num.sub_saturated(List.len(list), n) - List.takeLast list remaining + List.take_last(list, remaining) ## Drops n elements from the end of the list. -dropLast : List elem, U64 -> List elem -dropLast = \list, n -> - remaining = Num.subSaturated (List.len list) n +drop_last : List elem, U64 -> List elem +drop_last = \list, n -> + remaining = Num.sub_saturated(List.len(list), n) - List.takeFirst list remaining + List.take_first(list, remaining) ## Drops the element at the given index from the list. ## ## This has no effect if the given index is outside the bounds of the list. ## ## To replace the element at a given index, instead of dropping it, see [List.set]. -dropAt : List elem, U64 -> List elem +drop_at : List elem, U64 -> List elem min : List (Num a) -> Result (Num a) [ListWasEmpty] min = \list -> - when List.first list is - Ok initial -> - Ok (minHelp list initial) + when List.first(list) is + Ok(initial) -> + Ok(min_help(list, initial)) - Err ListWasEmpty -> - Err ListWasEmpty + Err(ListWasEmpty) -> + Err(ListWasEmpty) -minHelp : List (Num a), Num a -> Num a -minHelp = \list, initial -> - List.walk list initial \bestSoFar, current -> - if current < bestSoFar then +min_help : List (Num a), Num a -> Num a +min_help = \list, initial -> + List.walk(list, initial, \best_so_far, current -> + if current < best_so_far then current else - bestSoFar + best_so_far) max : List (Num a) -> Result (Num a) [ListWasEmpty] max = \list -> - when List.first list is - Ok initial -> - Ok (maxHelp list initial) + when List.first(list) is + Ok(initial) -> + Ok(max_help(list, initial)) - Err ListWasEmpty -> - Err ListWasEmpty + Err(ListWasEmpty) -> + Err(ListWasEmpty) -maxHelp : List (Num a), Num a -> Num a -maxHelp = \list, initial -> - List.walk list initial \bestSoFar, current -> - if current > bestSoFar then +max_help : List (Num a), Num a -> Num a +max_help = \list, initial -> + List.walk(list, initial, \best_so_far, current -> + if current > best_so_far then current else - bestSoFar + best_so_far) ## Like [List.map], except the transformation function wraps the return value ## in a list. At the end, all the lists get joined together into one list. ## -## You may know a similar function named `concatMap` in other languages. -joinMap : List a, (a -> List b) -> List b -joinMap = \list, mapper -> - List.walk list [] \state, elem -> List.concat state (mapper elem) +## You may know a similar function named `concat_map` in other languages. +join_map : List a, (a -> List b) -> List b +join_map = \list, mapper -> + List.walk(list, [], \state, elem -> List.concat(state, mapper(elem))) ## Returns the first element of the list satisfying a predicate function. ## If no satisfying element is found, an `Err NotFound` is returned. -findFirst : List elem, (elem -> Bool) -> Result elem [NotFound] -findFirst = \list, pred -> +find_first : List elem, (elem -> Bool) -> Result elem [NotFound] +find_first = \list, pred -> callback = \_, elem -> - if pred elem then - Break elem + if pred(elem) then + Break(elem) else - Continue {} + Continue({}) - when List.iterate list {} callback is - Continue {} -> Err NotFound - Break found -> Ok found + when List.iterate(list, {}, callback) is + Continue({}) -> Err(NotFound) + Break(found) -> Ok(found) ## Returns the last element of the list satisfying a predicate function. ## If no satisfying element is found, an `Err NotFound` is returned. -findLast : List elem, (elem -> Bool) -> Result elem [NotFound] -findLast = \list, pred -> +find_last : List elem, (elem -> Bool) -> Result elem [NotFound] +find_last = \list, pred -> callback = \_, elem -> - if pred elem then - Break elem + if pred(elem) then + Break(elem) else - Continue {} + Continue({}) - when List.iterateBackwards list {} callback is - Continue {} -> Err NotFound - Break found -> Ok found + when List.iterate_backwards(list, {}, callback) is + Continue({}) -> Err(NotFound) + Break(found) -> Ok(found) ## Returns the index at which the first element in the list ## satisfying a predicate function can be found. ## If no satisfying element is found, an `Err NotFound` is returned. -findFirstIndex : List elem, (elem -> Bool) -> Result U64 [NotFound] -findFirstIndex = \list, matcher -> - foundIndex = List.iterate list 0 \index, elem -> - if matcher elem then - Break index +find_first_index : List elem, (elem -> Bool) -> Result U64 [NotFound] +find_first_index = \list, matcher -> + found_index = List.iterate(list, 0, \index, elem -> + if matcher(elem) then + Break(index) else - Continue (Num.addWrap index 1) + Continue(Num.add_wrap(index, 1))) - when foundIndex is - Break index -> Ok index - Continue _ -> Err NotFound + when found_index is + Break(index) -> Ok(index) + Continue(_) -> Err(NotFound) ## Returns the last index at which the first element in the list ## satisfying a predicate function can be found. ## If no satisfying element is found, an `Err NotFound` is returned. -findLastIndex : List elem, (elem -> Bool) -> Result U64 [NotFound] -findLastIndex = \list, matches -> - foundIndex = List.iterateBackwards list (List.len list) \prevIndex, elem -> - answer = Num.subWrap prevIndex 1 +find_last_index : List elem, (elem -> Bool) -> Result U64 [NotFound] +find_last_index = \list, matches -> + found_index = List.iterate_backwards(list, List.len(list), \prev_index, elem -> + answer = Num.sub_wrap(prev_index, 1) - if matches elem then - Break answer + if matches(elem) then + Break(answer) else - Continue answer + Continue(answer)) - when foundIndex is - Break index -> Ok index - Continue _ -> Err NotFound + when found_index is + Break(index) -> Ok(index) + Continue(_) -> Err(NotFound) ## Returns a subsection of the given list, beginning at the `start` index and ## including a total of `len` elements. ## ## If `start` is outside the bounds of the given list, returns the empty list. ## ```roc -## List.sublist [1, 2, 3] { start: 4, len: 0 } +## List.sublist([1, 2, 3], { start: 4, len: 0 }) ## ``` ## If more elements are requested than exist in the list, returns as many as it can. ## ```roc -## List.sublist [1, 2, 3, 4, 5] { start: 2, len: 10 } +## List.sublist([1, 2, 3, 4, 5], { start: 2, len: 10 }) ## ``` ## > If you want a sublist which goes all the way to the end of the list, no -## > matter how long the list is, `List.takeLast` can do that more efficiently. +## > matter how long the list is, `List.take_last` can do that more efficiently. ## ## Some languages have a function called **`slice`** which works similarly to this. sublist : List elem, { start : U64, len : U64 } -> List elem sublist = \list, config -> - sublistLowlevel list config.start config.len + sublist_lowlevel(list, config.start, config.len) ## low-level slicing operation that does no bounds checking -sublistLowlevel : List elem, U64, U64 -> List elem +sublist_lowlevel : List elem, U64, U64 -> List elem ## Intersperses `sep` between the elements of `list` ## ```roc -## List.intersperse [1, 2, 3] 9 # [1, 9, 2, 9, 3] +## List.intersperse([1, 2, 3], 9) == [1, 9, 2, 9, 3] ## ``` intersperse : List elem, elem -> List elem intersperse = \list, sep -> - capacity = 2 * List.len list - init = List.withCapacity capacity - newList = - List.walk list init \acc, elem -> + capacity = 2 * List.len(list) + init = List.with_capacity(capacity) + new_list = + List.walk(list, init, \acc, elem -> acc - |> List.appendUnsafe elem - |> List.appendUnsafe sep + |> List.append_unsafe(elem) + |> List.append_unsafe(sep)) - List.dropLast newList 1 + List.drop_last(new_list, 1) ## Returns `Bool.true` if the first list starts with the second list. ## @@ -1224,11 +1227,11 @@ intersperse = \list, sep -> ## is considered to "start with" an empty list. ## ## If the first list is empty, this only returns `Bool.true` if the second list is empty. -startsWith : List elem, List elem -> Bool where elem implements Eq -startsWith = \list, prefix -> +starts_with : List elem, List elem -> Bool where elem implements Eq +starts_with = \list, prefix -> # TODO once we have seamless slices, verify that this wouldn't - # have better performance with a function like List.compareSublists - prefix == List.sublist list { start: 0, len: List.len prefix } + # have better performance with a function like List.compare_sublists + prefix == List.sublist(list, { start: 0, len: List.len(prefix) }) ## Returns `Bool.true` if the first list ends with the second list. ## @@ -1236,14 +1239,14 @@ startsWith = \list, prefix -> ## is considered to "end with" an empty list. ## ## If the first list is empty, this only returns `Bool.true` if the second list is empty. -endsWith : List elem, List elem -> Bool where elem implements Eq -endsWith = \list, suffix -> +ends_with : List elem, List elem -> Bool where elem implements Eq +ends_with = \list, suffix -> # TODO once we have seamless slices, verify that this wouldn't - # have better performance with a function like List.compareSublists - length = List.len suffix - start = Num.subSaturated (List.len list) length + # have better performance with a function like List.compare_sublists + length = List.len(suffix) + start = Num.sub_saturated(List.len(list), length) - suffix == List.sublist list { start, len: length } + suffix == List.sublist(list, { start, len: length }) ## Splits the list into two lists, around the given index. ## @@ -1252,113 +1255,113 @@ endsWith = \list, suffix -> ## than the given index, # and the `others` list will be all the others. (This ## means if you give an index of 0, the `before` list will be empty and the ## `others` list will have the same elements as the original list.) -splitAt : List elem, U64 -> { before : List elem, others : List elem } -splitAt = \elements, userSplitIndex -> - length = List.len elements - splitIndex = if length > userSplitIndex then userSplitIndex else length - before = List.sublist elements { start: 0, len: splitIndex } - others = List.sublist elements { start: splitIndex, len: Num.subWrap length splitIndex } +split_at : List elem, U64 -> { before : List elem, others : List elem } +split_at = \elements, user_split_index -> + length = List.len(elements) + split_index = if length > user_split_index then user_split_index else length + before = List.sublist(elements, { start: 0, len: split_index }) + others = List.sublist(elements, { start: split_index, len: Num.sub_wrap(length, split_index) }) { before, others } ## Splits the input list on the delimiter element. ## ## ```roc -## List.splitOn [1, 2, 3] 2 == [[1], [3]] +## List.split_on([1, 2, 3], 2) == [[1], [3]] ## ``` -splitOn : List a, a -> List (List a) where a implements Eq -splitOn = \elements, delimiter -> - help = \remaining, chunks, currentChunk -> +split_on : List a, a -> List (List a) where a implements Eq +split_on = \elements, delimiter -> + help = \remaining, chunks, current_chunk -> when remaining is - [] -> List.append chunks currentChunk + [] -> List.append(chunks, current_chunk) [x, .. as rest] if x == delimiter -> - help rest (List.append chunks currentChunk) [] + help(rest, List.append(chunks, current_chunk), []) [x, .. as rest] -> - help rest chunks (List.append currentChunk x) - help elements [] [] + help(rest, chunks, List.append(current_chunk, x)) + help(elements, [], []) ## Splits the input list on the delimiter list. ## ## ```roc -## List.splitOnList [1, 2, 3] [1, 2] == [[], [3]] +## List.split_on_list([1, 2, 3], [1, 2]) == [[], [3]] ## ``` -splitOnList : List a, List a -> List (List a) where a implements Eq -splitOnList = \elements, delimiter -> - help = \remaining, chunks, currentChunk -> +split_on_list : List a, List a -> List (List a) where a implements Eq +split_on_list = \elements, delimiter -> + help = \remaining, chunks, current_chunk -> when remaining is - [] -> List.append chunks currentChunk + [] -> List.append(chunks, current_chunk) [x, .. as rest] -> - if List.startsWith remaining delimiter then - help (List.dropFirst remaining (List.len delimiter)) (List.append chunks currentChunk) [] + if List.starts_with(remaining, delimiter) then + help(List.drop_first(remaining, List.len(delimiter)), List.append(chunks, current_chunk), []) else - help rest chunks (List.append currentChunk x) + help(rest, chunks, List.append(current_chunk, x)) if delimiter == [] then [elements] else - help elements [] [] + help(elements, [], []) ## Returns the elements before the first occurrence of a delimiter, as well as the ## remaining elements after that occurrence. If the delimiter is not found, returns `Err`. ## ```roc -## List.splitFirst [Foo, Z, Bar, Z, Baz] Z == Ok { before: [Foo], after: [Bar, Z, Baz] } +## List.split_first([Foo, Z, Bar, Z, Baz], Z) == Ok({ before: [Foo], after: [Bar, Z, Baz] }) ## ``` -splitFirst : List elem, elem -> Result { before : List elem, after : List elem } [NotFound] where elem implements Eq -splitFirst = \list, delimiter -> - when List.findFirstIndex list (\elem -> elem == delimiter) is - Ok index -> - before = List.sublist list { start: 0, len: index } - after = List.sublist list { start: Num.addWrap index 1, len: Num.subWrap (List.len list) index |> Num.subWrap 1 } +split_first : List elem, elem -> Result { before : List elem, after : List elem } [NotFound] where elem implements Eq +split_first = \list, delimiter -> + when List.find_first_index(list, \elem -> elem == delimiter) is + Ok(index) -> + before = List.sublist(list, { start: 0, len: index }) + after = List.sublist(list, { start: Num.add_wrap(index, 1), len: Num.sub_wrap(List.len(list), index) |> Num.sub_wrap(1) }) - Ok { before, after } + Ok({ before, after }) - Err NotFound -> Err NotFound + Err(NotFound) -> Err(NotFound) ## Returns the elements before the last occurrence of a delimiter, as well as the ## remaining elements after that occurrence. If the delimiter is not found, returns `Err`. ## ```roc -## List.splitLast [Foo, Z, Bar, Z, Baz] Z == Ok { before: [Foo, Z, Bar], after: [Baz] } +## List.split_last([Foo, Z, Bar, Z, Baz], Z) == Ok({ before: [Foo, Z, Bar], after: [Baz] }) ## ``` -splitLast : List elem, elem -> Result { before : List elem, after : List elem } [NotFound] where elem implements Eq -splitLast = \list, delimiter -> - when List.findLastIndex list (\elem -> elem == delimiter) is - Ok index -> - before = List.sublist list { start: 0, len: index } - after = List.sublist list { start: Num.addWrap index 1, len: Num.subWrap (List.len list) index |> Num.subWrap 1 } +split_last : List elem, elem -> Result { before : List elem, after : List elem } [NotFound] where elem implements Eq +split_last = \list, delimiter -> + when List.find_last_index(list, \elem -> elem == delimiter) is + Ok(index) -> + before = List.sublist(list, { start: 0, len: index }) + after = List.sublist(list, { start: Num.add_wrap(index, 1), len: Num.sub_wrap(List.len(list), index) |> Num.sub_wrap(1) }) - Ok { before, after } + Ok({ before, after }) - Err NotFound -> Err NotFound + Err(NotFound) -> Err(NotFound) ## Splits the list into many chunks, each of which is length of the given chunk ## size. The last chunk will be shorter if the list does not evenly divide by the ## chunk size. If the provided list is empty or if the chunk size is 0 then the ## result is an empty list. -chunksOf : List a, U64 -> List (List a) -chunksOf = \list, chunkSize -> - if chunkSize == 0 || List.isEmpty list then +chunks_of : List a, U64 -> List (List a) +chunks_of = \list, chunk_size -> + if chunk_size == 0 || List.is_empty(list) then [] else - chunkCapacity = Num.divCeil (List.len list) chunkSize - chunksOfHelp list chunkSize (List.withCapacity chunkCapacity) + chunk_capacity = Num.div_ceil(List.len(list), chunk_size) + chunks_of_help(list, chunk_size, List.with_capacity(chunk_capacity)) -chunksOfHelp : List a, U64, List (List a) -> List (List a) -chunksOfHelp = \listRest, chunkSize, chunks -> - if List.isEmpty listRest then +chunks_of_help : List a, U64, List (List a) -> List (List a) +chunks_of_help = \list_rest, chunk_size, chunks -> + if List.is_empty(list_rest) then chunks else - { before, others } = List.splitAt listRest chunkSize - chunksOfHelp others chunkSize (List.append chunks before) + { before, others } = List.split_at(list_rest, chunk_size) + chunks_of_help(others, chunk_size, List.append(chunks, before)) ## Like [List.map], except the transformation function returns a [Result]. -## If that function ever returns `Err`, [mapTry] immediately returns that `Err`. -## If it returns `Ok` for every element, [mapTry] returns `Ok` with the transformed list. -mapTry : List elem, (elem -> Result ok err) -> Result (List ok) err -mapTry = \list, toResult -> - walkTry list [] \state, elem -> - Result.map (toResult elem) \ok -> - List.append state ok +## If that function ever returns `Err`, [map_try] immediately returns that `Err`. +## If it returns `Ok` for every element, [map_try] returns `Ok` with the transformed list. +map_try : List elem, (elem -> Result ok err) -> Result (List ok) err +map_try = \list, to_result -> + walk_try(list, [], \state, elem -> + Result.map(to_result(elem), \ok -> + List.append(state, ok))) ## Same as [List.walk], except you can stop walking early by returning `Err`. ## @@ -1371,109 +1374,113 @@ mapTry = \list, toResult -> ## ## As such, it is typically better for performance to use this over [List.walk] ## if returning `Break` earlier than the last element is expected to be common. -walkTry : List elem, state, (state, elem -> Result state err) -> Result state err -walkTry = \list, init, func -> - walkTryHelp list init func 0 (List.len list) +walk_try : List elem, state, (state, elem -> Result state err) -> Result state err +walk_try = \list, init, func -> + walk_try_help(list, init, func, 0, List.len(list)) ## internal helper -walkTryHelp : List elem, state, (state, elem -> Result state err), U64, U64 -> Result state err -walkTryHelp = \list, state, f, index, length -> +walk_try_help : List elem, state, (state, elem -> Result state err), U64, U64 -> Result state err +walk_try_help = \list, state, f, index, length -> if index < length then - when f state (List.getUnsafe list index) is - Ok nextState -> walkTryHelp list nextState f (Num.addWrap index 1) length - Err b -> Err b + when f(state, List.get_unsafe(list, index)) is + Ok(next_state) -> walk_try_help(list, next_state, f, Num.add_wrap(index, 1), length) + Err(b) -> Err(b) else - Ok state + Ok(state) ## Primitive for iterating over a List, being able to decide at every element whether to continue iterate : List elem, s, (s, elem -> [Continue s, Break b]) -> [Continue s, Break b] iterate = \list, init, func -> - iterHelp list init func 0 (List.len list) + iter_help(list, init, func, 0, List.len(list)) ## internal helper -iterHelp : List elem, s, (s, elem -> [Continue s, Break b]), U64, U64 -> [Continue s, Break b] -iterHelp = \list, state, f, index, length -> +iter_help : List elem, s, (s, elem -> [Continue s, Break b]), U64, U64 -> [Continue s, Break b] +iter_help = \list, state, f, index, length -> if index < length then - when f state (List.getUnsafe list index) is - Continue nextState -> iterHelp list nextState f (Num.addWrap index 1) length - Break b -> Break b + when f(state, List.get_unsafe(list, index)) is + Continue(next_state) -> iter_help(list, next_state, f, Num.add_wrap(index, 1), length) + Break(b) -> Break(b) else - Continue state + Continue(state) ## Primitive for iterating over a List from back to front, being able to decide at every ## element whether to continue -iterateBackwards : List elem, s, (s, elem -> [Continue s, Break b]) -> [Continue s, Break b] -iterateBackwards = \list, init, func -> - iterBackwardsHelp list init func (List.len list) +iterate_backwards : List elem, s, (s, elem -> [Continue s, Break b]) -> [Continue s, Break b] +iterate_backwards = \list, init, func -> + iter_backwards_help(list, init, func, List.len(list)) ## internal helper -iterBackwardsHelp : List elem, s, (s, elem -> [Continue s, Break b]), U64 -> [Continue s, Break b] -iterBackwardsHelp = \list, state, f, prevIndex -> - if prevIndex > 0 then - index = Num.subWrap prevIndex 1 - - when f state (List.getUnsafe list index) is - Continue nextState -> iterBackwardsHelp list nextState f index - Break b -> Break b +iter_backwards_help : List elem, s, (s, elem -> [Continue s, Break b]), U64 -> [Continue s, Break b] +iter_backwards_help = \list, state, f, prev_index -> + if prev_index > 0 then + index = Num.sub_wrap(prev_index, 1) + + when f(state, List.get_unsafe(list, index)) is + Continue(next_state) -> iter_backwards_help(list, next_state, f, index) + Break(b) -> Break(b) else - Continue state + Continue(state) ## Concatenates the bytes of a string encoded as utf8 to a list of bytes. ## ```roc -## expect (List.concatUtf8 [1, 2, 3, 4] "🐦") == [1, 2, 3, 4, 240, 159, 144, 166] +## expect List.concat_utf8([1, 2, 3, 4], "🐦") == [1, 2, 3, 4, 240, 159, 144, 166] ## ``` -concatUtf8 : List U8, Str -> List U8 +concat_utf8 : List U8, Str -> List U8 -expect (List.concatUtf8 [1, 2, 3, 4] "🐦") == [1, 2, 3, 4, 240, 159, 144, 166] +expect (List.concat_utf8([1, 2, 3, 4], "🐦")) == [1, 2, 3, 4, 240, 159, 144, 166] ## Run an effectful function for each element on the list. ## ## ```roc -## List.forEach! ["Alice", "Bob", "Charlie"] \name -> -## createAccount! name -## log! "Account created" +## List.for_each!(["Alice", "Bob", "Charlie"], \name -> +## create_account!(name) +## log!("Account created") +## ) ## ``` ## -## If the function might fail or you need to return early, use [forEachTry!]. -forEach! : List a, (a => {}) => {} -forEach! = \list, func! -> +## If the function might fail or you need to return early, use [for_each_try!]. +for_each! : List a, (a => {}) => {} +for_each! = \list, func! -> when list is [] -> {} [elem, .. as rest] -> - func! elem - forEach! rest func! + func!(elem) + for_each!(rest, func!) ## Run an effectful function that might fail for each element on the list. ## ## If the function returns `Err`, the iteration stops and the error is returned. ## ## ```roc -## List.forEachTry! filesToDelete \path -> -## try File.delete! path -## Stdout.line! "$(path) deleted" +## List.for_each_try!(files_to_delete, \path -> +## File.delete!(path)? +## +## Stdout.line!("$(path) deleted") +## ) ## ``` -forEachTry! : List a, (a => Result {} err) => Result {} err -forEachTry! = \list, func! -> +for_each_try! : List a, (a => Result {} err) => Result {} err +for_each_try! = \list, func! -> when list is [] -> - Ok {} + Ok({}) [elem, .. as rest] -> - when func! elem is - Ok {} -> - forEachTry! rest func! + when func!(elem) is + Ok({}) -> + for_each_try!(rest, func!) - Err err -> - Err err + Err(err) -> + Err(err) ## Build a value from the contents of a list, using an effectful function. ## ## ```roc -## now_multiples = List.walk! [1, 2, 3] [] \nums, i -> -## now = Utc.now! {} |> Utc.to_millis_since_epoch -## List.append nums (now * i) +## now_multiples = List.walk!([1, 2, 3], [], \nums, i -> +## now = Utc.now!({}) |> Utc.to_millis_since_epoch +## List.append(nums, now * i) +## ) ## ``` ## ## This is the same as [walk], except that the step function can have effects. @@ -1482,5 +1489,5 @@ walk! = \list, state, func! -> when list is [] -> state [elem, .. as rest] -> - nextState = func! state elem - walk! rest nextState func! + next_state = func!(state, elem) + walk!(rest, next_state, func!) diff --git a/crates/compiler/builtins/roc/Num.roc b/crates/compiler/builtins/roc/Num.roc index ff1c1962f57..129bd29fd07 100644 --- a/crates/compiler/builtins/roc/Num.roc +++ b/crates/compiler/builtins/roc/Num.roc @@ -34,132 +34,132 @@ module [ pi, tau, abs, - absDiff, + abs_diff, neg, add, sub, mul, min, max, - isLt, - isLte, - isGt, - isGte, - isApproxEq, + is_lt, + is_lte, + is_gt, + is_gte, + is_approx_eq, sin, cos, tan, atan, acos, asin, - isZero, - isEven, - isOdd, - toFrac, - isPositive, - isNegative, - isNaN, - isInfinite, - isFinite, + is_zero, + is_even, + is_odd, + to_frac, + is_positive, + is_negative, + is_nan, + is_infinite, + is_finite, rem, - remChecked, + rem_checked, div, - divChecked, + div_checked, sqrt, - sqrtChecked, + sqrt_checked, log, - logChecked, + log_checked, round, ceiling, floor, compare, pow, - powInt, - countLeadingZeroBits, - countTrailingZeroBits, - countOneBits, - addWrap, - addChecked, - addSaturated, - bitwiseAnd, - bitwiseXor, - bitwiseOr, - bitwiseNot, - shiftLeftBy, - shiftRightBy, - shiftRightZfBy, - subWrap, - subChecked, - subSaturated, - mulWrap, - mulSaturated, - mulChecked, - intCast, - divCeil, - divCeilChecked, - divTrunc, - divTruncChecked, - toStr, - isMultipleOf, - minI8, - maxI8, - minU8, - maxU8, - minI16, - maxI16, - minU16, - maxU16, - minI32, - maxI32, - minU32, - maxU32, - minI64, - maxI64, - minU64, - maxU64, - minI128, - maxI128, - minU128, - maxU128, - minF32, - maxF32, - minF64, - maxF64, - toI8, - toI8Checked, - toI16, - toI16Checked, - toI32, - toI32Checked, - toI64, - toI64Checked, - toI128, - toI128Checked, - toU8, - toU8Checked, - toU16, - toU16Checked, - toU32, - toU32Checked, - toU64, - toU64Checked, - toU128, - toU128Checked, - toF32, - toF32Checked, - toF64, - toF64Checked, - withoutDecimalPoint, - withDecimalPoint, - f32ToParts, - f64ToParts, - f32FromParts, - f64FromParts, - fromBool, - nanF32, - nanF64, - infinityF32, - infinityF64, + pow_int, + count_leading_zero_bits, + count_trailing_zero_bits, + count_one_bits, + add_wrap, + add_checked, + add_saturated, + bitwise_and, + bitwise_xor, + bitwise_or, + bitwise_not, + shift_left_by, + shift_right_by, + shift_right_zf_by, + sub_wrap, + sub_checked, + sub_saturated, + mul_wrap, + mul_saturated, + mul_checked, + int_cast, + div_ceil, + div_ceil_checked, + div_trunc, + div_trunc_checked, + to_str, + is_multiple_of, + min_i8, + max_i8, + min_u8, + max_u8, + min_i16, + max_i16, + min_u16, + max_u16, + min_i32, + max_i32, + min_u32, + max_u32, + min_i64, + max_i64, + min_u64, + max_u64, + min_i128, + max_i128, + min_u128, + max_u128, + min_f32, + max_f32, + min_f64, + max_f64, + to_i8, + to_i8_checked, + to_i16, + to_i16_checked, + to_i32, + to_i32_checked, + to_i64, + to_i64_checked, + to_i128, + to_i128_checked, + to_u8, + to_u8_checked, + to_u16, + to_u16_checked, + to_u32, + to_u32_checked, + to_u64, + to_u64_checked, + to_u128, + to_u128_checked, + to_f32, + to_f32_checked, + to_f64, + to_f64_checked, + without_decimal_point, + with_decimal_point, + f32_to_parts, + f64_to_parts, + f32_from_parts, + f64_from_parts, + from_bool, + nan_f32, + nan_f64, + infinity_f32, + infinity_f64, ] import Bool exposing [Bool] @@ -193,14 +193,14 @@ import Result exposing [Result] ## have the type `Num *` at first, but usually end up taking on ## a more specific type based on how they're used. ## -## For example, in `(1 + List.len myList)`, the `1` has the type `Num *` at first, +## For example, in `1 + List.len(myList)`, the `1` has the type `Num *` at first, ## but because `List.len` returns a `U64`, the `1` ends up changing from ## `Num *` to the more specific `U64`, and the expression as a whole ## ends up having the type `U64`. ## ## Sometimes number literals don't become more specific. For example, -## the `Num.toStr` function has the type `Num * -> Str`. This means that -## when calling `Num.toStr (5 + 6)`, the expression `(5 + 6)` +## the `Num.to_str` function has the type `Num * -> Str`. This means that +## when calling `Num.to_str(5 + 6)`, the expression `5 + 6` ## still has the type `Num *`. When this happens, `Num *` defaults to ## being an [I64] - so this addition expression would overflow ## if either 5 or 6 were replaced with a number big enough to cause @@ -209,7 +209,7 @@ import Result exposing [Result] ## If this default of [I64] is not big enough for your purposes, ## you can add an `i128` to the end of the number literal, like so: ## ```roc -## Num.toStr 5_000_000_000i128 +## Num.to_str(5_000_000_000i128) ## ``` ## This `i128` suffix specifies that you want this number literal to be ## an [I128] instead of a `Num *`. All the other numeric types have @@ -328,7 +328,7 @@ Num range := range ## | ` 340_282_366_920_938_463_463_374_607_431_768_211_455` | | | ## ## If any operation would result in an [Int] that is either too big -## or too small to fit in that range (e.g. calling `Num.maxI32 + 1`), +## or too small to fit in that range (e.g. calling `Num.max_i32 + 1`), ## then the operation will *overflow*. When an overflow occurs, the program will crash. ## ## As such, it's very important to design your code not to exceed these bounds! @@ -369,7 +369,7 @@ Int range : Num (Integer range) ## when a floating-point calculation encounters an error. For example: ## * Dividing a positive [F64] by `0.0` returns ∞. ## * Dividing a negative [F64] by `0.0` returns -∞. -## * Dividing a [F64] of `0.0` by `0.0` returns [*NaN*](Num.isNaN). +## * Dividing a [F64] of `0.0` by `0.0` returns [*NaN*](Num.is_nan). ## ## These rules come from the [IEEE-754](https://en.wikipedia.org/wiki/IEEE_754) ## floating point standard. Because almost all modern processors are built to @@ -378,7 +378,7 @@ Int range : Num (Integer range) ## access to hardware-accelerated performance, Roc follows these rules exactly. ## ## There's no literal syntax for these error values, but you can check to see if -## you ended up with one of them by using #isNaN, #isFinite, and #isInfinite. +## you ended up with one of them by using #is_nan, #is_finite, and #is_infinite. ## Whenever a function in this module could return one of these values, that ## possibility is noted in the function's documentation. ## @@ -538,24 +538,24 @@ tau = 2 * pi ## Convert a number to a [Str]. ## ## ```roc -## Num.toStr 42 +## Num.to_str(42) ## ``` ## Only [Frac] values will include a decimal point, and they will always include one. ## ```roc -## Num.toStr 4.2 -## Num.toStr 4.0 +## Num.to_str(4.2) +## Num.to_str(4.0) ## ``` -## When this function is given a non-[finite](Num.isFinite) +## When this function is given a non-[finite](Num.is_finite) ## [F64] or [F32] value, the returned string will be `"NaN"`, `"∞"`, or `"-∞"`. ## -toStr : Num * -> Str +to_str : Num * -> Str ## Convert an [Int] to a new [Int] of the expected type: ## ## ```roc ## # Casts a U8 to a U16 ## x : U16 -## x = Num.intCast 255u8 +## x = Num.int_cast(255u8) ## ``` ## ## In the case of downsizing, information is lost: @@ -563,114 +563,113 @@ toStr : Num * -> Str ## ```roc ## # returns 0, as the bits were truncated. ## x : U8 -## x = Num.intCast 256u16 +## x = Num.int_cast(256u16) ## ``` ## -intCast : Int a -> Int b +int_cast : Int a -> Int b compare : Num a, Num a -> [LT, EQ, GT] ## Returns `Bool.true` if the first number is less than the second. ## -## `a < b` is shorthand for `Num.isLt a b`. +## `a < b` is shorthand for `Num.is_lt(a, b)`. ## -## If either argument is [*NaN*](Num.isNaN), returns `Bool.false` no matter what. (*NaN* +## If either argument is [*NaN*](Num.is_nan), returns `Bool.false` no matter what. (*NaN* ## is [defined to be unordered](https://en.wikipedia.org/wiki/NaN#Comparison_with_NaN).) ## ```roc ## 5 -## |> Num.isLt 6 +## |> Num.is_lt 6 ## ``` -isLt : Num a, Num a -> Bool +is_lt : Num a, Num a -> Bool ## Returns `Bool.true` if the first number is greater than the second. ## -## `a > b` is shorthand for `Num.isGt a b`. +## `a > b` is shorthand for `Num.is_gt a b`. ## -## If either argument is [*NaN*](Num.isNaN), returns `Bool.false` no matter what. (*NaN* +## If either argument is [*NaN*](Num.is_nan), returns `Bool.false` no matter what. (*NaN* ## is [defined to be unordered](https://en.wikipedia.org/wiki/NaN#Comparison_with_NaN).) ## ```roc -## 6 -## |> Num.isGt 5 +## Num.is_gt(6, 5) ## ``` -isGt : Num a, Num a -> Bool +is_gt : Num a, Num a -> Bool ## Returns `Bool.true` if the first number is less than or equal to the second. ## -## `a <= b` is shorthand for `Num.isLte a b`. +## `a <= b` is shorthand for `Num.is_lte(a, b)`. ## -## If either argument is [*NaN*](Num.isNaN), returns `Bool.false` no matter what. (*NaN* +## If either argument is [*NaN*](Num.is_nan), returns `Bool.false` no matter what. (*NaN* ## is [defined to be unordered](https://en.wikipedia.org/wiki/NaN#Comparison_with_NaN).) -isLte : Num a, Num a -> Bool +is_lte : Num a, Num a -> Bool ## Returns `Bool.true` if the first number is greater than or equal to the second. ## -## `a >= b` is shorthand for `Num.isGte a b`. +## `a >= b` is shorthand for `Num.is_gte(a, b)`. ## -## If either argument is [*NaN*](Num.isNaN), returns `Bool.false` no matter what. (*NaN* +## If either argument is [*NaN*](Num.is_nan), returns `Bool.false` no matter what. (*NaN* ## is [defined to be unordered](https://en.wikipedia.org/wiki/NaN#Comparison_with_NaN).) -isGte : Num a, Num a -> Bool +is_gte : Num a, Num a -> Bool ## Returns `Bool.true` if the first number and second number are within a specific threshold ## ## A specific relative and absolute tolerance can be provided to change the threshold ## -## This function is symmetric: `Num.isApproxEq a b == Num.isApproxEq b a` +## This function is symmetric: `Num.is_approx_eq(a, b) == Num.is_approx_eq(b, a)` ## -## If either argument is [*NaN*](Num.isNaN), returns `Bool.false` no matter what. (*NaN* +## If either argument is [*NaN*](Num.is_nan), returns `Bool.false` no matter what. (*NaN* ## is [defined to be unordered](https://en.wikipedia.org/wiki/NaN#Comparison_with_NaN).) -isApproxEq : Frac a, Frac a, { rtol ?? Frac a, atol ?? Frac a } -> Bool -isApproxEq = \x, y, { rtol ?? 0.00001, atol ?? 0.00000001 } -> +is_approx_eq : Frac a, Frac a, { rtol ?? Frac a, atol ?? Frac a } -> Bool +is_approx_eq = \x, y, { rtol ?? 0.00001, atol ?? 0.00000001 } -> eq = x <= y && x >= y - meetsTolerance = Num.absDiff x y <= Num.max atol (rtol * Num.max (Num.abs x) (Num.abs y)) - eq || meetsTolerance + meets_tolerance = Num.abs_diff(x, y) <= Num.max(atol, (rtol * Num.max(Num.abs(x), Num.abs(y)))) + eq || meets_tolerance ## Returns `Bool.true` if the number is `0`, and `Bool.false` otherwise. -isZero : Num a -> Bool +is_zero : Num a -> Bool ## A number is even if dividing it by 2 gives a remainder of 0. ## ## Examples of even numbers: 0, 2, 4, 6, 8, -2, -4, -6, -8 -isEven : Int a -> Bool -isEven = \x -> Num.isMultipleOf x 2 +is_even : Int a -> Bool +is_even = \x -> Num.is_multiple_of(x, 2) ## A number is odd if dividing it by 2 gives a remainder of 1. ## ## Examples of odd numbers: 1, 3, 5, 7, -1, -3, -5, -7 -isOdd : Int a -> Bool -isOdd = \x -> Bool.not (Num.isMultipleOf x 2) +is_odd : Int a -> Bool +is_odd = \x -> Bool.not(Num.is_multiple_of(x, 2)) ## Positive numbers are greater than `0`. -isPositive : Num a -> Bool -isPositive = \x -> x > 0 +is_positive : Num a -> Bool +is_positive = \x -> x > 0 ## Negative numbers are less than `0`. -isNegative : Num a -> Bool -isNegative = \x -> x < 0 +is_negative : Num a -> Bool +is_negative = \x -> x < 0 -toFrac : Num * -> Frac * +to_frac : Num * -> Frac * ## Returns `Bool.true` if the [Frac] is not a number as defined by [IEEE-754](https://en.wikipedia.org/wiki/IEEE_754) ## ## ```roc -## Num.isNaN (0 / 0) +## Num.is_nan(0 / 0) ## ``` -isNaN : Frac * -> Bool +is_nan : Frac * -> Bool ## Returns `Bool.true` if the [Frac] is positive or negative infinity as defined by [IEEE-754](https://en.wikipedia.org/wiki/IEEE_754) ## ## ```roc -## Num.isInfinite (1 / 0) +## Num.is_infinite(1 / 0) ## -## Num.isInfinite (-1 / 0) +## Num.is_infinite(-1 / 0) ## ``` -isInfinite : Frac * -> Bool +is_infinite : Frac * -> Bool ## Returns `Bool.true` if the [Frac] is not an infinity as defined by [IEEE-754](https://en.wikipedia.org/wiki/IEEE_754) ## ## ```roc -## Num.isFinite 42 +## Num.is_finite(42) ## ``` -isFinite : Frac * -> Bool +is_finite : Frac * -> Bool ## Returns the absolute value of the number. ## @@ -678,17 +677,17 @@ isFinite : Frac * -> Bool ## * For a negative number, returns the same number except positive. ## * For zero, returns zero. ## ```roc -## Num.abs 4 +## Num.abs(4) ## -## Num.abs -2.5 +## Num.abs(-2.5) ## -## Num.abs 0 +## Num.abs(0) ## -## Num.abs 0.0 +## Num.abs(0.0) ## ``` ## This is safe to use with any [Frac], but it can cause overflow when used with certain [Int] values. ## -## For example, calling #Num.abs on the lowest value of a signed integer (such as [Num.minI64] or [Num.minI32]) will cause overflow. +## For example, calling #Num.abs on the lowest value of a signed integer (such as [Num.min_i64] or [Num.min_i32]) will cause overflow. ## This is because, for any given size of signed integer (32-bit, 64-bit, etc.) its negated lowest value turns out to be 1 higher than ## the highest value it can represent. (For this reason, calling [Num.neg] on the lowest signed value will also cause overflow.) ## @@ -698,19 +697,19 @@ abs : Num a -> Num a ## Returns the absolute difference between two numbers. ## ## ```roc -## Num.absDiff 5 3 +## Num.abs_diff(5, 3) ## -## Num.absDiff -3 5 +## Num.abs_diff(-3, 5) ## -## Num.absDiff 3.0 5.0 +## Num.abs_diff(3.0, 5.0) ## ``` ## ## If the answer to this operation can't fit in the return value (e.g. an ## [I8] answer that's higher than 127 or lower than -128), the result is an ## *overflow*. For [F64] and [F32], overflow results in an answer of either ## ∞ or -∞. For all other number types, overflow results in a panic. -absDiff : Num a, Num a -> Num a -absDiff = \a, b -> +abs_diff : Num a, Num a -> Num a +abs_diff = \a, b -> if a > b then a - b else @@ -718,20 +717,20 @@ absDiff = \a, b -> ## Returns a negative number when given a positive one, and vice versa. ## ```roc -## Num.neg 5 +## Num.neg(5) ## -## Num.neg -2.5 +## Num.neg(-2.5) ## -## Num.neg 0 +## Num.neg(0) ## -## Num.neg 0.0 +## Num.neg(0.0) ## ``` ## !! Num.neg is not completely implemented for all types in all contexts, see github.com/roc-lang/roc/issues/6959 ## You can use `\someNum -> 0 - someNum` as a workaround. ## ## This is safe to use with any [Frac], but it can cause overflow when used with certain [Int] values. ## -## For example, calling #Num.neg on the lowest value of a signed integer (such as [Num.minI64] or [Num.minI32]) will cause overflow. +## For example, calling #Num.neg on the lowest value of a signed integer (such as [Num.min_i64] or [Num.min_i32]) will cause overflow. ## This is because, for any given size of signed integer (32-bit, 64-bit, etc.) its negated lowest value turns out to be 1 higher than ## the highest value it can represent. (For this reason, calling #Num.abs on the lowest signed value will also cause overflow.) ## @@ -744,16 +743,16 @@ neg : Num a -> Num a ## ## (To add an [Int] and a [Frac], first convert one so that they both have the same type. There are functions in this module that can convert both [Int] to [Frac] and the other way around.) ## -## `a + b` is shorthand for `Num.add a b`. +## `a + b` is shorthand for `Num.add(a, b)`. ## ```roc ## 5 + 7 ## -## Num.add 5 7 +## Num.add(5, 7) ## ``` ## `Num.add` can be convenient in pipelines. ## ```roc ## Frac.pi -## |> Num.add 1.0 +## |> Num.add(1.0) ## ``` ## If the answer to this operation can't fit in the return value (e.g. an ## [I8] answer that's higher than 127 or lower than -128), the result is an @@ -765,16 +764,16 @@ add : Num a, Num a -> Num a ## ## (To subtract an [Int] and a [Frac], first convert one so that they both have the same type. There are functions in this module that can convert both [Int] to [Frac] and the other way around.) ## -## `a - b` is shorthand for `Num.sub a b`. +## `a - b` is shorthand for `Num.sub(a, b)`. ## ```roc ## 7 - 5 ## -## Num.sub 7 5 +## Num.sub(7, 5) ## ``` ## `Num.sub` can be convenient in pipelines. ## ```roc ## Frac.pi -## |> Num.sub 2.0 +## |> Num.sub(2.0) ## ``` ## If the answer to this operation can't fit in the return value (e.g. an ## [I8] answer that's higher than 127 or lower than -128), the result is an @@ -786,18 +785,18 @@ sub : Num a, Num a -> Num a ## ## (To multiply an [Int] and a [Frac], first convert one so that they both have the same type. There are functions in this module that can convert both [Int] to [Frac] and the other way around.) ## -## `a * b` is shorthand for `Num.mul a b`. +## `a * b` is shorthand for `Num.mul(a, b)`. ## ```roc ## 5 * 7 ## -## Num.mul 5 7 +## Num.mul(5, 7) ## ``` ## ## `Num.mul` can be convenient in pipelines. ## ## ```roc ## Frac.pi -## |> Num.mul 2.0 +## |> Num.mul(2.0) ## ``` ## If the answer to this operation can't fit in the return value (e.g. an ## [I8] answer that's higher than 127 or lower than -128), the result is an @@ -808,9 +807,9 @@ mul : Num a, Num a -> Num a ## Obtains the smaller between two numbers of the same type. ## ## ```roc -## Num.min 100 0 +## Num.min(100, 0) ## -## Num.min 3.0 -3.0 +## Num.min(3.0, -3.0) ## ``` min : Num a, Num a -> Num a min = \a, b -> @@ -822,9 +821,9 @@ min = \a, b -> ## Obtains the greater between two numbers of the same type. ## ## ```roc -## Num.max 100 0 +## Num.max(100, 0) ## -## Num.max 3.0 -3.0 +## Num.max(3.0, -3.0) ## ``` max : Num a, Num a -> Num a max = \a, b -> @@ -848,8 +847,8 @@ atan : Frac a -> Frac a ## function a negative number! Calling [sqrt] on a negative [Dec] will cause a panic. ## ## Calling [sqrt] on [F32] and [F64] values follows these rules: -## * Passing a negative [F64] or [F32] returns [*NaN*](Num.isNaN). -## * Passing [*NaN*](Num.isNaN) or -∞ also returns [*NaN*](Num.isNaN). +## * Passing a negative [F64] or [F32] returns [*NaN*](Num.is_nan). +## * Passing [*NaN*](Num.is_nan) or -∞ also returns [*NaN*](Num.is_nan). ## * Passing ∞ returns ∞. ## ## > These rules come from the [IEEE-754](https://en.wikipedia.org/wiki/IEEE_754) @@ -858,36 +857,36 @@ atan : Frac a -> Frac a ## > cost! Since the most common reason to choose [F64] or [F32] over [Dec] is ## > access to hardware-accelerated performance, Roc follows these rules exactly. ## ```roc -## Num.sqrt 4.0 +## Num.sqrt(4.0) ## -## Num.sqrt 1.5 +## Num.sqrt(1.5) ## -## Num.sqrt 0.0 +## Num.sqrt(0.0) ## -## Num.sqrt -4.0f64 +## Num.sqrt(-4.0f64) ## ``` sqrt : Frac a -> Frac a -sqrtChecked : Frac a -> Result (Frac a) [SqrtOfNegative] -sqrtChecked = \x -> +sqrt_checked : Frac a -> Result (Frac a) [SqrtOfNegative] +sqrt_checked = \x -> if x < 0.0 then - Err SqrtOfNegative + Err(SqrtOfNegative) else - Ok (Num.sqrt x) + Ok(Num.sqrt(x)) ## Natural logarithm log : Frac a -> Frac a -logChecked : Frac a -> Result (Frac a) [LogNeedsPositive] -logChecked = \x -> +log_checked : Frac a -> Result (Frac a) [LogNeedsPositive] +log_checked = \x -> if x <= 0.0 then - Err LogNeedsPositive + Err(LogNeedsPositive) else - Ok (Num.log x) + Ok(Num.log(x)) ## Divides one [Frac] by another. ## -## `a / b` is shorthand for `Num.div a b`. +## `a / b` is shorthand for `Num.div(a, b)`. ## ## [Division by zero is undefined in mathematics](https://en.wikipedia.org/wiki/Division_by_zero). ## As such, you should make sure never to pass zero as the denominator to this function! @@ -896,7 +895,7 @@ logChecked = \x -> ## Calling [div] on [F32] and [F64] values follows these rules: ## * Dividing a positive [F64] or [F32] by zero returns ∞. ## * Dividing a negative [F64] or [F32] by zero returns -∞. -## * Dividing a zero [F64] or [F32] by zero returns [*NaN*](Num.isNaN). +## * Dividing a zero [F64] or [F32] by zero returns [*NaN*](Num.is_nan). ## ## > These rules come from the [IEEE-754](https://en.wikipedia.org/wiki/IEEE_754) ## > floating point standard. Because almost all modern processors are built to @@ -909,34 +908,34 @@ logChecked = \x -> ## ```roc ## 5.0 / 7.0 ## -## Num.div 5 7 +## Num.div(5, 7) ## ``` ## `Num.div` can be convenient in pipelines. ## ```roc ## Num.pi -## |> Num.div 2.0 +## |> Num.div (2.0) ## ``` div : Frac a, Frac a -> Frac a -divChecked : Frac a, Frac a -> Result (Frac a) [DivByZero] -divChecked = \a, b -> - if Num.isZero b then - Err DivByZero +div_checked : Frac a, Frac a -> Result (Frac a) [DivByZero] +div_checked = \a, b -> + if Num.is_zero(b) then + Err(DivByZero) else - Ok (Num.div a b) + Ok(Num.div(a, b)) -divCeil : Int a, Int a -> Int a +div_ceil : Int a, Int a -> Int a -divCeilChecked : Int a, Int a -> Result (Int a) [DivByZero] -divCeilChecked = \a, b -> - if Num.isZero b then - Err DivByZero +div_ceil_checked : Int a, Int a -> Result (Int a) [DivByZero] +div_ceil_checked = \a, b -> + if Num.is_zero(b) then + Err(DivByZero) else - Ok (Num.divCeil a b) + Ok(Num.div_ceil(a, b)) ## Divides two integers, truncating the result towards zero. ## -## `a // b` is shorthand for `Num.divTrunc a b`. +## `a // b` is shorthand for `Num.div_trunc(a, b)`. ## ## Division by zero is undefined in mathematics. As such, you should make ## sure never to pass zero as the denominator to this function! If you do, @@ -944,117 +943,117 @@ divCeilChecked = \a, b -> ## ```roc ## 5 // 7 ## -## Num.divTrunc 5 7 +## Num.div_trunc(5, 7) ## ## 8 // -3 ## -## Num.divTrunc 8 -3 +## Num.div_trunc(8, -3) ## ``` -divTrunc : Int a, Int a -> Int a -divTrunc = \a, b -> - if Num.isZero b then - crash "Integer division by 0!" +div_trunc : Int a, Int a -> Int a +div_trunc = \a, b -> + if Num.is_zero(b) then + crash("Integer division by 0!") else - Num.divTruncUnchecked a b + Num.div_trunc_unchecked(a, b) -divTruncChecked : Int a, Int a -> Result (Int a) [DivByZero] -divTruncChecked = \a, b -> - if Num.isZero b then - Err DivByZero +div_trunc_checked : Int a, Int a -> Result (Int a) [DivByZero] +div_trunc_checked = \a, b -> + if Num.is_zero(b) then + Err(DivByZero) else - Ok (Num.divTruncUnchecked a b) + Ok(Num.div_trunc_unchecked(a, b)) ## traps (hardware fault) when given zero as the second argument. -divTruncUnchecked : Int a, Int a -> Int a +div_trunc_unchecked : Int a, Int a -> Int a ## Obtains the remainder (truncating modulo) from the division of two integers. ## -## `a % b` is shorthand for `Num.rem a b`. +## `a % b` is shorthand for `Num.rem(a, b)`. ## ```roc ## 5 % 7 ## -## Num.rem 5 7 +## Num.rem(5, 7) ## ## -8 % -3 ## -## Num.rem -8 -3 +## Num.rem(-8, -3) ## ``` rem : Int a, Int a -> Int a rem = \a, b -> - if Num.isZero b then - crash "Integer division by 0!" + if Num.is_zero(b) then + crash("Integer division by 0!") else - Num.remUnchecked a b + Num.rem_unchecked(a, b) -remChecked : Int a, Int a -> Result (Int a) [DivByZero] -remChecked = \a, b -> - if Num.isZero b then - Err DivByZero +rem_checked : Int a, Int a -> Result (Int a) [DivByZero] +rem_checked = \a, b -> + if Num.is_zero(b) then + Err(DivByZero) else - Ok (Num.remUnchecked a b) + Ok(Num.rem_unchecked(a, b)) ## traps (hardware fault) when given zero as the second argument. -remUnchecked : Int a, Int a -> Int a +rem_unchecked : Int a, Int a -> Int a -isMultipleOf : Int a, Int a -> Bool +is_multiple_of : Int a, Int a -> Bool ## Does a "bitwise and". Each bit of the output is 1 if the corresponding bit ## of x AND of y is 1, otherwise it's 0. -bitwiseAnd : Int a, Int a -> Int a +bitwise_and : Int a, Int a -> Int a ## Does a "bitwise exclusive or". Each bit of the output is the same as the ## corresponding bit in x if that bit in y is 0, and it's the complement of ## the bit in x if that bit in y is 1. -bitwiseXor : Int a, Int a -> Int a +bitwise_xor : Int a, Int a -> Int a ## Does a "bitwise or". Each bit of the output is 0 if the corresponding bit ## of x OR of y is 0, otherwise it's 1. -bitwiseOr : Int a, Int a -> Int a +bitwise_or : Int a, Int a -> Int a ## Returns the complement of x - the number you get by switching each 1 for a ## 0 and each 0 for a 1. This is the same as -x - 1. -bitwiseNot : Int a -> Int a -bitwiseNot = \n -> - bitwiseXor n (subWrap 0 1) +bitwise_not : Int a -> Int a +bitwise_not = \n -> + bitwise_xor(n, sub_wrap(0, 1)) ## Bitwise left shift of a number by another ## ## The least significant bits always become 0. This means that shifting left is ## like multiplying by factors of two for unsigned integers. ## ```roc -## shiftLeftBy 0b0000_0011 2 == 0b0000_1100 +## shift_left_by(0b0000_0011, 2) == 0b0000_1100 ## -## 0b0000_0101 |> shiftLeftBy 2 == 0b0001_0100 +## 0b0000_0101 |> shift_left_by(2) == 0b0001_0100 ## ``` -## In some languages `shiftLeftBy` is implemented as a binary operator `<<`. -shiftLeftBy : Int a, U8 -> Int a +## In some languages `shift_left_by` is implemented as a binary operator `<<`. +shift_left_by : Int a, U8 -> Int a ## Bitwise arithmetic shift of a number by another ## ## The most significant bits are copied from the current. ## ```roc -## shiftRightBy 0b0000_1100 2 == 0b0000_0011 +## shift_right_by(0b0000_1100, 2) == 0b0000_0011 ## -## 0b0001_0100 |> shiftRightBy 2 == 0b0000_0101 +## 0b0001_0100 |> shift_right_by(2) == 0b0000_0101 ## -## 0b1001_0000 |> shiftRightBy 2 == 0b1110_0100 +## 0b1001_0000 |> shift_right_by(2) == 0b1110_0100 ## ``` -## In some languages `shiftRightBy` is implemented as a binary operator `>>>`. -shiftRightBy : Int a, U8 -> Int a +## In some languages `shift_right_by` is implemented as a binary operator `>>>`. +shift_right_by : Int a, U8 -> Int a ## Bitwise logical right shift of a number by another ## ## The most significant bits always become 0. This means that shifting right is ## like dividing by factors of two for unsigned integers. ## ```roc -## shiftRightZfBy 0b0010_1000 2 == 0b0000_1010 +## shift_right_zf_by(0b0010_1000, 2) == 0b0000_1010 ## -## 0b0010_1000 |> shiftRightZfBy 2 == 0b0000_1010 +## 0b0010_1000 |> shift_right_zf_by(2) == 0b0000_1010 ## -## 0b1001_0000 |> shiftRightZfBy 2 == 0b0010_0100 +## 0b1001_0000 |> shift_right_zf_by(2) == 0b0010_0100 ## ``` -## In some languages `shiftRightZfBy` is implemented as a binary operator `>>`. -shiftRightZfBy : Int a, U8 -> Int a +## In some languages `shift_right_zf_by` is implemented as a binary operator `>>`. +shift_right_zf_by : Int a, U8 -> Int a ## Round off the given fraction to the nearest integer. round : Frac * -> Int * @@ -1063,7 +1062,7 @@ ceiling : Frac * -> Int * ## Raises a [Frac] to the power of another [Frac]. ## -## For an [Int] alternative to this function, see [Num.powInt] +## For an [Int] alternative to this function, see [Num.pow_int] pow : Frac a, Frac a -> Frac a ## Raises an integer to the power of another, by multiplying the integer by @@ -1078,48 +1077,48 @@ pow : Frac a, Frac a -> Frac a ## ## It is very easy for this function to produce an answer ## so large it causes an overflow. -powInt : Int a, Int a -> Int a +pow_int : Int a, Int a -> Int a ## Counts the number of most-significant (leading in a big-Endian sense) zeroes in an integer. ## ## ```roc -## Num.countLeadingZeroBits 0b0001_1100u8 +## Num.count_leading_zero_bits(0b0001_1100u8) ## ## 3 ## -## Num.countLeadingZeroBits 0b0000_0000u8 +## Num.count_leading_zero_bits(0b0000_0000u8) ## ## 8 ## ``` -countLeadingZeroBits : Int a -> U8 +count_leading_zero_bits : Int a -> U8 ## Counts the number of least-significant (trailing in a big-Endian sense) zeroes in an integer. ## ## ```roc -## Num.countTrailingZeroBits 0b0001_1100u8 +## Num.count_trailing_zero_bits(0b0001_1100u8) ## ## 2 ## -## Num.countTrailingZeroBits 0b0000_0000u8 +## Num.count_trailing_zero_bits(0b0000_0000u8) ## ## 8 ## ``` -countTrailingZeroBits : Int a -> U8 +count_trailing_zero_bits : Int a -> U8 ## Counts the number of set bits in an integer. ## ## ```roc -## Num.countOneBits 0b0001_1100u8 +## Num.count_one_bits(0b0001_1100u8) ## ## 3 ## -## Num.countOneBits 0b0000_0000u8 +## Num.count_one_bits(0b0000_0000u8) ## ## 0 ## ``` -countOneBits : Int a -> U8 +count_one_bits : Int a -> U8 -addWrap : Int range, Int range -> Int range +add_wrap : Int range, Int range -> Int range ## Adds two numbers, clamping on the maximum representable number rather than ## overflowing. @@ -1128,92 +1127,92 @@ addWrap : Int range, Int range -> Int range ## addition is to overflow. ## For example, if `x : U8` is 200 and `y : U8` is 100, `addSaturated x y` will ## yield 255, the maximum value of a `U8`. -addSaturated : Num a, Num a -> Num a +add_saturated : Num a, Num a -> Num a ## Adds two numbers and checks for overflow. ## ## This is the same as [Num.add] except if the operation overflows, instead of ## panicking or returning ∞ or -∞, it will return `Err Overflow`. -addChecked : Num a, Num a -> Result (Num a) [Overflow] -addChecked = \a, b -> - result = addCheckedLowlevel a b +add_checked : Num a, Num a -> Result (Num a) [Overflow] +add_checked = \a, b -> + result = add_checked_lowlevel(a, b) if result.b then - Err Overflow + Err(Overflow) else - Ok result.a + Ok(result.a) -addCheckedLowlevel : Num a, Num a -> { b : Bool, a : Num a } +add_checked_lowlevel : Num a, Num a -> { b : Bool, a : Num a } -subWrap : Int range, Int range -> Int range +sub_wrap : Int range, Int range -> Int range ## Subtracts two numbers, clamping on the minimum representable number rather ## than overflowing. ## ## This is the same as [Num.sub] except for the saturating behavior if the ## subtraction is to overflow. -## For example, if `x : U8` is 10 and `y : U8` is 20, `subSaturated x y` will +## For example, if `x : U8` is 10 and `y : U8` is 20, `sub_saturated x y` will ## yield 0, the minimum value of a `U8`. -subSaturated : Num a, Num a -> Num a +sub_saturated : Num a, Num a -> Num a ## Subtracts two numbers and checks for overflow. ## ## This is the same as [Num.sub] except if the operation overflows, instead of ## panicking or returning ∞ or -∞, it will return `Err Overflow`. -subChecked : Num a, Num a -> Result (Num a) [Overflow] -subChecked = \a, b -> - result = subCheckedLowlevel a b +sub_checked : Num a, Num a -> Result (Num a) [Overflow] +sub_checked = \a, b -> + result = sub_checked_lowlevel(a, b) if result.b then - Err Overflow + Err(Overflow) else - Ok result.a + Ok(result.a) -subCheckedLowlevel : Num a, Num a -> { b : Bool, a : Num a } +sub_checked_lowlevel : Num a, Num a -> { b : Bool, a : Num a } -mulWrap : Int range, Int range -> Int range +mul_wrap : Int range, Int range -> Int range ## Multiplies two numbers, clamping on the maximum representable number rather than ## overflowing. ## ## This is the same as [Num.mul] except for the saturating behavior if the ## addition is to overflow. -mulSaturated : Num a, Num a -> Num a +mul_saturated : Num a, Num a -> Num a ## Multiplies two numbers and checks for overflow. ## ## This is the same as [Num.mul] except if the operation overflows, instead of ## panicking or returning ∞ or -∞, it will return `Err Overflow`. -mulChecked : Num a, Num a -> Result (Num a) [Overflow] -mulChecked = \a, b -> - result = mulCheckedLowlevel a b +mul_checked : Num a, Num a -> Result (Num a) [Overflow] +mul_checked = \a, b -> + result = mul_checked_lowlevel(a, b) if result.b then - Err Overflow + Err(Overflow) else - Ok result.a + Ok(result.a) -mulCheckedLowlevel : Num a, Num a -> { b : Bool, a : Num a } +mul_checked_lowlevel : Num a, Num a -> { b : Bool, a : Num a } ## Returns the lowest number that can be stored in an [I8] without underflowing ## its available memory and crashing. ## ## For reference, this number is `-128`. ## -## Note that the positive version of this number is larger than [Num.maxI8], -## which means if you call [Num.abs] on [Num.minI8], it will overflow and crash! -minI8 : I8 -minI8 = -128i8 +## Note that the positive version of this number is larger than [Num.max_i8], +## which means if you call [Num.abs] on [Num.min_i8], it will overflow and crash! +min_i8 : I8 +min_i8 = -128i8 ## Returns the highest number that can be stored in an [I8] without overflowing ## its available memory and crashing. ## ## For reference, this number is `127`. ## -## Note that this is smaller than the positive version of [Num.minI8], -## which means if you call [Num.abs] on [Num.minI8], it will overflow and crash! -maxI8 : I8 -maxI8 = 127i8 +## Note that this is smaller than the positive version of [Num.min_i8], +## which means if you call [Num.abs] on [Num.min_i8], it will overflow and crash! +max_i8 : I8 +max_i8 = 127i8 ## Returns the lowest number that can be stored in a [U8] without underflowing ## its available memory and crashing. @@ -1222,35 +1221,35 @@ maxI8 = 127i8 ## [unsigned](https://en.wikipedia.org/wiki/Signed_number_representations), ## and zero is the lowest unsigned number. ## Unsigned numbers cannot be negative. -minU8 : U8 -minU8 = 0u8 +min_u8 : U8 +min_u8 = 0u8 ## Returns the highest number that can be stored in a [U8] without overflowing ## its available memory and crashing. ## ## For reference, this number is `255`. -maxU8 : U8 -maxU8 = 255u8 +max_u8 : U8 +max_u8 = 255u8 ## Returns the lowest number that can be stored in an [I16] without underflowing ## its available memory and crashing. ## ## For reference, this number is `-32_768`. ## -## Note that the positive version of this number is larger than [Num.maxI16], -## which means if you call [Num.abs] on [Num.minI16], it will overflow and crash! -minI16 : I16 -minI16 = -32768i16 +## Note that the positive version of this number is larger than [Num.max_i16], +## which means if you call [Num.abs] on [Num.min_i16], it will overflow and crash! +min_i16 : I16 +min_i16 = -32768i16 ## Returns the highest number that can be stored in an [I16] without overflowing ## its available memory and crashing. ## ## For reference, this number is `32_767`. ## -## Note that this is smaller than the positive version of [Num.minI16], -## which means if you call [Num.abs] on [Num.minI16], it will overflow and crash! -maxI16 : I16 -maxI16 = 32767i16 +## Note that this is smaller than the positive version of [Num.min_i16], +## which means if you call [Num.abs] on [Num.min_i16], it will overflow and crash! +max_i16 : I16 +max_i16 = 32767i16 ## Returns the lowest number that can be stored in a [U16] without underflowing ## its available memory and crashing. @@ -1259,25 +1258,25 @@ maxI16 = 32767i16 ## [unsigned](https://en.wikipedia.org/wiki/Signed_number_representations), ## and zero is the lowest unsigned number. ## Unsigned numbers cannot be negative. -minU16 : U16 -minU16 = 0u16 +min_u16 : U16 +min_u16 = 0u16 ## Returns the highest number that can be stored in a [U16] without overflowing ## its available memory and crashing. ## ## For reference, this number is `65_535`. -maxU16 : U16 -maxU16 = 65535u16 +max_u16 : U16 +max_u16 = 65535u16 ## Returns the lowest number that can be stored in an [I32] without underflowing ## its available memory and crashing. ## ## For reference, this number is `-2_147_483_648`. ## -## Note that the positive version of this number is larger than [Num.maxI32], -## which means if you call [Num.abs] on [Num.minI32], it will overflow and crash! -minI32 : I32 -minI32 = -2147483648 +## Note that the positive version of this number is larger than [Num.max_i32], +## which means if you call [Num.abs] on [Num.min_i32], it will overflow and crash! +min_i32 : I32 +min_i32 = -2147483648 ## Returns the highest number that can be stored in an [I32] without overflowing ## its available memory and crashing. @@ -1285,10 +1284,10 @@ minI32 = -2147483648 ## For reference, this number is `2_147_483_647`, ## which is over 2 million. ## -## Note that this is smaller than the positive version of [Num.minI32], -## which means if you call [Num.abs] on [Num.minI32], it will overflow and crash! -maxI32 : I32 -maxI32 = 2147483647 +## Note that this is smaller than the positive version of [Num.min_i32], +## which means if you call [Num.abs] on [Num.min_i32], it will overflow and crash! +max_i32 : I32 +max_i32 = 2147483647 ## Returns the lowest number that can be stored in a [U32] without underflowing ## its available memory and crashing. @@ -1297,15 +1296,15 @@ maxI32 = 2147483647 ## [unsigned](https://en.wikipedia.org/wiki/Signed_number_representations), ## and zero is the lowest unsigned number. ## Unsigned numbers cannot be negative. -minU32 : U32 -minU32 = 0 +min_u32 : U32 +min_u32 = 0 ## Returns the highest number that can be stored in a [U32] without overflowing ## its available memory and crashing. ## ## For reference, this number is `4_294_967_295`. -maxU32 : U32 -maxU32 = 4294967295 +max_u32 : U32 +max_u32 = 4294967295 ## Returns the lowest number that can be stored in an [I64] without underflowing ## its available memory and crashing. @@ -1313,10 +1312,10 @@ maxU32 = 4294967295 ## For reference, this number is `-9_223_372_036_854_775_808`, ## which is under 9 quintillion. ## -## Note that the positive version of this number is larger than [Num.maxI64], -## which means if you call [Num.abs] on [Num.minI64], it will overflow and crash! -minI64 : I64 -minI64 = -9223372036854775808 +## Note that the positive version of this number is larger than [Num.max_i64], +## which means if you call [Num.abs] on [Num.min_i64], it will overflow and crash! +min_i64 : I64 +min_i64 = -9223372036854775808 ## Returns the highest number that can be stored in an [I64] without overflowing ## its available memory and crashing. @@ -1324,10 +1323,10 @@ minI64 = -9223372036854775808 ## For reference, this number is `9_223_372_036_854_775_807`, ## which is over 9 quintillion. ## -## Note that this is smaller than the positive version of [Num.minI64], -## which means if you call [Num.abs] on [Num.minI64], it will overflow and crash! -maxI64 : I64 -maxI64 = 9223372036854775807 +## Note that this is smaller than the positive version of [Num.min_i64], +## which means if you call [Num.abs] on [Num.min_i64], it will overflow and crash! +max_i64 : I64 +max_i64 = 9223372036854775807 ## Returns the lowest number that can be stored in a [U64] without underflowing ## its available memory and crashing. @@ -1336,16 +1335,16 @@ maxI64 = 9223372036854775807 ## [unsigned](https://en.wikipedia.org/wiki/Signed_number_representations), ## and zero is the lowest unsigned number. ## Unsigned numbers cannot be negative. -minU64 : U64 -minU64 = 0 +min_u64 : U64 +min_u64 = 0 ## Returns the highest number that can be stored in a [U64] without overflowing ## its available memory and crashing. ## ## For reference, this number is `18_446_744_073_709_551_615`, ## which is over 18 quintillion. -maxU64 : U64 -maxU64 = 18446744073709551615 +max_u64 : U64 +max_u64 = 18446744073709551615 ## Returns the lowest number that can be stored in an [I128] without underflowing ## its available memory and crashing. @@ -1353,10 +1352,10 @@ maxU64 = 18446744073709551615 ## For reference, this number is `-170_141_183_460_469_231_731_687_303_715_884_105_728`. ## which is under 170 undecillion. ## -## Note that the positive version of this number is larger than [Num.maxI128], -## which means if you call [Num.abs] on [Num.minI128], it will overflow and crash! -minI128 : I128 -minI128 = -170141183460469231731687303715884105728 +## Note that the positive version of this number is larger than [Num.max_i128], +## which means if you call [Num.abs] on [Num.min_i128], it will overflow and crash! +min_i128 : I128 +min_i128 = -170141183460469231731687303715884105728 ## Returns the highest number that can be stored in an [I128] without overflowing ## its available memory and crashing. @@ -1364,10 +1363,10 @@ minI128 = -170141183460469231731687303715884105728 ## For reference, this number is `170_141_183_460_469_231_731_687_303_715_884_105_727`, ## which is over 170 undecillion. ## -## Note that this is smaller than the positive version of [Num.minI128], -## which means if you call [Num.abs] on [Num.minI128], it will overflow and crash! -maxI128 : I128 -maxI128 = 170141183460469231731687303715884105727 +## Note that this is smaller than the positive version of [Num.min_i128], +## which means if you call [Num.abs] on [Num.min_i128], it will overflow and crash! +max_i128 : I128 +max_i128 = 170141183460469231731687303715884105727 ## Returns the lowest number that can be stored in a [U128] without underflowing ## its available memory and crashing. @@ -1376,114 +1375,114 @@ maxI128 = 170141183460469231731687303715884105727 ## [unsigned](https://en.wikipedia.org/wiki/Signed_number_representations), ## and zero is the lowest unsigned number. ## Unsigned numbers cannot be negative. -minU128 : U128 -minU128 = 0 +min_u128 : U128 +min_u128 = 0 ## Returns the highest number that can be stored in a [U128] without overflowing ## its available memory and crashing. ## ## For reference, this number is `340_282_366_920_938_463_463_374_607_431_768_211_455`, ## which is over 340 undecillion. -maxU128 : U128 -maxU128 = 340282366920938463463374607431768211455 +max_u128 : U128 +max_u128 = 340282366920938463463374607431768211455 -minF32 : F32 -minF32 = -3.40282347e38 +min_f32 : F32 +min_f32 = -3.40282347e38 -maxF32 : F32 -maxF32 = 3.40282347e38 +max_f32 : F32 +max_f32 = 3.40282347e38 -minF64 : F64 -minF64 = -1.7976931348623157e308 +min_f64 : F64 +min_f64 = -1.7976931348623157e308 -maxF64 : F64 -maxF64 = 1.7976931348623157e308 +max_f64 : F64 +max_f64 = 1.7976931348623157e308 ## Converts an [Int] to an [I8]. If the given number can't be precisely represented in an [I8], ## the returned number may be different from the given number. -toI8 : Int * -> I8 -toI16 : Int * -> I16 -toI32 : Int * -> I32 -toI64 : Int * -> I64 -toI128 : Int * -> I128 -toU8 : Int * -> U8 -toU16 : Int * -> U16 -toU32 : Int * -> U32 -toU64 : Int * -> U64 -toU128 : Int * -> U128 +to_i8 : Int * -> I8 +to_i16 : Int * -> I16 +to_i32 : Int * -> I32 +to_i64 : Int * -> I64 +to_i128 : Int * -> I128 +to_u8 : Int * -> U8 +to_u16 : Int * -> U16 +to_u32 : Int * -> U32 +to_u64 : Int * -> U64 +to_u128 : Int * -> U128 ## Converts a [Num] to an [F32]. If the given number can't be precisely represented in an [F32], ## the returned number may be different from the given number. -toF32 : Num * -> F32 +to_f32 : Num * -> F32 ## Converts a [Num] to an [F64]. If the given number can't be precisely represented in an [F64], ## the returned number may be different from the given number. -toF64 : Num * -> F64 +to_f64 : Num * -> F64 ## Converts a [Int] to an [I8]. ## If the given integer can't be precisely represented in an [I8], returns ## `Err OutOfBounds`. -toI8Checked : Int * -> Result I8 [OutOfBounds] -toI16Checked : Int * -> Result I16 [OutOfBounds] -toI32Checked : Int * -> Result I32 [OutOfBounds] -toI64Checked : Int * -> Result I64 [OutOfBounds] -toI128Checked : Int * -> Result I128 [OutOfBounds] -toU8Checked : Int * -> Result U8 [OutOfBounds] -toU16Checked : Int * -> Result U16 [OutOfBounds] -toU32Checked : Int * -> Result U32 [OutOfBounds] -toU64Checked : Int * -> Result U64 [OutOfBounds] -toU128Checked : Int * -> Result U128 [OutOfBounds] -toF32Checked : Num * -> Result F32 [OutOfBounds] -toF64Checked : Num * -> Result F64 [OutOfBounds] +to_i8_checked : Int * -> Result I8 [OutOfBounds] +to_i16_checked : Int * -> Result I16 [OutOfBounds] +to_i32_checked : Int * -> Result I32 [OutOfBounds] +to_i64_checked : Int * -> Result I64 [OutOfBounds] +to_i128_checked : Int * -> Result I128 [OutOfBounds] +to_u8_checked : Int * -> Result U8 [OutOfBounds] +to_u16_checked : Int * -> Result U16 [OutOfBounds] +to_u32_checked : Int * -> Result U32 [OutOfBounds] +to_u64_checked : Int * -> Result U64 [OutOfBounds] +to_u128_checked : Int * -> Result U128 [OutOfBounds] +to_f32_checked : Num * -> Result F32 [OutOfBounds] +to_f64_checked : Num * -> Result F64 [OutOfBounds] ## Turns a [Dec] into its [I128] representation by removing the decimal point. ## This is equivalent to multiplying the [Dec] by 10^18. -withoutDecimalPoint : Dec -> I128 +without_decimal_point : Dec -> I128 ## Turns a [I128] into the coresponding [Dec] by adding the decimal point. ## This is equivalent to dividing the [I128] by 10^18. -withDecimalPoint : I128 -> Dec +with_decimal_point : I128 -> Dec ## Splits a [F32] into its components according to IEEE 754 standard. -f32ToParts : F32 -> { sign : Bool, exponent : U8, fraction : U32 } +f32_to_parts : F32 -> { sign : Bool, exponent : U8, fraction : U32 } ## Splits a [F64] into its components according to IEEE 754 standard. -f64ToParts : F64 -> { sign : Bool, exponent : U16, fraction : U64 } +f64_to_parts : F64 -> { sign : Bool, exponent : U16, fraction : U64 } ## Combine parts of a [F32] according to IEEE 754 standard. ## The fraction should not be bigger than 0x007F_FFFF, any bigger value will be truncated. -f32FromParts : { sign : Bool, exponent : U8, fraction : U32 } -> F32 +f32_from_parts : { sign : Bool, exponent : U8, fraction : U32 } -> F32 ## Combine parts of a [F64] according to IEEE 754 standard. ## The fraction should not be bigger than 0x000F_FFFF_FFFF_FFFF, any bigger value will be truncated. ## The exponent should not be bigger than 0x07FF, any bigger value will be truncated. -f64FromParts : { sign : Bool, exponent : U16, fraction : U64 } -> F64 +f64_from_parts : { sign : Bool, exponent : U16, fraction : U64 } -> F64 ## Convert a `Bool` to a `Num` ## ```roc -## expect (Num.fromBool Bool.true) == 1 -## expect (Num.fromBool Bool.false) == 0 +## expect Num.from_bool(Bool.true) == 1 +## expect Num.from_bool(Bool.false) == 0 ## ``` -fromBool : Bool -> Num * -fromBool = \bool -> +from_bool : Bool -> Num * +from_bool = \bool -> if bool then 1 else 0 ## The value for not-a-number for a [F32] according to the IEEE 754 standard. -nanF32 : F32 -nanF32 = 0.0f32 / 0.0 +nan_f32 : F32 +nan_f32 = 0.0f32 / 0.0 ## The value for not-a-number for a [F64] according to the IEEE 754 standard. -nanF64 : F64 -nanF64 = 0.0f64 / 0.0 +nan_f64 : F64 +nan_f64 = 0.0f64 / 0.0 ## The value for infinity for a [F32] according to the IEEE 754 standard. -infinityF32 : F32 -infinityF32 = 1.0f32 / 0.0 +infinity_f32 : F32 +infinity_f32 = 1.0f32 / 0.0 ## The value for infinity for a [F64] according to the IEEE 754 standard. -infinityF64 : F64 -infinityF64 = 1.0f64 / 0.0 +infinity_f64 : F64 +infinity_f64 = 1.0f64 / 0.0 diff --git a/crates/compiler/builtins/roc/Result.roc b/crates/compiler/builtins/roc/Result.roc index 7905215f598..eedec3b6936 100644 --- a/crates/compiler/builtins/roc/Result.roc +++ b/crates/compiler/builtins/roc/Result.roc @@ -1,15 +1,15 @@ module [ Result, - isOk, - isErr, + is_ok, + is_err, map, - mapErr, - mapBoth, + map_err, + map_both, map2, try, - onErr, - onErr!, - withDefault, + on_err, + on_err!, + with_default, ] import Bool exposing [Bool] @@ -20,42 +20,42 @@ Result ok err : [Ok ok, Err err] ## Returns `Bool.true` if the result indicates a success, else returns `Bool.false` ## ```roc -## Result.isOk (Ok 5) +## Result.is_ok(Ok(5)) ## ``` -isOk : Result ok err -> Bool -isOk = \result -> +is_ok : Result ok err -> Bool +is_ok = \result -> when result is - Ok _ -> Bool.true - Err _ -> Bool.false + Ok(_) -> Bool.true + Err(_) -> Bool.false ## Returns `Bool.true` if the result indicates a failure, else returns `Bool.false` ## ```roc -## Result.isErr (Err "uh oh") +## Result.is_err(Err("uh oh")) ## ``` -isErr : Result ok err -> Bool -isErr = \result -> +is_err : Result ok err -> Bool +is_err = \result -> when result is - Ok _ -> Bool.false - Err _ -> Bool.true + Ok(_) -> Bool.false + Err(_) -> Bool.true ## If the result is `Ok`, returns the value it holds. Otherwise, returns ## the given default value. ## ```roc -## Result.withDefault (Ok 7) 42 -## Result.withDefault (Err "uh oh") 42 +## Result.with_default(Ok(7), 42) +## Result.with_default(Err("uh oh"), 42) ## ``` -withDefault : Result ok err, ok -> ok -withDefault = \result, default -> +with_default : Result ok err, ok -> ok +with_default = \result, default -> when result is - Ok value -> value - Err _ -> default + Ok(value) -> value + Err(_) -> default ## If the result is `Ok`, transforms the value it holds by running a conversion ## function on it. Then returns a new `Ok` holding the transformed value. If the -## result is `Err`, this has no effect. Use [mapErr] to transform an `Err`. +## result is `Err`, this has no effect. Use [map_err] to transform an `Err`. ## ```roc -## Result.map (Ok 12) Num.neg -## Result.map (Err "yipes!") Num.neg +## Result.map(Ok(12), Num.neg) +## Result.map(Err("yipes!"), Num.neg) ## ``` ## ## Functions like `map` are common in Roc; see for example [List.map], @@ -63,73 +63,75 @@ withDefault = \result, default -> map : Result a err, (a -> b) -> Result b err map = \result, transform -> when result is - Ok v -> Ok (transform v) - Err e -> Err e + Ok(v) -> Ok(transform(v)) + Err(e) -> Err(e) ## If the result is `Err`, transforms the value it holds by running a conversion ## function on it. Then returns a new `Err` holding the transformed value. If ## the result is `Ok`, this has no effect. Use [map] to transform an `Ok`. ## ```roc -## Result.mapErr (Err "yipes!") Str.isEmpty -## Result.mapErr (Ok 12) Str.isEmpty +## Result.map_err(Err("yipes!"), Str.is_empty) +## Result.map_err(Ok(12), Str.is_empty) ## ``` -mapErr : Result ok a, (a -> b) -> Result ok b -mapErr = \result, transform -> +map_err : Result ok a, (a -> b) -> Result ok b +map_err = \result, transform -> when result is - Ok v -> Ok v - Err e -> Err (transform e) + Ok(v) -> Ok(v) + Err(e) -> Err(transform(e)) ## Maps both the `Ok` and `Err` values of a `Result` to new values. -mapBoth : Result ok1 err1, (ok1 -> ok2), (err1 -> err2) -> Result ok2 err2 -mapBoth = \result, okTransform, errTransform -> +map_both : Result ok1 err1, (ok1 -> ok2), (err1 -> err2) -> Result ok2 err2 +map_both = \result, ok_transform, err_transform -> when result is - Ok val -> Ok (okTransform val) - Err err -> Err (errTransform err) + Ok(val) -> Ok(ok_transform(val)) + Err(err) -> Err(err_transform(err)) ## Maps the `Ok` values of two `Result`s to a new value using a given transformation, ## or returns the first `Err` value encountered. map2 : Result a err, Result b err, (a, b -> c) -> Result c err -map2 = \firstResult, secondResult, transform -> - when (firstResult, secondResult) is - (Ok first, Ok second) -> Ok (transform first second) - (Err err, _) -> Err err - (_, Err err) -> Err err +map2 = \first_result, second_result, transform -> + when (first_result, second_result) is + (Ok(first), Ok(second)) -> Ok(transform(first, second)) + (Err(err), _) -> Err(err) + (_, Err(err)) -> Err(err) ## If the result is `Ok`, transforms the entire result by running a conversion ## function on the value the `Ok` holds. Then returns that new result. If the -## result is `Err`, this has no effect. Use `onErr` to transform an `Err`. +## result is `Err`, this has no effect. Use `on_err` to transform an `Err`. ## ```roc -## Result.try (Ok -1) \num -> if num < 0 then Err "negative!" else Ok -num -## Result.try (Err "yipes!") \num -> if num < 0 then Err "negative!" else Ok -num +## Result.try(Ok(-1), (\num -> if num < 0 then Err("negative!") else Ok(-num))) +## Result.try(Err("yipes!"), (\num -> if num < 0 then Err("negative!") else Ok(-num))) ## ``` try : Result a err, (a -> Result b err) -> Result b err try = \result, transform -> when result is - Ok v -> transform v - Err e -> Err e + Ok(v) -> transform(v) + Err(e) -> Err(e) ## If the result is `Err`, transforms the entire result by running a conversion ## function on the value the `Err` holds. Then returns that new result. If the ## result is `Ok`, this has no effect. Use `try` to transform an `Ok`. ## ```roc -## Result.onErr (Ok 10) \errorNum -> Str.toU64 errorNum -## Result.onErr (Err "42") \errorNum -> Str.toU64 errorNum +## Result.on_err(Ok(10), (\error_num -> Str.to_u64(error_num))) +## Result.on_err(Err("42"), (\error_num -> Str.to_u64(error_num))) ## ``` -onErr : Result a err, (err -> Result a otherErr) -> Result a otherErr -onErr = \result, transform -> +on_err : Result a err, (err -> Result a other_err) -> Result a other_err +on_err = \result, transform -> when result is - Ok v -> Ok v - Err e -> transform e + Ok(v) -> Ok(v) + Err(e) -> transform(e) -## Like [onErr], but it allows the transformation function to produce effects. +## Like [on_err], but it allows the transformation function to produce effects. ## ## ```roc -## Result.onErr (Err "missing user") \msg -> -## try Stdout.line! "ERROR: $(msg)" -## Err msg +## Result.on_err(Err("missing user"), (\msg -> +## Stdout.line!("ERROR: $(msg)")? +## +## Err(msg) +## )) ## ``` -onErr! : Result a err, (err => Result a otherErr) => Result a otherErr -onErr! = \result, transform! -> +on_err! : Result a err, (err => Result a other_err) => Result a other_err +on_err! = \result, transform! -> when result is - Ok v -> Ok v - Err e -> transform! e + Ok(v) -> Ok(v) + Err(e) -> transform!(e) diff --git a/crates/compiler/builtins/roc/Set.roc b/crates/compiler/builtins/roc/Set.roc index 4d0c4a7332d..d7dc778f043 100644 --- a/crates/compiler/builtins/roc/Set.roc +++ b/crates/compiler/builtins/roc/Set.roc @@ -1,27 +1,27 @@ module [ Set, empty, - withCapacity, + with_capacity, reserve, - releaseExcessCapacity, + release_excess_capacity, single, walk, - walkUntil, - keepIf, - dropIf, + walk_until, + keep_if, + drop_if, insert, len, - isEmpty, + is_empty, capacity, remove, contains, - toList, - fromList, + to_list, + from_list, union, intersection, difference, map, - joinMap, + join_map, ] import List @@ -36,154 +36,154 @@ import Inspect exposing [Inspect, Inspector, InspectFormatter] Set k := Dict.Dict k {} where k implements Hash & Eq implements [ Eq { - isEq, + is_eq, }, Hash { - hash: hashSet, + hash: hash_set, }, Inspect { - toInspector: toInspectorSet, + to_inspector: to_inspector_set, }, ] -isEq : Set k, Set k -> Bool -isEq = \xs, ys -> - if len xs != len ys then +is_eq : Set k, Set k -> Bool +is_eq = \xs, ys -> + if len(xs) != len(ys) then Bool.false else - walkUntil xs Bool.true \_, elem -> - if contains ys elem then - Continue Bool.true + walk_until(xs, Bool.true, \_, elem -> + if contains(ys, elem) then + Continue(Bool.true) else - Break Bool.false + Break(Bool.false)) -hashSet : hasher, Set k -> hasher where hasher implements Hasher -hashSet = \hasher, @Set inner -> Hash.hash hasher inner +hash_set : hasher, Set k -> hasher where hasher implements Hasher +hash_set = \hasher, @Set(inner) -> Hash.hash(hasher, inner) -toInspectorSet : Set k -> Inspector f where k implements Inspect & Hash & Eq, f implements InspectFormatter -toInspectorSet = \set -> - Inspect.custom \fmt -> - Inspect.apply (Inspect.set set walk Inspect.toInspector) fmt +to_inspector_set : Set k -> Inspector f where k implements Inspect & Hash & Eq, f implements InspectFormatter +to_inspector_set = \set -> + Inspect.custom(\fmt -> + Inspect.apply(Inspect.set(set, walk, Inspect.to_inspector), fmt)) ## Creates a new empty `Set`. ## ```roc -## emptySet = Set.empty {} -## countValues = Set.len emptySet +## empty_set = Set.empty({}) +## count_values = Set.len(empty_set) ## -## expect countValues == 0 +## expect count_values == 0 ## ``` empty : {} -> Set * -empty = \{} -> @Set (Dict.empty {}) +empty = \{} -> @Set(Dict.empty({})) ## Return a set with space allocated for a number of entries. This ## may provide a performance optimization if you know how many entries will be ## inserted. -withCapacity : U64 -> Set * -withCapacity = \cap -> - @Set (Dict.withCapacity cap) +with_capacity : U64 -> Set * +with_capacity = \cap -> + @Set(Dict.with_capacity(cap)) ## Enlarge the set for at least capacity additional elements reserve : Set k, U64 -> Set k -reserve = \@Set dict, requested -> - @Set (Dict.reserve dict requested) +reserve = \@Set(dict), requested -> + @Set(Dict.reserve(dict, requested)) ## Shrink the memory footprint of a set such that capacity is as small as possible. ## This function will require regenerating the metadata if the size changes. ## There will still be some overhead due to dictionary metadata always being a power of 2. -releaseExcessCapacity : Set k -> Set k -releaseExcessCapacity = \@Set dict -> - @Set (Dict.releaseExcessCapacity dict) +release_excess_capacity : Set k -> Set k +release_excess_capacity = \@Set(dict) -> + @Set(Dict.release_excess_capacity(dict)) ## Creates a new `Set` with a single value. ## ```roc -## singleItemSet = Set.single "Apple" -## countValues = Set.len singleItemSet +## single_item_set = Set.single("Apple") +## count_values = Set.len(single_item_set) ## -## expect countValues == 1 +## expect count_values == 1 ## ``` single : k -> Set k single = \key -> - Dict.single key {} |> @Set + Dict.single(key, {}) |> @Set ## Insert a value into a `Set`. ## ```roc -## fewItemSet = -## Set.empty {} -## |> Set.insert "Apple" -## |> Set.insert "Pear" -## |> Set.insert "Banana" +## few_item_set = +## Set.empty({}) +## |> Set.insert("Apple") +## |> Set.insert("Pear") +## |> Set.insert("Banana") ## -## countValues = Set.len fewItemSet +## count_values = Set.len(few_item_set) ## -## expect countValues == 3 +## expect count_values == 3 ## ``` insert : Set k, k -> Set k -insert = \@Set dict, key -> - Dict.insert dict key {} |> @Set +insert = \@Set(dict), key -> + Dict.insert(dict, key, {}) |> @Set # Inserting a duplicate key has no effect. expect actual = - empty {} - |> insert "foo" - |> insert "bar" - |> insert "foo" - |> insert "baz" + empty({}) + |> insert("foo") + |> insert("bar") + |> insert("foo") + |> insert("baz") expected = - empty {} - |> insert "foo" - |> insert "bar" - |> insert "baz" + empty({}) + |> insert("foo") + |> insert("bar") + |> insert("baz") expected == actual ## Counts the number of values in a given `Set`. ## ```roc -## fewItemSet = -## Set.empty {} -## |> Set.insert "Apple" -## |> Set.insert "Pear" -## |> Set.insert "Banana" +## few_item_set = +## Set.empty({}) +## |> Set.insert("Apple") +## |> Set.insert("Pear") +## |> Set.insert("Banana") ## -## countValues = Set.len fewItemSet +## count_values = Set.len(few_item_set) ## -## expect countValues == 3 +## expect count_values == 3 ## ``` len : Set * -> U64 -len = \@Set dict -> - Dict.len dict +len = \@Set(dict) -> + Dict.len(dict) ## Returns the max number of elements the set can hold before requiring a rehash. ## ```roc -## foodSet = -## Set.empty {} -## |> Set.insert "apple" +## food_set = +## Set.empty({}) +## |> Set.insert("apple") ## -## capacityOfSet = Set.capacity foodSet +## capacity_of_set = Set.capacity(food_set) ## ``` capacity : Set * -> U64 -capacity = \@Set dict -> - Dict.capacity dict +capacity = \@Set(dict) -> + Dict.capacity(dict) ## Check if the set is empty. ## ```roc -## Set.isEmpty (Set.empty {} |> Set.insert 42) +## Set.is_empty(Set.empty({}) |> Set.insert(42)) ## -## Set.isEmpty (Set.empty {}) +## Set.is_empty(Set.empty({})) ## ``` -isEmpty : Set * -> Bool -isEmpty = \@Set dict -> - Dict.isEmpty dict +is_empty : Set * -> Bool +is_empty = \@Set(dict) -> + Dict.is_empty(dict) # Inserting a duplicate key has no effect on length. expect actual = - empty {} - |> insert "foo" - |> insert "bar" - |> insert "foo" - |> insert "baz" + empty({}) + |> insert("foo") + |> insert("bar") + |> insert("foo") + |> insert("baz") |> len actual == 3 @@ -191,20 +191,20 @@ expect ## Removes the value from the given `Set`. ## ```roc ## numbers = -## Set.empty {} -## |> Set.insert 10 -## |> Set.insert 20 -## |> Set.remove 10 +## Set.empty({}) +## |> Set.insert(10) +## |> Set.insert(20) +## |> Set.remove(10) ## -## has10 = Set.contains numbers 10 -## has20 = Set.contains numbers 20 +## has10 = Set.contains(numbers, 10) +## has20 = Set.contains(numbers, 20) ## ## expect has10 == Bool.false ## expect has20 == Bool.true ## ``` remove : Set k, k -> Set k -remove = \@Set dict, key -> - Dict.remove dict key |> @Set +remove = \@Set(dict), key -> + Dict.remove(dict, key) |> @Set ## Test if a value is in the `Set`. ## ```roc @@ -212,47 +212,47 @@ remove = \@Set dict, key -> ## ## fruit : Set Fruit ## fruit = -## Set.single Apple -## |> Set.insert Pear +## Set.single(Apple) +## |> Set.insert(Pear) ## -## hasApple = Set.contains fruit Apple -## hasBanana = Set.contains fruit Banana +## has_apple = Set.contains(fruit, Apple) +## has_banana = Set.contains(fruit, Banana) ## -## expect hasApple == Bool.true -## expect hasBanana == Bool.false +## expect has_apple == Bool.true +## expect has_banana == Bool.false ## ``` contains : Set k, k -> Bool -contains = \@Set dict, key -> - Dict.contains dict key +contains = \@Set(dict), key -> + Dict.contains(dict, key) ## Retrieve the values in a `Set` as a `List`. ## ```roc ## numbers : Set U64 -## numbers = Set.fromList [1,2,3,4,5] +## numbers = Set.from_list([1,2,3,4,5]) ## ## values = [1,2,3,4,5] ## -## expect Set.toList numbers == values +## expect Set.to_list(numbers) == values ## ``` -toList : Set k -> List k -toList = \@Set dict -> - Dict.keys dict +to_list : Set k -> List k +to_list = \@Set(dict) -> + Dict.keys(dict) ## Create a `Set` from a `List` of values. ## ```roc ## values = -## Set.empty {} -## |> Set.insert Banana -## |> Set.insert Apple -## |> Set.insert Pear +## Set.empty({}) +## |> Set.insert(Banana) +## |> Set.insert(Apple) +## |> Set.insert(Pear) ## -## expect Set.fromList [Pear, Apple, Banana] == values +## expect Set.from_list([Pear, Apple, Banana]) == values ## ``` -fromList : List k -> Set k -fromList = \list -> +from_list : List k -> Set k +from_list = \list -> list - |> List.map \k -> (k, {}) - |> Dict.fromList + |> List.map(\k -> (k, {})) + |> Dict.from_list |> @Set ## Combine two `Set` collection by keeping the @@ -260,234 +260,234 @@ fromList = \list -> ## of all the values pairs. This means that all of the values in both `Set`s ## will be combined. ## ```roc -## set1 = Set.single Left -## set2 = Set.single Right +## set1 = Set.single(Left) +## set2 = Set.single(Right) ## -## expect Set.union set1 set2 == Set.fromList [Left, Right] +## expect Set.union(set1, set2) == Set.from_list([Left, Right]) ## ``` union : Set k, Set k -> Set k -union = \@Set dict1, @Set dict2 -> - Dict.insertAll dict1 dict2 |> @Set +union = \@Set(dict1), @Set(dict2) -> + Dict.insert_all(dict1, dict2) |> @Set ## Combine two `Set`s by keeping the [intersection](https://en.wikipedia.org/wiki/Intersection_(set_theory)) ## of all the values pairs. This means that we keep only those values that are ## in both `Set`s. ## ```roc -## set1 = Set.fromList [Left, Other] -## set2 = Set.fromList [Left, Right] +## set1 = Set.from_list([Left, Other]) +## set2 = Set.from_list([Left, Right]) ## -## expect Set.intersection set1 set2 == Set.single Left +## expect Set.intersection(set1, set2) == Set.single(Left) ## ``` intersection : Set k, Set k -> Set k -intersection = \@Set dict1, @Set dict2 -> - Dict.keepShared dict1 dict2 |> @Set +intersection = \@Set(dict1), @Set(dict2) -> + Dict.keep_shared(dict1, dict2) |> @Set ## Remove the values in the first `Set` that are also in the second `Set` ## using the [set difference](https://en.wikipedia.org/wiki/Complement_(set_theory)#Relative_complement) ## of the values. This means that we will be left with only those values that ## are in the first and not in the second. ## ```roc -## first = Set.fromList [Left, Right, Up, Down] -## second = Set.fromList [Left, Right] +## first = Set.from_list([Left, Right, Up, Down]) +## second = Set.from_list([Left, Right]) ## -## expect Set.difference first second == Set.fromList [Up, Down] +## expect Set.difference(first, second) == Set.from_list([Up, Down]) ## ``` difference : Set k, Set k -> Set k -difference = \@Set dict1, @Set dict2 -> - Dict.removeAll dict1 dict2 |> @Set +difference = \@Set(dict1), @Set(dict2) -> + Dict.remove_all(dict1, dict2) |> @Set ## Iterate through the values of a given `Set` and build a value. ## ```roc -## values = Set.fromList ["March", "April", "May"] +## values = Set.from_list(["March", "April", "May"]) ## -## startsWithLetterM = \month -> -## when Str.toUtf8 month is +## starts_with_letter_m = \month -> +## when Str.to_utf8(month) is ## ['M', ..] -> Bool.true ## _ -> Bool.false ## ## reduce = \state, k -> -## if startsWithLetterM k then +## if starts_with_letter_m(k) then ## state + 1 ## else ## state ## -## result = Set.walk values 0 reduce +## result = Set.walk(values, 0, reduce) ## ## expect result == 2 ## ``` walk : Set k, state, (state, k -> state) -> state -walk = \@Set dict, state, step -> - Dict.walk dict state (\s, k, _ -> step s k) +walk = \@Set(dict), state, step -> + Dict.walk(dict, state, \s, k, _ -> step(s, k)) ## Convert each value in the set to something new, by calling a conversion ## function on each of them which receives the old value. Then return a ## new set containing the converted values. map : Set a, (a -> b) -> Set b map = \set, transform -> - init = withCapacity (capacity set) + init = with_capacity(capacity(set)) - walk set init \answer, k -> - insert answer (transform k) + walk(set, init, \answer, k -> + insert(answer, transform(k))) ## Like [Set.map], except the transformation function wraps the return value ## in a set. At the end, all the sets get joined together ## (using [Set.union]) into one set. ## -## You may know a similar function named `concatMap` in other languages. -joinMap : Set a, (a -> Set b) -> Set b -joinMap = \set, transform -> - init = withCapacity (capacity set) # Might be a pessimization +## You may know a similar function named `concat_map` in other languages. +join_map : Set a, (a -> Set b) -> Set b +join_map = \set, transform -> + init = with_capacity(capacity(set)) # Might be a pessimization - walk set init \answer, k -> - union answer (transform k) + walk(set, init, \answer, k -> + union(answer, transform(k))) ## Iterate through the values of a given `Set` and build a value, can stop ## iterating part way through the collection. ## ```roc -## numbers = Set.fromList [1,2,3,4,5,6,42,7,8,9,10] +## numbers = Set.from_list([1,2,3,4,5,6,42,7,8,9,10]) ## ## find42 = \state, k -> ## if k == 42 then -## Break FoundTheAnswer +## Break(FoundTheAnswer) ## else -## Continue state +## Continue(state) ## -## result = Set.walkUntil numbers NotFound find42 +## result = Set.walk_until(numbers, NotFound, find42) ## ## expect result == FoundTheAnswer ## ``` -walkUntil : Set k, state, (state, k -> [Continue state, Break state]) -> state -walkUntil = \@Set dict, state, step -> - Dict.walkUntil dict state (\s, k, _ -> step s k) +walk_until : Set k, state, (state, k -> [Continue state, Break state]) -> state +walk_until = \@Set(dict), state, step -> + Dict.walk_until(dict, state, \s, k, _ -> step(s, k)) ## Run the given function on each element in the `Set`, and return ## a `Set` with just the elements for which the function returned `Bool.true`. ## ```roc -## expect Set.fromList [1,2,3,4,5] -## |> Set.keepIf \k -> k >= 3 -## |> Bool.isEq (Set.fromList [3,4,5]) +## expect Set.from_list([1,2,3,4,5]) +## |> Set.keep_if(\k -> k >= 3) +## |> Bool.is_eq(Set.from_list([3,4,5])) ## ``` -keepIf : Set k, (k -> Bool) -> Set k -keepIf = \@Set dict, predicate -> - @Set (Dict.keepIf dict (\(k, _v) -> predicate k)) +keep_if : Set k, (k -> Bool) -> Set k +keep_if = \@Set(dict), predicate -> + @Set(Dict.keep_if(dict, \(k, _v) -> predicate(k))) ## Run the given function on each element in the `Set`, and return ## a `Set` with just the elements for which the function returned `Bool.false`. ## ```roc -## expect Set.fromList [1,2,3,4,5] -## |> Set.dropIf \k -> k >= 3 -## |> Bool.isEq (Set.fromList [1,2]) +## expect Set.from_list [1,2,3,4,5] +## |> Set.drop_if(\k -> k >= 3) +## |> Bool.is_eq(Set.from_list([1,2])) ## ``` -dropIf : Set k, (k -> Bool) -> Set k -dropIf = \@Set dict, predicate -> - @Set (Dict.dropIf dict (\(k, _v) -> predicate k)) +drop_if : Set k, (k -> Bool) -> Set k +drop_if = \@Set(dict), predicate -> + @Set(Dict.drop_if(dict, \(k, _v) -> predicate(k))) expect first = - single "Keep Me" - |> insert "And Me" - |> insert "Remove Me" + single("Keep Me") + |> insert("And Me") + |> insert("Remove Me") second = - single "Remove Me" - |> insert "I do nothing..." + single("Remove Me") + |> insert("I do nothing...") expected = - single "Keep Me" - |> insert "And Me" + single("Keep Me") + |> insert("And Me") - difference first second == expected + difference(first, second) == expected expect first = - single "Keep Me" - |> insert "And Me" - |> insert "Remove Me" + single("Keep Me") + |> insert("And Me") + |> insert("Remove Me") second = - single "Remove Me" - |> insert "I do nothing..." + single("Remove Me") + |> insert("I do nothing...") expected = - single "Keep Me" - |> insert "And Me" + single("Keep Me") + |> insert("And Me") - difference first second == expected + difference(first, second) == expected expect first = - single 1 - |> insert 2 + single(1) + |> insert(2) second = - single 1 - |> insert 3 - |> insert 4 + single(1) + |> insert(3) + |> insert(4) expected = - single 1 - |> insert 2 - |> insert 3 - |> insert 4 + single(1) + |> insert(2) + |> insert(3) + |> insert(4) - union first second == expected + union(first, second) == expected expect base = - single "Remove Me" - |> insert "Keep Me" - |> insert "And Me" + single("Remove Me") + |> insert("Keep Me") + |> insert("And Me") expected = - single "Keep Me" - |> insert "And Me" + single("Keep Me") + |> insert("And Me") - remove base "Remove Me" == expected + remove(base, "Remove Me") == expected expect x = - single 0 - |> insert 1 - |> insert 2 - |> insert 3 - |> insert 4 - |> insert 5 - |> insert 6 - |> insert 7 - |> insert 8 - |> insert 9 - - x == fromList (toList x) + single(0) + |> insert(1) + |> insert(2) + |> insert(3) + |> insert(4) + |> insert(5) + |> insert(6) + |> insert(7) + |> insert(8) + |> insert(9) + + x == from_list(to_list(x)) expect - orderOne : Set U64 - orderOne = - single 1 - |> insert 2 + order_one : Set U64 + order_one = + single(1) + |> insert(2) - orderTwo : Set U64 - orderTwo = - single 2 - |> insert 1 + order_two : Set U64 + order_two = + single(2) + |> insert(1) - wrapperOne : Set (Set U64) - wrapperOne = - single orderOne - |> insert orderTwo + wrapper_one : Set (Set U64) + wrapper_one = + single(order_one) + |> insert(order_two) - wrapperTwo : Set (Set U64) - wrapperTwo = - single orderTwo - |> insert orderOne + wrapper_two : Set (Set U64) + wrapper_two = + single(order_two) + |> insert(order_one) - wrapperOne == wrapperTwo + wrapper_one == wrapper_two expect - Set.fromList [1, 2, 3, 4, 5] - |> Set.keepIf \k -> k >= 3 - |> Bool.isEq (Set.fromList [3, 4, 5]) + Set.from_list([1, 2, 3, 4, 5]) + |> Set.keep_if(\k -> k >= 3) + |> Bool.is_eq(Set.from_list([3, 4, 5])) expect - Set.fromList [1, 2, 3, 4, 5] - |> Set.dropIf \k -> k >= 3 - |> Bool.isEq (Set.fromList [1, 2]) + Set.from_list([1, 2, 3, 4, 5]) + |> Set.drop_if(\k -> k >= 3) + |> Bool.is_eq(Set.from_list([1, 2])) diff --git a/crates/compiler/builtins/roc/Str.roc b/crates/compiler/builtins/roc/Str.roc index 331540439ea..3b1f2125294 100644 --- a/crates/compiler/builtins/roc/Str.roc +++ b/crates/compiler/builtins/roc/Str.roc @@ -44,7 +44,7 @@ ## ``` ## colors = ["red", "green", "blue"] ## -## "The colors are $(colors |> Str.joinWith ", ")!" +## "The colors are $(colors |> Str.join_with(", "))!" ## ``` ## ## Interpolation can be used in multiline strings, but the part inside the parentheses must still be on one line. @@ -245,7 +245,7 @@ ## ## A valuable feature of UTF-8 is that it is backwards-compatible with the [ASCII](https://en.wikipedia.org/wiki/ASCII) encoding that was widely used for many years. ASCII existed before Unicode did, and only used the integers 0 to 127 to represent its equivalent of code points. The Unicode code points 0 to 127 represent the same semantic information as ASCII, (e.g. the number 64 represents the letter "A" in both ASCII and in Unicode), and since UTF-8 represents code points 0 to 127 using one byte, all valid ASCII strings can be successfully parsed as UTF-8 without any need for conversion. ## -## Since many textual computer encodings—including [CSV](https://en.wikipedia.org/wiki/CSV), [XML](https://en.wikipedia.org/wiki/XML), and [JSON](https://en.wikipedia.org/wiki/JSON)—do not use any code points above 127 for their delimiters, it is often possible to write parsers for these formats using only `Str` functions which present UTF-8 as raw `U8` sequences, such as [`Str.walkUtf8`](https://www.roc-lang.org/builtins/Str#walkUtf8) and [`Str.toUtf8`](https://www.roc-lang.org/builtins/Str#toUtf8). In the typical case where they do not to need to parse out individual Unicode code points, they can get everything they need from `Str` UTF-8 functions without needing to depend on other packages. +## Since many textual computer encodings—including [CSV](https://en.wikipedia.org/wiki/CSV), [XML](https://en.wikipedia.org/wiki/XML), and [JSON](https://en.wikipedia.org/wiki/JSON)—do not use any code points above 127 for their delimiters, it is often possible to write parsers for these formats using only `Str` functions which present UTF-8 as raw `U8` sequences, such as [`Str.walk_utf8`](https://www.roc-lang.org/builtins/Str#walk_utf8) and [`Str.to_utf8`](https://www.roc-lang.org/builtins/Str#to_utf8). In the typical case where they do not to need to parse out individual Unicode code points, they can get everything they need from `Str` UTF-8 functions without needing to depend on other packages. ## ## ### When to use code points, graphemes, and UTF-8 ## @@ -253,8 +253,8 @@ ## ## The way Roc organizes the `Str` module and supporting packages is designed to help answer this question. Every situation is different, but the following rules of thumb are typical: ## -## * Most often, using `Str` values along with helper functions like [`splitOn`](https://www.roc-lang.org/builtins/Str#splitOn), [`joinWith`](https://www.roc-lang.org/builtins/Str#joinWith), and so on, is the best option. -## * If you are specifically implementing a parser, working in UTF-8 bytes is usually the best option. So functions like [`walkUtf8`](https://www.roc-lang.org/builtins/Str#walkUtf8), [toUtf8](https://www.roc-lang.org/builtins/Str#toUtf8), and so on. (Note that single-quote literals produce number literals, so ASCII-range literals like `'a'` gives an integer literal that works with a UTF-8 `U8`.) +## * Most often, using `Str` values along with helper functions like [`split_on`](https://www.roc-lang.org/builtins/Str#split_on), [`join_with`](https://www.roc-lang.org/builtins/Str#join_with), and so on, is the best option. +## * If you are specifically implementing a parser, working in UTF-8 bytes is usually the best option. So functions like [`walk_utf8`](https://www.roc-lang.org/builtins/Str#walk_utf8), [to_utf8](https://www.roc-lang.org/builtins/Str#to_utf8), and so on. (Note that single-quote literals produce number literals, so ASCII-range literals like `'a'` gives an integer literal that works with a UTF-8 `U8`.) ## * If you are implementing a Unicode library like [roc-lang/unicode](https://github.com/roc-lang/unicode), working in terms of code points will be unavoidable. Aside from basic readability considerations like `\u(...)` in string literals, if you have the option to avoid working in terms of code points, it is almost always correct to avoid them. ## * If it seems like a good idea to split a string into "characters" (graphemes), you should definitely stop and reconsider whether this is really the best design. Almost always, doing this is some combination of more error-prone or slower (usually both) than doing something else that does not require taking graphemes into consideration. ## @@ -275,7 +275,7 @@ ## ## Like lists, dictionaries, and sets, Roc strings are automatically reference-counted and can benefit from opportunistic in-place mutation. The reference count is stored on the heap immediately before the first byte of the string's contents, and it has the same size as a memory address. This means it can count so high that it's impossible to write a Roc program which overflows a reference count, because having that many simultaneous references (each of which is a memory address) would have exhausted the operating system's address space first. ## -## When the string's reference count is 1, functions like [`Str.concat`](https://www.roc-lang.org/builtins/Str#concat) and [`Str.replaceEach`](https://www.roc-lang.org/builtins/Str#replaceEach) mutate the string in-place rather than allocating a new string. This preserves semantic immutability because it is unobservable in terms of the operation's output; if the reference count is 1, it means that memory would have otherwise been deallocated immediately anyway, and it's more efficient to reuse it instead of deallocating it and then immediately making a new allocation. +## When the string's reference count is 1, functions like [`Str.concat`](https://www.roc-lang.org/builtins/Str#concat) and [`Str.replace_each`](https://www.roc-lang.org/builtins/Str#replace_each) mutate the string in-place rather than allocating a new string. This preserves semantic immutability because it is unobservable in terms of the operation's output; if the reference count is 1, it means that memory would have otherwise been deallocated immediately anyway, and it's more efficient to reuse it instead of deallocating it and then immediately making a new allocation. ## ## The contents of statically-known strings (today that means string literals) are stored in the readonly section of the binary, so they do not need heap allocations or reference counts. They are not eligible for in-place mutation, since mutating the readonly section of the binary would cause an operating system [access violation](https://en.wikipedia.org/wiki/Segmentation_fault). ## @@ -294,7 +294,7 @@ ## Try putting this into `roc repl`: ## ## ``` -## » "foo/bar/baz" |> Str.splitOn "/" +## » "foo/bar/baz" |> Str.split_on("/") ## ## ["foo", "bar", "baz"] : List Str ## ``` @@ -304,7 +304,7 @@ ## Now let's suppose they were long enough that this optimization no longer applied: ## ## ``` -## » "a much, much, much, much/longer/string compared to the last one!" |> Str.splitOn "/" +## » "a much, much, much, much/longer/string compared to the last one!" |> Str.split_on "/" ## ## ["a much, much, much, much", "longer", "string compared to the last one!"] : List Str ## ``` @@ -323,52 +323,52 @@ ## 2. The smaller slice is used for a long time in the program, whereas the much larger original string stops being used. ## 3. In this situation, it might have been better for total program memory usage (although not necessarily overall performance) if the original large string could have been deallocated sooner, even at the expense of having to copy the smaller string into a new allocation instead of reusing the bytes with a seamless slice. ## -## If a situation like this comes up, a slice can be turned into a separate string by using [`Str.concat`](https://www.roc-lang.org/builtins/Str#concat) to concatenate the slice onto an empty string (or one created with [`Str.withCapacity`](https://www.roc-lang.org/builtins/Str#withCapacity)). +## If a situation like this comes up, a slice can be turned into a separate string by using [`Str.concat`](https://www.roc-lang.org/builtins/Str#concat) to concatenate the slice onto an empty string (or one created with [`Str.with_capacity`](https://www.roc-lang.org/builtins/Str#with_capacity)). ## ## Currently, the only way to get seamless slices of strings is by calling certain `Str` functions which return them. In general, `Str` functions which accept a string and return a subset of that string tend to do this. [`Str.trim`](https://www.roc-lang.org/builtins/Str#trim) is another example of a function which returns a seamless slice. module [ Utf8Problem, Utf8ByteProblem, concat, - isEmpty, - joinWith, - splitOn, + is_empty, + join_with, + split_on, repeat, - countUtf8Bytes, - toUtf8, - fromUtf8, - startsWith, - endsWith, + count_utf8_bytes, + to_utf8, + from_utf8, + starts_with, + ends_with, trim, - trimStart, - trimEnd, - toDec, - toF64, - toF32, - toU128, - toI128, - toU64, - toI64, - toU32, - toI32, - toU16, - toI16, - toU8, - toI8, - replaceEach, - replaceFirst, - replaceLast, - splitFirst, - splitLast, - walkUtf8, - walkUtf8WithIndex, + trim_start, + trim_end, + to_dec, + to_f64, + to_f32, + to_u128, + to_i128, + to_u64, + to_i64, + to_u32, + to_i32, + to_u16, + to_i16, + to_u8, + to_i8, + replace_each, + replace_first, + replace_last, + split_first, + split_last, + walk_utf8, + walk_utf8_with_index, reserve, - releaseExcessCapacity, - withCapacity, - withPrefix, + release_excess_capacity, + with_capacity, + with_prefix, contains, - dropPrefix, - dropSuffix, + drop_prefix, + drop_suffix, ] import Bool exposing [Bool] @@ -385,20 +385,20 @@ Utf8ByteProblem : [ EncodesSurrogateHalf, ] -Utf8Problem : { byteIndex : U64, problem : Utf8ByteProblem } +Utf8Problem : { byte_index : U64, problem : Utf8ByteProblem } ## Returns [Bool.true] if the string is empty, and [Bool.false] otherwise. ## ```roc -## expect Str.isEmpty "hi!" == Bool.false -## expect Str.isEmpty "" == Bool.true +## expect Str.is_empty("hi!") == Bool.false +## expect Str.is_empty("") == Bool.true ## ``` -isEmpty : Str -> Bool +is_empty : Str -> Bool ## Concatenates two strings together. ## ```roc -## expect Str.concat "ab" "cd" == "abcd" -## expect Str.concat "hello" "" == "hello" -## expect Str.concat "" "" == "" +## expect Str.concat("ab", "cd") == "abcd" +## expect Str.concat("hello", "") == "hello" +## expect Str.concat("", "") == "" ## ``` concat : Str, Str -> Str @@ -412,21 +412,21 @@ concat : Str, Str -> Str ## subject = "Awesome Programmer" ## ## # Evaluates to "Hello and welcome to Roc, Awesome Programmer!" -## helloWorld = -## Str.withCapacity 45 -## |> Str.concat greeting -## |> Str.concat ", " -## |> Str.concat subject -## |> Str.concat "!" +## hello_world = +## Str.with_capacity(45) +## |> Str.concat(greeting) +## |> Str.concat(", ") +## |> Str.concat(subject) +## |> Str.concat("!") ## ``` ## ## In general, if you plan to use [Str.concat] on an empty string, it will be faster to start with -## [Str.withCapacity] than with `""`. Even if you don't know the exact capacity of the string, giving [withCapacity] +## [Str.with_capacity] than with `""`. Even if you don't know the exact capacity of the string, giving [with_capacity] ## a higher value than ends up being necessary can help prevent reallocation and copying—at ## the cost of using more memory than is necessary. ## ## For more details on how the performance optimization works, see [Str.reserve]. -withCapacity : U64 -> Str +with_capacity : U64 -> Str ## Increase a string's capacity by at least the given number of additional bytes. ## @@ -439,11 +439,11 @@ withCapacity : U64 -> Str ## subject = "Awesome Programmer" ## ## # Evaluates to "Hello and welcome to Roc, Awesome Programmer!" -## helloWorld = +## hello_world = ## greeting -## |> Str.concat ", " -## |> Str.concat subject -## |> Str.concat "!" +## |> Str.concat(", ") +## |> Str.concat(subject) +## |> Str.concat("!") ## ``` ## ## In this example: @@ -457,19 +457,19 @@ withCapacity : U64 -> Str ## Here's a modified example which uses [Str.reserve] to eliminate the need for all that reallocation, copying, and deallocation. ## ## ```roc -## helloWorld = +## hello_world = ## greeting -## |> Str.reserve 21 -## |> Str.concat ", " -## |> Str.concat subject -## |> Str.concat "!" +## |> Str.reserve(21) +## |> Str.concat(", ") +## |> Str.concat(subject) +## |> Str.concat("!") ## ``` ## ## In this example: ## 1. We again start with `greeting`, which has both a length and capacity of 24 bytes. -## 2. `|> Str.reserve 21` will ensure that there is enough capacity in the string for an additional 21 bytes (to make room for `", "`, `"Awesome Programmer"`, and `"!"`). Since the current capacity is only 24, it will create a new 45-byte (24 + 21) heap allocation and copy the contents of the existing allocation (`greeting`) into it. -## 3. `|> Str.concat ", "` will concatenate `, ` to the string. No reallocation, copying, or deallocation will be necessary, because the string already has a capacity of 45 btytes, and `greeting` will only use 24 of them. -## 4. `|> Str.concat subject` will concatenate `subject` (`"Awesome Programmer"`) to the string. Again, no reallocation, copying, or deallocation will be necessary. +## 2. `|> Str.reserve(21)` will ensure that there is enough capacity in the string for an additional 21 bytes (to make room for `", "`, `"Awesome Programmer"`, and `"!"`). Since the current capacity is only 24, it will create a new 45-byte (24 + 21) heap allocation and copy the contents of the existing allocation (`greeting`) into it. +## 3. `|> Str.concat(", ")` will concatenate `, ` to the string. No reallocation, copying, or deallocation will be necessary, because the string already has a capacity of 45 btytes, and `greeting` will only use 24 of them. +## 4. `|> Str.concat(subject)` will concatenate `subject` (`"Awesome Programmer"`) to the string. Again, no reallocation, copying, or deallocation will be necessary. ## 5. `|> Str.concat "!\n"` will concatenate `"!\n"` to the string, still without any reallocation, copying, or deallocation. ## ## Here, [Str.reserve] prevented multiple reallocations, copies, and deallocations during the @@ -483,399 +483,399 @@ withCapacity : U64 -> Str ## this, of course; if you always give it ten times what it turns out to need, that could prevent ## reallocations but will also waste a lot of memory! ## -## If you plan to use [Str.reserve] on an empty string, it's generally better to use [Str.withCapacity] instead. +## If you plan to use [Str.reserve] on an empty string, it's generally better to use [Str.with_capacity] instead. reserve : Str, U64 -> Str ## Combines a [List] of strings into a single string, with a separator ## string in between each. ## ```roc -## expect Str.joinWith ["one", "two", "three"] ", " == "one, two, three" -## expect Str.joinWith ["1", "2", "3", "4"] "." == "1.2.3.4" +## expect Str.join_with(["one", "two", "three"], ", ") == "one, two, three" +## expect Str.join_with(["1", "2", "3", "4"], ".") == "1.2.3.4" ## ``` -joinWith : List Str, Str -> Str +join_with : List Str, Str -> Str ## Split a string around a separator. ## ## Passing `""` for the separator is not useful; ## it returns the original string wrapped in a [List]. ## ```roc -## expect Str.splitOn "1,2,3" "," == ["1","2","3"] -## expect Str.splitOn "1,2,3" "" == ["1,2,3"] +## expect Str.split_on("1,2,3", ",") == ["1","2","3"] +## expect Str.split_on("1,2,3", "") == ["1,2,3"] ## ``` -splitOn : Str, Str -> List Str +split_on : Str, Str -> List Str ## Repeats a string the given number of times. ## ```roc -## expect Str.repeat "z" 3 == "zzz" -## expect Str.repeat "na" 8 == "nananananananana" +## expect Str.repeat("z", 3) == "zzz" +## expect Str.repeat("na", 8) == "nananananananana" ## ``` ## Returns `""` when given `""` for the string or `0` for the count. ## ```roc -## expect Str.repeat "" 10 == "" -## expect Str.repeat "anything" 0 == "" +## expect Str.repeat("", 10) == "" +## expect Str.repeat("anything", 0) == "" ## ``` repeat : Str, U64 -> Str ## Returns a [List] of the string's [U8] UTF-8 [code units](https://unicode.org/glossary/#code_unit). ## (To split the string into a [List] of smaller [Str] values instead of [U8] values, -## see [Str.splitOn].) +## see [Str.split_on].) ## ```roc -## expect Str.toUtf8 "Roc" == [82, 111, 99] -## expect Str.toUtf8 "鹏" == [233, 185, 143] -## expect Str.toUtf8 "சி" == [224, 174, 154, 224, 174, 191] -## expect Str.toUtf8 "🐦" == [240, 159, 144, 166] +## expect Str.to_utf8("Roc") == [82, 111, 99] +## expect Str.to_utf8("鹏") == [233, 185, 143] +## expect Str.to_utf8("சி") == [224, 174, 154, 224, 174, 191] +## expect Str.to_utf8("🐦") == [240, 159, 144, 166] ## ``` -toUtf8 : Str -> List U8 +to_utf8 : Str -> List U8 ## Converts a [List] of [U8] UTF-8 [code units](https://unicode.org/glossary/#code_unit) to a string. ## ## Returns `Err` if the given bytes are invalid UTF-8, and returns `Ok ""` when given `[]`. ## ```roc -## expect Str.fromUtf8 [82, 111, 99] == Ok "Roc" -## expect Str.fromUtf8 [233, 185, 143] == Ok "鹏" -## expect Str.fromUtf8 [224, 174, 154, 224, 174, 191] == Ok "சி" -## expect Str.fromUtf8 [240, 159, 144, 166] == Ok "🐦" -## expect Str.fromUtf8 [] == Ok "" -## expect Str.fromUtf8 [255] |> Result.isErr -## ``` -fromUtf8 : List U8 -> Result Str [BadUtf8 { problem : Utf8ByteProblem, index : U64 }] -fromUtf8 = \bytes -> - result = fromUtf8Lowlevel bytes - - if result.cIsOk then - Ok result.bString +## expect Str.from_utf8([82, 111, 99]) == Ok("Roc") +## expect Str.from_utf8([233, 185, 143]) == Ok("鹏") +## expect Str.from_utf8([224, 174, 154, 224, 174, 191]) == Ok("சி") +## expect Str.from_utf8([240, 159, 144, 166]) == Ok("🐦") +## expect Str.from_utf8([]) == Ok("") +## expect Str.from_utf8([255]) |> Result.is_err +## ``` +from_utf8 : List U8 -> Result Str [BadUtf8 { problem : Utf8ByteProblem, index : U64 }] +from_utf8 = \bytes -> + result = from_utf8_lowlevel bytes + + if result.c_is_ok then + Ok(result.b_string) else - Err (BadUtf8 { problem: result.dProblemCode, index: result.aByteIndex }) + Err (BadUtf8 { problem: result.d_problem_code, index: result.a_byte_index }) -expect (Str.fromUtf8 [82, 111, 99]) == Ok "Roc" -expect (Str.fromUtf8 [224, 174, 154, 224, 174, 191]) == Ok "சி" -expect (Str.fromUtf8 [240, 159, 144, 166]) == Ok "🐦" -expect (Str.fromUtf8 []) == Ok "" -expect (Str.fromUtf8 [255]) |> Result.isErr +expect (Str.from_utf8([82, 111, 99])) == Ok("Roc") +expect (Str.from_utf8([224, 174, 154, 224, 174, 191])) == Ok("சி") +expect (Str.from_utf8([240, 159, 144, 166])) == Ok("🐦") +expect (Str.from_utf8([])) == Ok("") +expect (Str.from_utf8([255])) |> Result.is_err FromUtf8Result : { - aByteIndex : U64, - bString : Str, - cIsOk : Bool, - dProblemCode : Utf8ByteProblem, + a_byte_index : U64, + b_string : Str, + c_is_ok : Bool, + d_problem_code : Utf8ByteProblem, } -fromUtf8Lowlevel : List U8 -> FromUtf8Result +from_utf8_lowlevel : List U8 -> FromUtf8Result ## Check if the given [Str] starts with a value. ## ```roc -## expect Str.startsWith "ABC" "A" == Bool.true -## expect Str.startsWith "ABC" "X" == Bool.false +## expect Str.starts_with("ABC", "A") == Bool.true +## expect Str.starts_with("ABC", "X") == Bool.false ## ``` -startsWith : Str, Str -> Bool +starts_with : Str, Str -> Bool ## Check if the given [Str] ends with a value. ## ```roc -## expect Str.endsWith "ABC" "C" == Bool.true -## expect Str.endsWith "ABC" "X" == Bool.false +## expect Str.ends_with("ABC", "C") == Bool.true +## expect Str.ends_with("ABC", "X") == Bool.false ## ``` -endsWith : Str, Str -> Bool +ends_with : Str, Str -> Bool ## Return the [Str] with all whitespace removed from both the beginning ## as well as the end. ## ```roc -## expect Str.trim " Hello \n\n" == "Hello" +## expect Str.trim(" Hello \n\n") == "Hello" ## ``` trim : Str -> Str ## Return the [Str] with all whitespace removed from the beginning. ## ```roc -## expect Str.trimStart " Hello \n\n" == "Hello \n\n" +## expect Str.trim_start(" Hello \n\n") == "Hello \n\n" ## ``` -trimStart : Str -> Str +trim_start : Str -> Str ## Return the [Str] with all whitespace removed from the end. ## ```roc -## expect Str.trimEnd " Hello \n\n" == " Hello" +## expect Str.trim_end(" Hello \n\n") == " Hello" ## ``` -trimEnd : Str -> Str +trim_end : Str -> Str ## Encode a [Str] to a [Dec]. A [Dec] value is a 128-bit decimal ## [fixed-point number](https://en.wikipedia.org/wiki/Fixed-point_arithmetic). ## ```roc -## expect Str.toDec "10" == Ok 10dec -## expect Str.toDec "-0.25" == Ok -0.25dec -## expect Str.toDec "not a number" == Err InvalidNumStr +## expect Str.to_dec("10") == Ok(10dec) +## expect Str.to_dec("-0.25") == Ok(-0.25dec) +## expect Str.to_dec("not a number") == Err(InvalidNumStr) ## ``` -toDec : Str -> Result Dec [InvalidNumStr] -toDec = \string -> strToNumHelp string +to_dec : Str -> Result Dec [InvalidNumStr] +to_dec = \string -> str_to_num_help(string) ## Encode a [Str] to a [F64]. A [F64] value is a 64-bit ## [floating-point number](https://en.wikipedia.org/wiki/IEEE_754) and can be ## specified with a `f64` suffix. ## ```roc -## expect Str.toF64 "0.10" == Ok 0.10f64 -## expect Str.toF64 "not a number" == Err InvalidNumStr +## expect Str.to_f64("0.10") == Ok(0.10f64) +## expect Str.to_f64("not a number") == Err(InvalidNumStr) ## ``` -toF64 : Str -> Result F64 [InvalidNumStr] -toF64 = \string -> strToNumHelp string +to_f64 : Str -> Result F64 [InvalidNumStr] +to_f64 = \string -> str_to_num_help(string) ## Encode a [Str] to a [F32].A [F32] value is a 32-bit ## [floating-point number](https://en.wikipedia.org/wiki/IEEE_754) and can be ## specified with a `f32` suffix. ## ```roc -## expect Str.toF32 "0.10" == Ok 0.10f32 -## expect Str.toF32 "not a number" == Err InvalidNumStr +## expect Str.to_f32("0.10") == Ok(0.10f32) +## expect Str.to_f32("not a number") == Err(InvalidNumStr) ## ``` -toF32 : Str -> Result F32 [InvalidNumStr] -toF32 = \string -> strToNumHelp string +to_f32 : Str -> Result F32 [InvalidNumStr] +to_f32 = \string -> str_to_num_help(string) ## Encode a [Str] to an unsigned [U128] integer. A [U128] value can hold numbers ## from `0` to `340_282_366_920_938_463_463_374_607_431_768_211_455` (over ## 340 undecillion). It can be specified with a u128 suffix. ## ```roc -## expect Str.toU128 "1500" == Ok 1500u128 -## expect Str.toU128 "0.1" == Err InvalidNumStr -## expect Str.toU128 "-1" == Err InvalidNumStr -## expect Str.toU128 "not a number" == Err InvalidNumStr +## expect Str.to_u128("1500") == Ok(1500u128) +## expect Str.to_u128("0.1") == Err(InvalidNumStr) +## expect Str.to_u128("-1") == Err(InvalidNumStr) +## expect Str.to_u128("not a number") == Err(InvalidNumStr) ## ``` -toU128 : Str -> Result U128 [InvalidNumStr] -toU128 = \string -> strToNumHelp string +to_u128 : Str -> Result U128 [InvalidNumStr] +to_u128 = \string -> str_to_num_help(string) ## Encode a [Str] to a signed [I128] integer. A [I128] value can hold numbers ## from `-170_141_183_460_469_231_731_687_303_715_884_105_728` to ## `170_141_183_460_469_231_731_687_303_715_884_105_727`. It can be specified ## with a i128 suffix. ## ```roc -## expect Str.toI128 "1500" == Ok 1500i128 -## expect Str.toI128 "-1" == Ok -1i128 -## expect Str.toI128 "0.1" == Err InvalidNumStr -## expect Str.toI128 "not a number" == Err InvalidNumStr +## expect Str.to_u128("1500") == Ok(1500i128) +## expect Str.to_i128("-1") == Ok(-1i128) +## expect Str.to_i128("0.1") == Err(InvalidNumStr) +## expect Str.to_i128("not a number") == Err(InvalidNumStr) ## ``` -toI128 : Str -> Result I128 [InvalidNumStr] -toI128 = \string -> strToNumHelp string +to_i128 : Str -> Result I128 [InvalidNumStr] +to_i128 = \string -> str_to_num_help(string) ## Encode a [Str] to an unsigned [U64] integer. A [U64] value can hold numbers ## from `0` to `18_446_744_073_709_551_615` (over 18 quintillion). It ## can be specified with a u64 suffix. ## ```roc -## expect Str.toU64 "1500" == Ok 1500u64 -## expect Str.toU64 "0.1" == Err InvalidNumStr -## expect Str.toU64 "-1" == Err InvalidNumStr -## expect Str.toU64 "not a number" == Err InvalidNumStr +## expect Str.to_u64("1500") == Ok(1500u64) +## expect Str.to_u64("0.1") == Err(InvalidNumStr) +## expect Str.to_u64("-1") == Err(InvalidNumStr) +## expect Str.to_u64("not a number") == Err(InvalidNumStr) ## ``` -toU64 : Str -> Result U64 [InvalidNumStr] -toU64 = \string -> strToNumHelp string +to_u64 : Str -> Result U64 [InvalidNumStr] +to_u64 = \string -> str_to_num_help(string) ## Encode a [Str] to a signed [I64] integer. A [I64] value can hold numbers ## from `-9_223_372_036_854_775_808` to `9_223_372_036_854_775_807`. It can be ## specified with a i64 suffix. ## ```roc -## expect Str.toI64 "1500" == Ok 1500i64 -## expect Str.toI64 "-1" == Ok -1i64 -## expect Str.toI64 "0.1" == Err InvalidNumStr -## expect Str.toI64 "not a number" == Err InvalidNumStr +## expect Str.to_i64("1500") == Ok(1500i64) +## expect Str.to_i64("-1") == Ok(-1i64) +## expect Str.to_i64("0.1") == Err(InvalidNumStr) +## expect Str.to_i64("not a number") == Err(InvalidNumStr) ## ``` -toI64 : Str -> Result I64 [InvalidNumStr] -toI64 = \string -> strToNumHelp string +to_i64 : Str -> Result I64 [InvalidNumStr] +to_i64 = \string -> str_to_num_help(string) ## Encode a [Str] to an unsigned [U32] integer. A [U32] value can hold numbers ## from `0` to `4_294_967_295` (over 4 billion). It can be specified with ## a u32 suffix. ## ```roc -## expect Str.toU32 "1500" == Ok 1500u32 -## expect Str.toU32 "0.1" == Err InvalidNumStr -## expect Str.toU32 "-1" == Err InvalidNumStr -## expect Str.toU32 "not a number" == Err InvalidNumStr +## expect Str.to_u32("1500") == Ok(1500u32) +## expect Str.to_u32("0.1") == Err(InvalidNumStr) +## expect Str.to_u32("-1") == Err(InvalidNumStr) +## expect Str.to_u32("not a number") == Err(InvalidNumStr) ## ``` -toU32 : Str -> Result U32 [InvalidNumStr] -toU32 = \string -> strToNumHelp string +to_u32 : Str -> Result U32 [InvalidNumStr] +to_u32 = \string -> str_to_num_help(string) ## Encode a [Str] to a signed [I32] integer. A [I32] value can hold numbers ## from `-2_147_483_648` to `2_147_483_647`. It can be ## specified with a i32 suffix. ## ```roc -## expect Str.toI32 "1500" == Ok 1500i32 -## expect Str.toI32 "-1" == Ok -1i32 -## expect Str.toI32 "0.1" == Err InvalidNumStr -## expect Str.toI32 "not a number" == Err InvalidNumStr +## expect Str.to_i32("1500") == Ok(1500i32) +## expect Str.to_i32("-1") == Ok(-1i32) +## expect Str.to_i32("0.1") == Err(InvalidNumStr) +## expect Str.to_i32("not a number") == Err(InvalidNumStr) ## ``` -toI32 : Str -> Result I32 [InvalidNumStr] -toI32 = \string -> strToNumHelp string +to_i32 : Str -> Result I32 [InvalidNumStr] +to_i32 = \string -> str_to_num_help(string) ## Encode a [Str] to an unsigned [U16] integer. A [U16] value can hold numbers ## from `0` to `65_535`. It can be specified with a u16 suffix. ## ```roc -## expect Str.toU16 "1500" == Ok 1500u16 -## expect Str.toU16 "0.1" == Err InvalidNumStr -## expect Str.toU16 "-1" == Err InvalidNumStr -## expect Str.toU16 "not a number" == Err InvalidNumStr +## expect Str.to_u16("1500") == Ok(1500u16) +## expect Str.to_u16("0.1") == Err(InvalidNumStr) +## expect Str.to_u16("-1") == Err(InvalidNumStr) +## expect Str.to_u16("not a number") == Err(InvalidNumStr) ## ``` -toU16 : Str -> Result U16 [InvalidNumStr] -toU16 = \string -> strToNumHelp string +to_u16 : Str -> Result U16 [InvalidNumStr] +to_u16 = \string -> str_to_num_help(string) ## Encode a [Str] to a signed [I16] integer. A [I16] value can hold numbers ## from `-32_768` to `32_767`. It can be ## specified with a i16 suffix. ## ```roc -## expect Str.toI16 "1500" == Ok 1500i16 -## expect Str.toI16 "-1" == Ok -1i16 -## expect Str.toI16 "0.1" == Err InvalidNumStr -## expect Str.toI16 "not a number" == Err InvalidNumStr +## expect Str.to_i16("1500") == Ok(1500i16) +## expect Str.to_i16("-1") == Ok(-1i16) +## expect Str.to_i16("0.1") == Err(InvalidNumStr) +## expect Str.to_i16("not a number") == Err(InvalidNumStr) ## ``` -toI16 : Str -> Result I16 [InvalidNumStr] -toI16 = \string -> strToNumHelp string +to_i16 : Str -> Result I16 [InvalidNumStr] +to_i16 = \string -> str_to_num_help(string) ## Encode a [Str] to an unsigned [U8] integer. A [U8] value can hold numbers ## from `0` to `255`. It can be specified with a u8 suffix. ## ```roc -## expect Str.toU8 "250" == Ok 250u8 -## expect Str.toU8 "-0.1" == Err InvalidNumStr -## expect Str.toU8 "not a number" == Err InvalidNumStr -## expect Str.toU8 "1500" == Err InvalidNumStr +## expect Str.to_u8("250") == Ok(250u8) +## expect Str.to_u8("-0.1") == Err(InvalidNumStr) +## expect Str.to_u8("not a number") == Err(InvalidNumStr) +## expect Str.to_u8("1500") == Err(InvalidNumStr) ## ``` -toU8 : Str -> Result U8 [InvalidNumStr] -toU8 = \string -> strToNumHelp string +to_u8 : Str -> Result U8 [InvalidNumStr] +to_u8 = \string -> str_to_num_help(string) ## Encode a [Str] to a signed [I8] integer. A [I8] value can hold numbers ## from `-128` to `127`. It can be ## specified with a i8 suffix. ## ```roc -## expect Str.toI8 "-15" == Ok -15i8 -## expect Str.toI8 "150.00" == Err InvalidNumStr -## expect Str.toI8 "not a number" == Err InvalidNumStr +## expect Str.to_i8("-15") == Ok(-15i8) +## expect Str.to_i8("150.00") == Err(InvalidNumStr) +## expect Str.to_i8("not a number") == Err(InvalidNumStr) ## ``` -toI8 : Str -> Result I8 [InvalidNumStr] -toI8 = \string -> strToNumHelp string +to_i8 : Str -> Result I8 [InvalidNumStr] +to_i8 = \string -> str_to_num_help(string) ## Get the byte at the given index, without performing a bounds check. -getUnsafe : Str, U64 -> U8 +get_unsafe : Str, U64 -> U8 ## Gives the number of bytes in a [Str] value. ## ```roc -## expect Str.countUtf8Bytes "Hello World" == 11 +## expect Str.count_utf8_bytes("Hello World") == 11 ## ``` -countUtf8Bytes : Str -> U64 +count_utf8_bytes : Str -> U64 -## string slice that does not do bounds checking or utf-8 verification -substringUnsafe : Str, U64, U64 -> Str +## string slice that does not do bounds checking or UTF-8 verification +substring_unsafe : Str, U64, U64 -> Str ## Returns the given [Str] with each occurrence of a substring replaced. ## If the substring is not found, returns the original string. ## ## ```roc -## expect Str.replaceEach "foo/bar/baz" "/" "_" == "foo_bar_baz" -## expect Str.replaceEach "not here" "/" "_" == "not here" +## expect Str.replace_each("foo/bar/baz", "/", "_") == "foo_bar_baz" +## expect Str.replace_each("not here", "/", "_") == "not here" ## ``` -replaceEach : Str, Str, Str -> Str -replaceEach = \haystack, needle, flower -> - when splitFirst haystack needle is - Ok { before, after } -> +replace_each : Str, Str, Str -> Str +replace_each = \haystack, needle, flower -> + when split_first(haystack, needle) is + Ok({ before, after }) -> # We found at least one needle, so start the buffer off with # `before` followed by the first replacement flower. - Str.withCapacity (Str.countUtf8Bytes haystack) - |> Str.concat before - |> Str.concat flower - |> replaceEachHelp after needle flower + Str.with_capacity(Str.count_utf8_bytes(haystack)) + |> Str.concat(before) + |> Str.concat(flower) + |> replace_each_help(after, needle, flower) - Err NotFound -> haystack + Err(NotFound) -> haystack -replaceEachHelp : Str, Str, Str, Str -> Str -replaceEachHelp = \buf, haystack, needle, flower -> - when splitFirst haystack needle is - Ok { before, after } -> +replace_each_help : Str, Str, Str, Str -> Str +replace_each_help = \buf, haystack, needle, flower -> + when split_first(haystack, needle) is + Ok({ before, after }) -> buf - |> Str.concat before - |> Str.concat flower - |> replaceEachHelp after needle flower + |> Str.concat(before) + |> Str.concat(flower) + |> replace_each_help(after, needle, flower) - Err NotFound -> Str.concat buf haystack + Err(NotFound) -> Str.concat(buf, haystack) -expect Str.replaceEach "abXdeXghi" "X" "_" == "ab_de_ghi" -expect Str.replaceEach "abcdefg" "nothing" "_" == "abcdefg" +expect Str.replace_each("abXdeXghi", "X", "_") == "ab_de_ghi" +expect Str.replace_each("abcdefg", "nothing", "_") == "abcdefg" ## Returns the given [Str] with the first occurrence of a substring replaced. ## If the substring is not found, returns the original string. ## ## ```roc -## expect Str.replaceFirst "foo/bar/baz" "/" "_" == "foo_bar/baz" -## expect Str.replaceFirst "no slashes here" "/" "_" == "no slashes here" +## expect Str.replace_first("foo/bar/baz", "/", "_") == "foo_bar/baz" +## expect Str.replace_first("no slashes here", "/", "_") == "no slashes here" ## ``` -replaceFirst : Str, Str, Str -> Str -replaceFirst = \haystack, needle, flower -> - when splitFirst haystack needle is - Ok { before, after } -> +replace_first : Str, Str, Str -> Str +replace_first = \haystack, needle, flower -> + when split_first(haystack, needle) is + Ok({ before, after }) -> "$(before)$(flower)$(after)" - Err NotFound -> haystack + Err(NotFound) -> haystack -expect Str.replaceFirst "abXdeXghi" "X" "_" == "ab_deXghi" -expect Str.replaceFirst "abcdefg" "nothing" "_" == "abcdefg" +expect Str.replace_first("abXdeXghi", "X", "_") == "ab_deXghi" +expect Str.replace_first("abcdefg", "nothing", "_") == "abcdefg" ## Returns the given [Str] with the last occurrence of a substring replaced. ## If the substring is not found, returns the original string. ## ## ```roc -## expect Str.replaceLast "foo/bar/baz" "/" "_" == "foo/bar_baz" -## expect Str.replaceLast "no slashes here" "/" "_" == "no slashes here" +## expect Str.replace_last("foo/bar/baz", "/", "_") == "foo/bar_baz" +## expect Str.replace_last("no slashes here", "/", "_") == "no slashes here" ## ``` -replaceLast : Str, Str, Str -> Str -replaceLast = \haystack, needle, flower -> - when splitLast haystack needle is - Ok { before, after } -> +replace_last : Str, Str, Str -> Str +replace_last = \haystack, needle, flower -> + when split_last(haystack, needle) is + Ok({ before, after }) -> "$(before)$(flower)$(after)" - Err NotFound -> haystack + Err(NotFound) -> haystack -expect Str.replaceLast "abXdeXghi" "X" "_" == "abXde_ghi" -expect Str.replaceLast "abcdefg" "nothing" "_" == "abcdefg" +expect Str.replace_last("abXdeXghi", "X", "_") == "abXde_ghi" +expect Str.replace_last("abcdefg", "nothing", "_") == "abcdefg" ## Returns the given [Str] before the first occurrence of a [delimiter](https://www.computerhope.com/jargon/d/delimite.htm), as well ## as the rest of the string after that occurrence. ## Returns [Err NotFound] if the delimiter is not found. ## ```roc -## expect Str.splitFirst "foo/bar/baz" "/" == Ok { before: "foo", after: "bar/baz" } -## expect Str.splitFirst "no slashes here" "/" == Err NotFound +## expect Str.split_first("foo/bar/baz", "/") == Ok({ before: "foo", after: "bar/baz" }) +## expect Str.split_first("no slashes here", "/") == Err(NotFound) ## ``` -splitFirst : Str, Str -> Result { before : Str, after : Str } [NotFound] -splitFirst = \haystack, needle -> - when firstMatch haystack needle is - Some index -> - remaining = Str.countUtf8Bytes haystack - Str.countUtf8Bytes needle - index +split_first : Str, Str -> Result { before : Str, after : Str } [NotFound] +split_first = \haystack, needle -> + when first_match(haystack, needle) is + Some(index) -> + remaining = Str.count_utf8_bytes(haystack) - Str.count_utf8_bytes(needle) - index - before = Str.substringUnsafe haystack 0 index - after = Str.substringUnsafe haystack (Num.addWrap index (Str.countUtf8Bytes needle)) remaining + before = Str.substring_unsafe(haystack, 0, index) + after = Str.substring_unsafe(haystack, Num.add_wrap(index, Str.count_utf8_bytes(needle)), remaining) - Ok { before, after } + Ok({ before, after }) None -> - Err NotFound + Err(NotFound) -# splitFirst when needle isn't in haystack -expect splitFirst "foo" "z" == Err NotFound +# split_first when needle isn't in haystack +expect split_first("foo", "z") == Err(NotFound) -# splitFirst when needle isn't in haystack, and haystack is empty -expect splitFirst "" "z" == Err NotFound +# split_first when needle isn't in haystack, and haystack is empty +expect split_first("", "z") == Err(NotFound) -# splitFirst when haystack ends with needle repeated -expect splitFirst "foo" "o" == Ok { before: "f", after: "o" } +# split_first when haystack ends with needle repeated +expect split_first("foo", "o") == Ok({ before: "f", after: "o" }) -# splitFirst with multi-byte needle -expect splitFirst "hullabaloo" "ab" == Ok { before: "hull", after: "aloo" } +# split_first with multi-byte needle +expect split_first("hullabaloo", "ab") == Ok({ before: "hull", after: "aloo" }) -# splitFirst when needle is haystack -expect splitFirst "foo" "foo" == Ok { before: "", after: "" } +# split_first when needle is haystack +expect split_first("foo", "foo") == Ok({ before: "", after: "" }) -firstMatch : Str, Str -> [Some U64, None] -firstMatch = \haystack, needle -> - haystackLength = Str.countUtf8Bytes haystack - needleLength = Str.countUtf8Bytes needle - lastPossible = Num.subSaturated haystackLength needleLength +first_match : Str, Str -> [Some U64, None] +first_match = \haystack, needle -> + haystack_length = Str.count_utf8_bytes(haystack) + needle_length = Str.count_utf8_bytes(needle) + last_possible = Num.sub_saturated(haystack_length, needle_length) - firstMatchHelp haystack needle 0 lastPossible + first_match_help(haystack, needle, 0, last_possible) -firstMatchHelp : Str, Str, U64, U64 -> [Some U64, None] -firstMatchHelp = \haystack, needle, index, lastPossible -> - if index <= lastPossible then - if matchesAt haystack index needle then - Some index +first_match_help : Str, Str, U64, U64 -> [Some U64, None] +first_match_help = \haystack, needle, index, last_possible -> + if index <= last_possible then + if matches_at(haystack, index, needle) then + Some(index) else - firstMatchHelp haystack needle (Num.addWrap index 1) lastPossible + first_match_help(haystack, needle, Num.add_wrap(index, 1), last_possible) else None @@ -883,113 +883,114 @@ firstMatchHelp = \haystack, needle, index, lastPossible -> ## the rest of the string after that occurrence. ## Returns [Err NotFound] if the delimiter is not found. ## ```roc -## expect Str.splitLast "foo/bar/baz" "/" == Ok { before: "foo/bar", after: "baz" } -## expect Str.splitLast "no slashes here" "/" == Err NotFound +## expect Str.split_last("foo/bar/baz", "/") == Ok({ before: "foo/bar", after: "baz" }) +## expect Str.split_last("no slashes here", "/") == Err(NotFound) ## ``` -splitLast : Str, Str -> Result { before : Str, after : Str } [NotFound] -splitLast = \haystack, needle -> - when lastMatch haystack needle is - Some index -> - remaining = Str.countUtf8Bytes haystack - Str.countUtf8Bytes needle - index +split_last : Str, Str -> Result { before : Str, after : Str } [NotFound] +split_last = \haystack, needle -> + when last_match(haystack, needle) is + Some(index) -> + remaining = Str.count_utf8_bytes(haystack) - Str.count_utf8_bytes(needle) - index - before = Str.substringUnsafe haystack 0 index - after = Str.substringUnsafe haystack (Num.addWrap index (Str.countUtf8Bytes needle)) remaining + before = Str.substring_unsafe(haystack, 0, index) + after = Str.substring_unsafe(haystack, Num.add_wrap(index, Str.count_utf8_bytes(needle)), remaining) - Ok { before, after } + Ok({ before, after }) None -> - Err NotFound + Err(NotFound) -# splitLast when needle isn't in haystack -expect Str.splitLast "foo" "z" == Err NotFound +# split_last when needle isn't in haystack +expect Str.split_last("foo", "z") == Err(NotFound) -# splitLast when haystack ends with needle repeated -expect Str.splitLast "foo" "o" == Ok { before: "fo", after: "" } +# split_last when haystack ends with needle repeated +expect Str.split_last("foo", "o") == Ok({ before: "fo", after: "" }) -# splitLast with multi-byte needle -expect Str.splitLast "hullabaloo" "ab" == Ok { before: "hull", after: "aloo" } +# split_last with multi-byte needle +expect Str.split_last("hullabaloo", "ab") == Ok({ before: "hull", after: "aloo" }) -# splitLast when needle is haystack -expect Str.splitLast "foo" "foo" == Ok { before: "", after: "" } +# split_last when needle is haystack +expect Str.split_last("foo", "foo") == Ok({ before: "", after: "" }) -lastMatch : Str, Str -> [Some U64, None] -lastMatch = \haystack, needle -> - haystackLength = Str.countUtf8Bytes haystack - needleLength = Str.countUtf8Bytes needle - lastPossibleIndex = Num.subSaturated haystackLength needleLength +last_match : Str, Str -> [Some U64, None] +last_match = \haystack, needle -> + haystack_length = Str.count_utf8_bytes(haystack) + needle_length = Str.count_utf8_bytes(needle) + last_possible_index = Num.sub_saturated(haystack_length, needle_length) - lastMatchHelp haystack needle lastPossibleIndex + last_match_help(haystack, needle, last_possible_index) -lastMatchHelp : Str, Str, U64 -> [Some U64, None] -lastMatchHelp = \haystack, needle, index -> - if matchesAt haystack index needle then - Some index +last_match_help : Str, Str, U64 -> [Some U64, None] +last_match_help = \haystack, needle, index -> + if matches_at(haystack, index, needle) then + Some(index) else - when Num.subChecked index 1 is - Ok nextIndex -> - lastMatchHelp haystack needle nextIndex + when Num.sub_checked(index, 1) is + Ok(next_index) -> + last_match_help(haystack, needle, next_index) - Err _ -> + Err(_) -> None min = \x, y -> if x < y then x else y -matchesAt : Str, U64, Str -> Bool -matchesAt = \haystack, haystackIndex, needle -> - haystackLength = Str.countUtf8Bytes haystack - needleLength = Str.countUtf8Bytes needle - endIndex = min (Num.addSaturated haystackIndex needleLength) haystackLength +matches_at : Str, U64, Str -> Bool +matches_at = \haystack, haystack_index, needle -> + haystack_length = Str.count_utf8_bytes(haystack) + needle_length = Str.count_utf8_bytes(needle) + end_index = min(Num.add_saturated(haystack_index, needle_length), haystack_length) - matchesAtHelp { + matches_at_help({ haystack, - haystackIndex, + haystack_index, needle, - needleIndex: 0, - needleLength, - endIndex, - } + needle_index: 0, + needle_length, + end_index, + }) -matchesAtHelp = \state -> - { haystack, haystackIndex, needle, needleIndex, needleLength, endIndex } = state - isAtEndOfHaystack = haystackIndex >= endIndex +matches_at_help = \state -> + { haystack, haystack_index, needle, needle_index, needle_length, end_index } = state + is_at_end_of_haystack = haystack_index >= end_index - if isAtEndOfHaystack then - didWalkEntireNeedle = needleIndex == needleLength + if is_at_end_of_haystack then + did_walk_entire_needle = needle_index == needle_length - didWalkEntireNeedle + did_walk_entire_needle else - doesThisMatch = - Str.getUnsafe haystack haystackIndex + does_this_match = + Str.get_unsafe(haystack, haystack_index) == - Str.getUnsafe needle needleIndex - doesRestMatch = - matchesAtHelp + Str.get_unsafe(needle, needle_index) + does_rest_match = + matches_at_help( { state & - haystackIndex: Num.addWrap haystackIndex 1, - needleIndex: Num.addWrap needleIndex 1, - } + haystack_index: Num.add_wrap(haystack_index, 1), + needle_index: Num.add_wrap(needle_index, 1), + }, + ) - doesThisMatch && doesRestMatch + does_this_match && does_rest_match ## Walks over the `UTF-8` bytes of the given [Str] and calls a function to update ## state for each byte. The index for that byte in the string is provided ## to the update function. ## ```roc ## f : List U8, U8, U64 -> List U8 -## f = \state, byte, _ -> List.append state byte -## expect Str.walkUtf8WithIndex "ABC" [] f == [65, 66, 67] +## f = \state, byte, _ -> List.append(state, byte) +## expect Str.walk_utf8_with_index("ABC", [], f) == [65, 66, 67] ## ``` -walkUtf8WithIndex : Str, state, (state, U8, U64 -> state) -> state -walkUtf8WithIndex = \string, state, step -> - walkUtf8WithIndexHelp string state step 0 (Str.countUtf8Bytes string) +walk_utf8_with_index : Str, state, (state, U8, U64 -> state) -> state +walk_utf8_with_index = \string, state, step -> + walk_utf8_with_index_help(string, state, step, 0, Str.count_utf8_bytes(string)) -walkUtf8WithIndexHelp : Str, state, (state, U8, U64 -> state), U64, U64 -> state -walkUtf8WithIndexHelp = \string, state, step, index, length -> +walk_utf8_with_index_help : Str, state, (state, U8, U64 -> state), U64, U64 -> state +walk_utf8_with_index_help = \string, state, step, index, length -> if index < length then - byte = Str.getUnsafe string index - newState = step state byte index + byte = Str.get_unsafe(string, index) + new_state = step(state, byte, index) - walkUtf8WithIndexHelp string newState step (Num.addWrap index 1) length + walk_utf8_with_index_help(string, new_state, step, Num.add_wrap(index, 1), length) else state @@ -997,78 +998,79 @@ walkUtf8WithIndexHelp = \string, state, step, index, length -> ## state for each byte. ## ## ```roc -## sumOfUtf8Bytes = -## Str.walkUtf8 "Hello, World!" 0 \total, byte -> +## sum_of_utf8_bytes = +## Str.walk_utf8("Hello, World!", 0, (\total, byte -> ## total + byte +## )) ## -## expect sumOfUtf8Bytes == 105 +## expect sum_of_utf8_bytes == 105 ## ``` -walkUtf8 : Str, state, (state, U8 -> state) -> state -walkUtf8 = \str, initial, step -> - walkUtf8Help str initial step 0 (Str.countUtf8Bytes str) +walk_utf8 : Str, state, (state, U8 -> state) -> state +walk_utf8 = \str, initial, step -> + walk_utf8_help(str, initial, step, 0, Str.count_utf8_bytes(str)) -walkUtf8Help : Str, state, (state, U8 -> state), U64, U64 -> state -walkUtf8Help = \str, state, step, index, length -> +walk_utf8_help : Str, state, (state, U8 -> state), U64, U64 -> state +walk_utf8_help = \str, state, step, index, length -> if index < length then - byte = Str.getUnsafe str index - newState = step state byte + byte = Str.get_unsafe(str, index) + new_state = step(state, byte) - walkUtf8Help str newState step (Num.addWrap index 1) length + walk_utf8_help(str, new_state, step, Num.add_wrap(index, 1), length) else state -expect (walkUtf8 "ABC" [] List.append) == [65, 66, 67] -expect (walkUtf8 "鹏" [] List.append) == [233, 185, 143] +expect (walk_utf8("ABC", [], List.append)) == [65, 66, 67] +expect (walk_utf8("鹏", [], List.append)) == [233, 185, 143] ## Shrink the memory footprint of a str such that its capacity and length are equal. ## Note: This will also convert seamless slices to regular lists. -releaseExcessCapacity : Str -> Str +release_excess_capacity : Str -> Str -strToNum : Str -> { berrorcode : U8, aresult : Num * } +str_to_num : Str -> { berrorcode : U8, aresult : Num * } -strToNumHelp : Str -> Result (Num a) [InvalidNumStr] -strToNumHelp = \string -> +str_to_num_help : Str -> Result (Num a) [InvalidNumStr] +str_to_num_help = \string -> result : { berrorcode : U8, aresult : Num a } - result = strToNum string + result = str_to_num(string) if result.berrorcode == 0 then - Ok result.aresult + Ok(result.aresult) else - Err InvalidNumStr + Err(InvalidNumStr) ## Adds a prefix to the given [Str]. ## ```roc -## expect Str.withPrefix "Awesome" "Roc" == "RocAwesome" +## expect Str.with_prefix("Awesome", "Roc") == "RocAwesome" ## ``` -withPrefix : Str, Str -> Str -withPrefix = \str, prefix -> Str.concat prefix str +with_prefix : Str, Str -> Str +with_prefix = \str, prefix -> Str.concat(prefix, str) ## Determines whether or not the first Str contains the second. ## ```roc -## expect Str.contains "foobarbaz" "bar" -## expect !(Str.contains "apple" "orange") -## expect Str.contains "anything" "" +## expect Str.contains("foobarbaz", "bar") +## expect !Str.contains("apple", "orange") +## expect Str.contains("anything", "") ## ``` contains : Str, Str -> Bool contains = \haystack, needle -> - when firstMatch haystack needle is - Some _index -> Bool.true + when first_match(haystack, needle) is + Some(_index) -> Bool.true None -> Bool.false ## Drops the given prefix [Str] from the start of a [Str] ## If the prefix is not found, returns the original string. ## ## ```roc -## expect Str.dropPrefix "bar" "foo" == "bar" -## expect Str.dropPrefix "foobar" "foo" == "bar" +## expect Str.drop_prefix("bar", "foo") == "bar" +## expect Str.drop_prefix("foobar", "foo") == "bar" ## ``` -dropPrefix : Str, Str -> Str -dropPrefix = \haystack, prefix -> - if Str.startsWith haystack prefix then - start = Str.countUtf8Bytes prefix - len = Num.subWrap (Str.countUtf8Bytes haystack) start +drop_prefix : Str, Str -> Str +drop_prefix = \haystack, prefix -> + if Str.starts_with(haystack, prefix) then + start = Str.count_utf8_bytes(prefix) + len = Num.sub_wrap(Str.count_utf8_bytes(haystack), start) - substringUnsafe haystack start len + substring_unsafe(haystack, start, len) else haystack @@ -1076,15 +1078,15 @@ dropPrefix = \haystack, prefix -> ## If the suffix is not found, returns the original string. ## ## ```roc -## expect Str.dropSuffix "bar" "foo" == "bar" -## expect Str.dropSuffix "barfoo" "foo" == "bar" +## expect Str.drop_suffix("bar", "foo") == "bar" +## expect Str.drop_suffix("barfoo", "foo") == "bar" ## ``` -dropSuffix : Str, Str -> Str -dropSuffix = \haystack, suffix -> - if Str.endsWith haystack suffix then +drop_suffix : Str, Str -> Str +drop_suffix = \haystack, suffix -> + if Str.ends_with(haystack, suffix) then start = 0 - len = Num.subWrap (Str.countUtf8Bytes haystack) (Str.countUtf8Bytes suffix) + len = Num.sub_wrap(Str.count_utf8_bytes(haystack), Str.count_utf8_bytes(suffix)) - substringUnsafe haystack start len + substring_unsafe(haystack, start, len) else haystack diff --git a/crates/compiler/builtins/roc/Task.roc b/crates/compiler/builtins/roc/Task.roc index 3f03f23d69e..63dbf2bbc35 100644 --- a/crates/compiler/builtins/roc/Task.roc +++ b/crates/compiler/builtins/roc/Task.roc @@ -4,16 +4,16 @@ module [ err, await, map, - mapErr, - onErr, + map_err, + on_err, attempt, forever, loop, - fromResult, + from_result, batch, combine, sequence, - forEach, + for_each, result, ] @@ -26,61 +26,62 @@ Task ok err := {} -> Result ok err ## Run a task repeatedly, until it fails with `err`. Note that this task does not return a success value. forever : Task a err -> Task * err -forever = \@Task task -> +forever = \@Task(task) -> looper = \{} -> - when task {} is - Err e -> Err e - Ok _ -> looper {} + when task({}) is + Err(e) -> Err(e) + Ok(_) -> looper({}) - @Task \{} -> looper {} + @Task(\{} -> looper({})) ## Run a task repeatedly, until it fails with `err` or completes with `done`. ## ## ``` ## sum = -## Task.loop! 0 \total -> -## numResult = +## Task.loop!(0, \total -> +## num_result = ## Stdin.line ## |> Task.result! -## |> Result.try Str.toU64 +## |> Result.try(Str.toU64) ## -## when numResult is -## Ok num -> Task.ok (Step (total + num)) -## Err (StdinErr EndOfFile) -> Task.ok (Done total) -## Err InvalidNumStr -> Task.err NonNumberGiven +## when num_result is +## Ok num -> Task.ok(Step(total + num)) +## Err(StdinErr(EndOfFile)) -> Task.ok(Done(total)) +## Err(InvalidNumStr) -> Task.err(NonNumberGiven) +## ) ## ``` loop : state, (state -> Task [Step state, Done done] err) -> Task done err loop = \state, step -> looper = \current -> - (@Task next) = step current - when next {} is - Err e -> Err e - Ok (Done newResult) -> Ok newResult - Ok (Step newState) -> looper (newState) + @Task(next) = step(current) + when next({}) is + Err(e) -> Err(e) + Ok(Done(new_result)) -> Ok(new_result) + Ok(Step(new_state)) -> looper(new_state) - @Task \{} -> looper state + @Task(\{} -> looper(state)) ## Create a task that always succeeds with the value provided. ## ## ``` ## # Always succeeds with "Louis" -## getName : Task.Task Str * -## getName = Task.ok "Louis" +## get_name : Task.Task Str * +## get_name = Task.ok("Louis") ## ``` ## ok : a -> Task a * -ok = \a -> @Task \{} -> Ok a +ok = \a -> @Task(\{} -> Ok(a)) ## Create a task that always fails with the error provided. ## ## ``` ## # Always fails with the tag `CustomError Str` ## customError : Str -> Task.Task {} [CustomError Str] -## customError = \err -> Task.err (CustomError err) +## customError = \err -> Task.err(CustomError(err)) ## ``` ## err : a -> Task * a -err = \a -> @Task \{} -> Err a +err = \a -> @Task(\{} -> Err(a)) ## Transform a given Task with a function that handles the success or error case ## and returns another task based on that. This is useful for chaining tasks @@ -88,105 +89,107 @@ err = \a -> @Task \{} -> Err a ## ## Consider the following task: ## -## `canFail : Task {} [Failure, AnotherFail, YetAnotherFail]` +## `can_fail : Task {} [Failure, AnotherFail, YetAnotherFail]` ## ## We can use [attempt] to handle the failure cases using the following: ## ## ``` -## Task.attempt canFail \result -> +## Task.attempt(can_fail, \result -> ## when result is -## Ok Success -> Stdout.line "Success!" -## Err Failure -> Stdout.line "Oops, failed!" -## Err AnotherFail -> Stdout.line "Ooooops, another failure!" -## Err YetAnotherFail -> Stdout.line "Really big oooooops, yet again!" +## Ok(Success) -> Stdout.line("Success!") +## Err(Failure) -> Stdout.line("Oops, failed!") +## Err(AnotherFail) -> Stdout.line("Ooooops, another failure!") +## Err(YetAnotherFail) -> Stdout.line("Really big oooooops, yet again!") +## ) ## ``` ## -## Here we know that the `canFail` task may fail, and so we use +## Here we know that the `can_fail` task may fail, and so we use ## `Task.attempt` to convert the task to a `Result` and then use pattern ## matching to handle the success and possible failure cases. attempt : Task a b, (Result a b -> Task c d) -> Task c d -attempt = \@Task task, transform -> - @Task \{} -> - (@Task transformed) = transform (task {}) +attempt = \@Task(task), transform -> + @Task(\{} -> + @Task(transformed) = transform(task({})) - transformed {} + transformed({})) ## Take the success value from a given [Task] and use that to generate a new [Task]. ## ## We can [await] Task results with callbacks: ## ## ``` -## Task.await (Stdin.line "What's your name?") \name -> -## Stdout.line "Your name is: $(name)" +## Task.await(Stdin.line("What's your name?")), \name -> +## Stdout.line("Your name is: $(name)") +## ) ## ``` ## ## Or we can more succinctly use the `!` bang operator, which desugars to [await]: ## ## ``` -## name = Stdin.line! "What's your name?" -## Stdout.line "Your name is: $(name)" +## name = Stdin.line!("What's your name?") +## Stdout.line("Your name is: $(name)") ## ``` await : Task a b, (a -> Task c b) -> Task c b -await = \@Task task, transform -> - @Task \{} -> - when task {} is - Ok a -> - (@Task transformed) = transform a - transformed {} +await = \@Task(task), transform -> + @Task(\{} -> + when task({}) is + Ok(a) -> + @Task(transformed) = transform(a) + transformed({}) - Err b -> - Err b + Err(b) -> + Err(b)) ## Take the error value from a given [Task] and use that to generate a new [Task]. ## ## ``` -## # Prints "Something went wrong!" to standard error if `canFail` fails. -## canFail -## |> Task.onErr \_ -> Stderr.line "Something went wrong!" +## # Prints "Something went wrong!" to standard error if `can_fail` fails. +## can_fail +## |> Task.on_err(\_ -> Stderr.line("Something went wrong!")) ## ``` -onErr : Task a b, (b -> Task a c) -> Task a c -onErr = \@Task task, transform -> - @Task \{} -> - when task {} is - Ok a -> - Ok a +on_err : Task a b, (b -> Task a c) -> Task a c +on_err = \@Task(task), transform -> + @Task(\{} -> + when task({}) is + Ok(a) -> + Ok(a) - Err b -> - (@Task transformed) = transform b - transformed {} + Err(b) -> + @Task(transformed) = transform(b) + transformed({})) ## Transform the success value of a given [Task] with a given function. ## ## ``` ## # Succeeds with a value of "Bonjour Louis!" -## Task.ok "Louis" -## |> Task.map (\name -> "Bonjour $(name)!") +## Task.ok("Louis") +## |> Task.map(\name -> "Bonjour $(name)!") ## ``` map : Task a c, (a -> b) -> Task b c -map = \@Task task, transform -> - @Task \{} -> - when task {} is - Ok a -> Ok (transform a) - Err b -> Err b +map = \@Task(task), transform -> + @Task(\{} -> + when task({}) is + Ok(a) -> Ok(transform(a)) + Err(b) -> Err(b)) ## Transform the error value of a given [Task] with a given function. ## ## ``` ## # Ignore the fail value, and map it to the tag `CustomError` -## canFail -## |> Task.mapErr \_ -> CustomError +## can_fail +## |> Task.map_err(\_ -> CustomError) ## ``` -mapErr : Task c a, (a -> b) -> Task c b -mapErr = \@Task task, transform -> - @Task \{} -> - when task {} is - Ok a -> Ok a - Err b -> Err (transform b) +map_err : Task c a, (a -> b) -> Task c b +map_err = \@Task(task), transform -> + @Task(\{} -> + when task({}) is + Ok(a) -> Ok(a) + Err(b) -> Err(transform(b))) ## Use a Result among other Tasks by converting it into a [Task]. -fromResult : Result a b -> Task a b -fromResult = \res -> - @Task \{} -> res +from_result : Result a b -> Task a b +from_result = \res -> + @Task(\{} -> res) ## Apply a task to another task applicatively. ## @@ -194,8 +197,8 @@ fromResult = \res -> batch : Task a c -> (Task (a -> b) c -> Task b c) batch = \current -> \next -> - await next \f -> - map current f + await(next, \f -> + map(current, f)) ## Combine the values of two tasks with a custom combining function. ## @@ -204,54 +207,54 @@ batch = \current -> ## ``` ## { a, b, c } = ## { Task.combine <- -## a: Task.ok 123, -## b: File.read "file.txt", -## c: Http.get "http://api.com/", +## a: Task.ok(123), +## b: File.read("file.txt"), +## c: Http.get("http://api.com/"), ## }! ## ``` combine : Task a err, Task b err, (a, b -> c) -> Task c err -combine = \@Task leftTask, @Task rightTask, combiner -> - @Task \{} -> - left = try leftTask {} - right = try rightTask {} +combine = \@Task(left_task), @Task(right_task), combiner -> + @Task(\{} -> + left = try(left_task, {}) + right = try(right_task, {}) - Ok (combiner left right) + Ok(combiner(left, right))) ## Apply each task in a list sequentially, and return a list of the resulting values. ## Each task will be awaited before beginning the next task. ## ## ``` -## fetchAuthorTasks : List (Task Author [DbError]) +## fetch_author_tasks : List (Task Author [DbError]) ## -## getAuthors : Task (List Author) [DbError] -## getAuthors = Task.sequence fetchAuthorTasks +## get_authors : Task (List Author) [DbError] +## get_authors = Task.sequence(fetch_author_tasks) ## ``` ## sequence : List (Task ok err) -> Task (List ok) err -sequence = \taskList -> - Task.loop (taskList, List.withCapacity (List.len taskList)) \(tasks, values) -> +sequence = \task_list -> + Task.loop((task_list, List.with_capacity(List.len(task_list))), \(tasks, values) -> when tasks is [task, .. as rest] -> - Task.map task \value -> - Step (rest, List.append values value) + Task.map(task, \value -> + Step((rest, List.append(values, value)))) [] -> - Task.ok (Done values) + Task.ok(Done(values))) ## Apply a task repeatedly for each item in a list ## ## ``` ## authors : List Author -## saveAuthor : Author -> Task {} [DbError] +## save_author : Author -> Task {} [DbError] ## -## saveAuthors : Task (List Author) [DbError] -## saveAuthors = Task.forEach authors saveAuthor +## save_authors : Task (List Author) [DbError] +## save_authors = Task.for_each(authors, save_author) ## ``` ## -forEach : List a, (a -> Task {} b) -> Task {} b -forEach = \items, fn -> - List.walk items (ok {}) \state, item -> - state |> await \_ -> fn item +for_each : List a, (a -> Task {} b) -> Task {} b +for_each = \items, fn -> + List.walk(items, ok({}), \state, item -> + state |> await(\_ -> fn(item))) ## Transform a task that can either succeed with `ok`, or fail with `err`, into ## a task that succeeds with `Result ok err`. @@ -260,16 +263,16 @@ forEach = \items, fn -> ## ## ``` ## # Path.roc -## checkFile : Str -> Task [Good, Bad] [IOError] +## check_file : Str -> Task [Good, Bad] [IOError] ## ## # main.roc -## when checkFile "/usr/local/bin/roc" |> Task.result! is -## Ok Good -> "..." -## Ok Bad -> "..." -## Err IOError -> "..." +## when check_file("/usr/local/bin/roc") |> Task.result! is +## Ok(Good) -> "..." +## Ok(Bad) -> "..." +## Err(IOError) -> "..." ## ``` ## result : Task ok err -> Task (Result ok err) * -result = \@Task task -> - @Task \{} -> - Ok (task {}) +result = \@Task(task) -> + @Task(\{} -> + Ok(task({}))) diff --git a/crates/compiler/can/src/def.rs b/crates/compiler/can/src/def.rs index cfce913b148..63a33e42819 100644 --- a/crates/compiler/can/src/def.rs +++ b/crates/compiler/can/src/def.rs @@ -846,8 +846,8 @@ fn canonicalize_opaque<'a>( // Did the user claim this implementation for a specialization of a different // type? e.g. // - // A implements [Hash {hash: myHash}] - // B implements [Hash {hash: myHash}] + // A implements [Hash {hash: my_hash}] + // B implements [Hash {hash: my_hash}] // // If so, that's an error and we drop the impl for this opaque type. let member_impl = match scope.abilities_store.impl_key(impl_symbol) { diff --git a/crates/compiler/can/src/derive.rs b/crates/compiler/can/src/derive.rs index 04fc1e29835..ac21d54af19 100644 --- a/crates/compiler/can/src/derive.rs +++ b/crates/compiler/can/src/derive.rs @@ -30,11 +30,11 @@ fn to_encoder<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { ast::PatternApplyStyle::Whitespace, ); - // Encode.toEncoder payload + // Encode.to_encoder(payload) let call_member = alloc_expr(ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Encode", - ident: "toEncoder", + ident: "to_encoder", }), &*env.arena.alloc([&*alloc_expr(ast::Expr::Var { module_name: "", @@ -43,7 +43,7 @@ fn to_encoder<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { roc_module::called_via::CalledVia::Space, )); - // \@Opaq payload -> Encode.toEncoder payload + // \@Opaq payload -> Encode.to_encoder(payload) ast::Expr::Closure( env.arena .alloc([Loc::at(DERIVED_REGION, opaque_apply_pattern)]), @@ -58,11 +58,11 @@ fn decoder<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { let bytes = "#bytes"; let fmt = "#fmt"; - // Decode.decodeWith bytes Decode.decoder fmt + // Decode.decode_with(bytes, Decode.decoder, fmt) let call_decode_with = ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Decode", - ident: "decodeWith", + ident: "decode_with", }), env.arena.alloc([ &*alloc_expr(ast::Expr::Var { @@ -81,11 +81,11 @@ fn decoder<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { CalledVia::Space, ); - // Decode.mapResult (Decode.decodeWith bytes Decode.decoder fmt) @Opaq + // Decode.map_result(Decode.decode_with(bytes, Decode.decoder, fmt), @Opaq) let call_map_result = ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Decode", - ident: "mapResult", + ident: "map_result", }), env.arena.alloc([ &*alloc_expr(call_decode_with), @@ -95,7 +95,7 @@ fn decoder<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { ); // \bytes, fmt -> - // Decode.mapResult (Decode.decodeWith bytes Decode.decoder fmt) @Opaq + // Decode.map_result(Decode.decode_with(bytes, Decode.decoder, fmt), @Opaq) let custom_closure = ast::Expr::Closure( env.arena.alloc([ Loc::at(DERIVED_REGION, ast::Pattern::Identifier { ident: bytes }), @@ -136,7 +136,7 @@ fn hash<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { PatternApplyStyle::Whitespace, ); - // Hash.hash hasher payload + // Hash.hash(hasher, payload) let call_member = alloc_expr(ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Hash", @@ -155,7 +155,7 @@ fn hash<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { roc_module::called_via::CalledVia::Space, )); - // \hasher, @Opaq payload -> Hash.hash hasher payload + // \hasher, @Opaq payload -> Hash.hash(hasher, payload) ast::Expr::Closure( env.arena.alloc([ Loc::at(DERIVED_REGION, ast::Pattern::Identifier { ident: hasher }), @@ -192,11 +192,11 @@ fn is_eq<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { PatternApplyStyle::Whitespace, ); - // Bool.isEq payload1 payload2 + // Bool.is_eq(payload1, payload2) let call_member = alloc_expr(ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Bool", - ident: "isEq", + ident: "is_eq", }), &*env.arena.alloc([ &*alloc_expr(ast::Expr::Var { @@ -211,7 +211,7 @@ fn is_eq<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { roc_module::called_via::CalledVia::Space, )); - // \@Opaq payload1, @Opaq payload2 -> Bool.isEq payload1 payload2 + // \@Opaq payload1, @Opaq payload2 -> Bool.is_eq(payload1, payload2) ast::Expr::Closure( env.arena.alloc([ Loc::at(DERIVED_REGION, opaque1), @@ -239,11 +239,11 @@ fn to_inspector<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { PatternApplyStyle::Whitespace, ); - // Inspect.toInspector payload + // Inspect.to_inspector(payload) let to_inspector_payload = alloc_expr(ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Inspect", - ident: "toInspector", + ident: "to_inspector", }), &*env.arena.alloc([&*alloc_expr(ast::Expr::Var { module_name: "", @@ -252,7 +252,7 @@ fn to_inspector<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { roc_module::called_via::CalledVia::Space, )); - // Inspect.tag "@opaque" [Inspect.toInspector payload] + // Inspect.tag("@opaque", [Inspect.to_inspector(payload)]) let to_inspector_list = alloc_expr(ast::Expr::List(Collection::with_items( &*env.arena.alloc([&*to_inspector_payload]), ))); @@ -269,7 +269,7 @@ fn to_inspector<'a>(env: &mut Env<'a>, at_opaque: &'a str) -> ast::Expr<'a> { let fmt = "#fmt"; - // \fmt -> Inspect.apply opaqueInspector fmt + // \fmt -> Inspect.apply(opaque_inspector, fmt) let apply_opaque_inspector = alloc_expr(ast::Expr::Apply( alloc_expr(ast::Expr::Var { module_name: "Inspect", @@ -325,14 +325,14 @@ pub(crate) fn synthesize_member_impl<'a>( let (impl_name, def_body): (String, ast::Expr<'a>) = match ability_member { Symbol::ENCODE_TO_ENCODER => ( - format!("#{opaque_name}_toEncoder"), + format!("#{opaque_name}_to_encoder"), to_encoder(env, at_opaque), ), Symbol::DECODE_DECODER => (format!("#{opaque_name}_decoder"), decoder(env, at_opaque)), Symbol::HASH_HASH => (format!("#{opaque_name}_hash"), hash(env, at_opaque)), - Symbol::BOOL_IS_EQ => (format!("#{opaque_name}_isEq"), is_eq(env, at_opaque)), + Symbol::BOOL_IS_EQ => (format!("#{opaque_name}_is_eq"), is_eq(env, at_opaque)), Symbol::INSPECT_TO_INSPECTOR => ( - format!("#{opaque_name}_toInspector"), + format!("#{opaque_name}_to_inspector"), to_inspector(env, at_opaque), ), other => internal_error!("{:?} is not a derivable ability member!", other), diff --git a/crates/compiler/can/src/desugar.rs b/crates/compiler/can/src/desugar.rs index d81630a14c1..4dd2cc70fa3 100644 --- a/crates/compiler/can/src/desugar.rs +++ b/crates/compiler/can/src/desugar.rs @@ -1494,7 +1494,7 @@ pub fn desugar_record_destructures<'a>( /// value produced by `expr`. Essentially: /// ( /// tmpVar = expr -/// LowLevelDbg (Inspect.toStr tmpVar) +/// LowLevelDbg (Inspect.to_str tmpVar) /// tmpVar /// ) fn desugar_dbg_expr<'a>( @@ -1552,7 +1552,7 @@ pub fn desugar_invalid_dbg_expr<'a>( desugar_dbg_expr(env, scope, placeholder_expr, outer_region) } -/// Desugars a `dbg x` statement into essentially `Inspect.toStr x |> LowLevelDbg` +/// Desugars a `dbg x` statement into essentially `Inspect.to_str x |> LowLevelDbg` fn desugar_dbg_stmt<'a>( env: &mut Env<'a>, condition: &'a Loc>, @@ -1562,7 +1562,7 @@ fn desugar_dbg_stmt<'a>( let inspect_fn = Var { module_name: ModuleName::INSPECT, - ident: "toStr", + ident: "to_str", }; let loc_inspect_fn_var = env.arena.alloc(Loc { value: inspect_fn, @@ -1608,16 +1608,16 @@ fn binop_to_function(binop: BinOp) -> (&'static str, &'static str) { Caret => (ModuleName::NUM, "pow"), Star => (ModuleName::NUM, "mul"), Slash => (ModuleName::NUM, "div"), - DoubleSlash => (ModuleName::NUM, "divTrunc"), + DoubleSlash => (ModuleName::NUM, "div_trunc"), Percent => (ModuleName::NUM, "rem"), Plus => (ModuleName::NUM, "add"), Minus => (ModuleName::NUM, "sub"), - Equals => (ModuleName::BOOL, "isEq"), - NotEquals => (ModuleName::BOOL, "isNotEq"), - LessThan => (ModuleName::NUM, "isLt"), - GreaterThan => (ModuleName::NUM, "isGt"), - LessThanOrEq => (ModuleName::NUM, "isLte"), - GreaterThanOrEq => (ModuleName::NUM, "isGte"), + Equals => (ModuleName::BOOL, "is_eq"), + NotEquals => (ModuleName::BOOL, "is_not_eq"), + LessThan => (ModuleName::NUM, "is_lt"), + GreaterThan => (ModuleName::NUM, "is_gt"), + LessThanOrEq => (ModuleName::NUM, "is_lte"), + GreaterThanOrEq => (ModuleName::NUM, "is_gte"), And => (ModuleName::BOOL, "and"), Or => (ModuleName::BOOL, "or"), Pizza => unreachable!("Cannot desugar the |> operator"), diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_expr.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_expr.snap index e671cbec8b1..b09bbd401a2 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_expr.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_expr.snap @@ -98,7 +98,7 @@ Defs { @21-26 Apply( @21-26 Var { module_name: "Inspect", - ident: "toStr", + ident: "to_str", }, [ @21-26 Var { @@ -126,7 +126,7 @@ Defs { @16-27 Apply( @16-27 Var { module_name: "Inspect", - ident: "toStr", + ident: "to_str", }, [ @16-27 Var { diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_simple.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_simple.snap index c6e36e9cc7f..706625b7ab0 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_simple.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_simple.snap @@ -49,7 +49,7 @@ Defs { @33-36 Apply( @33-36 Var { module_name: "Inspect", - ident: "toStr", + ident: "to_str", }, [ @33-36 Var { diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_stmt_arg.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_stmt_arg.snap index 7c505c58a76..f7cc5f82347 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_stmt_arg.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__dbg_stmt_arg.snap @@ -49,7 +49,7 @@ Defs { @15-16 Apply( @15-16 Var { module_name: "Inspect", - ident: "toStr", + ident: "to_str", }, [ @15-16 Var { diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__expect_then_bang.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__expect_then_bang.snap index 1562686d0a8..c5d6bfe6d9f 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__expect_then_bang.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__expect_then_bang.snap @@ -46,7 +46,7 @@ Defs { condition: @18-24 Apply( @20-22 Var { module_name: "Bool", - ident: "isEq", + ident: "is_eq", }, [ @18-19 Num( diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__issue_7081.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__issue_7081.snap index fef5f14bdf2..9396e9fac35 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__issue_7081.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__issue_7081.snap @@ -49,7 +49,7 @@ Defs { @19-24 Apply( @21-22 Var { module_name: "Num", - ident: "isGt", + ident: "is_gt", }, [ @19-20 Var { @@ -232,7 +232,7 @@ Defs { @213-227 Apply( @220-222 Var { module_name: "Bool", - ident: "isEq", + ident: "is_eq", }, [ @213-219 Var { diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__pizza_dbg.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__pizza_dbg.snap index 947dc76d843..d064a11fd38 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__pizza_dbg.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__pizza_dbg.snap @@ -87,7 +87,7 @@ Defs { @11-12 Apply( @11-12 Var { module_name: "Inspect", - ident: "toStr", + ident: "to_str", }, [ @11-12 Var { @@ -122,7 +122,7 @@ Defs { @11-40 Apply( @11-40 Var { module_name: "Inspect", - ident: "toStr", + ident: "to_str", }, [ @11-40 Var { diff --git a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__simple_double_question.snap b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__simple_double_question.snap index eef6b18099c..db3bd62f196 100644 --- a/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__simple_double_question.snap +++ b/crates/compiler/can/tests/snapshots/test_suffixed__suffixed_tests__simple_double_question.snap @@ -8,7 +8,7 @@ Defs { EitherIndex(2147483648), ], regions: [ - @0-85, + @0-86, ], space_before: [ Slice { start: 0, length: 0 }, @@ -25,19 +25,19 @@ Defs { @0-4 Identifier { ident: "main", }, - @11-69 Apply( - @11-69 Var { + @11-70 Apply( + @11-70 Var { module_name: "Task", ident: "await", }, [ - @11-69 Defs( + @11-70 Defs( Defs { tags: [ EitherIndex(2147483648), ], regions: [ - @11-69, + @11-70, ], space_before: [ Slice { start: 0, length: 0 }, @@ -49,34 +49,34 @@ Defs { type_defs: [], value_defs: [ AnnotatedBody { - ann_pattern: @11-69 Identifier { + ann_pattern: @11-70 Identifier { ident: "#!0_stmt", }, - ann_type: @11-69 Apply( + ann_type: @11-70 Apply( "", "Task", [ - @11-69 Record { + @11-70 Record { fields: [], ext: None, }, - @11-69 Inferred, + @11-70 Inferred, ], ), lines_between: [], - body_pattern: @11-69 Identifier { + body_pattern: @11-70 Identifier { ident: "#!0_stmt", }, - body_expr: @11-69 Apply( - @11-69 Var { + body_expr: @11-70 Apply( + @11-70 Var { module_name: "", ident: "line", }, [ - @11-56 Apply( - @47-56 Var { + @11-57 Apply( + @47-57 Var { module_name: "Num", - ident: "toStr", + ident: "to_str", }, [ @11-39 Apply( @@ -151,24 +151,24 @@ Defs { }, ], }, - @11-69 Var { + @11-70 Var { module_name: "", ident: "#!0_stmt", }, ), - @11-69 Closure( + @11-70 Closure( [ - @11-69 Underscore( + @11-70 Underscore( "#!stmt", ), ], - @75-85 Apply( - @75-82 Var { + @76-86 Apply( + @76-83 Var { module_name: "Task", ident: "ok", }, [ - @83-85 Record( + @84-86 Record( [], ), ], diff --git a/crates/compiler/can/tests/test_can.rs b/crates/compiler/can/tests/test_can.rs index aa7e818a481..92cbc21be27 100644 --- a/crates/compiler/can/tests/test_can.rs +++ b/crates/compiler/can/tests/test_can.rs @@ -806,7 +806,7 @@ mod test_can { fn question_suffix_simple() { let src = indoc!( r#" - (Str.toU64 "123")? + (Str.to_u64 "123")? "# ); let arena = Bump::new(); @@ -816,10 +816,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123") + // Try(Str.to_u64 "123") let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Space, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Space, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -829,7 +829,7 @@ mod test_can { fn question_suffix_after_function() { let src = indoc!( r#" - Str.toU64? "123" + Str.to_u64? "123" "# ); let arena = Bump::new(); @@ -839,10 +839,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123") + // Try(Str.to_u64 "123") let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Try, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Try, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -852,7 +852,7 @@ mod test_can { fn question_suffix_pipe() { let src = indoc!( r#" - "123" |> Str.toU64? + "123" |> Str.to_u64? "# ); let arena = Bump::new(); @@ -862,10 +862,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123") + // Try(Str.to_u64 "123") let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Try, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Try, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -875,7 +875,7 @@ mod test_can { fn question_suffix_pipe_nested() { let src = indoc!( r#" - "123" |> Str.toU64? (Ok 123)? + "123" |> Str.to_u64? (Ok 123)? "# ); let arena = Bump::new(); @@ -885,10 +885,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123" Try(Ok 123)) + // Try(Str.to_u64 "123" Try(Ok 123)) let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Try, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Try, &out.interns); assert_eq!(cond_args.len(), 2); @@ -906,7 +906,7 @@ mod test_can { fn try_desugar_plain_prefix() { let src = indoc!( r#" - try Str.toU64 "123" + try Str.to_u64 "123" "# ); let arena = Bump::new(); @@ -916,10 +916,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123") + // Try(Str.to_u64 "123") let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Try, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Try, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -929,7 +929,7 @@ mod test_can { fn try_desugar_pipe_prefix() { let src = indoc!( r#" - "123" |> try Str.toU64 + "123" |> try Str.to_u64 "# ); let arena = Bump::new(); @@ -939,10 +939,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123") + // Try(Str.to_u64 "123") let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Try, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Try, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -952,7 +952,7 @@ mod test_can { fn try_desugar_pipe_suffix() { let src = indoc!( r#" - Str.toU64 "123" |> try + Str.to_u64 "123" |> try "# ); let arena = Bump::new(); @@ -962,10 +962,10 @@ mod test_can { // Assert that we desugar to: // - // Try(Str.toU64 "123") + // Try(Str.to_u64 "123") let cond_expr = assert_try_expr(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Space, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Space, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -975,7 +975,7 @@ mod test_can { fn try_desugar_double_question_suffix() { let src = indoc!( r#" - Str.toU64 "123" ?? Num.maxU64 + Str.to_u64 "123" ?? Num.max_u64 "# ); let arena = Bump::new(); @@ -985,12 +985,12 @@ mod test_can { // Assert that we desugar to: // - // when Str.toU64 "123" + // when Str.to_u64 "123" // Ok success_BRANCH1_0_9 -> success_BRANCH1_0_9 - // Err _ -> Num.maxU64 + // Err _ -> Num.max_u64 let (cond_expr, branches) = assert_when(&out.loc_expr.value); - let cond_args = assert_func_call(cond_expr, "toU64", CalledVia::Space, &out.interns); + let cond_args = assert_func_call(cond_expr, "to_u64", CalledVia::Space, &out.interns); assert_eq!(cond_args.len(), 1); assert_str_value(&cond_args[0].1.value, "123"); @@ -1000,16 +1000,16 @@ mod test_can { assert_pattern_tag_apply_with_ident( &branches[0].patterns[0].pattern.value, "Ok", - "success_BRANCH1_0_15", + "success_BRANCH1_0_16", &out.interns, ); assert_var_usage( &branches[0].value.value, - "success_BRANCH1_0_15", + "success_BRANCH1_0_16", &out.interns, ); assert_pattern_tag_apply_with_underscore(&branches[1].patterns[0].pattern.value, "Err"); - assert_var_usage(&branches[1].value.value, "maxU64", &out.interns); + assert_var_usage(&branches[1].value.value, "max_u64", &out.interns); } #[test] diff --git a/crates/compiler/can/tests/test_suffixed.rs b/crates/compiler/can/tests/test_suffixed.rs index 34183b49411..0740ed66b13 100644 --- a/crates/compiler/can/tests/test_suffixed.rs +++ b/crates/compiler/can/tests/test_suffixed.rs @@ -164,7 +164,7 @@ mod suffixed_tests { main = "123" |> Str.toU8 ?? 255 - |> Num.toStr + |> Num.to_str |> line! Task.ok {} diff --git a/crates/compiler/checkmate/www/src/components/Graph/VariablesGraph.tsx b/crates/compiler/checkmate/www/src/components/Graph/VariablesGraph.tsx index 6b646c8d4cb..ed659541a7f 100644 --- a/crates/compiler/checkmate/www/src/components/Graph/VariablesGraph.tsx +++ b/crates/compiler/checkmate/www/src/components/Graph/VariablesGraph.tsx @@ -409,10 +409,10 @@ function Graph({ const edgeChanges: EdgeChange[] = []; while (toVariable !== undefined) { - const toVariableName = toVariable.toString(); + const toVariableName = toVariable.to_string(); if (canAddVariable(toVariableName, nodes)) { const newVariableNode = newVariable( - toVariable.toString(), + toVariable.to_string(), { subs, rawVariable: toVariable, @@ -440,7 +440,7 @@ function Graph({ const newEdge = addEdge({ id: `${fromVariable}->${toVariable}`, - source: fromVariable.toString(), + source: fromVariable.to_string(), target: toVariableName, markerEnd, }); diff --git a/crates/compiler/derive/src/decoding/record.rs b/crates/compiler/derive/src/decoding/record.rs index 97974bd5aae..635c42f9049 100644 --- a/crates/compiler/derive/src/decoding/record.rs +++ b/crates/compiler/derive/src/decoding/record.rs @@ -30,19 +30,19 @@ use super::wrap_in_decode_custom_decode_with; /// ```roc /// decoder : Decoder {first: a, second: b} fmt where a implements Decoding, b implements Decoding, fmt implements DecoderFormatting /// decoder = -/// initialState : {f0: Result a [NoField], f1: Result b [NoField]} -/// initialState = {f0: Err NoField, f1: Err NoField} +/// initial_state : {f0: Result a [NoField], f1: Result b [NoField]} +/// initial_state = {f0: Err NoField, f1: Err NoField} /// -/// stepField = \state, field -> +/// step_field = \state, field -> /// when field is /// "first" -> /// Keep (Decode.custom \bytes, fmt -> -/// when Decode.decodeWith bytes Decode.decoder fmt is +/// when Decode.decode_with bytes Decode.decoder fmt is /// {result, rest} -> /// {result: Result.map result \val -> {state & f0: Ok val}, rest}) /// "second" -> /// Keep (Decode.custom \bytes, fmt -> -/// when Decode.decodeWith bytes Decode.decoder fmt is +/// when Decode.decode_with bytes Decode.decoder fmt is /// {result, rest} -> /// {result: Result.map result \val -> {state & f1: Ok val}, rest}) /// _ -> Skip @@ -51,7 +51,7 @@ use super::wrap_in_decode_custom_decode_with; /// when /// when rec.f0 is /// Err NoField -> -/// when Decode.decodeWith [] Decode.decoder fmt is +/// when Decode.decode_with [] Decode.decoder fmt is /// rec2 -> rec2.result /// Ok a -> Ok a /// is @@ -59,7 +59,7 @@ use super::wrap_in_decode_custom_decode_with; /// when /// when rec.f1 is /// Err NoField -> -/// when Decode.decodeWith [] Decode.decoder fmt is +/// when Decode.decode_with [] Decode.decoder fmt is /// rec2 -> rec2.result /// Ok a -> Ok a /// is @@ -67,7 +67,7 @@ use super::wrap_in_decode_custom_decode_with; /// Err _ -> Err TooShort /// Err _ -> Err TooShort /// -/// Decode.custom \bytes, fmt -> Decode.decodeWith bytes (Decode.record initialState stepField finalizer) fmt +/// Decode.custom \bytes, fmt -> Decode.decode_with bytes (Decode.record initial_state step_field finalizer) fmt ///``` pub(crate) fn decoder( env: &mut Env, @@ -79,7 +79,7 @@ pub(crate) fn decoder( // The type of each field in the decoding state, e.g. {first: Result a [NoField], second: Result b [NoField]} let mut result_field_vars = Vec::with_capacity(fields.len()); - // initialState = ... + // initial_state = ... let (initial_state_var, initial_state) = initial_state(env, &fields, &mut field_vars, &mut result_field_vars); @@ -92,7 +92,7 @@ pub(crate) fn decoder( &result_field_vars, ); - // stepField = ... + // step_field = ... let (step_field, step_var) = step_field( env, fields, @@ -120,7 +120,7 @@ pub(crate) fn decoder( env.unify(decode_record_var, this_decode_record_var); - // Decode.record initialState stepField finalizer + // Decode.record initial_state step_field finalizer let call_decode_record = Expr::Call( Box::new(( this_decode_record_var, @@ -161,13 +161,13 @@ pub(crate) fn decoder( } // Example: -// stepField = \state, field -> +// step_field = \state, field -> // when field is // "first" -> // Keep (Decode.custom \bytes, fmt -> // # Uses a single-branch `when` because `let` is more expensive to monomorphize // # due to checks for polymorphic expressions, and `rec` would be polymorphic. -// when Decode.decodeWith bytes Decode.decoder fmt is +// when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -178,7 +178,7 @@ pub(crate) fn decoder( // // "second" -> // Keep (Decode.custom \bytes, fmt -> -// when Decode.decodeWith bytes Decode.decoder fmt is +// when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -196,7 +196,7 @@ pub(super) fn step_field( state_record_var: Variable, decode_err_var: Variable, ) -> (Expr, Variable) { - let state_arg_symbol = env.new_symbol("stateRecord"); + let state_arg_symbol = env.new_symbol("state_record"); let field_arg_symbol = env.new_symbol("field"); // +1 because of the default branch. @@ -228,7 +228,7 @@ pub(super) fn step_field( // Keep (Decode.custom \bytes, fmt -> // # Uses a single-branch `when` because `let` is more expensive to monomorphize // # due to checks for polymorphic expressions, and `rec` would be polymorphic. - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -254,7 +254,7 @@ pub(super) fn step_field( let keep = { // Keep (Decode.custom \bytes, fmt -> - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -274,7 +274,7 @@ pub(super) fn step_field( let branch = { // "first" -> // Keep (Decode.custom \bytes, fmt -> - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -326,7 +326,7 @@ pub(super) fn step_field( exhaustive: ExhaustiveMark::known_exhaustive(), }; - let step_field_closure = env.new_symbol("stepField"); + let step_field_closure = env.new_symbol("step_field"); let function_type = env.subs.fresh_unnamed_flex_var(); let closure_type = { let lambda_set = LambdaSet { @@ -395,7 +395,7 @@ struct DecodingFieldArgs { /// Decode.custom \bytes, fmt -> /// # Uses a single-branch `when` because `let` is more expensive to monomorphize /// # due to checks for polymorphic expressions, and `rec` would be polymorphic. -/// when Decode.decodeWith bytes Decode.decoder fmt is +/// when Decode.decode_with bytes Decode.decoder fmt is /// rec -> /// { /// rest: rec.rest, @@ -444,7 +444,7 @@ fn custom_decoder(env: &mut Env<'_>, args: DecodingFieldArgs) -> (Variable, Expr /// ```roc /// \bytes, fmt -> -/// when Decode.decodeWith bytes Decode.decoder fmt is +/// when Decode.decode_with bytes Decode.decoder fmt is /// rec -> /// { /// rest: rec.rest, @@ -467,7 +467,7 @@ fn custom_decoder_lambda(env: &mut Env<'_>, args: DecodingFieldArgs) -> (Variabl let custom_callback_ret_var; // \bytes, fmt -> - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -507,7 +507,7 @@ fn custom_decoder_lambda(env: &mut Env<'_>, args: DecodingFieldArgs) -> (Variabl synth_var(env.subs, Content::Structure(flat_type)) }; - // Decode.decodeWith bytes Decode.decoder fmt + // Decode.decode_with bytes Decode.decoder fmt let (condition_expr, rec_var, rec_dot_result) = decode_with( env, field_var, @@ -519,7 +519,7 @@ fn custom_decoder_lambda(env: &mut Env<'_>, args: DecodingFieldArgs) -> (Variabl // # Uses a single-branch `when` because `let` is more expensive to monomorphize // # due to checks for polymorphic expressions, and `rec` would be polymorphic. - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is // rec -> // { // rest: rec.rest, @@ -556,7 +556,7 @@ fn custom_decoder_lambda(env: &mut Env<'_>, args: DecodingFieldArgs) -> (Variabl redundant: RedundantMark::known_non_redundant(), }; - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is // ... Expr::When { loc_cond: Box::new(Loc::at_zero(condition_expr)), @@ -806,7 +806,7 @@ fn state_record_update( /// when /// when rec.f0 is /// Err NoField -> -/// when Decode.decodeWith [] Decode.decoder fmt is +/// when Decode.decode_with [] Decode.decoder fmt is /// rec2 -> rec2.result /// Ok a -> Ok a /// is @@ -814,7 +814,7 @@ fn state_record_update( /// when /// when rec.f1 is /// Err NoField -> -/// when Decode.decodeWith [] Decode.decoder fmt is +/// when Decode.decode_with [] Decode.decoder fmt is /// rec2 -> rec2.result /// Ok a -> Ok a /// is @@ -828,7 +828,7 @@ pub(super) fn finalizer( field_vars: &[Variable], result_field_vars: &[Variable], ) -> (Expr, Variable, Variable) { - let state_arg_symbol = env.new_symbol("stateRecord"); + let state_arg_symbol = env.new_symbol("state_record"); let mut fields_map = SendMap::default(); let mut pattern_symbols = Vec::with_capacity(fields.len()); @@ -909,7 +909,7 @@ pub(super) fn finalizer( // [Ok field_var, Err DecodeError] // when rec.f0 is // Err _ -> - // when Decode.decodeWith [] Decode.decoder fmt is + // when Decode.decode_with [] Decode.decoder fmt is // rec2 -> rec2.result // Ok a -> Ok a let (attempt_empty_decode_expr, attempt_empty_decode_var) = attempt_empty_decode_if_missing( @@ -968,11 +968,11 @@ pub(super) fn finalizer( }; // when - // when stateRecord.f0 is + // when state_record.f0 is // Ok f0 -> Ok f0 // _ -> - // when Decode.decodeWith [] Decode.decoder fmt is - // decRec -> decRec.result + // when Decode.decode_with [] Decode.decoder fmt is + // dec_rec -> dec_rec.result // is // _-> TooShort // Ok x -> expr @@ -1037,8 +1037,8 @@ pub(super) fn finalizer( /// ```roc /// when rec.f0 is /// Err _ -> -/// when Decode.decodeWith [] Decode.decoder fmt is -/// decRec-> decRec.result +/// when Decode.decode_with [] Decode.decoder fmt is +/// dec_rec-> dec_rec.result /// Ok a -> Ok a /// ``` /// Tries to decode the field with a zero byte input if it missing, @@ -1070,7 +1070,7 @@ fn attempt_empty_decode_if_missing( decode_err_var, ); let decode_when = { - let decoder_rec_symb = env.new_symbol("decRec"); + let decoder_rec_symb = env.new_symbol("dec_rec"); let branch = WhenBranch { patterns: vec![WhenBranchPattern { @@ -1088,7 +1088,7 @@ fn attempt_empty_decode_if_missing( redundant: RedundantMark::known_non_redundant(), }; - // when Decode.decodeWith bytes Decode.decoder fmt is + // when Decode.decode_with bytes Decode.decoder fmt is Expr::When { loc_cond: Box::new(Loc::at_zero(decode_expr)), cond_var: rec_result, @@ -1112,7 +1112,7 @@ fn attempt_empty_decode_if_missing( // Example: `Ok x -> Ok x` let ok_branch = ok_to_ok_branch(result_field_var, rec_dot_result, field_var, symbol, env); - // Example: `Err NoField -> when decodeWith [] decoder #Derived.fmt is` + // Example: `Err NoField -> when decode_with [] decoder #Derived.fmt is` let no_field_label = "NoField"; let union_tags = UnionTags::tag_without_arguments(env.subs, no_field_label.into()); let no_field_var = synth_var( @@ -1159,8 +1159,8 @@ fn attempt_empty_decode_if_missing( } // Example: -// initialState : {first: Result a [NoField], second: Result b [NoField]} -// initialState = {first: Err NoField, second: Err NoField} +// initial_state : {first: Result a [NoField], second: Result b [NoField]} +// initial_state = {first: Err NoField, second: Err NoField} fn initial_state( env: &mut Env<'_>, field_names: &[Lowercase], @@ -1237,16 +1237,16 @@ fn initial_state( } struct DecodeWithVars { - /// Type of the record returned by `Decode.decodeWith` + /// Type of the record returned by `Decode.decode_with` /// `rec : { rest: List U8, result: (typeof rec.result) }` rec_var: Variable, - /// type of the result field of the record returned by `Decode.decodeWith` + /// type of the result field of the record returned by `Decode.decode_with` rec_dot_result: Variable, /// type of `Decode.decoder` decoder_var: Variable, - /// lambda set for `Decode.decodeWith` call + /// lambda set for `Decode.decode_with` call lambda_set_var: Variable, - /// specialised type of this specific call to `Decode.decodeWith` + /// specialised type of this specific call to `Decode.decode_with` this_decode_with_var: Variable, } @@ -1314,9 +1314,9 @@ fn make_decode_with_vars( } } -/// `Decode.decodeWith bytes Decode.decoder fmt` +/// `Decode.decode_with bytes Decode.decoder fmt` /// -/// Generates a call to decodeWith, returns that expression, +/// Generates a call to decode_with, returns that expression, /// the variable of the return value `{ rest: List U8, result: (typeof rec.result) }`, /// and the variable of the result field of the return value `[Ok field_var, Err DecodeError]`. pub(super) fn decode_with( diff --git a/crates/compiler/derive/src/inspect.rs b/crates/compiler/derive/src/inspect.rs index 8a41356ca6c..0720c879ecb 100644 --- a/crates/compiler/derive/src/inspect.rs +++ b/crates/compiler/derive/src/inspect.rs @@ -109,7 +109,7 @@ pub(crate) fn derive_to_inspector( } fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { - // Build \lst -> list, List.walk, (\elem -> Inspect.toInspector elem) + // Build \lst -> list, List.walk, (\elem -> Inspect.to_inspector elem) use Expr::*; @@ -124,7 +124,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { Content::Structure(FlatType::Apply(Symbol::LIST_LIST, elem_var_slice)), ); - // build `toInspector elem` type + // build `to_inspector elem` type // val -[uls]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_fn_var = env.import_builtin_symbol_var(Symbol::INSPECT_TO_INSPECTOR); @@ -145,7 +145,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { // ~ elem -[clos]-> t1 env.unify(to_inspector_fn_var, elem_to_inspector_fn_var); - // toInspector : (typeof rcd.a) -[clos]-> Inspector fmt where fmt implements InspectorFormatter + // to_inspector : (typeof rcd.a) -[clos]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_var = AbilityMember(Symbol::INSPECT_TO_INSPECTOR, None, elem_to_inspector_fn_var); let to_inspector_fn = Box::new(( @@ -156,14 +156,14 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { Variable::PURE, )); - // toInspector elem + // to_inspector elem let to_inspector_call = Call( to_inspector_fn, vec![(elem_var, Loc::at_zero(Var(elem_sym, elem_var)))], CalledVia::Space, ); - // elem -[to_elem_inspector]-> toInspector elem + // elem -[to_elem_inspector]-> to_inspector elem let to_elem_inspector_sym = env.new_symbol("to_elem_inspector"); // Create fn_var for ambient capture; we fix it up below. @@ -181,7 +181,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { ambient_function: to_elem_inspector_fn_var, }), ); - // elem -[to_elem_inspector]-> toInspector elem + // elem -[to_elem_inspector]-> to_inspector elem env.subs.set_content( to_elem_inspector_fn_var, Content::Structure(FlatType::Func( @@ -192,7 +192,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { )), ); - // \elem -> toInspector elem + // \elem -> to_inspector elem let to_elem_inspector = Closure(ClosureData { function_type: to_elem_inspector_fn_var, closure_type: to_elem_inspector_lset, @@ -210,7 +210,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { loc_body: Box::new(Loc::at_zero(to_inspector_call)), }); - // build `Inspect.list lst (\elem -> Inspect.toInspector elem)` type + // build `Inspect.list lst (\elem -> Inspect.to_inspector elem)` type // List e, (e -> Inspector fmt) -[uls]-> Inspector fmt where fmt implements InspectorFormatter let inspect_list_fn_var = env.import_builtin_symbol_var(Symbol::INSPECT_LIST); @@ -268,7 +268,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { list_var, ); - // \lst -> Inspect.list lst (\elem -> Inspect.toInspector elem) + // \lst -> Inspect.list lst (\elem -> Inspect.to_inspector elem) // Create fn_var for ambient capture; we fix it up below. let fn_var = synth_var(env.subs, Content::Error); @@ -295,7 +295,7 @@ fn to_inspector_list(env: &mut Env<'_>, fn_name: Symbol) -> (Expr, Variable) { )), ); - // \lst -[fn_name]-> Inspect.list lst (\elem -> Inspect.toInspector elem) + // \lst -[fn_name]-> Inspect.list lst (\elem -> Inspect.to_inspector elem) let clos = Closure(ClosureData { function_type: fn_var, closure_type: fn_clos_var, @@ -325,8 +325,8 @@ fn to_inspector_record( // Suppose rcd = { a: t1, b: t2 }. Build // // \rcd -> Inspect.record [ - // { key: "a", value: Inspect.toInspector rcd.a }, - // { key: "b", value: Inspect.toInspector rcd.b }, + // { key: "a", value: Inspect.to_inspector rcd.a }, + // { key: "b", value: Inspect.to_inspector rcd.b }, // ] let rcd_sym = env.new_symbol("rcd"); @@ -360,7 +360,7 @@ fn to_inspector_record( field: field_name, }; - // build `toInspector rcd.a` type + // build `to_inspector rcd.a` type // val -[uls]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_fn_var = env.import_builtin_symbol_var(Symbol::INSPECT_TO_INSPECTOR); @@ -381,7 +381,7 @@ fn to_inspector_record( // ~ (typeof rcd.a) -[clos]-> t1 env.unify(to_inspector_fn_var, this_to_inspector_fn_var); - // toInspector : (typeof rcd.a) -[clos]-> Inspector fmt where fmt implements InspectorFormatter + // to_inspector : (typeof rcd.a) -[clos]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_var = AbilityMember(Symbol::INSPECT_TO_INSPECTOR, None, to_inspector_fn_var); let to_inspector_fn = Box::new(( @@ -392,21 +392,21 @@ fn to_inspector_record( Variable::PURE, )); - // toInspector rcd.a + // to_inspector rcd.a let to_inspector_call = Call( to_inspector_fn, vec![(field_var, Loc::at_zero(field_access))], CalledVia::Space, ); - // value: toInspector rcd.a + // value: to_inspector rcd.a let value_field = Field { var: inspector_var, region: Region::zero(), loc_expr: Box::new(Loc::at_zero(to_inspector_call)), }; - // { key: "a", value: toInspector rcd.a } + // { key: "a", value: to_inspector rcd.a } let mut kv = SendMap::default(); kv.insert("key".into(), key_field); kv.insert("value".into(), value_field); @@ -542,8 +542,8 @@ fn to_inspector_tuple( // Suppose tup = (t1, t2). Build // // \tup -> Inspect.tuple [ - // Inspect.toInspector tup.0, - // Inspect.toInspector tup.1, + // Inspect.to_inspector tup.0, + // Inspect.to_inspector tup.1, // ] let tup_sym = env.new_symbol("tup"); @@ -570,7 +570,7 @@ fn to_inspector_tuple( index, }; - // build `toInspector tup.0` type + // build `to_inspector tup.0` type // val -[uls]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_fn_var = env.import_builtin_symbol_var(Symbol::INSPECT_TO_INSPECTOR); @@ -591,7 +591,7 @@ fn to_inspector_tuple( // ~ (typeof tup.0) -[clos]-> t1 env.unify(to_inspector_fn_var, this_to_inspector_fn_var); - // toInspector : (typeof tup.0) -[clos]-> Inspector fmt where fmt implements InspectorFormatter + // to_inspector : (typeof tup.0) -[clos]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_var = AbilityMember(Symbol::INSPECT_TO_INSPECTOR, None, to_inspector_fn_var); let to_inspector_fn = Box::new(( @@ -602,7 +602,7 @@ fn to_inspector_tuple( Variable::PURE, )); - // toInspector tup.0 + // to_inspector tup.0 let to_inspector_call = Call( to_inspector_fn, vec![(elem_var, Loc::at_zero(tuple_access))], @@ -616,7 +616,7 @@ fn to_inspector_tuple( }) .collect::>(); - // typeof [ toInspector tup.0, toInspector tup.1 ] + // typeof [ to_inspector tup.0, to_inspector tup.1 ] let whole_inspector_in_list_var_slice = env.subs.insert_into_vars(once(whole_inspector_in_list_var)); let elem_inspectors_list_var = synth_var( @@ -627,13 +627,13 @@ fn to_inspector_tuple( )), ); - // [ toInspector tup.0, toInspector tup.1 ] + // [ to_inspector tup.0, to_inspector tup.1 ] let elem_inspectors_list = List { elem_var: whole_inspector_in_list_var, loc_elems: elem_inspectors_list, }; - // build `Inspect.tuple [ toInspector tup.0, toInspector tup.1 ]` type + // build `Inspect.tuple [ to_inspector tup.0, to_inspector tup.1 ]` type // List (Inspector fmt) -[uls]-> Inspector fmt where fmt implements InspectorFormatter let inspect_tuple_fn_var = env.import_builtin_symbol_var(Symbol::INSPECT_TUPLE); @@ -732,8 +732,8 @@ fn to_inspector_tag_union( // Suppose tag = [ A t1 t2, B t3 ]. Build // // \tag -> when tag is - // A v1 v2 -> Inspect.tag "A" [ Inspect.toInspector v1, Inspect.toInspector v2 ] - // B v3 -> Inspect.tag "B" [ Inspect.toInspector v3 ] + // A v1 v2 -> Inspect.tag "A" [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] + // B v3 -> Inspect.tag "B" [ Inspect.to_inspector v3 ] let tag_sym = env.new_symbol("tag"); let whole_tag_inspectors_var = env.subs.fresh_unnamed_flex_var(); // type of the Inspect.tag ... calls in the branch bodies @@ -769,13 +769,13 @@ fn to_inspector_tag_union( degenerate: false, }; - // whole type of the elements in [ Inspect.toInspector v1, Inspect.toInspector v2 ] + // whole type of the elements in [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] let whole_payload_inspectors_var = env.subs.fresh_unnamed_flex_var(); - // [ Inspect.toInspector v1, Inspect.toInspector v2 ] + // [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] let payload_to_inspectors = (payload_syms.iter()) .zip(payload_vars.iter()) .map(|(&sym, &sym_var)| { - // build `toInspector v1` type + // build `to_inspector v1` type // expected: val -[uls]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_fn_var = env.import_builtin_symbol_var(Symbol::INSPECT_TO_INSPECTOR); @@ -798,7 +798,7 @@ fn to_inspector_tag_union( // ~ t1 -[clos]-> t' env.unify(to_inspector_fn_var, this_to_inspector_fn_var); - // toInspector : t1 -[clos]-> Inspector fmt where fmt implements InspectorFormatter + // to_inspector : t1 -[clos]-> Inspector fmt where fmt implements InspectorFormatter let to_inspector_var = AbilityMember(Symbol::INSPECT_TO_INSPECTOR, None, this_to_inspector_fn_var); let to_inspector_fn = Box::new(( @@ -809,7 +809,7 @@ fn to_inspector_tag_union( Variable::PURE, )); - // toInspector rcd.a + // to_inspector rcd.a let to_inspector_call = Call( to_inspector_fn, vec![(sym_var, Loc::at_zero(Var(sym, sym_var)))], @@ -823,7 +823,7 @@ fn to_inspector_tag_union( }) .collect(); - // typeof [ Inspect.toInspector v1, Inspect.toInspector v2 ] + // typeof [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] let whole_inspectors_var_slice = env.subs.insert_into_vars([whole_payload_inspectors_var]); let payload_inspectors_list_var = synth_var( @@ -834,7 +834,7 @@ fn to_inspector_tag_union( )), ); - // [ Inspect.toInspector v1, Inspect.toInspector v2 ] + // [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] let payload_inspectors_list = List { elem_var: whole_payload_inspectors_var, loc_elems: payload_to_inspectors, @@ -874,13 +874,13 @@ fn to_inspector_tag_union( Variable::PURE, )); - // Inspect.tag "A" [ Inspect.toInspector v1, Inspect.toInspector v2 ] + // Inspect.tag "A" [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] let inspect_tag_call = Call( inspect_tag_fn, vec![ // (Str, "A") (Variable::STR, Loc::at_zero(Str(tag_name.0.as_str().into()))), - // (List (Inspector fmt), [ Inspect.toInspector v1, Inspect.toInspector v2 ]) + // (List (Inspector fmt), [ Inspect.to_inspector v1, Inspect.to_inspector v2 ]) ( payload_inspectors_list_var, Loc::at_zero(payload_inspectors_list), @@ -890,7 +890,7 @@ fn to_inspector_tag_union( ); // NOTE: must be done to unify the lambda sets under `inspector_var` - // Inspect.tag "A" [ Inspect.toInspector v1, Inspect.toInspector v2 ] ~ whole_inspectors + // Inspect.tag "A" [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] ~ whole_inspectors env.unify(this_inspector_var, whole_tag_inspectors_var); WhenBranch { @@ -903,8 +903,8 @@ fn to_inspector_tag_union( .collect::>(); // when tag is - // A v1 v2 -> Inspect.tag "A" [ Inspect.toInspector v1, Inspect.toInspector v2 ] - // B v3 -> Inspect.tag "B" [ Inspect.toInspector v3 ] + // A v1 v2 -> Inspect.tag "A" [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] + // B v3 -> Inspect.tag "B" [ Inspect.to_inspector v3 ] let when_branches = When { loc_cond: Box::new(Loc::at_zero(Var(tag_sym, tag_union_var))), cond_var: tag_union_var, @@ -953,8 +953,8 @@ fn to_inspector_tag_union( // \tag -> // Inspect.custom \fmt -> Inspect.apply ( // when tag is - // A v1 v2 -> Inspect.tag "A" [ Inspect.toInspector v1, Inspect.toInspector v2 ] - // B v3 -> Inspect.tag "B" [ Inspect.toInspector v3 ]) + // A v1 v2 -> Inspect.tag "A" [ Inspect.to_inspector v1, Inspect.to_inspector v2 ] + // B v3 -> Inspect.tag "B" [ Inspect.to_inspector v3 ]) // fmt let clos = Closure(ClosureData { function_type: fn_var, diff --git a/crates/compiler/derive_key/src/lib.rs b/crates/compiler/derive_key/src/lib.rs index 7454dcc6aa9..cb1f55818c3 100644 --- a/crates/compiler/derive_key/src/lib.rs +++ b/crates/compiler/derive_key/src/lib.rs @@ -48,10 +48,10 @@ pub enum DeriveKey { impl DeriveKey { pub fn debug_name(&self) -> String { match self { - DeriveKey::ToEncoder(key) => format!("toEncoder_{}", key.debug_name()), + DeriveKey::ToEncoder(key) => format!("to_encoder_{}", key.debug_name()), DeriveKey::Decoder(key) => format!("decoder_{}", key.debug_name()), DeriveKey::Hash(key) => format!("hash_{}", key.debug_name()), - DeriveKey::ToInspector(key) => format!("toInspector_{}", key.debug_name()), + DeriveKey::ToInspector(key) => format!("to_inspector_{}", key.debug_name()), } } } diff --git a/crates/compiler/gen_llvm/src/llvm/build.rs b/crates/compiler/gen_llvm/src/llvm/build.rs index 241d35c2570..1dca00d0b23 100644 --- a/crates/compiler/gen_llvm/src/llvm/build.rs +++ b/crates/compiler/gen_llvm/src/llvm/build.rs @@ -5799,8 +5799,8 @@ fn expose_alias_to_host<'a>( RawFunctionLayout::Function(arguments, closure, result) => { // define closure size and return value size, e.g. // - // * roc__mainForHost_1_Update_size() -> i64 - // * roc__mainForHost_1_Update_result_size() -> i64 + // * roc__main_for_host_1_Update_size() -> i64 + // * roc__main_for_host_1_Update_result_size() -> i64 let it = hels.proc_layout.arguments.iter().copied(); let bytes = roc_alias_analysis::func_name_bytes_help( @@ -5847,7 +5847,7 @@ fn expose_alias_to_host<'a>( RawFunctionLayout::ZeroArgumentThunk(result) => { // Define only the return value size, since this is a thunk // - // * roc__mainForHost_1_Update_result_size() -> i64 + // * roc__main_for_host_1_Update_result_size() -> i64 let result_type = basic_type_from_layout(env, layout_interner, layout_interner.get_repr(result)); @@ -5894,7 +5894,7 @@ fn build_closure_caller<'a, 'ctx>( // STEP 1: build function header - // e.g. `roc__mainForHost_0_caller` (def_name is `mainForHost_0`) + // e.g. `roc__main_for_host_0_caller` (def_name is `main_for_host_0`) let function_name = format!("roc__{def_name}_caller"); let function_spec = FunctionSpec::cconv(env, CCReturn::Void, None, &argument_types); diff --git a/crates/compiler/gen_llvm/src/llvm/build_str.rs b/crates/compiler/gen_llvm/src/llvm/build_str.rs index 7e23c88e03f..3e1a5a4ce6d 100644 --- a/crates/compiler/gen_llvm/src/llvm/build_str.rs +++ b/crates/compiler/gen_llvm/src/llvm/build_str.rs @@ -28,7 +28,7 @@ pub(crate) fn decode_from_utf8_result<'a, 'ctx>( ) } -/// Dec.toStr : Dec -> Str +/// Dec.to_str : Dec -> Str /// Str.equal : Str, Str -> Bool pub(crate) fn str_equal<'ctx>( diff --git a/crates/compiler/gen_llvm/src/llvm/lowlevel.rs b/crates/compiler/gen_llvm/src/llvm/lowlevel.rs index d414ce8dc3b..0947b9ee312 100644 --- a/crates/compiler/gen_llvm/src/llvm/lowlevel.rs +++ b/crates/compiler/gen_llvm/src/llvm/lowlevel.rs @@ -871,7 +871,7 @@ pub(crate) fn run_low_level<'a, 'ctx>( } } NumToStr => { - // Num.toStr : Num a -> Str + // Num.to_str : Num a -> Str arguments_with_layouts!((num, num_layout)); match layout_interner.get_repr(num_layout) { diff --git a/crates/compiler/gen_wasm/README.md b/crates/compiler/gen_wasm/README.md index 5957c02cb3e..02f73eb396d 100644 --- a/crates/compiler/gen_wasm/README.md +++ b/crates/compiler/gen_wasm/README.md @@ -186,7 +186,7 @@ The [official spec](https://webassembly.github.io/spec/core/binary/modules.html# We implement a few linking operations in the Wasm backend. The most important are host-to-app calls. -In the host .wasm file, `roc__mainForHost_1_exposed` is defined as a Wasm Import, as if it were an external JavaScript function. But when we link the host and app, we need to make it an internal function instead. +In the host .wasm file, `roc__main_for_host_1_exposed` is defined as a Wasm Import, as if it were an external JavaScript function. But when we link the host and app, we need to make it an internal function instead. There are a few important facts to note about the Wasm binary format: @@ -197,8 +197,8 @@ There are a few important facts to note about the Wasm binary format: With that background, here are the linking steps for a single app function that gets called by the host: -- Remove `roc__mainForHost_1_exposed` from the imports, updating all call sites to the new index, which is somewhere in the app. -- Swap the _last_ JavaScript import into the slot where `roc__mainForHost_1_exposed` was, updating all of its call sites in the host. +- Remove `roc__main_for_host_1_exposed` from the imports, updating all call sites to the new index, which is somewhere in the app. +- Swap the _last_ JavaScript import into the slot where `roc__main_for_host_1_exposed` was, updating all of its call sites in the host. - Insert an internally-defined dummy function at the index where the last JavaScript import used to be. The diagram below illustrates this process. diff --git a/crates/compiler/gen_wasm/docs/host-to-app-calls.svg b/crates/compiler/gen_wasm/docs/host-to-app-calls.svg index c6c2e64d259..0c11f8d5b35 100644 --- a/crates/compiler/gen_wasm/docs/host-to-app-calls.svg +++ b/crates/compiler/gen_wasm/docs/host-to-app-calls.svg @@ -1 +1 @@ -ImportsDefined0456mainForHost (must be removed from imports)18194104mainForHost (Roc)194648hostapp4142insertdummy@ 18185relocate18→56now only 17 importshost defined functionskeep the same indices!preprocessed hostfinal binaryImport section: swap_remove(5)Function section: signatures[5] = signatures[18]Code section: relocate calls 5→46 relocate calls 18→5 prepend 1 dummy functionOne host-to-app callImportsDefined04565 and 11 to be linked18194104Linked Roc functions194648hostapp4142insertdummy@ 17,18185relocate18→5, 17→116now only 16 importshost defined functionskeep the same indices!preprocessed hostfinal binaryImport section: swap_remove(5) swap_remove(11)Function section: signatures[5] = signatures[18] signatures[11] = signatures[17]Code section: relocate calls 5→46 relocate calls 18→5 relocate calls 11→44 relocate calls 17→11 prepend 2 dummy functionsTwo host-to-app calls11 \ No newline at end of file +ImportsDefined0456main_for_host (must be removed from imports)18194104main_for_host (Roc)194648hostapp4142insertdummy@ 18185relocate18→56now only 17 importshost defined functionskeep the same indices!preprocessed hostfinal binaryImport section: swap_remove(5)Function section: signatures[5] = signatures[18]Code section: relocate calls 5→46 relocate calls 18→5 prepend 1 dummy functionOne host-to-app callImportsDefined04565 and 11 to be linked18194104Linked Roc functions194648hostapp4142insertdummy@ 17,18185relocate18→5, 17→116now only 16 importshost defined functionskeep the same indices!preprocessed hostfinal binaryImport section: swap_remove(5) swap_remove(11)Function section: signatures[5] = signatures[18] signatures[11] = signatures[17]Code section: relocate calls 5→46 relocate calls 18→5 relocate calls 11→44 relocate calls 17→11 prepend 2 dummy functionsTwo host-to-app calls11 \ No newline at end of file diff --git a/crates/compiler/load/tests/platform.roc b/crates/compiler/load/tests/platform.roc index 3403eed8586..18d29729ee2 100644 --- a/crates/compiler/load/tests/platform.roc +++ b/crates/compiler/load/tests/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : {} -> {} -mainForHost = \{} -> {} +main_for_host : {} -> {} +main_for_host = \{} -> {} diff --git a/crates/compiler/load/tests/test_reporting.rs b/crates/compiler/load/tests/test_reporting.rs index affdd97c5bb..bbc4d2e335a 100644 --- a/crates/compiler/load/tests/test_reporting.rs +++ b/crates/compiler/load/tests/test_reporting.rs @@ -489,10 +489,10 @@ mod test_reporting { Did you mean one of these? - List.isEmpty + List.is_empty List.set List.get - List.keepIf + List.sum " ); @@ -586,7 +586,7 @@ mod test_reporting { indoc!( r"x = 1 y = - if selectedId != thisId == adminsId then + if selected_id != this_id == admins_id then 4 else @@ -601,8 +601,8 @@ mod test_reporting { Using != and == together requires parentheses, to clarify how they should be grouped. - 6│ if selectedId != thisId == adminsId then - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 6│ if selected_id != this_id == admins_id then + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ " ); @@ -698,7 +698,7 @@ mod test_reporting { r#" y = 9 - box = \class, htmlChildren -> + box = \class, html_children -> div [class] [] div = \_, _ -> 4 @@ -709,14 +709,14 @@ mod test_reporting { @r#" ── UNUSED ARGUMENT in /code/proj/Main.roc ────────────────────────────────────── - `box` doesn't use `htmlChildren`. + `box` doesn't use `html_children`. - 6│ box = \class, htmlChildren -> - ^^^^^^^^^^^^ + 6│ box = \class, html_children -> + ^^^^^^^^^^^^^ - If you don't need `htmlChildren`, then you can just remove it. However, - if you really do need `htmlChildren` as an argument of `box`, prefix it - with an underscore, like this: "_`htmlChildren`". Adding an underscore + If you don't need `html_children`, then you can just remove it. However, + if you really do need `html_children` as an argument of `box`, prefix it + with an underscore, like this: "_`html_children`". Adding an underscore at the start of a variable name is a way of saying that the variable is not used. @@ -736,9 +736,9 @@ mod test_reporting { fn report_value_color() { let src: &str = indoc!( r" - activityIndicatorLarge = div + activity_indicator_large = div - view activityIndicatorLarge + view activity_indicator_large " ); @@ -751,7 +751,7 @@ mod test_reporting { let alloc = RocDocAllocator::new(&src_lines, home, &interns); - let symbol = interns.symbol(test_home(), "activityIndicatorLarge".into()); + let symbol = interns.symbol(test_home(), "activity_indicator_large".into()); to_simple_report(alloc.symbol_unqualified(symbol)).render_color_terminal( &mut buf, @@ -759,7 +759,10 @@ mod test_reporting { &DEFAULT_PALETTE, ); - assert_eq!(human_readable(&buf), "activityIndicatorLarge"); + assert_eq!( + human_readable(&buf), + "activity_indicator_large" + ); } #[test] @@ -796,27 +799,27 @@ mod test_reporting { color_report_problem_as( indoc!( r" - isDisabled = \user -> user.isAdmin + is_disabled = \user -> user.is_admin - theAdmin - |> isDisabled + the_admin + |> is_disabled " ), indoc!( r" ── UNRECOGNIZED NAME in /code/proj/Main.roc ──────────────────────────────────── - Nothing is named `theAdmin` in this scope. + Nothing is named `the_admin` in this scope. - 3 theAdmin - ^^^^^^^^ + 3 the_admin + ^^^^^^^^^ Did you mean one of these? List Box Str - isDisabled + is_disabled " ), ); @@ -1065,7 +1068,7 @@ mod test_reporting { Every element in a list must have the same type! Tip: You can convert between integers and fractions using functions - like `Num.toFrac` and `Num.round`. + like `Num.to_frac` and `Num.round`. " ); @@ -1543,7 +1546,7 @@ mod test_reporting { Int * Tip: You can convert between integers and fractions using functions - like `Num.toFrac` and `Num.round`. + like `Num.to_frac` and `Num.round`. " ); @@ -1578,7 +1581,7 @@ mod test_reporting { Int * Tip: You can convert between integers and fractions using functions - like `Num.toFrac` and `Num.round`. + like `Num.to_frac` and `Num.round`. " ); @@ -1610,7 +1613,7 @@ mod test_reporting { Int * Tip: You can convert between integers and fractions using functions - like `Num.toFrac` and `Num.round`. + like `Num.to_frac` and `Num.round`. " ); @@ -1931,7 +1934,7 @@ mod test_reporting { { x : Int * } Tip: You can convert between integers and fractions using functions - like `Num.toFrac` and `Num.round`. + like `Num.to_frac` and `Num.round`. " ); @@ -2488,7 +2491,7 @@ mod test_reporting { Int * Tip: You can convert between integers and fractions using functions - like `Num.toFrac` and `Num.round`. + like `Num.to_frac` and `Num.round`. " ); @@ -3763,7 +3766,7 @@ mod test_reporting { indoc!( r" foo = { bar: 3 } - updateNestedRecord = { foo.bar & x: 4 } + update_nested_record = { foo.bar & x: 4 } example = { age: 42 } @@ -3771,7 +3774,7 @@ mod test_reporting { y = { Test.example & age: 3 } x = { example & age: 4 } - { updateNestedRecord, foo, x, y } + { update_nested_record, foo, x, y } " ), @r" @@ -3779,8 +3782,8 @@ mod test_reporting { This expression cannot be updated: - 5│ updateNestedRecord = { foo.bar & x: 4 } - ^^^^^^^ + 5│ update_nested_record = { foo.bar & x: 4 } + ^^^^^^^ Only variables can be updated with record update syntax. @@ -4323,7 +4326,7 @@ mod test_reporting { { x, y } " ), - @r###" + @r#" ── STATEMENT AFTER EXPRESSION in /code/proj/Main.roc ─────────────────────────── I just finished parsing an expression with a series of definitions, @@ -4337,14 +4340,14 @@ mod test_reporting { However, I already saw the final expression in that series of definitions. - Tip: An expression like `4`, `"hello"`, or `functionCall MyThing` is + Tip: An expression like `4`, `"hello"`, or `function_call(MyThing)` is like `return 4` in other programming languages. To me, it seems like you did `return 4` followed by more code in the lines after, that code would never be executed! Tip: If you are working with `Task`, this error can happen if you forgot a `!` somewhere. - "### + "# ); test_report!( @@ -4981,19 +4984,19 @@ mod test_reporting { record_update_in_module_params, indoc!( r" - import Menu { myParams & echo: echoFn } + import Menu { my_params & echo: echo_fn } " - ),@r###" + ),@r" ── RECORD UPDATE IN MODULE PARAMS in ...ecord_update_in_module_params/Test.roc ─ I was partway through parsing module params, but I got stuck here: - 4│ import Menu { myParams & echo: echoFn } - ^^^^^^^^ + 4│ import Menu { my_params & echo: echo_fn } + ^^^^^^^^^ It looks like you're trying to update a record, but module params require a standalone record literal. - "### + " ); test_report!( @@ -5148,29 +5151,29 @@ mod test_reporting { r#" app "dict" imports [] provides [main] to "./platform" - myDict : Dict Num.I64 Str - myDict = Dict.insert (Dict.empty {}) "foo" 42 + my_dict : Dict Num.I64 Str + my_dict = Dict.insert (Dict.empty {}) "foo" 42 - main = myDict + main = my_dict "# ), - @r###" + @r#" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - Something is off with the body of the `myDict` definition: + Something is off with the body of the `my_dict` definition: - 3│ myDict : Dict Num.I64 Str - 4│ myDict = Dict.insert (Dict.empty {}) "foo" 42 - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 3│ my_dict : Dict Num.I64 Str + 4│ my_dict = Dict.insert (Dict.empty {}) "foo" 42 + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ This `insert` call produces: Dict Str (Num *) - But the type annotation on `myDict` says it should be: + But the type annotation on `my_dict` says it should be: Dict I64 Str - "### + "# ); test_report!( @@ -5183,26 +5186,26 @@ mod test_reporting { foo : Str -> HSet {} - myDict : HSet Str - myDict = foo "bar" + my_dict : HSet Str + my_dict = foo "bar" - main = myDict + main = my_dict "# ), @r#" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - Something is off with the body of the `myDict` definition: + Something is off with the body of the `my_dict` definition: - 7│ myDict : HSet Str - 8│ myDict = foo "bar" - ^^^^^^^^^ + 7│ my_dict : HSet Str + 8│ my_dict = foo "bar" + ^^^^^^^^^ This `foo` call produces: HSet {} - But the type annotation on `myDict` says it should be: + But the type annotation on `my_dict` says it should be: HSet Str "# @@ -6353,12 +6356,12 @@ All branches in an `if` must have the same type! exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] effects fx.Effect { - putChar : I64 -> Effect {}, - putLine : Str -> Effect {}, - getLine : Effect Str + put_char : I64 -> Effect {}, + put_line : Str -> Effect {}, + get_line : Effect Str } "# ), @@ -6838,14 +6841,14 @@ All branches in an `if` must have the same type! r#" Result a b : [Ok a, Err b] - canIGo : _ -> Result _ - canIGo = \color -> + can_i_go : _ -> Result _ + can_i_go = \color -> when color is "green" -> Ok "go!" "yellow" -> Err (SlowIt "whoa, let's slow down!") "red" -> Err (StopIt "absolutely not") _ -> Err (UnknownColor "this is a weird stoplight") - canIGo + can_i_go "# ), @r" @@ -6863,8 +6866,8 @@ All branches in an `if` must have the same type! The `Result` alias expects 2 type arguments, but it got 1 instead: - 6│ canIGo : _ -> Result _ - ^^^^^^^^ + 6│ can_i_go : _ -> Result _ + ^^^^^^^^ Are there missing parentheses? " @@ -6876,14 +6879,14 @@ All branches in an `if` must have the same type! r#" Result a b : [Ok a, Err b] - canIGo : _ -> Result _ _ _ - canIGo = \color -> + can_i_go : _ -> Result _ _ _ + can_i_go = \color -> when color is "green" -> Ok "go!" "yellow" -> Err (SlowIt "whoa, let's slow down!") "red" -> Err (StopIt "absolutely not") _ -> Err (UnknownColor "this is a weird stoplight") - canIGo + can_i_go "# ), @r" @@ -6901,8 +6904,8 @@ All branches in an `if` must have the same type! The `Result` alias expects 2 type arguments, but it got 3 instead: - 6│ canIGo : _ -> Result _ _ _ - ^^^^^^^^^^^^ + 6│ can_i_go : _ -> Result _ _ _ + ^^^^^^^^^^^^ Are there missing parentheses? " @@ -7109,27 +7112,27 @@ All branches in an `if` must have the same type! mismatched_single_tag_arg, indoc!( r#" - isEmpty = + is_empty = \email -> Email str = email - Str.isEmpty str + Str.is_empty str - isEmpty (Name "boo") + is_empty (Name "boo") "# ), @r#" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - This 1st argument to `isEmpty` has an unexpected type: + This 1st argument to `is_empty` has an unexpected type: - 9│ isEmpty (Name "boo") - ^^^^^^^^^^ + 9│ is_empty (Name "boo") + ^^^^^^^^^^ This `Name` tag application has the type: [Name Str] - But `isEmpty` needs its 1st argument to be: + But `is_empty` needs its 1st argument to be: [Email Str] @@ -9302,7 +9305,7 @@ All branches in an `if` must have the same type! ability_specialization_called_with_non_specializing, indoc!( r#" - app "test" provides [noGoodVeryBadTerrible] to "./platform" + app "test" provides [no_good_very_bad_terrible] to "./platform" MHash implements hash : a -> U64 where a implements MHash @@ -9313,10 +9316,10 @@ All branches in an `if` must have the same type! User := {} - noGoodVeryBadTerrible = + no_good_very_bad_terrible = { nope: hash (@User {}), - notYet: hash (A 1), + not_yet: hash (A 1), } "# ), @@ -9325,8 +9328,8 @@ All branches in an `if` must have the same type! This expression has a type that does not implement the abilities it's expected to: - 15│ notYet: hash (A 1), - ^^^ + 15│ not_yet: hash (A 1), + ^^^ I can't generate an implementation of the `MHash` ability for @@ -9420,16 +9423,16 @@ All branches in an `if` must have the same type! MHash implements hash : a -> U64 where a implements MHash - mulMHashes : MHash, MHash -> U64 - mulMHashes = \x, y -> hash x * hash y + mul_m_hashes : MHash, MHash -> U64 + mul_m_hashes = \x, y -> hash x * hash y - Id := U64 implements [MHash {hash: hashId}] - hashId = \@Id n -> n + Id := U64 implements [MHash {hash: hash_id}] + hash_id = \@Id n -> n - Three := {} implements [MHash {hash: hashThree}] - hashThree = \@Three _ -> 3 + Three := {} implements [MHash {hash: hash_three}] + hash_three = \@Three _ -> 3 - result = mulMHashes (@Id 100) (@Three {}) + result = mul_m_hashes (@Id 100) (@Three {}) "# ), @r" @@ -9437,8 +9440,8 @@ All branches in an `if` must have the same type! You are attempting to use the ability `MHash` as a type directly: - 6│ mulMHashes : MHash, MHash -> U64 - ^^^^^ + 6│ mul_m_hashes : MHash, MHash -> U64 + ^^^^^ Abilities can only be used in type annotations to constrain type variables. @@ -9451,8 +9454,8 @@ All branches in an `if` must have the same type! You are attempting to use the ability `MHash` as a type directly: - 6│ mulMHashes : MHash, MHash -> U64 - ^^^^^ + 6│ mul_m_hashes : MHash, MHash -> U64 + ^^^^^ Abilities can only be used in type annotations to constrain type variables. @@ -9575,13 +9578,13 @@ All branches in an `if` must have the same type! issue_2778_specialization_is_not_a_redundant_pattern, indoc!( r#" - formatColor = \color -> + format_color = \color -> when color is Red -> "red" Yellow -> "yellow" _ -> "unknown" - Red |> formatColor |> Str.concat (formatColor Orange) + Red |> format_color |> Str.concat (format_color Orange) "# ), @"" // no problem @@ -9751,7 +9754,7 @@ All branches in an `if` must have the same type! r#" app "test" imports [] provides [main] to "./platform" - main = Encode.toEncoder \x -> x + main = Encode.to_encoder \x -> x "# ), @r" @@ -9759,8 +9762,8 @@ All branches in an `if` must have the same type! This expression has a type that does not implement the abilities it's expected to: - 3│ main = Encode.toEncoder \x -> x - ^^^^^^^ + 3│ main = Encode.to_encoder \x -> x + ^^^^^^^ I can't generate an implementation of the `Encoding` ability for @@ -9777,7 +9780,7 @@ All branches in an `if` must have the same type! app "test" imports [] provides [main] to "./platform" A := {} - main = Encode.toEncoder { x: @A {} } + main = Encode.to_encoder { x: @A {} } "# ), // TODO: this error message is quite unfortunate. We should remove the duplication, and @@ -9787,8 +9790,8 @@ All branches in an `if` must have the same type! This expression has a type that does not implement the abilities it's expected to: - 4│ main = Encode.toEncoder { x: @A {} } - ^^^^^^^^^^^^ + 4│ main = Encode.to_encoder { x: @A {} } + ^^^^^^^^^^^^ I can't generate an implementation of the `Encoding` ability for @@ -9878,36 +9881,36 @@ All branches in an `if` must have the same type! opaque_ability_impl_not_found, indoc!( r#" - app "test" provides [A, myMEq] to "./platform" + app "test" provides [A, my_m_eq] to "./platform" MEq implements eq : a, a -> Bool where a implements MEq - A := U8 implements [ MEq {eq: aMEq} ] + A := U8 implements [ MEq {eq: a_m_eq} ] - myMEq = \m, n -> m == n + my_m_eq = \m, n -> m == n "# ), @r" ── UNRECOGNIZED NAME in /code/proj/Main.roc ──────────────────────────────────── - Nothing is named `aMEq` in this scope. + Nothing is named `a_m_eq` in this scope. - 5│ A := U8 implements [ MEq {eq: aMEq} ] - ^^^^ + 5│ A := U8 implements [ MEq {eq: a_m_eq} ] + ^^^^^^ Did you mean one of these? - MEq - Eq - myMEq + my_m_eq eq + Eq + Num ── INCOMPLETE ABILITY IMPLEMENTATION in /code/proj/Main.roc ──────────────────── This type does not fully implement the `MEq` ability: - 5│ A := U8 implements [ MEq {eq: aMEq} ] - ^^^^^^^^^^^^^^ + 5│ A := U8 implements [ MEq {eq: a_m_eq} ] + ^^^^^^^^^^^^^^^^ The following necessary members are missing implementations: @@ -9919,13 +9922,13 @@ All branches in an `if` must have the same type! opaque_ability_impl_optional, indoc!( r#" - app "test" provides [A, myMEq] to "./platform" + app "test" provides [A, my_m_eq] to "./platform" MEq implements eq : a, a -> Bool where a implements MEq - A := U8 implements [ MEq {eq ? aMEq} ] + A := U8 implements [ MEq {eq ? a_m_eq} ] - myMEq = \m, n -> m == n + my_m_eq = \m, n -> m == n "# ), @r" @@ -9933,8 +9936,8 @@ All branches in an `if` must have the same type! Ability implementations cannot be optional: - 5│ A := U8 implements [ MEq {eq ? aMEq} ] - ^^^^^^^^^ + 5│ A := U8 implements [ MEq {eq ? a_m_eq} ] + ^^^^^^^^^^^ Custom implementations must be supplied fully. @@ -9944,8 +9947,8 @@ All branches in an `if` must have the same type! This type does not fully implement the `MEq` ability: - 5│ A := U8 implements [ MEq {eq ? aMEq} ] - ^^^^^^^^^^^^^^^ + 5│ A := U8 implements [ MEq {eq ? a_m_eq} ] + ^^^^^^^^^^^^^^^^^ The following necessary members are missing implementations: @@ -9959,11 +9962,11 @@ All branches in an `if` must have the same type! r#" app "test" imports [] - provides [A, myEncoder] to "./platform" + provides [A, my_encoder] to "./platform" - A := U8 implements [ Encoding {toEncoder ? myEncoder} ] + A := U8 implements [ Encoding {to_encoder ? my_encoder} ] - myEncoder = 1 + my_encoder = 1 "# ), @r" @@ -9971,8 +9974,8 @@ All branches in an `if` must have the same type! Ability implementations cannot be optional: - 5│ A := U8 implements [ Encoding {toEncoder ? myEncoder} ] - ^^^^^^^^^^^^^^^^^^^^^ + 5│ A := U8 implements [ Encoding {to_encoder ? my_encoder} ] + ^^^^^^^^^^^^^^^^^^^^^^^ Custom implementations must be supplied fully. @@ -9984,12 +9987,12 @@ All branches in an `if` must have the same type! This type does not fully implement the `Encoding` ability: - 5│ A := U8 implements [ Encoding {toEncoder ? myEncoder} ] - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 5│ A := U8 implements [ Encoding {to_encoder ? my_encoder} ] + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The following necessary members are missing implementations: - toEncoder + to_encoder " ); @@ -10073,9 +10076,9 @@ All branches in an `if` must have the same type! MEq implements eq : a, a -> Bool where a implements MEq - A := U8 implements [ MEq {eq: eqA, eq: eqA} ] + A := U8 implements [ MEq {eq: eq_a, eq: eq_a} ] - eqA = \@A m, @A n -> m == n + eq_a = \@A m, @A n -> m == n "# ), @r" @@ -10083,13 +10086,13 @@ All branches in an `if` must have the same type! This ability member implementation is duplicate: - 5│ A := U8 implements [ MEq {eq: eqA, eq: eqA} ] - ^^^^^^^ + 5│ A := U8 implements [ MEq {eq: eq_a, eq: eq_a} ] + ^^^^^^^^ The first implementation was defined here: - 5│ A := U8 implements [ MEq {eq: eqA, eq: eqA} ] - ^^^^^^^ + 5│ A := U8 implements [ MEq {eq: eq_a, eq: eq_a} ] + ^^^^^^^^ Only one custom implementation can be defined for an ability member. " @@ -10269,27 +10272,27 @@ All branches in an `if` must have the same type! open : {} -> Result Handle * close : Handle -> Result {} * - withOpen : (Handle -> Result {} *) -> Result {} * - withOpen = \callback -> + with_open : (Handle -> Result {} *) -> Result {} * + with_open = \callback -> await (open {}) \handle -> await (callback handle) \_ -> close handle - withOpen + with_open " ), @r" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - Something is off with the body of the `withOpen` definition: + Something is off with the body of the `with_open` definition: - 10│ withOpen : (Handle -> Result {} *) -> Result {} * - 11│ withOpen = \callback -> + 10│ with_open : (Handle -> Result {} *) -> Result {} * + 11│ with_open = \callback -> 12│> await (open {}) \handle -> 13│> await (callback handle) \_ -> 14│> close handle - The type annotation on `withOpen` says this `await` call should have the + The type annotation on `with_open` says this `await` call should have the type: Result {} * @@ -10298,7 +10301,7 @@ All branches in an `if` must have the same type! way that isn't reflected in this annotation. Tip: Any connection between types must use a named type variable, not - a `*`! Maybe the annotation on `withOpen` should have a named type + a `*`! Maybe the annotation on `with_open` should have a named type variable in place of the `*`? " @@ -10594,7 +10597,7 @@ All branches in an `if` must have the same type! indoc!( r#" when [] is - [] | [_, .. as rest] if List.isEmpty rest -> [] + [] | [_, .. as rest] if List.is_empty rest -> [] _ -> [] "# ), @@ -10603,7 +10606,7 @@ All branches in an `if` must have the same type! `rest` is not bound in all patterns of this `when` branch - 5│ [] | [_, .. as rest] if List.isEmpty rest -> [] + 5│ [] | [_, .. as rest] if List.is_empty rest -> [] ^^^^ Identifiers introduced in a `when` branch must be bound in all patterns @@ -11206,26 +11209,26 @@ All branches in an `if` must have the same type! import Decode exposing [decoder] main = - myDecoder : Decoder (a -> a) fmt where fmt implements DecoderFormatting - myDecoder = decoder + my_decoder : Decoder (a -> a) fmt where fmt implements DecoderFormatting + my_decoder = decoder - myDecoder + my_decoder "# ), - @r###" + @r" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── This expression has a type that does not implement the abilities it's expected to: - 7│ myDecoder = decoder - ^^^^^^^ + 7│ my_decoder = decoder + ^^^^^^^ I can't generate an implementation of the `Decoding` ability for a -> a Note: `Decoding` cannot be generated for functions. - "### + " ); test_report!( @@ -11239,19 +11242,19 @@ All branches in an `if` must have the same type! A := {} main = - myDecoder : Decoder {x : A} fmt where fmt implements DecoderFormatting - myDecoder = decoder + my_decoder : Decoder {x : A} fmt where fmt implements DecoderFormatting + my_decoder = decoder - myDecoder + my_decoder "# ), - @r###" + @r" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── This expression has a type that does not implement the abilities it's expected to: - 9│ myDecoder = decoder - ^^^^^^^ + 9│ my_decoder = decoder + ^^^^^^^ I can't generate an implementation of the `Decoding` ability for @@ -11265,7 +11268,7 @@ All branches in an `if` must have the same type! Tip: `A` does not implement `Decoding`. Consider adding a custom implementation or `implements Decode.Decoding` to the definition of `A`. - "### + " ); test_report!( @@ -11294,11 +11297,11 @@ All branches in an `if` must have the same type! expected_tag_has_too_many_args, indoc!( r#" - app "test" provides [fromBytes] to "./platform" + app "test" provides [from_bytes] to "./platform" u8 : [Good (List U8), Bad [DecodeProblem]] - fromBytes = + from_bytes = when u8 is Good _ _ -> Ok "foo" @@ -11429,49 +11432,49 @@ All branches in an `if` must have the same type! app "test" imports [] provides [main] to "./platform" ErrDecoder := {} implements [DecoderFormatting { - u8: decodeU8, - u16: decodeU16, - u32: decodeU32, - u64: decodeU64, - u128: decodeU128, - i8: decodeI8, - i16: decodeI16, - i32: decodeI32, - i64: decodeI64, - i128: decodeI128, - f32: decodeF32, - f64: decodeF64, - dec: decodeDec, - bool: decodeBool, - string: decodeString, - list: decodeList, - record: decodeRecord, - tuple: decodeTuple, + u8: decode_u8, + u16: decode_u16, + u32: decode_u32, + u64: decode_u64, + u128: decode_u128, + i8: decode_i8, + i16: decode_i16, + i32: decode_i32, + i64: decode_i64, + i128: decode_i128, + f32: decode_f32, + f64: decode_f64, + dec: decode_dec, + bool: decode_bool, + string: decode_string, + list: decode_list, + record: decode_record, + tuple: decode_tuple, }] - decodeU8 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeU16 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeU32 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeU64 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeU128 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeI8 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeI16 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeI32 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeI64 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeI128 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeF32 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeF64 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeDec = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeBool = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeString = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeList : Decoder elem (ErrDecoder) -> Decoder (List elem) (ErrDecoder) - decodeList = \_ -> Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeRecord : state, (state, Str -> [Keep (Decoder state (ErrDecoder)), Skip]), (state, (ErrDecoder) -> Result val DecodeError) -> Decoder val (ErrDecoder) - decodeRecord =\_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} - decodeTuple : state, (state, U64 -> [Next (Decoder state (ErrDecoder)), TooLong]), (state -> Result val DecodeError) -> Decoder val (ErrDecoder) - decodeTuple = \_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_u8 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_u16 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_u32 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_u64 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_u128 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_i8 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_i16 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_i32 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_i64 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_i128 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_f32 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_f64 = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_dec = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_bool = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_string = Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_list : Decoder elem (ErrDecoder) -> Decoder (List elem) (ErrDecoder) + decode_list = \_ -> Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_record : state, (state, Str -> [Keep (Decoder state (ErrDecoder)), Skip]), (state, (ErrDecoder) -> Result val DecodeError) -> Decoder val (ErrDecoder) + decode_record =\_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} + decode_tuple : state, (state, U64 -> [Next (Decoder state (ErrDecoder)), TooLong]), (state -> Result val DecodeError) -> Decoder val (ErrDecoder) + decode_tuple = \_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> {result: Err TooShort, rest} main = - decoded = Str.toUtf8 "{\"first\":\"ab\",\"second\":\"cd\"}" |> Decode.fromBytes (@ErrDecoder {}) + decoded = Str.to_utf8 "{\"first\":\"ab\",\"second\":\"cd\"}" |> Decode.from_bytes (@ErrDecoder {}) when decoded is Ok rcd -> rcd.first rcd.second _ -> "something went wrong" @@ -11502,19 +11505,19 @@ All branches in an `if` must have the same type! import Decode exposing [decoder] main = - myDecoder : Decoder {x : Str, y ? Str} fmt where fmt implements DecoderFormatting - myDecoder = decoder + my_decoder : Decoder {x : Str, y ? Str} fmt where fmt implements DecoderFormatting + my_decoder = decoder - myDecoder + my_decoder "# ), - @r###" + @r" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── This expression has a type that does not implement the abilities it's expected to: - 7│ myDecoder = decoder - ^^^^^^^ + 7│ my_decoder = decoder + ^^^^^^^ I can't generate an implementation of the `Decoding` ability for @@ -11528,7 +11531,7 @@ All branches in an `if` must have the same type! over records that may or may not contain them at compile time, but are not a concept that extends to runtime! Maybe you wanted to use a `Result`? - "### + " ); test_report!( @@ -12131,55 +12134,55 @@ All branches in an `if` must have the same type! indoc!( r" { - a: Num.shiftLeftBy 1 -1, - b: Num.shiftRightBy 1 -1, - c: Num.shiftRightZfBy 1 -1, + a: Num.shift_left_by 1 -1, + b: Num.shift_right_by 1 -1, + c: Num.shift_right_zf_by 1 -1, } " ), @r" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - This 2nd argument to `shiftRightZfBy` has an unexpected type: + This 2nd argument to `shift_right_zf_by` has an unexpected type: - 7│ c: Num.shiftRightZfBy 1 -1, - ^^ + 7│ c: Num.shift_right_zf_by 1 -1, + ^^ The argument is a number of type: I8, I16, F32, I32, F64, I64, I128, or Dec - But `shiftRightZfBy` needs its 2nd argument to be: + But `shift_right_zf_by` needs its 2nd argument to be: U8 ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - This 2nd argument to `shiftRightBy` has an unexpected type: + This 2nd argument to `shift_right_by` has an unexpected type: - 6│ b: Num.shiftRightBy 1 -1, - ^^ + 6│ b: Num.shift_right_by 1 -1, + ^^ The argument is a number of type: I8, I16, F32, I32, F64, I64, I128, or Dec - But `shiftRightBy` needs its 2nd argument to be: + But `shift_right_by` needs its 2nd argument to be: U8 ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - This 2nd argument to `shiftLeftBy` has an unexpected type: + This 2nd argument to `shift_left_by` has an unexpected type: - 5│ a: Num.shiftLeftBy 1 -1, - ^^ + 5│ a: Num.shift_left_by 1 -1, + ^^ The argument is a number of type: I8, I16, F32, I32, F64, I64, I128, or Dec - But `shiftLeftBy` needs its 2nd argument to be: + But `shift_left_by` needs its 2nd argument to be: U8 " @@ -12285,7 +12288,7 @@ All branches in an `if` must have the same type! 3│ A := F32 implements [Eq] ^^ - Note: I can't derive `Bool.isEq` for floating-point types. That's + Note: I can't derive `Bool.is_eq` for floating-point types. That's because Roc's floating-point numbers cannot be compared for total equality - in Roc, `NaN` is never comparable to `NaN`. If a type doesn't support total equality, it cannot support the `Eq` ability! @@ -12311,7 +12314,7 @@ All branches in an `if` must have the same type! 3│ A := F64 implements [Eq] ^^ - Note: I can't derive `Bool.isEq` for floating-point types. That's + Note: I can't derive `Bool.is_eq` for floating-point types. That's because Roc's floating-point numbers cannot be compared for total equality - in Roc, `NaN` is never comparable to `NaN`. If a type doesn't support total equality, it cannot support the `Eq` ability! @@ -12554,7 +12557,7 @@ All branches in an `if` must have the same type! cannot be generated. - Note: I can't derive `Bool.isEq` for floating-point types. That's + Note: I can't derive `Bool.is_eq` for floating-point types. That's because Roc's floating-point numbers cannot be compared for total equality - in Roc, `NaN` is never comparable to `NaN`. If a type doesn't support total equality, it cannot support the `Eq` ability! @@ -12566,38 +12569,38 @@ All branches in an `if` must have the same type! indoc!( r" { - a: Bool.structuralEq, - b: Bool.structuralNotEq, + a: Bool.structural_eq, + b: Bool.structural_not_eq, } " ), @r" ── NOT EXPOSED in /code/proj/Main.roc ────────────────────────────────────────── - The Bool module does not expose `structuralEq`: + The Bool module does not expose `structural_eq`: - 5│ a: Bool.structuralEq, - ^^^^^^^^^^^^^^^^^ + 5│ a: Bool.structural_eq, + ^^^^^^^^^^^^^^^^^^ Did you mean one of these? Bool.true - Bool.isNotEq + Bool.is_not_eq Bool.false - Bool.isEq + Bool.is_eq ── NOT EXPOSED in /code/proj/Main.roc ────────────────────────────────────────── - The Bool module does not expose `structuralNotEq`: + The Bool module does not expose `structural_not_eq`: - 6│ b: Bool.structuralNotEq, - ^^^^^^^^^^^^^^^^^^^^ + 6│ b: Bool.structural_not_eq, + ^^^^^^^^^^^^^^^^^^^^^^ Did you mean one of these? - Bool.isNotEq + Bool.is_not_eq + Bool.bool_is_eq Bool.true - Bool.boolIsEq Bool.false " ); @@ -13734,7 +13737,7 @@ All branches in an `if` must have the same type! FloatingPoint ? - Note: I can't derive `Bool.isEq` for floating-point types. That's + Note: I can't derive `Bool.is_eq` for floating-point types. That's because Roc's floating-point numbers cannot be compared for total equality - in Roc, `NaN` is never comparable to `NaN`. If a type doesn't support total equality, it cannot support the `Eq` ability! @@ -14099,10 +14102,10 @@ All branches in an `if` must have the same type! import Decode exposing [decoder] main = - myDecoder : Decoder (U32, Str) fmt where fmt implements DecoderFormatting - myDecoder = decoder + my_decoder : Decoder (U32, Str) fmt where fmt implements DecoderFormatting + my_decoder = decoder - myDecoder + my_decoder "# ) ); @@ -14116,26 +14119,26 @@ All branches in an `if` must have the same type! import Decode exposing [decoder] main = - myDecoder : Decoder (U32, {} -> {}) fmt where fmt implements DecoderFormatting - myDecoder = decoder + my_decoder : Decoder (U32, {} -> {}) fmt where fmt implements DecoderFormatting + my_decoder = decoder - myDecoder + my_decoder "# ), - @r###" + @r" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── This expression has a type that does not implement the abilities it's expected to: - 7│ myDecoder = decoder - ^^^^^^^ + 7│ my_decoder = decoder + ^^^^^^^ I can't generate an implementation of the `Decoding` ability for U32, {} -> {} Note: `Decoding` cannot be generated for functions. - "### + " ); test_no_problem!( @@ -14146,7 +14149,7 @@ All branches in an `if` must have the same type! x : (U32, Str) - main = Encode.toEncoder x + main = Encode.to_encoder x "# ) ); @@ -14159,7 +14162,7 @@ All branches in an `if` must have the same type! x : (U32, {} -> {}) - main = Encode.toEncoder x + main = Encode.to_encoder x "# ), @r" @@ -14167,8 +14170,8 @@ All branches in an `if` must have the same type! This expression has a type that does not implement the abilities it's expected to: - 5│ main = Encode.toEncoder x - ^ + 5│ main = Encode.to_encoder x + ^ I can't generate an implementation of the `Encoding` ability for @@ -14186,7 +14189,7 @@ All branches in an `if` must have the same type! x : U8 - ifThenCase = + if_then_case = when x is 0 -> Red 1 -> Yellow @@ -14195,7 +14198,7 @@ All branches in an `if` must have the same type! _ -> Green main = - when ifThenCase is + when if_then_case is Red -> "red" Green -> "green" Yellow -> "yellow" @@ -14207,7 +14210,7 @@ All branches in an `if` must have the same type! This `when` does not cover all the possibilities: - 14│> when ifThenCase is + 14│> when if_then_case is 15│> Red -> "red" 16│> Green -> "green" 17│> Yellow -> "yellow" @@ -14580,14 +14583,14 @@ All branches in an `if` must have the same type! return_outside_of_function, indoc!( r" - someVal = + some_val = if 10 > 5 then x = 5 return x else 6 - someVal + 2 + some_val + 2 " ), @r###" @@ -14606,7 +14609,7 @@ All branches in an `if` must have the same type! statements_after_return, indoc!( r#" - myFunction = \x -> + my_function = \x -> if x == 2 then return x @@ -14615,7 +14618,7 @@ All branches in an `if` must have the same type! else x + 5 - myFunction 2 + my_function 2 "# ), @r###" @@ -14637,12 +14640,12 @@ All branches in an `if` must have the same type! return_at_end_of_function, indoc!( r#" - myFunction = \x -> - y = Num.toStr x + my_function = \x -> + y = Num.to_str x return y - myFunction 3 + my_function 3 "# ), @r###" @@ -14662,13 +14665,13 @@ All branches in an `if` must have the same type! mismatch_early_return_with_function_output, indoc!( r#" - myFunction = \x -> + my_function = \x -> if x == 5 then return "abc" else x - myFunction 3 + my_function 3 "# ), @r#" @@ -14700,17 +14703,17 @@ All branches in an `if` must have the same type! import pf.Effect - validateNum = \num -> + validate_num = \num -> if num > 5 then Ok {} else Err TooBig main! = \{} -> - Effect.putLine! "hello" + Effect.put_line! "hello" # this returns {}, so it's ignored - try validateNum 10 + try validate_num 10 # this returns a value, so we are incorrectly # dropping the parsed value @@ -14747,7 +14750,7 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! "hello" + Effect.put_line! "hello" # this outputs {}, so it's ignored if 7 > 5 then @@ -14790,13 +14793,13 @@ All branches in an `if` must have the same type! mismatch_only_early_returns, indoc!( r#" - myFunction = \x -> + my_function = \x -> if x == 5 then return "abc" else return 123 - myFunction 3 + my_function 3 "# ), @r#" @@ -14830,7 +14833,7 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! "hello" + Effect.put_line! "hello" # not ignored, warning try List.get [1, 2, 3] 5 @@ -14870,7 +14873,7 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! "hello" + Effect.put_line! "hello" # not ignored, warning when List.get [1, 2, 3] 5 is @@ -14925,9 +14928,9 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! "hello" + Effect.put_line! "hello" - Num.toStr 123 + Num.to_str 123 Ok {} "# @@ -14935,10 +14938,10 @@ All branches in an `if` must have the same type! @r#" ── IGNORED RESULT in /code/proj/Main.roc ─────────────────────────────────────── - The result of this call to `Num.toStr` is ignored: + The result of this call to `Num.to_str` is ignored: - 8│ Num.toStr 123 - ^^^^^^^^^ + 8│ Num.to_str 123 + ^^^^^^^^^^ Standalone statements are required to produce an empty record, but the type of this one is: @@ -14953,8 +14956,8 @@ All branches in an `if` must have the same type! This statement does not produce any effects: - 8│ Num.toStr 123 - ^^^^^^^^^^^^^ + 8│ Num.to_str 123 + ^^^^^^^^^^^^^^ Standalone statements are only useful if they call effectful functions. @@ -14972,9 +14975,9 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! "hello" + Effect.put_line! "hello" - _ignored = Num.toStr 123 + _ignored = Num.to_str 123 Ok {} "# @@ -14984,7 +14987,7 @@ All branches in an `if` must have the same type! This assignment doesn't introduce any new variables: - 8│ _ignored = Num.toStr 123 + 8│ _ignored = Num.to_str 123 ^^^^^^^^ Since it doesn't call any effectful functions, this assignment cannot @@ -14997,23 +15000,23 @@ All branches in an `if` must have the same type! mismatch_early_return_annotated_function, indoc!( r#" - myFunction : U64 -> Str - myFunction = \x -> + my_function : U64 -> Str + my_function = \x -> if x == 5 then return 123 else "abc" - myFunction 3 + my_function 3 "# ), @r###" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - Something is off with the body of the `myFunction` definition: + Something is off with the body of the `my_function` definition: - 4│ myFunction : U64 -> Str - 5│ myFunction = \x -> + 4│ my_function : U64 -> Str + 5│ my_function = \x -> 6│ if x == 5 then 7│ return 123 ^^^^^^^^^^ @@ -15022,7 +15025,7 @@ All branches in an `if` must have the same type! Num * - But the type annotation on `myFunction` says it should be: + But the type annotation on `my_function` says it should be: Str @@ -15033,16 +15036,16 @@ All branches in an `if` must have the same type! function_with_early_return_generalizes, indoc!( r#" - parseItemsWith = \parser -> - when List.mapTry ["123", "456"] parser is + parse_items_with = \parser -> + when List.map_try ["123", "456"] parser is Ok ok -> Ok ok Err err -> return Err err - u64Nums = parseItemsWith Str.toU64 - u8Nums = parseItemsWith Str.toU8 + u64_nums = parse_items_with Str.to_u64 + u8_nums = parse_items_with Str.to_u8 - "$(Inspect.toStr u64Nums) $(Inspect.toStr u8Nums)" + "$(Inspect.to_str u64_nums) $(Inspect.to_str u8_nums)" "# ), @"" // no errors @@ -15052,13 +15055,13 @@ All branches in an `if` must have the same type! keyword_try_with_non_result_target, indoc!( r#" - invalidTry = \{} -> - nonResult = "abc" - x = try nonResult + invalid_try = \{} -> + non_result = "abc" + x = try non_result Ok (x * 2) - invalidTry {} + invalid_try {} "# ), @r" @@ -15066,8 +15069,8 @@ All branches in an `if` must have the same type! This expression cannot be used as a `try` target: - 6│ x = try nonResult - ^^^^^^^^^ + 6│ x = try non_result + ^^^^^^^^^^ I expected a Result, but it actually has type: @@ -15081,13 +15084,13 @@ All branches in an `if` must have the same type! question_try_with_non_result_target, indoc!( r#" - invalidTry = \{} -> - nonResult = "abc" - x = nonResult? + invalid_try = \{} -> + non_result = "abc" + x = non_result? Ok (x * 2) - invalidTry {} + invalid_try {} "# ), @r" @@ -15095,8 +15098,8 @@ All branches in an `if` must have the same type! This expression cannot be tried with the `?` operator: - 6│ x = nonResult? - ^^^^^^^^^^ + 6│ x = non_result? + ^^^^^^^^^^^ I expected a Result, but it actually has type: @@ -15110,14 +15113,14 @@ All branches in an `if` must have the same type! incompatible_try_errs, indoc!( r#" - incompatibleTrys = \{} -> + incompatible_trys = \{} -> x = try Err 123 y = try Err "abc" Ok (x + y) - incompatibleTrys {} + incompatible_trys {} "# ), @r#" @@ -15146,17 +15149,17 @@ All branches in an `if` must have the same type! keyword_try_prefix_in_pipe, indoc!( r#" - readFile : Str -> Str + read_file : Str -> Str - getFileContents : Str -> Result Str _ - getFileContents = \filePath -> + get_file_contents : Str -> Result Str _ + get_file_contents = \file_path -> contents = - readFile filePath - |> try Result.mapErr ErrWrapper + read_file file_path + |> try Result.map_err ErrWrapper contents - getFileContents "file.txt" + get_file_contents "file.txt" "# ), @r" @@ -15164,10 +15167,10 @@ All branches in an `if` must have the same type! This 1st argument to this function has an unexpected type: - 9│> readFile filePath - 10│ |> try Result.mapErr ErrWrapper + 9│> read_file file_path + 10│ |> try Result.map_err ErrWrapper - This `readFile` call produces: + This `read_file` call produces: Str @@ -15181,18 +15184,18 @@ All branches in an `if` must have the same type! keyword_try_suffix_in_pipe, indoc!( r#" - readFile : Str -> Str + read_file : Str -> Str - getFileContents : Str -> Result Str _ - getFileContents = \filePath -> + get_file_contents : Str -> Result Str _ + get_file_contents = \file_path -> contents = - readFile filePath - |> Result.mapErr ErrWrapper + read_file file_path + |> Result.map_err ErrWrapper |> try contents - getFileContents "file.txt" + get_file_contents "file.txt" "# ), @r" @@ -15200,10 +15203,10 @@ All branches in an `if` must have the same type! This 1st argument to |> has an unexpected type: - 9│> readFile filePath - 10│ |> Result.mapErr ErrWrapper + 9│> read_file file_path + 10│ |> Result.map_err ErrWrapper - This `readFile` call produces: + This `read_file` call produces: Str @@ -15217,17 +15220,17 @@ All branches in an `if` must have the same type! question_try_in_pipe, indoc!( r#" - readFile : Str -> Str + read_file : Str -> Str - getFileContents : Str -> Result Str _ - getFileContents = \filePath -> + get_file_contents : Str -> Result Str _ + get_file_contents = \file_path -> contents = - readFile filePath - |> Result.mapErr? ErrWrapper + read_file file_path + |> Result.map_err? ErrWrapper contents - getFileContents "file.txt" + get_file_contents "file.txt" "# ), @r" @@ -15235,10 +15238,10 @@ All branches in an `if` must have the same type! This 1st argument to this function has an unexpected type: - 9│> readFile filePath - 10│ |> Result.mapErr? ErrWrapper + 9│> read_file file_path + 10│ |> Result.map_err? ErrWrapper - This `readFile` call produces: + This `read_file` call produces: Str @@ -15259,7 +15262,7 @@ All branches in an `if` must have the same type! main! = \{} -> identity {} - Effect.putLine! "hello" + Effect.put_line! "hello" identity = \x -> x "# @@ -15288,33 +15291,33 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! (getCheer "hello") + Effect.put_line! (get_cheer "hello") - getCheer : Str -> Str - getCheer = \msg -> - name = Effect.getLine! {} + get_cheer : Str -> Str + get_cheer = \msg -> + name = Effect.get_line! {} "$(msg), $(name)!" "# ), - @r###" + @r" ── EFFECT IN PURE FUNCTION in /code/proj/Main.roc ────────────────────────────── - This call to `Effect.getLine!` might produce an effect: + This call to `Effect.get_line!` might produce an effect: - 10│ name = Effect.getLine! {} - ^^^^^^^^^^^^^^^^^^ + 10│ name = Effect.get_line! {} + ^^^^^^^^^^^^^^^^^^^ However, the type of the enclosing function requires that it's pure: - 8│ getCheer : Str -> Str - ^^^^^^^^^^ + 8│ get_cheer : Str -> Str + ^^^^^^^^^^ Tip: Replace `->` with `=>` to annotate it as effectful. You can still run the program with this error, which can be helpful when you're debugging. - "### + " ); test_report!( @@ -15330,17 +15333,17 @@ All branches in an `if` must have the same type! trim : Str -> Str trim = \msg -> - Effect.putLine! "Trimming $(msg)" + Effect.put_line! "Trimming $(msg)" Str.trim msg "# ), @r#" ── EFFECT IN PURE FUNCTION in /code/proj/Main.roc ────────────────────────────── - This call to `Effect.putLine!` might produce an effect: + This call to `Effect.put_line!` might produce an effect: - 10│ Effect.putLine! "Trimming $(msg)" - ^^^^^^^^^^^^^^^ + 10│ Effect.put_line! "Trimming $(msg)" + ^^^^^^^^^^^^^^^^ However, the type of the enclosing function requires that it's pure: @@ -15363,26 +15366,26 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - printHello = \{} -> - Effect.putLine! "hello" + print_hello = \{} -> + Effect.put_line! "hello" - printHello {} + print_hello {} "# ), - @r###" + @r" ── MISSING EXCLAMATION in /code/proj/Main.roc ────────────────────────────────── This function is effectful, but its name does not indicate so: - 6│ printHello = \{} -> - ^^^^^^^^^^ + 6│ print_hello = \{} -> + ^^^^^^^^^^^ Add an exclamation mark at the end, like: - printHello! + print_hello! This will help readers identify it as a source of effects. - "### + " ); test_report!( @@ -15394,17 +15397,17 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.getLine! {} + Effect.get_line! {} {} "# ), - @r###" + @r#" ── IGNORED RESULT in /code/proj/Main.roc ─────────────────────────────────────── - The result of this call to `Effect.getLine!` is ignored: + The result of this call to `Effect.get_line!` is ignored: - 6│ Effect.getLine! {} - ^^^^^^^^^^^^^^^ + 6│ Effect.get_line! {} + ^^^^^^^^^^^^^^^^ Standalone statements are required to produce an empty record, but the type of this one is: @@ -15414,7 +15417,7 @@ All branches in an `if` must have the same type! If you still want to ignore it, assign it to `_`, like this: _ = File.delete! "data.json" - "### + "# ); test_report!( @@ -15426,17 +15429,17 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.getLine! - Effect.putLine! "hi" + Effect.get_line! + Effect.put_line! "hi" "# ), - @r###" + @r" ── IGNORED RESULT in /code/proj/Main.roc ─────────────────────────────────────── The result of this expression is ignored: - 6│ Effect.getLine! - ^^^^^^^^^^^^^^^ + 6│ Effect.get_line! + ^^^^^^^^^^^^^^^^ Standalone statements are required to produce an empty record, but the type of this one is: @@ -15449,14 +15452,14 @@ All branches in an `if` must have the same type! This statement does not produce any effects: - 6│ Effect.getLine! - ^^^^^^^^^^^^^^^ + 6│ Effect.get_line! + ^^^^^^^^^^^^^^^^ Standalone statements are only useful if they call effectful functions. Did you forget to use its result? If not, feel free to remove it. - "### + " ); test_report!( @@ -15468,7 +15471,7 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Effect.putLine! (hello! {}) + Effect.put_line! (hello! {}) hello! = \{} -> "hello" @@ -15497,20 +15500,20 @@ All branches in an `if` must have the same type! import pf.Effect hello = - Effect.putLine! "calling hello!" + Effect.put_line! "calling hello!" "hello" main! = \{} -> - Effect.putLine! hello + Effect.put_line! hello "# ), - @r###" + @r#" ── EFFECT IN TOP-LEVEL in /code/proj/Main.roc ────────────────────────────────── - This call to `Effect.putLine!` might produce an effect: + This call to `Effect.put_line!` might produce an effect: - 6│ Effect.putLine! "calling hello!" - ^^^^^^^^^^^^^^^ + 6│ Effect.put_line! "calling hello!" + ^^^^^^^^^^^^^^^^ However, it appears in a top-level def instead of a function. If we allowed this, importing this module would produce a side effect. @@ -15523,7 +15526,7 @@ All branches in an `if` must have the same type! Stdin.line! {} This will allow the caller to control when the effects run. - "### + "# ); test_report!( @@ -15535,25 +15538,25 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - printLn "Hello" + print_ln "Hello" - printLn = Effect.putLine! + print_ln = Effect.put_line! "# ), - @r###" + @r" ── MISSING EXCLAMATION in /code/proj/Main.roc ────────────────────────────────── This function is effectful, but its name does not indicate so: - 8│ printLn = Effect.putLine! - ^^^^^^^ + 8│ print_ln = Effect.put_line! + ^^^^^^^^ Add an exclamation mark at the end, like: - printLn! + print_ln! This will help readers identify it as a source of effects. - "### + " ); test_report!( @@ -15566,26 +15569,26 @@ All branches in an `if` must have the same type! main! = \{} -> fx = { - putLine: Effect.putLine! + put_line: Effect.put_line! } - fx.putLine "hello world!" + fx.put_line "hello world!" "# ), - @r###" + @r" ── MISSING EXCLAMATION in /code/proj/Main.roc ────────────────────────────────── This field's value is an effectful function, but its name does not indicate so: - 7│ putLine: Effect.putLine! - ^^^^^^^^^^^^^^^^^^^^^^^^ + 7│ put_line: Effect.put_line! + ^^^^^^^^^^^^^^^^^^^^^^^^^^ Add an exclamation mark at the end, like: - { readFile! : File.read! } + { read_file! : File.read! } This will help readers identify it as a source of effects. - "### + " ); test_report!( @@ -15595,7 +15598,7 @@ All branches in an `if` must have the same type! module [Fx] Fx : { - getLine: {} => Str + get_line: {} => Str } "# ), @@ -15605,12 +15608,12 @@ All branches in an `if` must have the same type! The type of this record field is an effectful function, but its name does not indicate so: - 4│ getLine: {} => Str - ^^^^^^^^^^^^^^^^^^ + 4│ get_line: {} => Str + ^^^^^^^^^^^^^^^^^^^ Add an exclamation mark at the end, like: - { readFile!: Str => Str } + { read_file!: Str => Str } This will help readers identify it as a source of effects. " @@ -15623,7 +15626,7 @@ All branches in an `if` must have the same type! module [Fx] Fx : { - getLine!: {} -> Str + get_line!: {} -> Str } "# ), @@ -15633,8 +15636,8 @@ All branches in an `if` must have the same type! The type of this record field is a pure function, but its name suggests otherwise: - 4│ getLine!: {} -> Str - ^^^^^^^^^^^^^^^^^^^ + 4│ get_line!: {} -> Str + ^^^^^^^^^^^^^^^^^^^^ The exclamation mark at the end is reserved for effectful functions. @@ -15652,31 +15655,31 @@ All branches in an `if` must have the same type! main! = \{} -> ["Hello", "world!"] - |> forEach! Effect.putLine! + |> for_each! Effect.put_line! - forEach! : List a, (a => {}) => {} - forEach! = \l, f -> + for_each! : List a, (a => {}) => {} + for_each! = \l, f -> when l is [] -> {} [x, .. as xs] -> f x - forEach! xs f + for_each! xs f "# ), - @r###" + @r" ── MISSING EXCLAMATION in /code/proj/Main.roc ────────────────────────────────── This function is effectful, but its name does not indicate so: - 10│ forEach! = \l, f -> - ^ + 10│ for_each! = \l, f -> + ^ Add an exclamation mark at the end, like: f! This will help readers identify it as a source of effects. - "### + " ); test_report!( @@ -15689,29 +15692,29 @@ All branches in an `if` must have the same type! main! = \{} -> Ok " hi " - |> mapOk Str.trim - |> Result.withDefault "" - |> Effect.putLine! + |> map_ok Str.trim + |> Result.with_default "" + |> Effect.put_line! - mapOk : Result a err, (a -> b) -> Result b err - mapOk = \result, fn! -> + map_ok : Result a err, (a -> b) -> Result b err + map_ok = \result, fn! -> when result is Ok x -> Ok (fn! x) Err e -> Err e "# ), - @r###" + @r" ── UNNECESSARY EXCLAMATION in /code/proj/Main.roc ────────────────────────────── This function is pure, but its name suggests otherwise: - 12│ mapOk = \result, fn! -> - ^^^ + 12│ map_ok = \result, fn! -> + ^^^ The exclamation mark at the end is reserved for effectful functions. Hint: Did you forget to run an effect? Is the type annotation wrong? - "### + " ); test_report!( @@ -15723,7 +15726,7 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - (get, put) = (Effect.getLine!, Effect.putLine!) + (get, put) = (Effect.get_line!, Effect.put_line!) name = get {} put "Hi, $(name)" @@ -15734,7 +15737,7 @@ All branches in an `if` must have the same type! This function is effectful, but its name does not indicate so: - 6│ (get, put) = (Effect.getLine!, Effect.putLine!) + 6│ (get, put) = (Effect.get_line!, Effect.put_line!) ^^^ Add an exclamation mark at the end, like: @@ -15747,7 +15750,7 @@ All branches in an `if` must have the same type! This function is effectful, but its name does not indicate so: - 6│ (get, put) = (Effect.getLine!, Effect.putLine!) + 6│ (get, put) = (Effect.get_line!, Effect.put_line!) ^^^ Add an exclamation mark at the end, like: @@ -15769,7 +15772,7 @@ All branches in an `if` must have the same type! main! = \{} -> (msg, trim!) = (" hi ", Str.trim) - Effect.putLine! (trim! msg) + Effect.put_line! (trim! msg) "# ), @r###" @@ -15795,7 +15798,7 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - Tag get put = Tag Effect.getLine! Effect.putLine! + Tag get put = Tag Effect.get_line! Effect.put_line! name = get {} put "Hi, $(name)" @@ -15806,7 +15809,7 @@ All branches in an `if` must have the same type! This function is effectful, but its name does not indicate so: - 6│ Tag get put = Tag Effect.getLine! Effect.putLine! + 6│ Tag get put = Tag Effect.get_line! Effect.put_line! ^^^ Add an exclamation mark at the end, like: @@ -15819,7 +15822,7 @@ All branches in an `if` must have the same type! This function is effectful, but its name does not indicate so: - 6│ Tag get put = Tag Effect.getLine! Effect.putLine! + 6│ Tag get put = Tag Effect.get_line! Effect.put_line! ^^^ Add an exclamation mark at the end, like: @@ -15841,7 +15844,7 @@ All branches in an `if` must have the same type! main! = \{} -> Tag msg trim! = Tag " hi " Str.trim - Effect.putLine! (trim! msg) + Effect.put_line! (trim! msg) "# ), @r###" @@ -15869,7 +15872,7 @@ All branches in an `if` must have the same type! PutLine := Str => {} main! = \{} -> - @PutLine put = @PutLine Effect.putLine! + @PutLine put = @PutLine Effect.put_line! put "Hi!" "# @@ -15879,7 +15882,7 @@ All branches in an `if` must have the same type! This function is effectful, but its name does not indicate so: - 8│ @PutLine put = @PutLine Effect.putLine! + 8│ @PutLine put = @PutLine Effect.put_line! ^^^ Add an exclamation mark at the end, like: @@ -15903,7 +15906,7 @@ All branches in an `if` must have the same type! main! = \{} -> @Trim trim! = @Trim Str.trim - Effect.putLine! (trim! " hi ") + Effect.put_line! (trim! " hi ") "# ), @r###" @@ -15929,24 +15932,24 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - pureHigherOrder Effect.putLine! "hi" + pure_higher_order Effect.put_line! "hi" - pureHigherOrder = \f, x -> f x + pure_higher_order = \f, x -> f x "# ), @r#" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - This 1st argument to `pureHigherOrder` has an unexpected type: + This 1st argument to `pure_higher_order` has an unexpected type: - 6│ pureHigherOrder Effect.putLine! "hi" - ^^^^^^^^^^^^^^^ + 6│ pure_higher_order Effect.put_line! "hi" + ^^^^^^^^^^^^^^^^ - This `Effect.putLine!` value is a: + This `Effect.put_line!` value is a: Str => {} - But `pureHigherOrder` needs its 1st argument to be: + But `pure_higher_order` needs its 1st argument to be: Str -> {} "# @@ -15961,25 +15964,25 @@ All branches in an `if` must have the same type! import pf.Effect main! = \{} -> - pureHigherOrder Effect.putLine! "hi" + pure_higher_order Effect.put_line! "hi" - pureHigherOrder : _, _ -> _ - pureHigherOrder = \f, x -> f x + pure_higher_order : _, _ -> _ + pure_higher_order = \f, x -> f x "# ), @r#" ── TYPE MISMATCH in /code/proj/Main.roc ──────────────────────────────────────── - This 1st argument to `pureHigherOrder` has an unexpected type: + This 1st argument to `pure_higher_order` has an unexpected type: - 6│ pureHigherOrder Effect.putLine! "hi" - ^^^^^^^^^^^^^^^ + 6│ pure_higher_order Effect.put_line! "hi" + ^^^^^^^^^^^^^^^^ - This `Effect.putLine!` value is a: + This `Effect.put_line!` value is a: Str => {} - But `pureHigherOrder` needs its 1st argument to be: + But `pure_higher_order` needs its 1st argument to be: Str -> {} "# diff --git a/crates/compiler/load_internal/src/module.rs b/crates/compiler/load_internal/src/module.rs index 76953675cf4..e29c5385781 100644 --- a/crates/compiler/load_internal/src/module.rs +++ b/crates/compiler/load_internal/src/module.rs @@ -228,7 +228,7 @@ pub struct Expectations { #[derive(Clone, Debug, Default)] pub struct ExposedToHost { - /// usually `mainForHost` + /// usually `main_for_host` pub top_level_values: MutMap, /// exposed closure types, typically `Fx` pub closure_types: Vec, diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/AStar.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/AStar.roc index 69a1db59e05..385ca3a0307 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/AStar.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/AStar.roc @@ -1,111 +1,99 @@ -interface AStar - exposes [initialModel, reconstructPath, updateCost, cheapestOpen, astar, findPath] - imports [] - +module [initial_model, reconstruct_path, update_cost, cheapest_open, astar, find_path] # a port of https://github.com/krisajenkins/elm-astar/blob/2.1.3/src/AStar/Generalised.elm -Model position : - { evaluated : Set position - , openSet : Set position - , costs : Map.Map position F64 - , cameFrom : Map.Map position position - } - - -initialModel : position -> Model position -initialModel = \start -> - { evaluated : Set.empty {} - , openSet : Set.single start - , costs : Dict.single start 0.0 - , cameFrom : Map.empty - } - - -cheapestOpen : (position -> F64), Model position -> Result position [KeyNotFound]* -cheapestOpen = \costFunction, model -> - - folder = \resSmallestSoFar, position -> - when Map.get model.costs position is - Err e -> - Err e - - Ok cost -> - positionCost = costFunction position - - when resSmallestSoFar is - Err _ -> Ok { position, cost: cost + positionCost } - Ok smallestSoFar -> - if positionCost + cost < smallestSoFar.cost then - Ok { position, cost: cost + positionCost } - - else - Ok smallestSoFar - - Set.walk model.openSet (Err KeyNotFound) folder - |> Result.map (\x -> x.position) - - - -reconstructPath : Map position position, position -> List position -reconstructPath = \cameFrom, goal -> - when Map.get cameFrom goal is - Err KeyNotFound -> +Model position : { + evaluated : Set position, + open_set : Set position, + costs : Map.Map position F64, + came_from : Map.Map position position, +} + +initial_model : position -> Model position +initial_model = \start -> { + evaluated: Set.empty({}), + open_set: Set.single(start), + costs: Dict.single(start, 0.0), + came_from: Map.empty, +} + +cheapest_open : (position -> F64), Model position -> Result position [KeyNotFound]* +cheapest_open = \cost_function, model -> + + folder = \res_smallest_so_far, position -> + when Map.get(model.costs, position) is + Err(e) -> + Err(e) + + Ok(cost) -> + position_cost = cost_function(position) + + when res_smallest_so_far is + Err(_) -> Ok({ position, cost: cost + position_cost }) + Ok(smallest_so_far) -> + if position_cost + cost < smallest_so_far.cost then + Ok({ position, cost: cost + position_cost }) + else + Ok(smallest_so_far) + + Set.walk(model.open_set, Err(KeyNotFound), folder) + |> Result.map(\x -> x.position) + +reconstruct_path : Map position position, position -> List position +reconstruct_path = \came_from, goal -> + when Map.get(came_from, goal) is + Err(KeyNotFound) -> [] - Ok next -> - List.append (reconstructPath cameFrom next) goal - -updateCost : position, position, Model position -> Model position -updateCost = \current, neighbour, model -> - newCameFrom = Map.insert model.cameFrom neighbour current + Ok(next) -> + List.append(reconstruct_path(came_from, next), goal) - newCosts = Map.insert model.costs neighbour distanceTo +update_cost : position, position, Model position -> Model position +update_cost = \current, neighbour, model -> + new_came_from = Map.insert(model.came_from, neighbour, current) - distanceTo = reconstructPath newCameFrom neighbour - |> List.len - |> Num.toFrac + new_costs = Map.insert(model.costs, neighbour, distance_to) - newModel = { model & costs : newCosts , cameFrom : newCameFrom } + distance_to = + reconstruct_path(new_came_from, neighbour) + |> List.len + |> Num.to_frac - when Map.get model.costs neighbour is - Err KeyNotFound -> - newModel + new_model = { model & costs: new_costs, came_from: new_came_from } - Ok previousDistance -> - if distanceTo < previousDistance then - newModel + when Map.get(model.costs, neighbour) is + Err(KeyNotFound) -> + new_model + Ok(previous_distance) -> + if distance_to < previous_distance then + new_model else model - -findPath : { costFunction: (position, position -> F64), moveFunction: (position -> Set position), start : position, end : position } -> Result (List position) [KeyNotFound]* -findPath = \{ costFunction, moveFunction, start, end } -> - astar costFunction moveFunction end (initialModel start) - +find_path : { cost_function : position, position -> F64, move_function : position -> Set position, start : position, end : position } -> Result (List position) [KeyNotFound]* +find_path = \{ cost_function, move_function, start, end } -> + astar(cost_function, move_function, end, initial_model(start)) astar : (position, position -> F64), (position -> Set position), position, Model position -> [Err [KeyNotFound]*, Ok (List position)]* -astar = \costFn, moveFn, goal, model -> - when cheapestOpen (\position -> costFn goal position) model is - Err _ -> - Err KeyNotFound +astar = \cost_fn, move_fn, goal, model -> + when cheapest_open(\position -> cost_fn(goal, position), model) is + Err(_) -> + Err(KeyNotFound) - Ok current -> + Ok(current) -> if current == goal then - Ok (reconstructPath model.cameFrom goal) - + Ok(reconstruct_path(model.came_from, goal)) else + model_popped = { model & open_set: Set.remove(model.open_set, current), evaluated: Set.insert(model.evaluated, current) } - modelPopped = { model & openSet : Set.remove model.openSet current, evaluated : Set.insert model.evaluated current } - - neighbours = moveFn current + neighbours = move_fn(current) - newNeighbours = Set.difference neighbours modelPopped.evaluated + new_neighbours = Set.difference(neighbours, model_popped.evaluated) - modelWithNeighbours = { modelPopped & openSet : Set.union modelPopped.openSet newNeighbours } + model_with_neighbours = { model_popped & open_set: Set.union(model_popped.open_set, new_neighbours) } - modelWithCosts = Set.walk newNeighbours modelWithNeighbours (\md, nb -> updateCost current nb md) + model_with_costs = Set.walk(new_neighbours, model_with_neighbours, \md, nb -> update_cost(current, nb, md)) - astar costFn moveFn goal modelWithCosts + astar(cost_fn, move_fn, goal, model_with_costs) diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep1.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep1.roc index 4f6db7aab88..363898813d8 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep1.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep1.roc @@ -1,6 +1,4 @@ -interface Dep1 - exposes [three, str, Unit, Identity, one, two] - imports [] +module [three, str, Unit, Identity, one, two] import Dep3Blah exposing [foo] diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep2.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep2.roc index fed179b515d..fb237f5345a 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep2.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep2.roc @@ -1,6 +1,4 @@ -interface Dep2 - exposes [one, two, blah] - imports [] +module [one, two, blah] import Dep3Blah exposing [foo, bar] diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Blah.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Blah.roc index a469d5919d8..ab83948d758 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Blah.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Blah.roc @@ -1,6 +1,4 @@ -interface Dep3Blah - exposes [one, two, foo, bar] - imports [] +module [one, two, foo, bar] import Dep3Other diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Other.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Other.roc index 3d450953065..f50b4cd19ff 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Other.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Dep3Other.roc @@ -1,6 +1,4 @@ -interface Dep3Other - exposes [foo, bar] - imports [] +module [foo, bar] foo = "foo from Dep3Other" bar = "bar from Dep3Other" diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ImportAlias.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ImportAlias.roc index 59227f131b5..0e20144ee4d 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ImportAlias.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ImportAlias.roc @@ -1,6 +1,4 @@ -interface ImportAlias - exposes [unit] - imports [] +module [unit] import Dep1 diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ManualAttr.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ManualAttr.roc index 5e51189cbb6..ae05664515e 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ManualAttr.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/ManualAttr.roc @@ -1,18 +1,16 @@ -interface ManualAttr - exposes [] - imports [] +module [] # manually replicates the Attr wrapping that uniqueness inference uses, to try and find out why they are different # It is very important that there are no signatures here! elm uses an optimization that leads to less copying when # signatures are given. map = - unAttr = \Attr _ foobar -> foobar + un_attr = \Attr(_, foobar) -> foobar - r = Attr unknown "bar" + r = Attr(unknown, "bar") - s = Attr unknown2 { left : Attr Shared "foo" } + s = Attr(unknown2, { left: Attr(Shared, "foo") }) when True is - _ -> { y : r } - _ -> { y : (unAttr s).left } + _ -> { y: r } + _ -> { y: (un_attr(s)).left } diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/OneDep.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/OneDep.roc index 8ef639ab1cf..ff1f93d5297 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/OneDep.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/OneDep.roc @@ -1,6 +1,4 @@ -interface OneDep - exposes [str] - imports [] +module [str] import Dep3Blah exposing [foo] diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Primary.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Primary.roc index 7d28d26d214..6512dab3f35 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Primary.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Primary.roc @@ -1,6 +1,4 @@ -interface Primary - exposes [blah2, blah3, str, alwaysThree, identity, z, w, succeed, withDefault, yay] - imports [] +module [blah2, blah3, str, always_three, identity, z, w, succeed, with_default, yay] import Dep1 import Dep2 @@ -12,24 +10,24 @@ blah3 = bar str = Dep1.str -alwaysThree = \_ -> Dep1.three +always_three = \_ -> Dep1.three identity = \a -> a -z = identity (alwaysThree {}) +z = identity(always_three({})) w : Dep1.Identity {} -w = Identity {} +w = Identity({}) succeed : a -> Dep1.Identity a -succeed = \x -> Identity x +succeed = \x -> Identity(x) -withDefault = Res.withDefault +with_default = Res.with_default yay : Res.Res {} err yay = - ok = Ok "foo" + ok = Ok("foo") f = \_ -> {} - Res.map ok f + Res.map(ok, f) diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Quicksort.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Quicksort.roc index 8e57a8b6d26..e61c0731165 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Quicksort.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Quicksort.roc @@ -1,49 +1,46 @@ -app "quicksort" provides [swap, partition, partitionHelp, quicksort] to "./platform" +app [swap, partition, partition_help, quicksort] {} quicksort : List (Num a), U64, U64 -> List (Num a) quicksort = \list, low, high -> - when partition low high list is - Pair partitionIndex partitioned -> + when partition(low, high, list) is + Pair(partition_index, partitioned) -> partitioned - |> quicksort low (partitionIndex - 1) - |> quicksort (partitionIndex + 1) high - + |> quicksort(low, (partition_index - 1)) + |> quicksort((partition_index + 1), high) swap : U64, U64, List a -> List a swap = \i, j, list -> - when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + when Pair(List.get(list, i), List.get(list, j)) is + Pair(Ok(at_i), Ok(at_j)) -> list - |> List.set i atJ - |> List.set j atI + |> List.set(i, at_j) + |> List.set(j, at_i) _ -> [] - partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] -partition = \low, high, initialList -> - when List.get initialList high is - Ok pivot -> - when partitionHelp (low - 1) low initialList high pivot is - Pair newI newList -> - Pair (newI + 1) (swap (newI + 1) high newList) - - Err _ -> - Pair (low - 1) initialList - - -partitionHelp : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] -partitionHelp = \i, j, list, high, pivot -> +partition = \low, high, initial_list -> + when List.get(initial_list, high) is + Ok(pivot) -> + when partition_help((low - 1), low, initial_list, high, pivot) is + Pair(new_i, new_list) -> + Pair((new_i + 1), swap((new_i + 1), high, new_list)) + + Err(_) -> + Pair((low - 1), initial_list) + +partition_help : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] +partition_help = \i, j, list, high, pivot -> if j < high then - when List.get list j is - Ok value -> + when List.get(list, j) is + Ok(value) -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap (i + 1) j list) high pivot + partition_help((i + 1), (j + 1), swap((i + 1), j, list), high, pivot) else - partitionHelp i (j + 1) list high pivot + partition_help(i, (j + 1), list, high, pivot) - Err _ -> - Pair i list + Err(_) -> + Pair(i, list) else - Pair i list + Pair(i, list) diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/QuicksortMultiDef.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/QuicksortMultiDef.roc index a5de036e0b8..75be3bf0475 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/QuicksortMultiDef.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/QuicksortMultiDef.roc @@ -1,57 +1,53 @@ -app "quicksort" provides [quicksort] to "./platform" +app [quicksort] {} -quicksortHelp : List (Num a), U64, U64 -> List (Num a) -quicksortHelp = \list, low, high -> +quicksort_help : List (Num a), U64, U64 -> List (Num a) +quicksort_help = \list, low, high -> if low < high then - when partition low high list is - Pair partitionIndex partitioned -> + when partition(low, high, list) is + Pair(partition_index, partitioned) -> partitioned - |> quicksortHelp low (partitionIndex - 1) - |> quicksortHelp (partitionIndex + 1) high + |> quicksort_help(low, (partition_index - 1)) + |> quicksort_help((partition_index + 1), high) else list - swap : U64, U64, List a -> List a swap = \i, j, list -> - when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + when Pair(List.get(list, i), List.get(list, j)) is + Pair(Ok(at_i), Ok(at_j)) -> list - |> List.set i atJ - |> List.set j atI + |> List.set(i, at_j) + |> List.set(j, at_i) _ -> [] partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] -partition = \low, high, initialList -> - when List.get initialList high is - Ok pivot -> - when partitionHelp (low - 1) low initialList high pivot is - Pair newI newList -> - Pair (newI + 1) (swap (newI + 1) high newList) - - Err _ -> - Pair (low - 1) initialList - - -partitionHelp : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] -partitionHelp = \i, j, list, high, pivot -> +partition = \low, high, initial_list -> + when List.get(initial_list, high) is + Ok(pivot) -> + when partition_help((low - 1), low, initial_list, high, pivot) is + Pair(new_i, new_list) -> + Pair((new_i + 1), swap((new_i + 1), high, new_list)) + + Err(_) -> + Pair((low - 1), initial_list) + +partition_help : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] +partition_help = \i, j, list, high, pivot -> if j < high then - when List.get list j is - Ok value -> + when List.get(list, j) is + Ok(value) -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap (i + 1) j list) high pivot + partition_help((i + 1), (j + 1), swap((i + 1), j, list), high, pivot) else - partitionHelp i (j + 1) list high pivot + partition_help(i, (j + 1), list, high, pivot) - Err _ -> - Pair i list + Err(_) -> + Pair(i, list) else - Pair i list - - + Pair(i, list) -quicksort = \originalList -> - n = List.len originalList - quicksortHelp originalList 0 (n - 1) +quicksort = \original_list -> + n = List.len(original_list) + quicksort_help(original_list, 0, (n - 1)) diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Records.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Records.roc index d2eda2ba5f1..a6104a31691 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Records.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Records.roc @@ -1,8 +1,6 @@ -interface Records - exposes [intVal] - imports [] +module [int_val] -intVal = +int_val = foo = \{ x } -> x - foo { x: 5 } + foo({ x: 5 }) diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Res.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Res.roc index b0ae7c15547..8697cb779dd 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Res.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/Res.roc @@ -1,31 +1,29 @@ -interface Res - exposes [Res, withDefault, map, andThen, ConsList] - imports [] +module [Res, with_default, map, and_then, ConsList] Res ok err : [Ok ok, Err err] ConsList a : [Cons a (ConsList a), Nil] -listMap : ConsList a, (a -> b) -> ConsList b -listMap = \list, f -> - when list is - Nil -> Nil - Cons x xs -> Cons (f x) (listMap xs f) +list_map : ConsList a, (a -> b) -> ConsList b +list_map = \list, f -> + when list is + Nil -> Nil + Cons(x, xs) -> Cons(f(x), list_map(xs, f)) map : Res a err, (a -> b) -> Res b err map = \result, transform -> when result is - Ok ok -> Ok (transform ok) - Err err -> Err err + Ok(ok) -> Ok(transform(ok)) + Err(err) -> Err(err) -withDefault : Res a err, a -> a -withDefault = \result, default -> +with_default : Res a err, a -> a +with_default = \result, default -> when result is - Ok ok -> ok - Err _ -> default + Ok(ok) -> ok + Err(_) -> default -andThen : Res a err, (a -> Res b err) -> Res b err -andThen = \result, transform -> +and_then : Res a err, (a -> Res b err) -> Res b err +and_then = \result, transform -> when result is - Ok ok -> transform ok - Err err -> Err err + Ok(ok) -> transform(ok) + Err(err) -> Err(err) diff --git a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/WithBuiltins.roc b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/WithBuiltins.roc index 0c71396bef6..05c871eab09 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/WithBuiltins.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/app_with_deps/WithBuiltins.roc @@ -1,22 +1,20 @@ -interface WithBuiltins - exposes [floatTest, divisionFn, divisionTest, intTest, constantNum, fromDep2, divDep1ByDep2] - imports [] +module [float_test, division_fn, division_test, int_test, constant_num, from_dep2, div_dep1_by_dep2] import Dep1 import Dep2 exposing [two] -floatTest = Num.maxF64 +float_test = Num.max_f64 -divisionFn = Num.div +division_fn = Num.div x = 5.0 -divisionTest = Num.maxF64 / x +division_test = Num.max_f64 / x -intTest = Num.maxI64 +int_test = Num.max_i64 -constantNum = 5 +constant_num = 5 -fromDep2 = Dep2.two +from_dep2 = Dep2.two -divDep1ByDep2 = Dep1.three / fromDep2 +div_dep1_by_dep2 = Dep1.three / from_dep2 diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/AStar.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/AStar.roc index b9b44ddbd61..43e240a8905 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/AStar.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/AStar.roc @@ -1,111 +1,99 @@ -interface AStar - exposes [initialModel, reconstructPath, updateCost, cheapestOpen, astar, findPath] - imports [] - +module [initial_model, reconstruct_path, update_cost, cheapest_open, astar, find_path] # a port of https://github.com/krisajenkins/elm-astar/blob/2.1.3/src/AStar/Generalised.elm -Model position : - { evaluated : Set position - , openSet : Set position - , costs : Dict.Dict position F64 - , cameFrom : Dict.Dict position position - } - - -initialModel : position -> Model position where position implements Hash & Eq -initialModel = \start -> - { evaluated : Set.empty {} - , openSet : Set.single start - , costs : Dict.single start 0.0 - , cameFrom : Dict.empty {} - } - - -cheapestOpen : (position -> F64), Model position -> Result position [KeyNotFound] where position implements Hash & Eq -cheapestOpen = \costFunction, model -> - - folder = \resSmallestSoFar, position -> - when Dict.get model.costs position is - Err e -> - Err e - - Ok cost -> - positionCost = costFunction position - - when resSmallestSoFar is - Err _ -> Ok { position, cost: cost + positionCost } - Ok smallestSoFar -> - if positionCost + cost < smallestSoFar.cost then - Ok { position, cost: cost + positionCost } - - else - Ok smallestSoFar - - Set.walk model.openSet (Err KeyNotFound) folder - |> Result.map (\x -> x.position) - - - -reconstructPath : Dict position position, position -> List position where position implements Hash & Eq -reconstructPath = \cameFrom, goal -> - when Dict.get cameFrom goal is - Err KeyNotFound -> +Model position : { + evaluated : Set position, + open_set : Set position, + costs : Dict.Dict position F64, + came_from : Dict.Dict position position, +} + +initial_model : position -> Model position where position implements Hash & Eq +initial_model = \start -> { + evaluated: Set.empty({}), + open_set: Set.single(start), + costs: Dict.single(start, 0.0), + came_from: Dict.empty({}), +} + +cheapest_open : (position -> F64), Model position -> Result position [KeyNotFound] where position implements Hash & Eq +cheapest_open = \cost_function, model -> + + folder = \res_smallest_so_far, position -> + when Dict.get(model.costs, position) is + Err(e) -> + Err(e) + + Ok(cost) -> + position_cost = cost_function(position) + + when res_smallest_so_far is + Err(_) -> Ok({ position, cost: cost + position_cost }) + Ok(smallest_so_far) -> + if position_cost + cost < smallest_so_far.cost then + Ok({ position, cost: cost + position_cost }) + else + Ok(smallest_so_far) + + Set.walk(model.open_set, Err(KeyNotFound), folder) + |> Result.map(\x -> x.position) + +reconstruct_path : Dict position position, position -> List position where position implements Hash & Eq +reconstruct_path = \came_from, goal -> + when Dict.get(came_from, goal) is + Err(KeyNotFound) -> [] - Ok next -> - List.append (reconstructPath cameFrom next) goal - -updateCost : position, position, Model position -> Model position where position implements Hash & Eq -updateCost = \current, neighbour, model -> - newCameFrom = Dict.insert model.cameFrom neighbour current + Ok(next) -> + List.append(reconstruct_path(came_from, next), goal) - newCosts = Dict.insert model.costs neighbour distanceTo +update_cost : position, position, Model position -> Model position where position implements Hash & Eq +update_cost = \current, neighbour, model -> + new_came_from = Dict.insert(model.came_from, neighbour, current) - distanceTo = reconstructPath newCameFrom neighbour - |> List.len - |> Num.toFrac + new_costs = Dict.insert(model.costs, neighbour, distance_to) - newModel = { model & costs : newCosts , cameFrom : newCameFrom } + distance_to = + reconstruct_path(new_came_from, neighbour) + |> List.len + |> Num.to_frac - when Dict.get model.costs neighbour is - Err KeyNotFound -> - newModel + new_model = { model & costs: new_costs, came_from: new_came_from } - Ok previousDistance -> - if distanceTo < previousDistance then - newModel + when Dict.get(model.costs, neighbour) is + Err(KeyNotFound) -> + new_model + Ok(previous_distance) -> + if distance_to < previous_distance then + new_model else model - -findPath : { costFunction: (position, position -> F64), moveFunction: (position -> Set position), start : position, end : position } -> Result (List position) [KeyNotFound] where position implements Hash & Eq -findPath = \{ costFunction, moveFunction, start, end } -> - astar costFunction moveFunction end (initialModel start) - +find_path : { cost_function : position, position -> F64, move_function : position -> Set position, start : position, end : position } -> Result (List position) [KeyNotFound] where position implements Hash & Eq +find_path = \{ cost_function, move_function, start, end } -> + astar(cost_function, move_function, end, initial_model(start)) astar : (position, position -> F64), (position -> Set position), position, Model position -> [Err [KeyNotFound], Ok (List position)] where position implements Hash & Eq -astar = \costFn, moveFn, goal, model -> - when cheapestOpen (\position -> costFn goal position) model is - Err _ -> - Err KeyNotFound +astar = \cost_fn, move_fn, goal, model -> + when cheapest_open(\position -> cost_fn(goal, position), model) is + Err(_) -> + Err(KeyNotFound) - Ok current -> + Ok(current) -> if current == goal then - Ok (reconstructPath model.cameFrom goal) - + Ok(reconstruct_path(model.came_from, goal)) else + model_popped = { model & open_set: Set.remove(model.open_set, current), evaluated: Set.insert(model.evaluated, current) } - modelPopped = { model & openSet : Set.remove model.openSet current, evaluated : Set.insert model.evaluated current } - - neighbours = moveFn current + neighbours = move_fn(current) - newNeighbours = Set.difference neighbours modelPopped.evaluated + new_neighbours = Set.difference(neighbours, model_popped.evaluated) - modelWithNeighbours = { modelPopped & openSet : Set.union modelPopped.openSet newNeighbours } + model_with_neighbours = { model_popped & open_set: Set.union(model_popped.open_set, new_neighbours) } - modelWithCosts = Set.walk newNeighbours modelWithNeighbours (\md, nb -> updateCost current nb md) + model_with_costs = Set.walk(new_neighbours, model_with_neighbours, \md, nb -> update_cost(current, nb, md)) - astar costFn moveFn goal modelWithCosts + astar(cost_fn, move_fn, goal, model_with_costs) diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep1.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep1.roc index bbe8e6fdb79..a8367d04469 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep1.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep1.roc @@ -1,6 +1,4 @@ -interface Dep1 - exposes [three, str, Unit, Identity, one, two] - imports [] +module [three, str, Unit, Identity, one, two] import Dep3 exposing [foo] diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep2.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep2.roc index b4a7820afb5..39e07f4e4bf 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep2.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep2.roc @@ -1,6 +1,4 @@ -interface Dep2 - exposes [one, two, blah] - imports [] +module [one, two, blah] import Dep3 exposing [foo, bar] diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep3.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep3.roc index 40c3bb29947..32d50cc0253 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep3.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Dep3.roc @@ -1,6 +1,4 @@ -interface Dep3 - exposes [one, two, foo, bar] - imports [] +module [one, two, foo, bar] one = 1 diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ExposedUsedOutsideScope.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ExposedUsedOutsideScope.roc index 1578b7e0b17..5d2260de15f 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ExposedUsedOutsideScope.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ExposedUsedOutsideScope.roc @@ -1,4 +1,4 @@ -interface ExposedUsedOutsideScope exposes [good, bad] imports [] +module [good, bad] good = import Dep2 exposing [two] diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportAlias.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportAlias.roc index 59227f131b5..0e20144ee4d 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportAlias.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportAlias.roc @@ -1,6 +1,4 @@ -interface ImportAlias - exposes [unit] - imports [] +module [unit] import Dep1 diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportInsideDef.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportInsideDef.roc index 3e433a22161..4054f4f6fd2 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportInsideDef.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportInsideDef.roc @@ -1,10 +1,10 @@ -interface ImportInsideDef exposes [dep1Str, dep2TwoDobuled] imports [] +module [dep1_str, dep2_two_dobuled] -dep1Str = +dep1_str = import Dep1 Dep1.str -dep2TwoDobuled = +dep2_two_dobuled = 2 * ( import Dep2 exposing [two] diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportUsedOutsideScope.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportUsedOutsideScope.roc index 29b620eb50b..7a2ec397e35 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportUsedOutsideScope.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ImportUsedOutsideScope.roc @@ -1,4 +1,4 @@ -interface ImportUsedOutsideScope exposes [good, bad] imports [] +module [good, bad] good = import Dep2 diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFile.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFile.roc index 7dd415732c5..49d4a955726 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFile.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFile.roc @@ -1,6 +1,4 @@ -interface IngestedFile - exposes [str, nested] - imports [] +module [str, nested] import "IngestedFile.roc" as foo : Str diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFileBytes.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFileBytes.roc index be7f46aa654..e4857cd1e49 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFileBytes.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/IngestedFileBytes.roc @@ -1,7 +1,5 @@ -interface IngestedFileBytes - exposes [str] - imports [] +module [str] import "IngestedFileBytes.roc" as foo : List U8 -str = Str.fromUtf8 foo |> Result.withDefault "" +str = Str.from_utf8(foo) |> Result.with_default("") diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ManualAttr.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ManualAttr.roc index 5e51189cbb6..ae05664515e 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ManualAttr.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/ManualAttr.roc @@ -1,18 +1,16 @@ -interface ManualAttr - exposes [] - imports [] +module [] # manually replicates the Attr wrapping that uniqueness inference uses, to try and find out why they are different # It is very important that there are no signatures here! elm uses an optimization that leads to less copying when # signatures are given. map = - unAttr = \Attr _ foobar -> foobar + un_attr = \Attr(_, foobar) -> foobar - r = Attr unknown "bar" + r = Attr(unknown, "bar") - s = Attr unknown2 { left : Attr Shared "foo" } + s = Attr(unknown2, { left: Attr(Shared, "foo") }) when True is - _ -> { y : r } - _ -> { y : (unAttr s).left } + _ -> { y: r } + _ -> { y: (un_attr(s)).left } diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/OneDep.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/OneDep.roc index 379abf8a5b3..0b83da65675 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/OneDep.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/OneDep.roc @@ -1,6 +1,4 @@ -interface OneDep - exposes [str] - imports [] +module [str] import Dep3 exposing [foo] diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Primary.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Primary.roc index b952c5102d9..f47f972474c 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Primary.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Primary.roc @@ -1,6 +1,4 @@ -interface Primary - exposes [blah2, blah3, str, alwaysThree, identity, z, w, succeed, withDefault, yay] - imports [] +module [blah2, blah3, str, always_three, identity, z, w, succeed, with_default, yay] import Dep1 import Dep2 @@ -12,24 +10,24 @@ blah3 = bar str = Dep1.str -alwaysThree = \_ -> Dep1.three +always_three = \_ -> Dep1.three identity = \a -> a -z = identity (alwaysThree {}) +z = identity(always_three({})) w : Dep1.Identity {} -w = Identity {} +w = Identity({}) succeed : a -> Dep1.Identity a -succeed = \x -> Identity x +succeed = \x -> Identity(x) -withDefault = Res.withDefault +with_default = Res.with_default yay : Res.Res {} err yay = - ok = Ok "foo" + ok = Ok("foo") f = \_ -> {} - Res.map ok f + Res.map(ok, f) diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Quicksort.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Quicksort.roc index 344bc0151c8..4c9fb6e14b5 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Quicksort.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Quicksort.roc @@ -1,51 +1,46 @@ -interface Quicksort - exposes [swap, partition, quicksort] - imports [] +module [swap, partition, quicksort] quicksort : List (Num a), U64, U64 -> List (Num a) quicksort = \list, low, high -> - when partition low high list is - Pair partitionIndex partitioned -> + when partition(low, high, list) is + Pair(partition_index, partitioned) -> partitioned - |> quicksort low (partitionIndex - 1) - |> quicksort (partitionIndex + 1) high - + |> quicksort(low, (partition_index - 1)) + |> quicksort((partition_index + 1), high) swap : U64, U64, List a -> List a swap = \i, j, list -> - when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + when Pair(List.get(list, i), List.get(list, j)) is + Pair(Ok(at_i), Ok(at_j)) -> list - |> List.set i atJ - |> List.set j atI + |> List.set(i, at_j) + |> List.set(j, at_i) _ -> [] - partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] -partition = \low, high, initialList -> - when List.get initialList high is - Ok pivot -> - when partitionHelp (low - 1) low initialList high pivot is - Pair newI newList -> - Pair (newI + 1) (swap (newI + 1) high newList) - - Err _ -> - Pair (low - 1) initialList - - -partitionHelp : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] -partitionHelp = \i, j, list, high, pivot -> +partition = \low, high, initial_list -> + when List.get(initial_list, high) is + Ok(pivot) -> + when partition_help((low - 1), low, initial_list, high, pivot) is + Pair(new_i, new_list) -> + Pair((new_i + 1), swap((new_i + 1), high, new_list)) + + Err(_) -> + Pair((low - 1), initial_list) + +partition_help : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] +partition_help = \i, j, list, high, pivot -> if j < high then - when List.get list j is - Ok value -> + when List.get(list, j) is + Ok(value) -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap (i + 1) j list) high pivot + partition_help((i + 1), (j + 1), swap((i + 1), j, list), high, pivot) else - partitionHelp i (j + 1) list high pivot + partition_help(i, (j + 1), list, high, pivot) - Err _ -> - Pair i list + Err(_) -> + Pair(i, list) else - Pair i list + Pair(i, list) diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Records.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Records.roc index d2eda2ba5f1..a6104a31691 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Records.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Records.roc @@ -1,8 +1,6 @@ -interface Records - exposes [intVal] - imports [] +module [int_val] -intVal = +int_val = foo = \{ x } -> x - foo { x: 5 } + foo({ x: 5 }) diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Res.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Res.roc index 3e81bbddca2..42afa2e7a93 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Res.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/Res.roc @@ -1,31 +1,29 @@ -interface Res - exposes [Res, withDefault, map, listMap, andThen, ConsList] - imports [] +module [Res, with_default, map, list_map, and_then, ConsList] Res ok err : [Ok ok, Err err] ConsList a : [Cons a (ConsList a), Nil] -listMap : ConsList a, (a -> b) -> ConsList b -listMap = \list, f -> - when list is - Nil -> Nil - Cons x xs -> Cons (f x) (listMap xs f) +list_map : ConsList a, (a -> b) -> ConsList b +list_map = \list, f -> + when list is + Nil -> Nil + Cons(x, xs) -> Cons(f(x), list_map(xs, f)) map : Res a err, (a -> b) -> Res b err map = \result, transform -> when result is - Ok ok -> Ok (transform ok) - Err err -> Err err + Ok(ok) -> Ok(transform(ok)) + Err(err) -> Err(err) -withDefault : Res a err, a -> a -withDefault = \result, default -> +with_default : Res a err, a -> a +with_default = \result, default -> when result is - Ok ok -> ok - Err _ -> default + Ok(ok) -> ok + Err(_) -> default -andThen : Res a err, (a -> Res b err) -> Res b err -andThen = \result, transform -> +and_then : Res a err, (a -> Res b err) -> Res b err +and_then = \result, transform -> when result is - Ok ok -> transform ok - Err err -> Err err + Ok(ok) -> transform(ok) + Err(err) -> Err(err) diff --git a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/WithBuiltins.roc b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/WithBuiltins.roc index 35e619fed39..1078412555e 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/WithBuiltins.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/module_with_deps/WithBuiltins.roc @@ -1,22 +1,20 @@ -interface WithBuiltins - exposes [floatTest, divisionFn, divisionTest, intTest, constantNum, fromDep2, divDep1ByDep2] - imports [] +module [float_test, division_fn, division_test, int_test, constant_num, from_dep2, div_dep1_by_dep2] import Dep1 import Dep2 -floatTest = Num.maxF64 +float_test = Num.max_f64 -divisionFn = Num.div +division_fn = Num.div x = 5.0 -divisionTest = Num.maxF64 / x +division_test = Num.max_f64 / x -intTest = Num.maxI64 +int_test = Num.max_i64 -constantNum = 5 +constant_num = 5 -fromDep2 = Dep2.two +from_dep2 = Dep2.two -divDep1ByDep2 = Dep1.three / fromDep2 +div_dep1_by_dep2 = Dep1.three / from_dep2 diff --git a/crates/compiler/load_internal/tests/fixtures/build/no_deps/Docs.roc b/crates/compiler/load_internal/tests/fixtures/build/no_deps/Docs.roc index 16d04881a59..a547ebdc91a 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/no_deps/Docs.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/no_deps/Docs.roc @@ -1,7 +1,5 @@ ## An interface for docs tests -interface Docs - exposes [makeUser, getNameExposed] - imports [] +module [make_user, get_name_exposed] ## This is a user User : { name : Str } @@ -9,12 +7,12 @@ User : { name : Str } ## Makes a user ## ## Takes a name Str. -makeUser : Str -> User -makeUser = \name -> +make_user : Str -> User +make_user = \name -> { name } ## Gets the user's name -getName = \a -> a.name +get_name = \a -> a.name -getNameExposed = getName +get_name_exposed = get_name diff --git a/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingDep.roc b/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingDep.roc index 4de52ec2dbe..7bb2ab8fa68 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingDep.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingDep.roc @@ -1,6 +1,4 @@ -interface MissingDep - exposes [unit] - imports [] +module [unit] import ThisFileIsMissing diff --git a/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingIngestedFile.roc b/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingIngestedFile.roc index 8af91a88468..131ce37106e 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingIngestedFile.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/no_deps/MissingIngestedFile.roc @@ -1,6 +1,4 @@ -interface MissingIngestedFile - exposes [unit] - imports [] +module [unit] import "ThisFileIsMissing" as data : List U8 diff --git a/crates/compiler/load_internal/tests/fixtures/build/no_deps/Principal.roc b/crates/compiler/load_internal/tests/fixtures/build/no_deps/Principal.roc index 1391a998a8d..989b9a964eb 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/no_deps/Principal.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/no_deps/Principal.roc @@ -1,7 +1,5 @@ -interface Principal - exposes [identity, intVal] - imports [] +module [identity, int_val] identity = \a -> a -intVal = identity "hi" +int_val = identity("hi") diff --git a/crates/compiler/load_internal/tests/fixtures/build/no_deps/Unit.roc b/crates/compiler/load_internal/tests/fixtures/build/no_deps/Unit.roc index c2ae5c833f7..ac931aa8672 100644 --- a/crates/compiler/load_internal/tests/fixtures/build/no_deps/Unit.roc +++ b/crates/compiler/load_internal/tests/fixtures/build/no_deps/Unit.roc @@ -1,6 +1,4 @@ -interface Unit - exposes [unit] - imports [] +module [unit] Unit : [Unit] diff --git a/crates/compiler/load_internal/tests/test_load.rs b/crates/compiler/load_internal/tests/test_load.rs index d623f0854f2..deef83c1879 100644 --- a/crates/compiler/load_internal/tests/test_load.rs +++ b/crates/compiler/load_internal/tests/test_load.rs @@ -512,11 +512,11 @@ fn load_docs() { (None, Some("An interface for docs tests\n")), (Some("User"), Some("This is a user\n")), ( - Some("makeUser"), + Some("make_user"), Some("Makes a user\n\nTakes a name Str.\n"), ), - (Some("getName"), Some("Gets the user's name\n")), - (Some("getNameExposed"), None), + (Some("get_name"), Some("Gets the user's name\n")), + (Some("get_name_exposed"), None), ] .into_iter() .map(|(ident_str_opt, doc_str_opt)| { @@ -553,8 +553,8 @@ fn import_inside_def() { expect_types( loaded_module, hashmap! { - "dep1Str" => "Str", - "dep2TwoDobuled" => "Frac *", + "dep1_str" => "Str", + "dep2_two_dobuled" => "Frac *", }, ); } @@ -585,15 +585,15 @@ fn test_load_and_typecheck() { expect_types( loaded_module, hashmap! { - "floatTest" => "F64", - "divisionFn" => "Frac a, Frac a -> Frac a", + "float_test" => "F64", + "division_fn" => "Frac a, Frac a -> Frac a", "x" => "Frac *", - "divisionTest" => "F64", - "intTest" => "I64", - "constantNum" => "Num *", - "divisionTest" => "F64", - "divDep1ByDep2" => "Frac a", - "fromDep2" => "Frac a", + "division_test" => "F64", + "int_test" => "I64", + "constant_num" => "Num *", + "division_test" => "F64", + "div_dep1_by_dep2" => "Frac a", + "from_dep2" => "Frac a", }, ); } @@ -608,7 +608,7 @@ fn iface_quicksort() { hashmap! { "swap" => "U64, U64, List a -> List a", "partition" => "U64, U64, List (Num a) -> [Pair U64 (List (Num a))]", - "partitionHelp" => "U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))]", + "partition_help" => "U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))]", "quicksort" => "List (Num a), U64, U64 -> List (Num a)", }, ); @@ -622,11 +622,11 @@ fn load_astar() { expect_types( loaded_module, hashmap! { - "findPath" => "{ costFunction : position, position -> F64, end : position, moveFunction : position -> Set position, start : position } -> Result (List position) [KeyNotFound] where position implements Hash & Eq", - "initialModel" => "position -> Model position where position implements Hash & Eq", - "reconstructPath" => "Dict position position, position -> List position where position implements Hash & Eq", - "updateCost" => "position, position, Model position -> Model position where position implements Hash & Eq", - "cheapestOpen" => "(position -> F64), Model position -> Result position [KeyNotFound] where position implements Hash & Eq", + "find_path" => "{ cost_function : position, position -> F64, end : position, move_function : position -> Set position, start : position } -> Result (List position) [KeyNotFound] where position implements Hash & Eq", + "initial_model" => "position -> Model position where position implements Hash & Eq", + "reconstruct_path" => "Dict position position, position -> List position where position implements Hash & Eq", + "update_cost" => "position, position, Model position -> Model position where position implements Hash & Eq", + "cheapest_open" => "(position -> F64), Model position -> Result position [KeyNotFound] where position implements Hash & Eq", "astar" => "(position, position -> F64), (position -> Set position), position, Model position -> [Err [KeyNotFound], Ok (List position)] where position implements Hash & Eq", }, ); @@ -640,7 +640,7 @@ fn load_principal_types() { expect_types( loaded_module, hashmap! { - "intVal" => "Str", + "int_val" => "Str", "identity" => "a -> a", }, ); @@ -657,13 +657,13 @@ fn iface_dep_types() { "blah2" => "Frac *", "blah3" => "Str", "str" => "Str", - "alwaysThree" => "* -> Frac *", + "always_three" => "* -> Frac *", "identity" => "a -> a", "z" => "Frac *", "w" => "Dep1.Identity {}", "succeed" => "a -> Dep1.Identity a", "yay" => "Res.Res {} err", - "withDefault" => "Res.Res a err, a -> a", + "with_default" => "Res.Res a err, a -> a", }, ); } @@ -679,13 +679,13 @@ fn app_dep_types() { "blah2" => "Frac *", "blah3" => "Str", "str" => "Str", - "alwaysThree" => "* -> Frac *", + "always_three" => "* -> Frac *", "identity" => "a -> a", "z" => "Frac *", "w" => "Dep1.Identity {}", "succeed" => "a -> Dep1.Identity a", "yay" => "Res.Res {} err", - "withDefault" => "Res.Res a err, a -> a", + "with_default" => "Res.Res a err, a -> a", }, ); } @@ -855,10 +855,10 @@ fn platform_exposes_main_return_by_pointer_issue() { exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] - mainForHost : { content: Str, other: Str } - mainForHost = main + main_for_host : { content: Str, other: Str } + main_for_host = main "# ), ), @@ -897,13 +897,13 @@ fn opaque_wrapped_unwrapped_outside_defining_module() { "Main.roc", indoc!( r" - module [twenty, readAge] + module [twenty, read_age] import Age exposing [Age] twenty = @Age 20 - readAge = \@Age n -> n + read_age = \@Age n -> n " ), ), @@ -933,8 +933,8 @@ fn opaque_wrapped_unwrapped_outside_defining_module() { The unwrapped opaque type Age referenced here: - 7│ readAge = \@Age n -> n - ^^^^ + 7│ read_age = \@Age n -> n + ^^^^ is imported from another module: @@ -997,27 +997,27 @@ fn unused_imports() { "Main.roc", indoc!( r#" - module [usedModule, unusedModule, unusedExposed, usingThreeValue, unusedWithAlias] + module [used_module, unused_module, unused_exposed, using_three_value, unused_with_alias] import Dep1 import Dep3 exposing [Three] - usedModule = + used_module = import Dep2 Dep2.two - unusedModule = + unused_module = import Dep2 2 - unusedExposed = + unused_exposed = import Dep2 exposing [two] 2 - usingThreeValue = + using_three_value = Dep3.three - unusedWithAlias = + unused_with_alias = import Dep2 as D2 2 "# @@ -1191,13 +1191,13 @@ fn explicit_builtin_type_import() { r#" interface Main exposes [main] imports [] - import Dict exposing [Dict, isEmpty] + import Dict exposing [Dict, is_empty] - myDict : Dict * * - myDict = + my_dict : Dict * * + my_dict = Dict.empty {} - main = isEmpty myDict + main = is_empty my_dict "# ), )]; @@ -1210,7 +1210,7 @@ fn explicit_builtin_type_import() { `Dict.Dict` was imported here: - 3│ import Dict exposing [Dict, isEmpty] + 3│ import Dict exposing [Dict, is_empty] ^^^^ All types from builtins are automatically exposed, so you can remove @@ -1490,9 +1490,9 @@ fn alias_using_builtin_name() { "BoolExtra.roc", indoc!( r" - interface BoolExtra exposes [toNum] imports [] + interface BoolExtra exposes [to_num] imports [] - toNum = \value -> + to_num = \value -> if value then 1 else 0 " ), @@ -1839,7 +1839,7 @@ fn module_params_missing() { r#" module { key, exp } -> [url] - url = "example.com/$(key)?exp=$(Num.toStr exp)" + url = "example.com/$(key)?exp=$(Num.to_str exp)" "# ), ), @@ -1896,10 +1896,10 @@ fn issue_2863_module_type_does_not_exist() { exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] - mainForHost : Str - mainForHost = main + main_for_host : Str + main_for_host = main "# ), ), @@ -1957,12 +1957,12 @@ fn import_builtin_in_platform_and_check_app() { exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] import Str - mainForHost : Str - mainForHost = main + main_for_host : Str + main_for_host = main "# ), ), diff --git a/crates/compiler/module/src/symbol.rs b/crates/compiler/module/src/symbol.rs index 8be0f15cdd4..4965eaf75e6 100644 --- a/crates/compiler/module/src/symbol.rs +++ b/crates/compiler/module/src/symbol.rs @@ -1195,45 +1195,45 @@ define_builtins! { 12 NUM_F64: "F64" exposed_type=true // the Num.F64 type alias 13 NUM_F32: "F32" exposed_type=true // the Num.F32 type alias 14 NUM_FLOATINGPOINT: "FloatingPoint" exposed_type=true // Float : Num FloatingPoint - 15 NUM_MAX_F32: "maxF32" - 16 NUM_MIN_F32: "minF32" + 15 NUM_MAX_F32: "max_f32" + 16 NUM_MIN_F32: "min_f32" 17 NUM_ABS: "abs" 18 NUM_NEG: "neg" 19 NUM_ADD: "add" 20 NUM_SUB: "sub" 21 NUM_MUL: "mul" - 22 NUM_LT: "isLt" - 23 NUM_LTE: "isLte" - 24 NUM_GT: "isGt" - 25 NUM_GTE: "isGte" - 26 NUM_TO_FRAC: "toFrac" + 22 NUM_LT: "is_lt" + 23 NUM_LTE: "is_lte" + 24 NUM_GT: "is_gt" + 25 NUM_GTE: "is_gte" + 26 NUM_TO_FRAC: "to_frac" 27 NUM_SIN: "sin" 28 NUM_COS: "cos" 29 NUM_TAN: "tan" - 30 NUM_IS_ZERO: "isZero" - 31 NUM_IS_EVEN: "isEven" - 32 NUM_IS_ODD: "isOdd" - 33 NUM_IS_POSITIVE: "isPositive" - 34 NUM_IS_NEGATIVE: "isNegative" + 30 NUM_IS_ZERO: "is_zero" + 31 NUM_IS_EVEN: "is_even" + 32 NUM_IS_ODD: "is_odd" + 33 NUM_IS_POSITIVE: "is_positive" + 34 NUM_IS_NEGATIVE: "is_negative" 35 NUM_REM: "rem" - 36 NUM_REM_CHECKED: "remChecked" + 36 NUM_REM_CHECKED: "rem_checked" 37 NUM_DIV_FRAC: "div" - 38 NUM_DIV_FRAC_CHECKED: "divChecked" - 39 NUM_DIV_TRUNC: "divTrunc" - 40 NUM_DIV_TRUNC_CHECKED: "divTruncChecked" + 38 NUM_DIV_FRAC_CHECKED: "div_checked" + 39 NUM_DIV_TRUNC: "div_trunc" + 40 NUM_DIV_TRUNC_CHECKED: "div_trunc_checked" 41 NUM_SQRT: "sqrt" - 42 NUM_SQRT_CHECKED: "sqrtChecked" + 42 NUM_SQRT_CHECKED: "sqrt_checked" 43 NUM_LOG: "log" - 44 NUM_LOG_CHECKED: "logChecked" + 44 NUM_LOG_CHECKED: "log_checked" 45 NUM_ROUND: "round" 46 NUM_COMPARE: "compare" 47 NUM_POW: "pow" 48 NUM_CEILING: "ceiling" - 49 NUM_POW_INT: "powInt" + 49 NUM_POW_INT: "pow_int" 50 NUM_FLOOR: "floor" - 51 NUM_ADD_WRAP: "addWrap" - 52 NUM_ADD_CHECKED: "addChecked" - 53 NUM_ADD_SATURATED: "addSaturated" + 51 NUM_ADD_WRAP: "add_wrap" + 52 NUM_ADD_CHECKED: "add_checked" + 53 NUM_ADD_SATURATED: "add_saturated" 54 NUM_ATAN: "atan" 55 NUM_ACOS: "acos" 56 NUM_ASIN: "asin" @@ -1249,107 +1249,107 @@ define_builtins! { 66 NUM_UNSIGNED8: "Unsigned8" exposed_type=true 67 NUM_BINARY64: "Binary64" exposed_type=true 68 NUM_BINARY32: "Binary32" exposed_type=true - 69 NUM_BITWISE_AND: "bitwiseAnd" - 70 NUM_BITWISE_XOR: "bitwiseXor" - 71 NUM_BITWISE_OR: "bitwiseOr" - 72 NUM_SHIFT_LEFT: "shiftLeftBy" - 73 NUM_SHIFT_RIGHT: "shiftRightBy" - 74 NUM_SHIFT_RIGHT_ZERO_FILL: "shiftRightZfBy" - 75 NUM_SUB_WRAP: "subWrap" - 76 NUM_SUB_CHECKED: "subChecked" - 77 NUM_SUB_SATURATED: "subSaturated" - 78 NUM_MUL_WRAP: "mulWrap" - 79 NUM_MUL_CHECKED: "mulChecked" - 80 NUM_MUL_SATURATED: "mulSaturated" + 69 NUM_BITWISE_AND: "bitwise_and" + 70 NUM_BITWISE_XOR: "bitwise_xor" + 71 NUM_BITWISE_OR: "bitwise_or" + 72 NUM_SHIFT_LEFT: "shift_left_by" + 73 NUM_SHIFT_RIGHT: "shift_right_by" + 74 NUM_SHIFT_RIGHT_ZERO_FILL: "shift_right_zf_by" + 75 NUM_SUB_WRAP: "sub_wrap" + 76 NUM_SUB_CHECKED: "sub_checked" + 77 NUM_SUB_SATURATED: "sub_saturated" + 78 NUM_MUL_WRAP: "mul_wrap" + 79 NUM_MUL_CHECKED: "mul_checked" + 80 NUM_MUL_SATURATED: "mul_saturated" 81 NUM_INT: "Int" exposed_type=true 82 NUM_FRAC: "Frac" exposed_type=true 83 NUM_E: "e" 84 NUM_PI: "pi" 85 NUM_TAU: "tau" - 86 NUM_IS_MULTIPLE_OF: "isMultipleOf" + 86 NUM_IS_MULTIPLE_OF: "is_multiple_of" 87 NUM_DECIMAL: "Decimal" exposed_type=true 88 NUM_DEC: "Dec" exposed_type=true // the Num.Dectype alias - 89 NUM_COUNT_ONE_BITS: "countOneBits" - 90 NUM_ABS_DIFF: "absDiff" - 91 NUM_IS_NAN: "isNaN" - 92 NUM_IS_INFINITE: "isInfinite" - 93 NUM_IS_FINITE: "isFinite" - 94 NUM_COUNT_LEADING_ZERO_BITS: "countLeadingZeroBits" - 95 NUM_COUNT_TRAILING_ZERO_BITS: "countTrailingZeroBits" - 96 NUM_TO_STR: "toStr" - 97 NUM_MIN_I8: "minI8" - 98 NUM_MAX_I8: "maxI8" - 99 NUM_MIN_U8: "minU8" - 100 NUM_MAX_U8: "maxU8" - 101 NUM_MIN_I16: "minI16" - 102 NUM_MAX_I16: "maxI16" - 103 NUM_MIN_U16: "minU16" - 104 NUM_MAX_U16: "maxU16" - 105 NUM_MIN_I32: "minI32" - 106 NUM_MAX_I32: "maxI32" - 107 NUM_MIN_U32: "minU32" - 108 NUM_MAX_U32: "maxU32" - 109 NUM_MIN_I64: "minI64" - 110 NUM_MAX_I64: "maxI64" - 111 NUM_MIN_U64: "minU64" - 112 NUM_MAX_U64: "maxU64" - 113 NUM_MIN_I128: "minI128" - 114 NUM_MAX_I128: "maxI128" - 115 NUM_MIN_U128: "minU128" - 116 NUM_MAX_U128: "maxU128" - 117 NUM_TO_I8: "toI8" - 118 NUM_TO_I8_CHECKED: "toI8Checked" - 119 NUM_TO_I16: "toI16" - 120 NUM_TO_I16_CHECKED: "toI16Checked" - 121 NUM_TO_I32: "toI32" - 122 NUM_TO_I32_CHECKED: "toI32Checked" - 123 NUM_TO_I64: "toI64" - 124 NUM_TO_I64_CHECKED: "toI64Checked" - 125 NUM_TO_I128: "toI128" - 126 NUM_TO_I128_CHECKED: "toI128Checked" - 127 NUM_TO_U8: "toU8" - 128 NUM_TO_U8_CHECKED: "toU8Checked" - 129 NUM_TO_U16: "toU16" - 130 NUM_TO_U16_CHECKED: "toU16Checked" - 131 NUM_TO_U32: "toU32" - 132 NUM_TO_U32_CHECKED: "toU32Checked" - 133 NUM_TO_U64: "toU64" - 134 NUM_TO_U64_CHECKED: "toU64Checked" - 135 NUM_TO_U128: "toU128" - 136 NUM_TO_U128_CHECKED: "toU128Checked" - 137 NUM_DIV_CEIL: "divCeil" - 138 NUM_DIV_CEIL_CHECKED: "divCeilChecked" - 139 NUM_TO_F32: "toF32" - 140 NUM_TO_F32_CHECKED: "toF32Checked" - 141 NUM_TO_F64: "toF64" - 142 NUM_TO_F64_CHECKED: "toF64Checked" - 143 NUM_MAX_F64: "maxF64" - 144 NUM_MIN_F64: "minF64" - 145 NUM_ADD_CHECKED_LOWLEVEL: "addCheckedLowlevel" - 146 NUM_SUB_CHECKED_LOWLEVEL: "subCheckedLowlevel" - 147 NUM_MUL_CHECKED_LOWLEVEL: "mulCheckedLowlevel" + 89 NUM_COUNT_ONE_BITS: "count_one_bits" + 90 NUM_ABS_DIFF: "abs_diff" + 91 NUM_IS_NAN: "is_nan" + 92 NUM_IS_INFINITE: "is_infinite" + 93 NUM_IS_FINITE: "is_finite" + 94 NUM_COUNT_LEADING_ZERO_BITS: "count_leading_zero_bits" + 95 NUM_COUNT_TRAILING_ZERO_BITS: "count_trailing_zero_bits" + 96 NUM_TO_STR: "to_str" + 97 NUM_MIN_I8: "min_i8" + 98 NUM_MAX_I8: "max_i8" + 99 NUM_MIN_U8: "min_u8" + 100 NUM_MAX_U8: "max_u8" + 101 NUM_MIN_I16: "min_i16" + 102 NUM_MAX_I16: "max_i16" + 103 NUM_MIN_U16: "min_u16" + 104 NUM_MAX_U16: "max_u16" + 105 NUM_MIN_I32: "min_i32" + 106 NUM_MAX_I32: "max_i32" + 107 NUM_MIN_U32: "min_u32" + 108 NUM_MAX_U32: "max_u32" + 109 NUM_MIN_I64: "min_i64" + 110 NUM_MAX_I64: "max_i64" + 111 NUM_MIN_U64: "min_u64" + 112 NUM_MAX_U64: "max_u64" + 113 NUM_MIN_I128: "min_i128" + 114 NUM_MAX_I128: "max_i128" + 115 NUM_MIN_U128: "min_u128" + 116 NUM_MAX_U128: "max_u128" + 117 NUM_TO_I8: "to_i8" + 118 NUM_TO_I8_CHECKED: "to_i8_checked" + 119 NUM_TO_I16: "to_i16" + 120 NUM_TO_I16_CHECKED: "to_i16_checked" + 121 NUM_TO_I32: "to_i32" + 122 NUM_TO_I32_CHECKED: "to_i32_checked" + 123 NUM_TO_I64: "to_i64" + 124 NUM_TO_I64_CHECKED: "to_i64_checked" + 125 NUM_TO_I128: "to_i128" + 126 NUM_TO_I128_CHECKED: "to_i128_checked" + 127 NUM_TO_U8: "to_u8" + 128 NUM_TO_U8_CHECKED: "to_u8_checked" + 129 NUM_TO_U16: "to_u16" + 130 NUM_TO_U16_CHECKED: "to_u16_checked" + 131 NUM_TO_U32: "to_u32" + 132 NUM_TO_U32_CHECKED: "to_u32_checked" + 133 NUM_TO_U64: "to_u64" + 134 NUM_TO_U64_CHECKED: "to_u64_checked" + 135 NUM_TO_U128: "to_u128" + 136 NUM_TO_U128_CHECKED: "to_u128_checked" + 137 NUM_DIV_CEIL: "div_ceil" + 138 NUM_DIV_CEIL_CHECKED: "div_ceil_checked" + 139 NUM_TO_F32: "to_f32" + 140 NUM_TO_F32_CHECKED: "to_f32_checked" + 141 NUM_TO_F64: "to_f64" + 142 NUM_TO_F64_CHECKED: "to_f64_checked" + 143 NUM_MAX_F64: "max_f64" + 144 NUM_MIN_F64: "min_f64" + 145 NUM_ADD_CHECKED_LOWLEVEL: "add_checked_lowlevel" + 146 NUM_SUB_CHECKED_LOWLEVEL: "sub_checked_lowlevel" + 147 NUM_MUL_CHECKED_LOWLEVEL: "mul_checked_lowlevel" 148 NUM_MIN: "min" 149 NUM_MAX: "max" - 150 NUM_BITWISE_NOT: "bitwiseNot" - 151 NUM_INT_CAST: "intCast" - 152 NUM_IS_APPROX_EQ: "isApproxEq" - 153 NUM_BYTES_TO_U16_LOWLEVEL: "bytesToU16Lowlevel" - 154 NUM_BYTES_TO_U32_LOWLEVEL: "bytesToU32Lowlevel" - 155 NUM_BYTES_TO_U64_LOWLEVEL: "bytesToU64Lowlevel" - 156 NUM_BYTES_TO_U128_LOWLEVEL: "bytesToU128Lowlevel" - 157 NUM_DIV_TRUNC_UNCHECKED: "divTruncUnchecked" // traps on division by zero - 158 NUM_REM_UNCHECKED: "remUnchecked" // traps on division by zero - 159 NUM_WITHOUT_DECIMAL_POINT: "withoutDecimalPoint" - 160 NUM_WITH_DECIMAL_POINT: "withDecimalPoint" - 161 NUM_F32_TO_PARTS: "f32ToParts" - 162 NUM_F64_TO_PARTS: "f64ToParts" - 163 NUM_F32_FROM_PARTS: "f32FromParts" - 164 NUM_F64_FROM_PARTS: "f64FromParts" - 165 NUM_NAN_F32: "nanF32" - 166 NUM_NAN_F64: "nanF64" - 167 NUM_INFINITY_F32: "infinityF32" - 168 NUM_INFINITY_F64: "infinityF64" - 169 NUM_FROM_BOOL: "fromBool" + 150 NUM_BITWISE_NOT: "bitwise_not" + 151 NUM_INT_CAST: "int_cast" + 152 NUM_IS_APPROX_EQ: "is_approx_eq" + 153 NUM_BYTES_TO_U16_LOWLEVEL: "bytes_to_u16_owlevel" + 154 NUM_BYTES_TO_U32_LOWLEVEL: "bytes_to_u32_lowlevel" + 155 NUM_BYTES_TO_U64_LOWLEVEL: "bytes_to_u64_lowlevel" + 156 NUM_BYTES_TO_U128_LOWLEVEL: "bytes_to_u128_lowlevel" + 157 NUM_DIV_TRUNC_UNCHECKED: "div_trunc_unchecked" // traps on division by zero + 158 NUM_REM_UNCHECKED: "rem_unchecked" // traps on division by zero + 159 NUM_WITHOUT_DECIMAL_POINT: "without_decimal_point" + 160 NUM_WITH_DECIMAL_POINT: "with_decimal_point" + 161 NUM_F32_TO_PARTS: "f32_to_parts" + 162 NUM_F64_TO_PARTS: "f64_to_parts" + 163 NUM_F32_FROM_PARTS: "f32_from_parts" + 164 NUM_F64_FROM_PARTS: "f64_from_parts" + 165 NUM_NAN_F32: "nan_f32" + 166 NUM_NAN_F64: "nan_f64" + 167 NUM_INFINITY_F32: "infinity_f32" + 168 NUM_INFINITY_F64: "infinity_f64" + 169 NUM_FROM_BOOL: "from_bool" } 4 BOOL: "Bool" => { 0 BOOL_BOOL: "Bool" exposed_type=true // the Bool.Bool type alias @@ -1359,75 +1359,75 @@ define_builtins! { 4 BOOL_OR: "or" 5 BOOL_NOT: "not" 6 BOOL_XOR: "xor" - 7 BOOL_NEQ: "isNotEq" + 7 BOOL_NEQ: "is_not_eq" 8 BOOL_EQ: "Eq" exposed_type=true - 9 BOOL_IS_EQ: "isEq" - 10 BOOL_IS_EQ_IMPL: "boolIsEq" - unexposed 11 BOOL_STRUCTURAL_EQ: "structuralEq" - unexposed 12 BOOL_STRUCTURAL_NOT_EQ: "structuralNotEq" + 9 BOOL_IS_EQ: "is_eq" + 10 BOOL_IS_EQ_IMPL: "bool_is_eq" + unexposed 11 BOOL_STRUCTURAL_EQ: "structural_eq" + unexposed 12 BOOL_STRUCTURAL_NOT_EQ: "structural_not_eq" } 5 STR: "Str" => { 0 STR_STR: "Str" exposed_apply_type=true // the Str.Str type alias - 1 STR_IS_EMPTY: "isEmpty" + 1 STR_IS_EMPTY: "is_empty" 2 STR_APPEND: "#append" // unused 3 STR_CONCAT: "concat" - 4 STR_JOIN_WITH: "joinWith" - 5 STR_SPLIT_ON: "splitOn" - 6 STR_WITH_PREFIX: "withPrefix" - 7 STR_STARTS_WITH: "startsWith" - 8 STR_ENDS_WITH: "endsWith" - 9 STR_FROM_UTF8: "fromUtf8" + 4 STR_JOIN_WITH: "join_with" + 5 STR_SPLIT_ON: "split_on" + 6 STR_WITH_PREFIX: "with_prefix" + 7 STR_STARTS_WITH: "starts_with" + 8 STR_ENDS_WITH: "ends_with" + 9 STR_FROM_UTF8: "from_utf8" 10 STR_UT8_PROBLEM: "Utf8Problem" // the Utf8Problem type alias 11 STR_UT8_BYTE_PROBLEM: "Utf8ByteProblem" // the Utf8ByteProblem type alias - 12 STR_TO_UTF8: "toUtf8" - 13 STR_WALK_UTF8: "walkUtf8" + 12 STR_TO_UTF8: "to_utf8" + 13 STR_WALK_UTF8: "walk_utf8" 14 STR_ALIAS_ANALYSIS_STATIC: "#aliasAnalysisStatic" // string with the static lifetime - 15 STR_FROM_UTF8_RANGE: "fromUtf8Range" + 15 STR_FROM_UTF8_RANGE: "from_utf8_range" 16 STR_REPEAT: "repeat" 17 STR_TRIM: "trim" - 18 STR_TRIM_START: "trimStart" - 19 STR_TRIM_END: "trimEnd" - 20 STR_WITH_CAPACITY: "withCapacity" - 21 STR_TO_F64: "toF64" - 22 STR_TO_F32: "toF32" - 23 STR_TO_DEC: "toDec" - 24 STR_TO_U128: "toU128" - 25 STR_TO_I128: "toI128" - 26 STR_TO_U64: "toU64" - 27 STR_TO_I64: "toI64" - 28 STR_TO_U32: "toU32" - 29 STR_TO_I32: "toI32" - 30 STR_TO_U16: "toU16" - 31 STR_TO_I16: "toI16" - 32 STR_TO_U8: "toU8" - 33 STR_TO_I8: "toI8" + 18 STR_TRIM_START: "trim_start" + 19 STR_TRIM_END: "trim_end" + 20 STR_WITH_CAPACITY: "with_capacity" + 21 STR_TO_F64: "to_f64" + 22 STR_TO_F32: "to_f32" + 23 STR_TO_DEC: "to_dec" + 24 STR_TO_U128: "to_u128" + 25 STR_TO_I128: "to_i128" + 26 STR_TO_U64: "to_u64" + 27 STR_TO_I64: "to_i64" + 28 STR_TO_U32: "to_u32" + 29 STR_TO_I32: "to_i32" + 30 STR_TO_U16: "to_u16" + 31 STR_TO_I16: "to_i16" + 32 STR_TO_U8: "to_u8" + 33 STR_TO_I8: "to_i8" 34 STR_CONTAINS: "contains" - 35 STR_GET_UNSAFE: "getUnsafe" - 36 STR_COUNT_UTF8_BYTES: "countUtf8Bytes" - 37 STR_SUBSTRING_UNSAFE: "substringUnsafe" - 38 STR_SPLIT_FIRST: "splitFirst" - 39 STR_SPLIT_LAST: "splitLast" - 40 STR_WALK_UTF8_WITH_INDEX: "walkUtf8WithIndex" + 35 STR_GET_UNSAFE: "get_unsafe" + 36 STR_COUNT_UTF8_BYTES: "count_utf8_bytes" + 37 STR_SUBSTRING_UNSAFE: "substring_unsafe" + 38 STR_SPLIT_FIRST: "split_first" + 39 STR_SPLIT_LAST: "split_last" + 40 STR_WALK_UTF8_WITH_INDEX: "walk_utf8_with_index" 41 STR_RESERVE: "reserve" - 42 STR_TO_NUM: "strToNum" - 43 STR_FROM_UTF8_LOWLEVEL: "fromUtf8Lowlevel" + 42 STR_TO_NUM: "str_to_num" + 43 STR_FROM_UTF8_LOWLEVEL: "from_utf8_lowlevel" 44 STR_CAPACITY: "capacity" - 45 STR_REPLACE_EACH: "replaceEach" - 46 STR_REPLACE_FIRST: "replaceFirst" - 47 STR_REPLACE_LAST: "replaceLast" - 48 STR_RELEASE_EXCESS_CAPACITY: "releaseExcessCapacity" - 49 STR_DROP_PREFIX: "dropPrefix" - 50 STR_DROP_SUFFIX: "dropSuffix" + 45 STR_REPLACE_EACH: "replace_each" + 46 STR_REPLACE_FIRST: "replace_first" + 47 STR_REPLACE_LAST: "replace_last" + 48 STR_RELEASE_EXCESS_CAPACITY: "release_excess_capacity" + 49 STR_DROP_PREFIX: "drop_prefix" + 50 STR_DROP_SUFFIX: "drop_suffix" } 6 LIST: "List" => { 0 LIST_LIST: "List" exposed_apply_type=true // the List.List type alias - 1 LIST_IS_EMPTY: "isEmpty" + 1 LIST_IS_EMPTY: "is_empty" 2 LIST_GET: "get" 3 LIST_SET: "set" 4 LIST_APPEND: "append" 5 LIST_MAP: "map" 6 LIST_LEN_U64: "len" - 7 LIST_WALK_BACKWARDS: "walkBackwards" + 7 LIST_WALK_BACKWARDS: "walk_backwards" 8 LIST_CONCAT: "concat" 9 LIST_FIRST: "first" 10 LIST_SINGLE: "single" @@ -1435,99 +1435,99 @@ define_builtins! { 12 LIST_REVERSE: "reverse" 13 LIST_PREPEND: "prepend" 14 LIST_JOIN: "join" - 15 LIST_KEEP_IF: "keepIf" + 15 LIST_KEEP_IF: "keep_if" 16 LIST_CONTAINS: "contains" 17 LIST_SUM: "sum" 18 LIST_WALK: "walk" 19 LIST_LAST: "last" - 20 LIST_KEEP_OKS: "keepOks" - 21 LIST_KEEP_ERRS: "keepErrs" - 22 LIST_MAP_WITH_INDEX: "mapWithIndex" + 20 LIST_KEEP_OKS: "keep_oks" + 21 LIST_KEEP_ERRS: "keep_errs" + 22 LIST_MAP_WITH_INDEX: "map_with_index" 23 LIST_MAP2: "map2" 24 LIST_MAP3: "map3" 25 LIST_PRODUCT: "product" - 26 LIST_WALK_UNTIL: "walkUntil" + 26 LIST_WALK_UNTIL: "walk_until" 27 LIST_RANGE: "range" - 28 LIST_SORT_WITH: "sortWith" - 29 LIST_CHUNKS_OF: "chunksOf" + 28 LIST_SORT_WITH: "sort_with" + 29 LIST_CHUNKS_OF: "chunks_of" 30 LIST_SWAP: "swap" - 31 LIST_DROP_AT: "dropAt" - 32 LIST_DROP_LAST: "dropLast" + 31 LIST_DROP_AT: "drop_at" + 32 LIST_DROP_LAST: "drop_last" 33 LIST_MIN: "min" - 34 LIST_MIN_LT: "#minlt" + 34 LIST_MIN_LT: "#min_lt" 35 LIST_MAX: "max" - 36 LIST_MAX_GT: "#maxGt" + 36 LIST_MAX_GT: "#max_gt" 37 LIST_MAP4: "map4" - 38 LIST_DROP_FIRST: "dropFirst" - 39 LIST_JOIN_MAP: "joinMap" - 40 LIST_JOIN_MAP_CONCAT: "#joinMapConcat" + 38 LIST_DROP_FIRST: "drop_first" + 39 LIST_JOIN_MAP: "join_map" + 40 LIST_JOIN_MAP_CONCAT: "#join_map_concat" 41 LIST_ANY: "any" - 42 LIST_TAKE_FIRST: "takeFirst" - 43 LIST_TAKE_LAST: "takeLast" - 44 LIST_FIND_FIRST: "findFirst" - 45 LIST_FIND_LAST: "findLast" - 46 LIST_FIND_FIRST_INDEX: "findFirstIndex" - 47 LIST_FIND_LAST_INDEX: "findLastIndex" + 42 LIST_TAKE_FIRST: "take_first" + 43 LIST_TAKE_LAST: "take_last" + 44 LIST_FIND_FIRST: "find_first" + 45 LIST_FIND_LAST: "find_last" + 46 LIST_FIND_FIRST_INDEX: "find_first_index" + 47 LIST_FIND_LAST_INDEX: "find_last_index" 48 LIST_FIND_RESULT: "#find_result" // symbol used in the definition of List.findFirst 49 LIST_SUBLIST: "sublist" 50 LIST_INTERSPERSE: "intersperse" - 51 LIST_INTERSPERSE_CLOS: "#intersperseClos" - 52 LIST_SPLIT_AT: "splitAt" - 53 LIST_SPLIT_FIRST: "splitFirst" - 54 LIST_SPLIT_LAST: "splitLast" - 55 LIST_SPLIT_CLOS: "#splitClos" + 51 LIST_INTERSPERSE_CLOS: "#intersperse_clos" + 52 LIST_SPLIT_AT: "split_at" + 53 LIST_SPLIT_FIRST: "split_first" + 54 LIST_SPLIT_LAST: "split_last" + 55 LIST_SPLIT_CLOS: "#split_clos" 56 LIST_ALL: "all" - 57 LIST_DROP_IF: "dropIf" - 58 LIST_DROP_IF_PREDICATE: "#dropIfPred" - 59 LIST_SORT_ASC: "sortAsc" - 60 LIST_SORT_DESC: "sortDesc" - 61 LIST_SORT_DESC_COMPARE: "#sortDescCompare" - 62 LIST_STARTS_WITH: "startsWith" - 63 LIST_ENDS_WITH: "endsWith" + 57 LIST_DROP_IF: "drop_if" + 58 LIST_DROP_IF_PREDICATE: "#drop_if_pred" + 59 LIST_SORT_ASC: "sort_asc" + 60 LIST_SORT_DESC: "sort_desc" + 61 LIST_SORT_DESC_COMPARE: "#sort_desc_compare" + 62 LIST_STARTS_WITH: "starts_with" + 63 LIST_ENDS_WITH: "ends_with" 64 LIST_REPLACE: "replace" - 65 LIST_IS_UNIQUE: "#isUnique" - 66 LIST_GET_UNSAFE: "getUnsafe" - 67 LIST_REPLACE_UNSAFE: "replaceUnsafe" - 68 LIST_WITH_CAPACITY: "withCapacity" + 65 LIST_IS_UNIQUE: "#is_unique" + 66 LIST_GET_UNSAFE: "get_unsafe" + 67 LIST_REPLACE_UNSAFE: "replace_unsafe" + 68 LIST_WITH_CAPACITY: "with_capacity" 69 LIST_UNREACHABLE: "unreachable" 70 LIST_RESERVE: "reserve" - 71 LIST_APPEND_UNSAFE: "appendUnsafe" - 72 LIST_SUBLIST_LOWLEVEL: "sublistLowlevel" + 71 LIST_APPEND_UNSAFE: "append_unsafe" + 72 LIST_SUBLIST_LOWLEVEL: "sublist_lowlevel" 73 LIST_CAPACITY: "capacity" - 74 LIST_MAP_TRY: "mapTry" - 75 LIST_WALK_TRY: "walkTry" - 76 LIST_WALK_BACKWARDS_UNTIL: "walkBackwardsUntil" - 77 LIST_COUNT_IF: "countIf" - 78 LIST_WALK_FROM: "walkFrom" - 79 LIST_WALK_FROM_UNTIL: "walkFromUntil" - 80 LIST_ITER_HELP: "iterHelp" - 81 LIST_RELEASE_EXCESS_CAPACITY: "releaseExcessCapacity" + 74 LIST_MAP_TRY: "map_try" + 75 LIST_WALK_TRY: "walk_try" + 76 LIST_WALK_BACKWARDS_UNTIL: "walk_backwards_until" + 77 LIST_COUNT_IF: "count_if" + 78 LIST_WALK_FROM: "walk_from" + 79 LIST_WALK_FROM_UNTIL: "walk_from_until" + 80 LIST_ITER_HELP: "iter_help" + 81 LIST_RELEASE_EXCESS_CAPACITY: "release_excess_capacity" 82 LIST_UPDATE: "update" - 83 LIST_WALK_WITH_INDEX: "walkWithIndex" - 84 LIST_APPEND_IF_OK: "appendIfOk" - 85 LIST_PREPEND_IF_OK: "prependIfOk" - 86 LIST_WALK_WITH_INDEX_UNTIL: "walkWithIndexUntil" + 83 LIST_WALK_WITH_INDEX: "walk_with_index" + 84 LIST_APPEND_IF_OK: "append_if_ok" + 85 LIST_PREPEND_IF_OK: "prepend_if_ok" + 86 LIST_WALK_WITH_INDEX_UNTIL: "walk_with_index_until" 87 LIST_CLONE: "clone" - 88 LIST_LEN_USIZE: "lenUsize" - 89 LIST_CONCAT_UTF8: "concatUtf8" - 90 LIST_FOR_EACH_FX: "forEach!" - 91 LIST_FOR_EACH_TRY_FX: "forEachTry!" + 88 LIST_LEN_USIZE: "len_usize" + 89 LIST_CONCAT_UTF8: "concat_utf8" + 90 LIST_FOR_EACH_FX: "for_each!" + 91 LIST_FOR_EACH_TRY_FX: "for_each_try!" 92 LIST_WALK_FX: "walk!" - 93 LIST_SPLIT_ON: "splitOn" - 94 LIST_SPLIT_ON_LIST: "splitOnList" + 93 LIST_SPLIT_ON: "split_on" + 94 LIST_SPLIT_ON_LIST: "split_on_list" } 7 RESULT: "Result" => { 0 RESULT_RESULT: "Result" exposed_type=true // the Result.Result type alias - 1 RESULT_IS_ERR: "isErr" - 2 RESULT_ON_ERR: "onErr" + 1 RESULT_IS_ERR: "is_err" + 2 RESULT_ON_ERR: "on_err" 3 RESULT_MAP: "map" - 4 RESULT_MAP_ERR: "mapErr" - 5 RESULT_WITH_DEFAULT: "withDefault" + 4 RESULT_MAP_ERR: "map_err" + 5 RESULT_WITH_DEFAULT: "with_default" 6 RESULT_TRY: "try" - 7 RESULT_IS_OK: "isOk" - 8 RESULT_MAP_BOTH: "mapBoth" + 7 RESULT_IS_OK: "is_ok" + 8 RESULT_MAP_BOTH: "map_both" 9 RESULT_MAP_TWO: "map2" - 10 RESULT_ON_ERR_FX: "onErr!" + 10 RESULT_ON_ERR_FX: "on_err!" } 8 DICT: "Dict" => { 0 DICT_DICT: "Dict" exposed_type=true // the Dict.Dict type alias @@ -1542,29 +1542,29 @@ define_builtins! { 9 DICT_REMOVE: "remove" 10 DICT_WALK: "walk" - 11 DICT_WALK_UNTIL: "walkUntil" - 12 DICT_FROM_LIST: "fromList" - 13 DICT_TO_LIST: "toList" + 11 DICT_WALK_UNTIL: "walk_until" + 12 DICT_FROM_LIST: "from_list" + 13 DICT_TO_LIST: "to_list" 14 DICT_KEYS: "keys" 15 DICT_VALUES: "values" - 16 DICT_INSERT_ALL: "insertAll" // union - 17 DICT_KEEP_SHARED: "keepShared" // intersection - 18 DICT_REMOVE_ALL: "removeAll" // difference + 16 DICT_INSERT_ALL: "insert_all" // union + 17 DICT_KEEP_SHARED: "keep_shared" // intersection + 18 DICT_REMOVE_ALL: "remove_all" // difference - 19 DICT_WITH_CAPACITY: "withCapacity" + 19 DICT_WITH_CAPACITY: "with_capacity" 20 DICT_CAPACITY: "capacity" 21 DICT_UPDATE: "update" - 22 DICT_LIST_GET_UNSAFE: "listGetUnsafe" - 23 DICT_PSEUDO_SEED: "pseudoSeed" - 24 DICT_IS_EMPTY: "isEmpty" + 22 DICT_LIST_GET_UNSAFE: "list_get_unsafe" + 23 DICT_PSEUDO_SEED: "pseudo_seed" + 24 DICT_IS_EMPTY: "is_empty" 25 DICT_MAP: "map" - 26 DICT_JOINMAP: "joinMap" - 27 DICT_KEEP_IF: "keepIf" - 28 DICT_DROP_IF: "dropIf" + 26 DICT_JOINMAP: "join_map" + 27 DICT_KEEP_IF: "keep_if" + 28 DICT_DROP_IF: "drop_if" 29 DICT_RESERVE: "reserve" - 30 DICT_RELEASE_EXCESS_CAPACITY: "releaseExcessCapacity" + 30 DICT_RELEASE_EXCESS_CAPACITY: "release_excess_capacity" } 9 SET: "Set" => { 0 SET_SET: "Set" exposed_type=true // the Set.Set type alias @@ -1576,22 +1576,22 @@ define_builtins! { 6 SET_UNION: "union" 7 SET_DIFFERENCE: "difference" 8 SET_INTERSECTION: "intersection" - 9 SET_TO_LIST: "toList" - 10 SET_FROM_LIST: "fromList" + 9 SET_TO_LIST: "to_list" + 10 SET_FROM_LIST: "from_list" 11 SET_WALK: "walk" - 12 SET_WALK_UNTIL: "walkUntil" + 12 SET_WALK_UNTIL: "walk_until" 13 SET_WALK_USER_FUNCTION: "#walk_user_function" 14 SET_CONTAINS: "contains" - 15 SET_TO_DICT: "toDict" + 15 SET_TO_DICT: "to_dict" 16 SET_CAPACITY: "capacity" - 17 SET_IS_EMPTY: "isEmpty" + 17 SET_IS_EMPTY: "is_empty" 18 SET_MAP: "map" - 19 SET_JOIN_MAP: "joinMap" - 20 SET_KEEP_IF: "keepIf" - 21 SET_DROP_IF: "dropIf" - 22 SET_WITH_CAPACITY: "withCapacity" + 19 SET_JOIN_MAP: "join_map" + 20 SET_KEEP_IF: "keep_if" + 21 SET_DROP_IF: "drop_if" + 22 SET_WITH_CAPACITY: "with_capacity" 23 SET_RESERVE: "reserve" - 24 SET_RELEASE_EXCESS_CAPACITY: "releaseExcessCapacity" + 24 SET_RELEASE_EXCESS_CAPACITY: "release_excess_capacity" } 10 BOX: "Box" => { 0 BOX_BOX_TYPE: "Box" exposed_apply_type=true // the Box.Box opaque type @@ -1601,7 +1601,7 @@ define_builtins! { 11 ENCODE: "Encode" => { 0 ENCODE_ENCODER: "Encoder" exposed_type=true 1 ENCODE_ENCODING: "Encoding" exposed_type=true - 2 ENCODE_TO_ENCODER: "toEncoder" + 2 ENCODE_TO_ENCODER: "to_encoder" 3 ENCODE_ENCODERFORMATTING: "EncoderFormatting" exposed_type=true 4 ENCODE_U8: "u8" 5 ENCODE_U16: "u16" @@ -1623,9 +1623,9 @@ define_builtins! { 21 ENCODE_TUPLE: "tuple" 22 ENCODE_TAG: "tag" 23 ENCODE_CUSTOM: "custom" - 24 ENCODE_APPEND_WITH: "appendWith" + 24 ENCODE_APPEND_WITH: "append_with" 25 ENCODE_APPEND: "append" - 26 ENCODE_TO_BYTES: "toBytes" + 26 ENCODE_TO_BYTES: "to_bytes" } 12 DECODE: "Decode" => { 0 DECODE_DECODE_ERROR: "DecodeError" exposed_type=true @@ -1653,33 +1653,33 @@ define_builtins! { 22 DECODE_RECORD: "record" 23 DECODE_TUPLE: "tuple" 24 DECODE_CUSTOM: "custom" - 25 DECODE_DECODE_WITH: "decodeWith" - 26 DECODE_FROM_BYTES_PARTIAL: "fromBytesPartial" - 27 DECODE_FROM_BYTES: "fromBytes" - 28 DECODE_MAP_RESULT: "mapResult" + 25 DECODE_DECODE_WITH: "decode_with" + 26 DECODE_FROM_BYTES_PARTIAL: "from_bytes_partial" + 27 DECODE_FROM_BYTES: "from_bytes" + 28 DECODE_MAP_RESULT: "map_result" } 13 HASH: "Hash" => { 0 HASH_HASH_ABILITY: "Hash" exposed_type=true 1 HASH_HASH: "hash" 2 HASH_HASHER: "Hasher" exposed_type=true - 3 HASH_ADD_BYTES: "addBytes" - 4 HASH_ADD_U8: "addU8" - 5 HASH_ADD_U16: "addU16" - 6 HASH_ADD_U32: "addU32" - 7 HASH_ADD_U64: "addU64" - 8 HASH_ADD_U128: "addU128" - 9 HASH_HASH_BOOL: "hashBool" - 10 HASH_HASH_I8: "hashI8" - 11 HASH_HASH_I16: "hashI16" - 12 HASH_HASH_I32: "hashI32" - 13 HASH_HASH_I64: "hashI64" - 14 HASH_HASH_I128: "hashI128" - 15 HASH_HASH_UNORDERED: "hashUnordered" - 16 I128_OF_DEC: "i128OfDec" - 17 HASH_HASH_DEC: "hashDec" + 3 HASH_ADD_BYTES: "add_bytes" + 4 HASH_ADD_U8: "add_u8" + 5 HASH_ADD_U16: "add_u16" + 6 HASH_ADD_U32: "add_u32" + 7 HASH_ADD_U64: "add_u64" + 8 HASH_ADD_U128: "add_u128" + 9 HASH_HASH_BOOL: "hash_bool" + 10 HASH_HASH_I8: "hash_i8" + 11 HASH_HASH_I16: "hash_i16" + 12 HASH_HASH_I32: "hash_i32" + 13 HASH_HASH_I64: "hash_i64" + 14 HASH_HASH_I128: "hash_i128" + 15 HASH_HASH_UNORDERED: "hash_unordered" + 16 I128_OF_DEC: "i128_of_dec" + 17 HASH_HASH_DEC: "hash_dec" 18 HASH_COMPLETE: "complete" - 19 HASH_HASH_STR_BYTES: "hashStrBytes" - 20 HASH_HASH_LIST: "hashList" + 19 HASH_HASH_STR_BYTES: "hash_str_bytes" + 20 HASH_HASH_LIST: "hash_list" } 14 INSPECT: "Inspect" => { 0 INSPECT_INSPECT_ABILITY: "Inspect" exposed_type=true @@ -1714,8 +1714,8 @@ define_builtins! { 29 INSPECT_DEC: "dec" 30 INSPECT_CUSTOM: "custom" 31 INSPECT_APPLY: "apply" - 32 INSPECT_TO_INSPECTOR: "toInspector" - 33 INSPECT_TO_STR: "toStr" + 32 INSPECT_TO_INSPECTOR: "to_inspector" + 33 INSPECT_TO_STR: "to_str" } 15 TASK: "Task" => { 0 TASK_TASK: "Task" exposed_type=true // the Task.Task opaque type @@ -1725,14 +1725,14 @@ define_builtins! { 4 TASK_ERR: "err" 5 TASK_ATTEMPT: "attempt" 6 TASK_AWAIT: "await" - 7 TASK_ON_ERR: "onErr" + 7 TASK_ON_ERR: "on_err" 8 TASK_MAP: "map" - 9 TASK_MAP_ERR: "mapErr" - 10 TASK_FROM_RESULT: "fromResult" + 9 TASK_MAP_ERR: "map_err" + 10 TASK_FROM_RESULT: "from_result" 11 TASK_BATCH: "batch" 12 TASK_COMBINE: "combine" 13 TASK_SEQUENCE: "sequence" - 14 TASK_FOR_EACH: "forEach" + 14 TASK_FOR_EACH: "for_each" 15 TASK_RESULT: "result" } diff --git a/crates/compiler/mono/src/ir.rs b/crates/compiler/mono/src/ir.rs index be065c998fd..01c19f9a008 100644 --- a/crates/compiler/mono/src/ir.rs +++ b/crates/compiler/mono/src/ir.rs @@ -3222,7 +3222,7 @@ fn specialize_external_help<'a>( } if procs.host_exposed_symbols.contains(&proc.name.name()) { - // layouts that are (transitively) used in the type of `mainForHost`. + // layouts that are (transitively) used in the type of `main_for_host`. let mut host_exposed_layouts: Vec<_> = top_level .arguments .iter() diff --git a/crates/compiler/mono/src/layout.rs b/crates/compiler/mono/src/layout.rs index 941395edce6..f24c42d83d8 100644 --- a/crates/compiler/mono/src/layout.rs +++ b/crates/compiler/mono/src/layout.rs @@ -1290,7 +1290,7 @@ enum NichePriv<'a> { /// ```roc /// capture : _ -> ({} -> Str) /// capture = \val -> -/// forcer = \{} -> Num.toStr val +/// forcer = \{} -> Num.to_str val /// forcer /// /// fun = \x -> diff --git a/crates/compiler/parse/src/expr.rs b/crates/compiler/parse/src/expr.rs index d5bb6182167..24f0cbfa5fb 100644 --- a/crates/compiler/parse/src/expr.rs +++ b/crates/compiler/parse/src/expr.rs @@ -208,7 +208,7 @@ fn loc_term_or_closure<'a>( )), loc_term(), ) - .trace("term_or_underscore") + .trace("term_or_closure") } fn loc_term<'a>() -> impl Parser<'a, Loc>, EExpr<'a>> { @@ -718,7 +718,19 @@ fn parse_stmt_operator_chain<'a>( .. }, state, - )) if matches!(expr_state.expr.value, Expr::Tag(..)) => { + )) if matches!( + expr_state.expr.value, + Expr::Tag(..) + | Expr::Apply( + Loc { + region: _, + value: Expr::Tag(..) + }, + &[], + _ + ) + ) => + { return parse_ability_def(expr_state, state, arena, implements, call_min_indent) .map(|(td, s)| (MadeProgress, Stmt::TypeDef(td), s)); } @@ -1991,6 +2003,14 @@ fn parse_ability_def<'a>( let name = expr_state.expr.map_owned(|e| match e { Expr::Tag(name) => name, + Expr::Apply( + Loc { + region: _, + value: Expr::Tag(name), + }, + &[], + _, + ) => name, _ => unreachable!(), }); diff --git a/crates/compiler/solve/src/ability.rs b/crates/compiler/solve/src/ability.rs index b9156ee97e3..728e1afca0b 100644 --- a/crates/compiler/solve/src/ability.rs +++ b/crates/compiler/solve/src/ability.rs @@ -1383,7 +1383,7 @@ impl DerivableVisitor for DeriveEq { #[inline(always)] fn visit_ranged_number(_var: Variable, _range: NumericRange) -> Result<(), NotDerivable> { // Ranged numbers are allowed, because they are always possibly ints - floats can not have - // `isEq` derived, but if something were to be a float, we'd see it exactly as a float. + // `is_eq` derived, but if something were to be a float, we'd see it exactly as a float. Ok(()) } } diff --git a/crates/compiler/solve/tests/solve_expr.rs b/crates/compiler/solve/tests/solve_expr.rs index 015508f0312..8c6e02c6e53 100644 --- a/crates/compiler/solve/tests/solve_expr.rs +++ b/crates/compiler/solve/tests/solve_expr.rs @@ -138,7 +138,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Str.startsWith + Str.starts_with " ), "Str, Str -> Bool", @@ -150,7 +150,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.toStr + Num.to_str " ), "Num * -> Str", @@ -162,7 +162,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Str.fromUtf8 + Str.from_utf8 " ), "List U8 -> Result Str [BadUtf8 { index : U64, problem : Utf8ByteProblem }]", @@ -174,7 +174,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - List.concatUtf8 + List.concat_utf8 " ), "List U8, Str -> List U8", @@ -322,9 +322,9 @@ mod solve_expr { infer_eq( indoc!( r#" - whatItIs = "great" + what_it_is = "great" - "type inference is $(whatItIs)!" + "type inference is $(what_it_is)!" "# ), "Str", @@ -336,11 +336,11 @@ mod solve_expr { infer_eq( indoc!( r#" - whatItIs = "great" + what_it_is = "great" - str = "type inference is $(whatItIs)!" + str = "type inference is $(what_it_is)!" - whatItIs + what_it_is "# ), "Str", @@ -352,14 +352,14 @@ mod solve_expr { infer_eq( indoc!( r#" - rec = { whatItIs: "great" } + rec = { what_it_is: "great" } - str = "type inference is $(rec.whatItIs)!" + str = "type inference is $(rec.what_it_is)!" rec "# ), - "{ whatItIs : Str }", + "{ what_it_is : Str }", ); } @@ -690,9 +690,9 @@ mod solve_expr { infer_eq( indoc!( r#" - alwaysFive = \_ -> 5 + always_five = \_ -> 5 - alwaysFive "stuff" + always_five "stuff" "# ), "Num *", @@ -766,9 +766,9 @@ mod solve_expr { indoc!( r#" always = \val -> (\_ -> val) - alwaysFoo = always "foo" + always_foo = always "foo" - alwaysFoo 42 + always_foo 42 "# ), "Str", @@ -1005,7 +1005,7 @@ mod solve_expr { // #[test] // fn no_higher_ranked_types() { - // // This should error because it can't type of alwaysFive + // // This should error because it can't type of always_five // infer_eq( // indoc!( // r#" @@ -1021,9 +1021,9 @@ mod solve_expr { infer_eq( indoc!( r#" - alwaysFive = \_ -> 5 + always_five = \_ -> 5 - [alwaysFive "foo", alwaysFive []] + [always_five "foo", always_five []] "# ), "List (Num *)", @@ -1215,9 +1215,9 @@ mod solve_expr { # technically, an empty record can be destructured thunk = \{} -> 42 - xEmpty = if thunk {} == 42 then { x: {} } else { x: {} } + x_empty = if thunk {} == 42 then { x: {} } else { x: {} } - when xEmpty is + when x_empty is { x: {} } -> {} " ), @@ -2250,15 +2250,15 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - numIdentity : Num.Num a -> Num.Num a - numIdentity = \x -> x + num_identity : Num.Num a -> Num.Num a + num_identity = \x -> x - y = numIdentity 3.14 + y = num_identity 3.14 - { numIdentity, x : numIdentity 42, y } + { num_identity, x : num_identity 42, y } " ), - "{ numIdentity : Num a -> Num a, x : Num *, y : Frac * }", + "{ num_identity : Num a -> Num a, x : Num *, y : Frac * }", ); } @@ -2319,12 +2319,12 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - toBit = \bool -> + to_bit = \bool -> when bool is True -> 1 False -> 0 - toBit + to_bit " ), "[False, True] -> Num *", @@ -2355,12 +2355,12 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - fromBit = \int -> + from_bit = \int -> when int is 0 -> False _ -> True - fromBit + from_bit " ), "Num * -> [False, True]", @@ -2424,15 +2424,15 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - alwaysThreePointZero = \_ -> 3.0 + always_three_point_zero = \_ -> 3.0 answer = 42 identity = \a -> a - threePointZero = identity (alwaysThreePointZero {}) + three_point_zero = identity (always_three_point_zero {}) - threePointZero + three_point_zero " ), "Frac *", @@ -2741,14 +2741,14 @@ mod solve_expr { r" ConsList a : [Cons a (ConsList a), Nil] - toEmpty : ConsList a -> ConsList a - toEmpty = \_ -> + to_empty : ConsList a -> ConsList a + to_empty = \_ -> result : ConsList a result = Nil result - toEmpty + to_empty " ), "ConsList a -> ConsList a", @@ -2762,14 +2762,14 @@ mod solve_expr { r" ConsList a : [Cons a (ConsList a), Nil] - toEmpty : ConsList a -> ConsList a - toEmpty = \_ -> + to_empty : ConsList a -> ConsList a + to_empty = \_ -> result : ConsList _ # TODO to enable using `a` we need scoped variables result = Nil - toEmpty result + to_empty result - toEmpty + to_empty " ), "ConsList a -> ConsList a", @@ -2785,15 +2785,15 @@ mod solve_expr { ConsList a : [Cons a (ConsList a), Nil] - toEmpty : ConsList a -> ConsList a - toEmpty = \_ -> + to_empty : ConsList a -> ConsList a + to_empty = \_ -> result : ConsList _ # TODO to enable using `a` we need scoped variables result = Nil - toEmpty result + to_empty result main = - toEmpty + to_empty "# ), "ConsList a -> ConsList a", @@ -2961,8 +2961,8 @@ mod solve_expr { Cons a listb -> when listb is Nil -> Nil - Cons b newLista -> - Cons a (Cons (f b) (toAs f newLista)) + Cons b new_lista -> + Cons a (Cons (f b) (toAs f new_lista)) toAs " @@ -3001,8 +3001,8 @@ mod solve_expr { Cons a listb -> when listb is Nil -> Nil - Cons b newLista -> - Cons a (Cons (f b) (toAs f newLista)) + Cons b new_lista -> + Cons a (Cons (f b) (toAs f new_lista)) toAs " @@ -3029,13 +3029,13 @@ mod solve_expr { indoc!( r" partition : U64, U64, List (Int a) -> [Pair U64 (List (Int a))] - partition = \low, high, initialList -> - when List.get initialList high is + partition = \low, high, initial_list -> + when List.get initial_list high is Ok _ -> Pair 0 [] Err _ -> - Pair (low - 1) initialList + Pair (low - 1) initial_list partition " @@ -3052,17 +3052,17 @@ mod solve_expr { swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set i atJ - |> List.set j atI + |> List.set i at_j + |> List.set j at_i _ -> list partition : U64, U64, List (Int a) -> [Pair U64 (List (Int a))] - partition = \low, high, initialList -> - when List.get initialList high is + partition = \low, high, initial_list -> + when List.get initial_list high is Ok pivot -> go = \i, j, list -> if j < high then @@ -3078,12 +3078,12 @@ mod solve_expr { else Pair i list - when go (low - 1) low initialList is - Pair newI newList -> - Pair (newI + 1) (swap (newI + 1) high newList) + when go (low - 1) low initial_list is + Pair new_i new_list -> + Pair (new_i + 1) (swap (new_i + 1) high new_list) Err _ -> - Pair (low - 1) initialList + Pair (low - 1) initial_list partition " @@ -3097,11 +3097,11 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - idList : List a -> List a - idList = \list -> list + id_list : List a -> List a + id_list = \list -> list foo : List I64 -> List I64 - foo = \initialList -> idList initialList + foo = \initial_list -> id_list initial_list foo @@ -3167,7 +3167,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.toFrac + Num.to_frac " ), "Num * -> Frac a", @@ -3227,7 +3227,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.divChecked + Num.div_checked " ), "Frac a, Frac a -> Result (Frac a) [DivByZero]", @@ -3239,7 +3239,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.divCeil + Num.div_ceil " ), "Int a, Int a -> Int a", @@ -3251,7 +3251,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.divCeilChecked + Num.div_ceil_checked " ), "Int a, Int a -> Result (Int a) [DivByZero]", @@ -3263,7 +3263,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.divTrunc + Num.div_trunc " ), "Int a, Int a -> Int a", @@ -3275,7 +3275,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.divTruncChecked + Num.div_trunc_checked " ), "Int a, Int a -> Result (Int a) [DivByZero]", @@ -3299,7 +3299,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.minI128 + Num.min_i128 " ), "I128", @@ -3311,7 +3311,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.maxI128 + Num.max_i128 " ), "I128", @@ -3323,7 +3323,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.minI64 + Num.min_i64 " ), "I64", @@ -3335,7 +3335,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.maxI64 + Num.max_i64 " ), "I64", @@ -3347,7 +3347,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.minU64 + Num.min_u64 " ), "U64", @@ -3359,7 +3359,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.maxU64 + Num.max_u64 " ), "U64", @@ -3371,7 +3371,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.minI32 + Num.min_i32 " ), "I32", @@ -3383,7 +3383,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.maxI32 + Num.max_i32 " ), "I32", @@ -3395,7 +3395,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.minU32 + Num.min_u32 " ), "U32", @@ -3407,7 +3407,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Num.maxU32 + Num.max_u32 " ), "U32", @@ -3419,16 +3419,16 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - reconstructPath : Dict position position, position -> List position where position implements Hash & Eq - reconstructPath = \cameFrom, goal -> - when Dict.get cameFrom goal is + reconstruct_path : Dict position position, position -> List position where position implements Hash & Eq + reconstruct_path = \came_from, goal -> + when Dict.get came_from goal is Err KeyNotFound -> [] Ok next -> - List.append (reconstructPath cameFrom next) goal + List.append (reconstruct_path came_from next) goal - reconstructPath + reconstruct_path " ), "Dict position position, position -> List position where position implements Hash & Eq", @@ -3464,25 +3464,25 @@ mod solve_expr { boom = \_ -> boom {} - Model position : { openSet : Set position } + Model position : { open_set : Set position } - cheapestOpen : Model position -> Result position [KeyNotFound] where position implements Hash & Eq - cheapestOpen = \model -> + cheapest_open : Model position -> Result position [KeyNotFound] where position implements Hash & Eq + cheapest_open = \model -> - folder = \resSmallestSoFar, position -> - when resSmallestSoFar is - Err _ -> resSmallestSoFar - Ok smallestSoFar -> - if position == smallestSoFar.position then resSmallestSoFar + folder = \res_smallest_so_far, position -> + when res_smallest_so_far is + Err _ -> res_smallest_so_far + Ok smallest_so_far -> + if position == smallest_so_far.position then res_smallest_so_far - else - Ok { position, cost: 0.0 } + else + Ok { position, cost: 0.0 } - Set.walk model.openSet (Ok { position: boom {}, cost: 0.0 }) folder + Set.walk model.open_set (Ok { position: boom {}, cost: 0.0 }) folder |> Result.map (\x -> x.position) astar : Model position -> Result position [KeyNotFound] where position implements Hash & Eq - astar = \model -> cheapestOpen model + astar = \model -> cheapest_open model main = astar @@ -3522,7 +3522,7 @@ mod solve_expr { f : cm, cm -> Order f = \_, _ -> LT - sortWith f xs + sort_with f xs sortBy : (x -> cmpl), ConsList x -> ConsList x sortBy = @@ -3530,12 +3530,12 @@ mod solve_expr { cmp : x, x -> Order cmp = \_, _ -> LT - sortWith cmp list + sort_with cmp list always = \x, _ -> x - sortWith : (foobar, foobar -> Order), ConsList foobar -> ConsList foobar - sortWith = + sort_with : (foobar, foobar -> Order), ConsList foobar -> ConsList foobar + sort_with = \_, list -> f = \arg -> g arg @@ -3549,7 +3549,7 @@ mod solve_expr { Order : [LT, GT, EQ] ConsList a : [Nil, Cons a (ConsList a)] - { x: sortWith, y: sort, z: sortBy } + { x: sort_with, y: sort, z: sortBy } " ), "{ x : (foobar, foobar -> Order), ConsList foobar -> ConsList foobar, y : ConsList cm -> ConsList cm, z : (x -> cmpl), ConsList x -> ConsList x }" @@ -3639,9 +3639,9 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - negatePoint : { x : I64, y : I64, z ? Num c } -> { x : I64, y : I64, z : Num c } + negate_point : { x : I64, y : I64, z ? Num c } -> { x : I64, y : I64, z : Num c } - negatePoint { x: 1, y: 2 } + negate_point { x: 1, y: 2 } " ), "{ x : I64, y : I64, z : Num c }", @@ -3653,10 +3653,10 @@ mod solve_expr { infer_eq_without_problem( indoc!( r#" - negatePoint : { x : I64, y : I64, z ? Num c }r -> { x : I64, y : I64, z : Num c }r + negate_point : { x : I64, y : I64, z ? Num c }r -> { x : I64, y : I64, z : Num c }r - a = negatePoint { x: 1, y: 2 } - b = negatePoint { x: 1, y: 2, blah : "hi" } + a = negate_point { x: 1, y: 2 } + b = negate_point { x: 1, y: 2, blah : "hi" } { a, b } "# @@ -3670,9 +3670,9 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - negatePoint : { x : Num a, y : Num b, z ? c } -> { x : Num a, y : Num b, z : c } + negate_point : { x : Num a, y : Num b, z ? c } -> { x : Num a, y : Num b, z : c } - negatePoint { x: 1, y: 2.1, z: 0x3 } + negate_point { x: 1, y: 2.1, z: 0x3 } " ), "{ x : Num *, y : Frac *, z : Int * }", @@ -3684,10 +3684,10 @@ mod solve_expr { infer_eq_without_problem( indoc!( r#" - negatePoint : { x : Num a, y : Num b, z ? c }r -> { x : Num a, y : Num b, z : c }r + negate_point : { x : Num a, y : Num b, z ? c }r -> { x : Num a, y : Num b, z : c }r - a = negatePoint { x: 1, y: 2.1 } - b = negatePoint { x: 1, y: 2.1, blah : "hi" } + a = negate_point { x: 1, y: 2.1 } + b = negate_point { x: 1, y: 2.1, blah : "hi" } { a, b } "# @@ -3757,7 +3757,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - List.walkBackwards + List.walk_backwards " ), "List elem, state, (state, elem -> state) -> state", @@ -3773,7 +3773,7 @@ mod solve_expr { empty = [] - List.walkBackwards empty 0 (\a, b -> a + b) + List.walk_backwards empty 0 (\a, b -> a + b) " ), "I64", @@ -3783,7 +3783,7 @@ mod solve_expr { #[test] fn list_walk_with_index_until() { infer_eq_without_problem( - indoc!(r"List.walkWithIndexUntil"), + indoc!(r"List.walk_with_index_until"), "List elem, state, (state, elem, U64 -> [Break state, Continue state]) -> state", ); } @@ -3793,7 +3793,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - List.dropAt + List.drop_at " ), "List elem, U64 -> List elem", @@ -3817,7 +3817,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - Str.trimStart + Str.trim_start " ), "Str -> Str", @@ -3829,7 +3829,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - List.takeFirst + List.take_first " ), "List elem, U64 -> List elem", @@ -3841,7 +3841,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - List.takeLast + List.take_last " ), "List elem, U64 -> List elem", @@ -3863,7 +3863,7 @@ mod solve_expr { #[test] fn list_split() { infer_eq_without_problem( - indoc!("List.splitAt"), + indoc!("List.split_at"), "List elem, U64 -> { before : List elem, others : List elem }", ); } @@ -3873,7 +3873,7 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - List.dropLast + List.drop_last " ), "List elem, U64 -> List elem", @@ -4070,20 +4070,20 @@ mod solve_expr { RBTree k v : [Node NodeColor k v (RBTree k v) (RBTree k v), Empty] - moveRedLeft : RBTree k v -> RBTree k v - moveRedLeft = \dict -> + move_red_left : RBTree k v -> RBTree k v + move_red_left = \dict -> when dict is - # Node clr k v (Node lClr lK lV lLeft lRight) (Node rClr rK rV ((Node Red rlK rlV rlL rlR) as rLeft) rRight) -> - # Node clr k v (Node lClr lK lV lLeft lRight) (Node rClr rK rV rLeft rRight) -> - Node clr k v (Node _ lK lV lLeft lRight) (Node _ rK rV rLeft rRight) -> - when rLeft is - Node Red rlK rlV rlL rlR -> + # Node clr k v (Node l_clr l_k l_v l_left l_right) (Node r_clr r_k r_v ((Node Red rl_k rl_v rl_l rl_r) as r_left) r_right) -> + # Node clr k v (Node l_clr l_k l_v l_left l_right) (Node r_clr r_k r_v r_left r_right) -> + Node clr k v (Node _ l_k l_v l_left l_right) (Node _ r_k r_v r_left r_right) -> + when r_left is + Node Red rl_k rl_v rl_l rl_r -> Node Red - rlK - rlV - (Node Black k v (Node Red lK lV lLeft lRight) rlL) - (Node Black rK rV rlR rRight) + rl_k + rl_v + (Node Black k v (Node Red l_k l_v l_left l_right) rl_l) + (Node Black r_k r_v rl_r r_right) _ -> when clr is @@ -4092,16 +4092,16 @@ mod solve_expr { Black k v - (Node Red lK lV lLeft lRight) - (Node Red rK rV rLeft rRight) + (Node Red l_k l_v l_left l_right) + (Node Red r_k r_v r_left r_right) Red -> Node Black k v - (Node Red lK lV lLeft lRight) - (Node Red rK rV rLeft rRight) + (Node Red l_k l_v l_left l_right) + (Node Red r_k r_v r_left r_right) _ -> dict @@ -4109,28 +4109,28 @@ mod solve_expr { balance : NodeColor, k, v, RBTree k v, RBTree k v -> RBTree k v balance = \color, key, value, left, right -> when right is - Node Red rK rV rLeft rRight -> + Node Red r_k r_v r_left r_right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node Red key value - (Node Black lK lV lLeft lRight) - (Node Black rK rV rLeft rRight) + (Node Black l_k l_v l_left l_right) + (Node Black r_k r_v r_left r_right) _ -> - Node color rK rV (Node Red key value left rLeft) rRight + Node color r_k r_v (Node Red key value left r_left) r_right _ -> when left is - Node Red lK lV (Node Red llK llV llLeft llRight) lRight -> + Node Red l_k l_v (Node Red ll_k ll_v ll_left ll_right) l_right -> Node Red - lK - lV - (Node Black llK llV llLeft llRight) - (Node Black key value lRight right) + l_k + l_v + (Node Black ll_k ll_v ll_left ll_right) + (Node Black key value l_right right) _ -> Node color key value left right @@ -4138,151 +4138,151 @@ mod solve_expr { Key k : Num k - removeHelpEQGT : Key k, RBTree (Key k) v -> RBTree (Key k) v where k implements Hash & Eq - removeHelpEQGT = \targetKey, dict -> + remove_help_eq_gt : Key k, RBTree (Key k) v -> RBTree (Key k) v where k implements Hash & Eq + remove_help_eq_gt = \target_key, dict -> when dict is Node color key value left right -> - if targetKey == key then - when getMin right is - Node _ minKey minValue _ _ -> - balance color minKey minValue left (removeMin right) + if target_key == key then + when get_min right is + Node _ min_key min_value _ _ -> + balance color min_key min_value left (remove_min right) Empty -> Empty else - balance color key value left (removeHelp targetKey right) + balance color key value left (remove_help target_key right) Empty -> Empty - getMin : RBTree k v -> RBTree k v - getMin = \dict -> + get_min : RBTree k v -> RBTree k v + get_min = \dict -> when dict is # Node _ _ _ ((Node _ _ _ _ _) as left) _ -> Node _ _ _ left _ -> when left is - Node _ _ _ _ _ -> getMin left + Node _ _ _ _ _ -> get_min left _ -> dict _ -> dict - moveRedRight : RBTree k v -> RBTree k v - moveRedRight = \dict -> + move_red_right : RBTree k v -> RBTree k v + move_red_right = \dict -> when dict is - Node clr k v (Node lClr lK lV (Node Red llK llV llLeft llRight) lRight) (Node rClr rK rV rLeft rRight) -> + Node clr k v (Node l_clr l_k l_v (Node Red ll_k ll_v ll_left ll_right) l_right) (Node r_clr r_k r_v r_left r_right) -> Node Red - lK - lV - (Node Black llK llV llLeft llRight) - (Node Black k v lRight (Node Red rK rV rLeft rRight)) + l_k + l_v + (Node Black ll_k ll_v ll_left ll_right) + (Node Black k v l_right (Node Red r_k r_v r_left r_right)) - Node clr k v (Node lClr lK lV lLeft lRight) (Node rClr rK rV rLeft rRight) -> + Node clr k v (Node l_clr l_k l_v l_left l_right) (Node r_clr r_k r_v r_left r_right) -> when clr is Black -> Node Black k v - (Node Red lK lV lLeft lRight) - (Node Red rK rV rLeft rRight) + (Node Red l_k l_v l_left l_right) + (Node Red r_k r_v r_left r_right) Red -> Node Black k v - (Node Red lK lV lLeft lRight) - (Node Red rK rV rLeft rRight) + (Node Red l_k l_v l_left l_right) + (Node Red r_k r_v r_left r_right) _ -> dict - removeHelpPrepEQGT : Key k, RBTree (Key k) v, NodeColor, (Key k), v, RBTree (Key k) v, RBTree (Key k) v -> RBTree (Key k) v - removeHelpPrepEQGT = \_, dict, color, key, value, left, right -> + remove_help_prep_eq_gt : Key k, RBTree (Key k) v, NodeColor, (Key k), v, RBTree (Key k) v, RBTree (Key k) v -> RBTree (Key k) v + remove_help_prep_eq_gt = \_, dict, color, key, value, left, right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node color - lK - lV - lLeft - (Node Red key value lRight right) + l_k + l_v + l_left + (Node Red key value l_right right) _ -> when right is Node Black _ _ (Node Black _ _ _ _) _ -> - moveRedRight dict + move_red_right dict Node Black _ _ Empty _ -> - moveRedRight dict + move_red_right dict _ -> dict - removeMin : RBTree k v -> RBTree k v - removeMin = \dict -> + remove_min : RBTree k v -> RBTree k v + remove_min = \dict -> when dict is Node color key value left right -> when left is - Node lColor _ _ lLeft _ -> + Node lColor _ _ l_left _ -> when lColor is Black -> - when lLeft is + when l_left is Node Red _ _ _ _ -> - Node color key value (removeMin left) right + Node color key value (remove_min left) right _ -> - when moveRedLeft dict is # here 1 - Node nColor nKey nValue nLeft nRight -> - balance nColor nKey nValue (removeMin nLeft) nRight + when move_red_left dict is # here 1 + Node n_color n_key n_value n_left n_right -> + balance n_color n_key n_value (remove_min n_left) n_right Empty -> Empty _ -> - Node color key value (removeMin left) right + Node color key value (remove_min left) right _ -> Empty _ -> Empty - removeHelp : Key k, RBTree (Key k) v -> RBTree (Key k) v where k implements Hash & Eq - removeHelp = \targetKey, dict -> + remove_help : Key k, RBTree (Key k) v -> RBTree (Key k) v where k implements Hash & Eq + remove_help = \target_key, dict -> when dict is Empty -> Empty Node color key value left right -> - if targetKey < key then + if target_key < key then when left is - Node Black _ _ lLeft _ -> - when lLeft is + Node Black _ _ l_left _ -> + when l_left is Node Red _ _ _ _ -> - Node color key value (removeHelp targetKey left) right + Node color key value (remove_help target_key left) right _ -> - when moveRedLeft dict is # here 2 - Node nColor nKey nValue nLeft nRight -> - balance nColor nKey nValue (removeHelp targetKey nLeft) nRight + when move_red_left dict is # here 2 + Node n_color n_key n_value n_left n_right -> + balance n_color n_key n_value (remove_help target_key n_left) n_right Empty -> Empty _ -> - Node color key value (removeHelp targetKey left) right + Node color key value (remove_help target_key left) right else - removeHelpEQGT targetKey (removeHelpPrepEQGT targetKey dict color key value left right) + remove_help_eq_gt target_key (remove_help_prep_eq_gt target_key dict color key value left right) main : RBTree I64 I64 main = - removeHelp 1i64 Empty + remove_help 1i64 Empty "# ), "RBTree (Key (Integer Signed64)) I64", @@ -4298,31 +4298,31 @@ mod solve_expr { RBTree k : [Node k (RBTree k) (RBTree k), Empty] - removeHelp : Num k, RBTree (Num k) -> RBTree (Num k) - removeHelp = \targetKey, dict -> + remove_help : Num k, RBTree (Num k) -> RBTree (Num k) + remove_help = \target_key, dict -> when dict is Empty -> Empty Node key left right -> - if targetKey < key then + if target_key < key then when left is - Node _ lLeft _ -> - when lLeft is + Node _ l_left _ -> + when l_left is Node _ _ _ -> Empty _ -> Empty _ -> - Node key (removeHelp targetKey left) right + Node key (remove_help target_key left) right else Empty main : RBTree I64 main = - removeHelp 1 Empty + remove_help 1 Empty "# ), "RBTree I64", @@ -4340,65 +4340,65 @@ mod solve_expr { RBTree k v : [Node NodeColor k v (RBTree k v) (RBTree k v), Empty] - removeHelp : Num k, RBTree (Num k) v -> RBTree (Num k) v where k implements Hash & Eq - removeHelp = \targetKey, dict -> + remove_help : Num k, RBTree (Num k) v -> RBTree (Num k) v where k implements Hash & Eq + remove_help = \target_key, dict -> when dict is Empty -> Empty Node color key value left right -> - if targetKey < key then + if target_key < key then when left is - Node Black _ _ lLeft _ -> - when lLeft is + Node Black _ _ l_left _ -> + when l_left is Node Red _ _ _ _ -> - Node color key value (removeHelp targetKey left) right + Node color key value (remove_help target_key left) right _ -> - when moveRedLeft dict is # here 2 - Node nColor nKey nValue nLeft nRight -> - balance nColor nKey nValue (removeHelp targetKey nLeft) nRight + when move_red_left dict is # here 2 + Node n_color n_key n_value n_left n_right -> + balance n_color n_key n_value (remove_help target_key n_left) n_right Empty -> Empty _ -> - Node color key value (removeHelp targetKey left) right + Node color key value (remove_help target_key left) right else - removeHelpEQGT targetKey (removeHelpPrepEQGT targetKey dict color key value left right) + remove_help_eq_gt target_key (remove_help_prep_eq_gt target_key dict color key value left right) Key k : Num k balance : NodeColor, k, v, RBTree k v, RBTree k v -> RBTree k v - moveRedLeft : RBTree k v -> RBTree k v + move_red_left : RBTree k v -> RBTree k v - removeHelpPrepEQGT : Key k, RBTree (Key k) v, NodeColor, (Key k), v, RBTree (Key k) v, RBTree (Key k) v -> RBTree (Key k) v + remove_help_prep_eq_gt : Key k, RBTree (Key k) v, NodeColor, (Key k), v, RBTree (Key k) v, RBTree (Key k) v -> RBTree (Key k) v - removeHelpEQGT : Key k, RBTree (Key k) v -> RBTree (Key k) v where k implements Hash & Eq - removeHelpEQGT = \targetKey, dict -> + remove_help_eq_gt : Key k, RBTree (Key k) v -> RBTree (Key k) v where k implements Hash & Eq + remove_help_eq_gt = \target_key, dict -> when dict is Node color key value left right -> - if targetKey == key then - when getMin right is - Node _ minKey minValue _ _ -> - balance color minKey minValue left (removeMin right) + if target_key == key then + when get_min right is + Node _ min_key min_value _ _ -> + balance color min_key min_value left (remove_min right) Empty -> Empty else - balance color key value left (removeHelp targetKey right) + balance color key value left (remove_help target_key right) Empty -> Empty - getMin : RBTree k v -> RBTree k v + get_min : RBTree k v -> RBTree k v - removeMin : RBTree k v -> RBTree k v + remove_min : RBTree k v -> RBTree k v main : RBTree I64 I64 main = - removeHelp 1i64 Empty + remove_help 1i64 Empty "# ), "RBTree I64 I64", @@ -4410,28 +4410,28 @@ mod solve_expr { infer_eq_without_problem( indoc!( r#" - app "test" provides [partitionHelp] to "./platform" + app "test" provides [partition_help] to "./platform" swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set i atJ - |> List.set j atI + |> List.set i at_j + |> List.set j at_i _ -> [] - partitionHelp : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] - partitionHelp = \i, j, list, high, pivot -> + partition_help : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] + partition_help = \i, j, list, high, pivot -> if j < high then when List.get list j is Ok value -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap (i + 1) j list) high pivot + partition_help (i + 1) (j + 1) (swap (i + 1) j list) high pivot else - partitionHelp i (j + 1) list high pivot + partition_help i (j + 1) list high pivot Err _ -> Pair i list @@ -4503,28 +4503,28 @@ mod solve_expr { balance : NodeColor, k, v, RBTree k v, RBTree k v -> RBTree k v balance = \color, key, value, left, right -> when right is - Node Red rK rV rLeft rRight -> + Node Red r_k r_v r_left r_right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node Red key value - (Node Black lK lV lLeft lRight) - (Node Black rK rV rLeft rRight) + (Node Black l_k l_v l_left l_right) + (Node Black r_k r_v r_left r_right) _ -> - Node color rK rV (Node Red key value left rLeft) rRight + Node color r_k r_v (Node Red key value left r_left) r_right _ -> when left is - Node Red lK lV (Node Red llK llV llLeft llRight) lRight -> + Node Red l_k l_v (Node Red ll_k ll_v ll_left ll_right) l_right -> Node Red - lK - lV - (Node Black llK llV llLeft llRight) - (Node Black key value lRight right) + l_k + l_v + (Node Black ll_k ll_v ll_left ll_right) + (Node Black key value l_right right) _ -> Node color key value left right @@ -4550,8 +4550,8 @@ mod solve_expr { balance : k, RBTree k -> RBTree k balance = \key, left -> when left is - Node _ _ lRight -> - Node key lRight Empty + Node _ _ l_right -> + Node key l_right Empty _ -> Empty @@ -4575,20 +4575,20 @@ mod solve_expr { Expr : [Add Expr Expr, Val I64, Var I64] - printExpr : Expr -> Str - printExpr = \e -> + print_expr : Expr -> Str + print_expr = \e -> when e is Add a b -> "Add (" - |> Str.concat (printExpr a) + |> Str.concat (print_expr a) |> Str.concat ") (" - |> Str.concat (printExpr b) + |> Str.concat (print_expr b) |> Str.concat ")" - Val v -> Num.toStr v - Var v -> "Var " |> Str.concat (Num.toStr v) + Val v -> Num.to_str v + Var v -> "Var " |> Str.concat (Num.to_str v) main : Str - main = printExpr (Var 3) + main = print_expr (Var 3) "# ), "Str", @@ -4605,7 +4605,7 @@ mod solve_expr { x = 4 f : U8 -> U32 - f = \z -> Num.intCast z + f = \z -> Num.int_cast z y = f x @@ -4630,8 +4630,8 @@ mod solve_expr { balance : a, RBTree a -> RBTree a balance = \key, left -> when left is - Node _ _ lRight -> - Node key lRight Empty + Node _ _ l_right -> + Node key l_right Empty _ -> Empty @@ -4665,14 +4665,14 @@ mod solve_expr { infer_eq_without_problem( indoc!( r#" - canIGo : _ -> Result.Result _ _ - canIGo = \color -> + can_i_go : _ -> Result.Result _ _ + can_i_go = \color -> when color is "green" -> Ok "go!" "yellow" -> Err (SlowIt "whoa, let's slow down!") "red" -> Err (StopIt "absolutely not") _ -> Err (UnknownColor "this is a weird stoplight") - canIGo + can_i_go "# ), "Str -> Result Str [SlowIt Str, StopIt Str, UnknownColor Str]", @@ -4684,9 +4684,9 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - swapRcd: {x: _, y: _} -> {x: _, y: _} - swapRcd = \{x, y} -> {x: y, y: x} - swapRcd + swap_rcd: {x: _, y: _} -> {x: _, y: _} + swap_rcd = \{x, y} -> {x: y, y: x} + swap_rcd " ), "{ x : a, y : b } -> { x : b, y : a }", @@ -4698,9 +4698,9 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - swapRcd: {x: tx, y: ty} -> {x: _, y: _} - swapRcd = \{x, y} -> {x: y, y: x} - swapRcd + swap_rcd: {x: tx, y: ty} -> {x: _, y: _} + swap_rcd = \{x, y} -> {x: y, y: x} + swap_rcd " ), "{ x : tx, y : ty } -> { x : ty, y : tx }", @@ -4712,12 +4712,12 @@ mod solve_expr { infer_eq_without_problem( indoc!( r#" - badComics: [True, False] -> [CowTools _, Thagomizer _] - badComics = \c -> + bad_comics: [True, False] -> [CowTools _, Thagomizer _] + bad_comics = \c -> when c is True -> CowTools "The Far Side" False -> Thagomizer "The Far Side" - badComics + bad_comics "# ), "[False, True] -> [CowTools Str, Thagomizer Str]", @@ -4749,10 +4749,10 @@ mod solve_expr { infer_eq_without_problem( indoc!( r#" - setRocEmail : _ -> { name: Str, email: Str }_ - setRocEmail = \person -> + set_roc_email : _ -> { name: Str, email: Str }_ + set_roc_email = \person -> { person & email: "$(person.name)@roclang.com" } - setRocEmail + set_roc_email "# ), "{ email : Str, name : Str }a -> { email : Str, name : Str }a", @@ -4766,10 +4766,10 @@ mod solve_expr { r" LinkedList elem : [Empty, Prepend (LinkedList elem) elem] - fromList : List elem -> LinkedList elem - fromList = \elems -> List.walk elems Empty Prepend + from_list : List elem -> LinkedList elem + from_list = \elems -> List.walk elems Empty Prepend - fromList + from_list " ), "List elem -> LinkedList elem", @@ -4781,10 +4781,10 @@ mod solve_expr { infer_eq_without_problem( indoc!( r" - fromList : List elem -> [Empty, Prepend (LinkedList elem) elem] as LinkedList elem - fromList = \elems -> List.walk elems Empty Prepend + from_list : List elem -> [Empty, Prepend (LinkedList elem) elem] as LinkedList elem + from_list = \elems -> List.walk elems Empty Prepend - fromList + from_list " ), "List elem -> LinkedList elem", @@ -4968,7 +4968,7 @@ mod solve_expr { r" \email -> Email str = email - Str.isEmpty str + Str.is_empty str " ), "[Email Str] -> Bool", diff --git a/crates/compiler/test_derive/src/decoding.rs b/crates/compiler/test_derive/src/decoding.rs index a733468d724..ab5b68b4eb0 100644 --- a/crates/compiler/test_derive/src/decoding.rs +++ b/crates/compiler/test_derive/src/decoding.rs @@ -104,7 +104,7 @@ fn derivable_record_with_record_ext() { #[test] fn list() { derive_test(Decoder, v!(Symbol::LIST_LIST v!(STR)), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for List Str # Decoder (List val) fmt where fmt implements DecoderFormatting, val implements Decoding # List U8, fmt -[[custom(3)]]-> { rest : List U8, result : [Err [TooShort], Ok (List val)] } where fmt implements DecoderFormatting, val implements Decoding @@ -113,8 +113,8 @@ fn list() { #Derived.decoder_list = custom \#Derived.bytes, #Derived.fmt -> - decodeWith #Derived.bytes (list decoder) #Derived.fmt - "### + decode_with #Derived.bytes (list decoder) #Derived.fmt + " ) }) } @@ -122,7 +122,7 @@ fn list() { #[test] fn record_2_fields() { derive_test(Decoder, v!({first: v!(STR), second: v!(STR),}), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for { first : Str, second : Str } # Decoder { first : val, second : val1 } fmt where fmt implements DecoderFormatting, val implements Decoding, val1 implements Decoding # List U8, fmt -[[custom(25)]]-> { rest : List U8, result : [Err [TooShort], Ok { first : val, second : val1 }] } where fmt implements DecoderFormatting, val implements Decoding, val1 implements Decoding @@ -131,55 +131,55 @@ fn record_2_fields() { #Derived.decoder_{first,second} = custom \#Derived.bytes3, #Derived.fmt4 -> - decodeWith + decode_with #Derived.bytes3 (record { second: Err NoField, first: Err NoField } - \#Derived.stateRecord2, #Derived.field -> + \#Derived.state_record2, #Derived.field -> when #Derived.field is "first" -> Keep (custom \#Derived.bytes, #Derived.fmt2 -> - when decodeWith #Derived.bytes decoder #Derived.fmt2 is + when decode_with #Derived.bytes decoder #Derived.fmt2 is #Derived.rec -> { result: when #Derived.rec.result is Ok #Derived.val -> - Ok { stateRecord2 & first: Ok #Derived.val } + Ok { state_record2 & first: Ok #Derived.val } Err #Derived.err -> Err #Derived.err, rest: #Derived.rec.rest }) "second" -> Keep (custom \#Derived.bytes2, #Derived.fmt3 -> - when decodeWith #Derived.bytes2 decoder #Derived.fmt3 is + when decode_with #Derived.bytes2 decoder #Derived.fmt3 is #Derived.rec2 -> { result: when #Derived.rec2.result is Ok #Derived.val2 -> - Ok { stateRecord2 & second: Ok #Derived.val2 } + Ok { state_record2 & second: Ok #Derived.val2 } Err #Derived.err2 -> Err #Derived.err2, rest: #Derived.rec2.rest }) _ -> Skip - \#Derived.stateRecord, #Derived.fmt -> - when when #Derived.stateRecord.first is + \#Derived.state_record, #Derived.fmt -> + when when #Derived.state_record.first is Ok #Derived.first -> Ok #Derived.first Err (NoField) -> - when decodeWith [] decoder #Derived.fmt is - #Derived.decRec2 -> #Derived.decRec2.result is + when decode_with [] decoder #Derived.fmt is + #Derived.dec_rec2 -> #Derived.dec_rec2.result is Ok #Derived.first -> - when when #Derived.stateRecord.second is + when when #Derived.state_record.second is Ok #Derived.second -> Ok #Derived.second Err (NoField) -> - when decodeWith [] decoder #Derived.fmt is - #Derived.decRec -> #Derived.decRec.result is + when decode_with [] decoder #Derived.fmt is + #Derived.dec_rec -> #Derived.dec_rec.result is Ok #Derived.second -> Ok { second: #Derived.second, first: #Derived.first } _ -> Err TooShort _ -> Err TooShort) #Derived.fmt4 - "### + "## ) }) } @@ -187,7 +187,7 @@ fn record_2_fields() { #[test] fn tuple_2_fields() { derive_test(Decoder, v!((v!(STR), v!(U8),)), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for ( Str, U8 )* # Decoder ( val, val1 )* fmt where fmt implements DecoderFormatting, val implements Decoding, val1 implements Decoding # List U8, fmt -[[custom(22)]]-> { rest : List U8, result : [Err [TooShort], Ok ( val, val1 )a] } where fmt implements DecoderFormatting, val implements Decoding, val1 implements Decoding @@ -196,7 +196,7 @@ fn tuple_2_fields() { #Derived.decoder_(arity:2) = custom \#Derived.bytes3, #Derived.fmt3 -> - decodeWith + decode_with #Derived.bytes3 (tuple { e1: Err NoElem, e0: Err NoElem } @@ -205,7 +205,7 @@ fn tuple_2_fields() { 0 -> Next (custom \#Derived.bytes, #Derived.fmt -> - when decodeWith #Derived.bytes decoder #Derived.fmt is + when decode_with #Derived.bytes decoder #Derived.fmt is #Derived.rec -> { result: when #Derived.rec.result is @@ -217,7 +217,7 @@ fn tuple_2_fields() { 1 -> Next (custom \#Derived.bytes2, #Derived.fmt2 -> - when decodeWith #Derived.bytes2 decoder #Derived.fmt2 is + when decode_with #Derived.bytes2 decoder #Derived.fmt2 is #Derived.rec2 -> { result: when #Derived.rec2.result is @@ -235,7 +235,7 @@ fn tuple_2_fields() { _ -> Err TooShort _ -> Err TooShort) #Derived.fmt3 - "### + " ) }) } diff --git a/crates/compiler/test_derive/src/encoding.rs b/crates/compiler/test_derive/src/encoding.rs index 82740620599..ed126cf7399 100644 --- a/crates/compiler/test_derive/src/encoding.rs +++ b/crates/compiler/test_derive/src/encoding.rs @@ -186,19 +186,19 @@ fn derivable_tag_with_tag_ext() { #[test] fn empty_record() { derive_test(ToEncoder, v!(EMPTY_RECORD), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for {} - # {} -[[toEncoder_{}(0)]]-> Encoder fmt where fmt implements EncoderFormatting - # {} -[[toEncoder_{}(0)]]-> (List U8, fmt -[[custom(2) {}]]-> List U8) where fmt implements EncoderFormatting + # {} -[[to_encoder_{}(0)]]-> Encoder fmt where fmt implements EncoderFormatting + # {} -[[to_encoder_{}(0)]]-> (List U8, fmt -[[custom(2) {}]]-> List U8) where fmt implements EncoderFormatting # Specialization lambda sets: - # @<1>: [[toEncoder_{}(0)]] + # @<1>: [[to_encoder_{}(0)]] # @<2>: [[custom(2) {}]] - #Derived.toEncoder_{} = + #Derived.to_encoder_{} = \#Derived.rcd -> custom \#Derived.bytes, #Derived.fmt -> - appendWith #Derived.bytes (record []) #Derived.fmt - "### + append_with #Derived.bytes (record []) #Derived.fmt + " ) }) } @@ -206,19 +206,19 @@ fn empty_record() { #[test] fn zero_field_record() { derive_test(ToEncoder, v!({}), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for {} - # {} -[[toEncoder_{}(0)]]-> Encoder fmt where fmt implements EncoderFormatting - # {} -[[toEncoder_{}(0)]]-> (List U8, fmt -[[custom(2) {}]]-> List U8) where fmt implements EncoderFormatting + # {} -[[to_encoder_{}(0)]]-> Encoder fmt where fmt implements EncoderFormatting + # {} -[[to_encoder_{}(0)]]-> (List U8, fmt -[[custom(2) {}]]-> List U8) where fmt implements EncoderFormatting # Specialization lambda sets: - # @<1>: [[toEncoder_{}(0)]] + # @<1>: [[to_encoder_{}(0)]] # @<2>: [[custom(2) {}]] - #Derived.toEncoder_{} = + #Derived.to_encoder_{} = \#Derived.rcd -> custom \#Derived.bytes, #Derived.fmt -> - appendWith #Derived.bytes (record []) #Derived.fmt - "### + append_with #Derived.bytes (record []) #Derived.fmt + " ) }) } @@ -226,22 +226,22 @@ fn zero_field_record() { #[test] fn one_field_record() { derive_test(ToEncoder, v!({ a: v!(U8), }), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for { a : U8 } - # { a : val } -[[toEncoder_{a}(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding - # { a : val } -[[toEncoder_{a}(0)]]-> (List U8, fmt -[[custom(2) { a : val }]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding + # { a : val } -[[to_encoder_{a}(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding + # { a : val } -[[to_encoder_{a}(0)]]-> (List U8, fmt -[[custom(2) { a : val }]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_{a}(0)]] + # @<1>: [[to_encoder_{a}(0)]] # @<2>: [[custom(2) { a : val }]] where val implements Encoding - #Derived.toEncoder_{a} = + #Derived.to_encoder_{a} = \#Derived.rcd -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes - (record [{ value: toEncoder #Derived.rcd.a, key: "a" }]) + (record [{ value: to_encoder #Derived.rcd.a, key: "a" }]) #Derived.fmt - "### + "## ) }) } @@ -249,26 +249,26 @@ fn one_field_record() { #[test] fn two_field_record() { derive_test(ToEncoder, v!({ a: v!(U8), b: v!(STR), }), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for { a : U8, b : Str } - # { a : val, b : val1 } -[[toEncoder_{a,b}(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding - # { a : val, b : val1 } -[[toEncoder_{a,b}(0)]]-> (List U8, fmt -[[custom(2) { a : val, b : val1 }]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # { a : val, b : val1 } -[[to_encoder_{a,b}(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # { a : val, b : val1 } -[[to_encoder_{a,b}(0)]]-> (List U8, fmt -[[custom(2) { a : val, b : val1 }]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_{a,b}(0)]] + # @<1>: [[to_encoder_{a,b}(0)]] # @<2>: [[custom(2) { a : val, b : val1 }]] where val implements Encoding, val1 implements Encoding - #Derived.toEncoder_{a,b} = + #Derived.to_encoder_{a,b} = \#Derived.rcd -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes (record [ - { value: toEncoder #Derived.rcd.a, key: "a" }, - { value: toEncoder #Derived.rcd.b, key: "b" }, + { value: to_encoder #Derived.rcd.a, key: "a" }, + { value: to_encoder #Derived.rcd.b, key: "b" }, ]) #Derived.fmt - "### + "## ) }) } @@ -276,22 +276,22 @@ fn two_field_record() { #[test] fn two_field_tuple() { derive_test(ToEncoder, v!((v!(U8), v!(STR),)), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for ( U8, Str )* - # ( val, val1 )* -[[toEncoder_(arity:2)(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding - # ( val, val1 )a -[[toEncoder_(arity:2)(0)]]-> (List U8, fmt -[[custom(2) ( val, val1 )a]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # ( val, val1 )* -[[to_encoder_(arity:2)(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # ( val, val1 )a -[[to_encoder_(arity:2)(0)]]-> (List U8, fmt -[[custom(2) ( val, val1 )a]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_(arity:2)(0)]] + # @<1>: [[to_encoder_(arity:2)(0)]] # @<2>: [[custom(2) ( val, val1 )*]] where val implements Encoding, val1 implements Encoding - #Derived.toEncoder_(arity:2) = + #Derived.to_encoder_(arity:2) = \#Derived.tup -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes - (tuple [toEncoder #Derived.tup.0, toEncoder #Derived.tup.1]) + (tuple [to_encoder #Derived.tup.0, to_encoder #Derived.tup.1]) #Derived.fmt - "### + " ) }) } @@ -312,23 +312,23 @@ fn empty_tag_union() { #[test] fn tag_one_label_zero_args() { derive_test(ToEncoder, v!([A]), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for [A] - # [A] -[[toEncoder_[A 0](0)]]-> Encoder fmt where fmt implements EncoderFormatting - # [A] -[[toEncoder_[A 0](0)]]-> (List U8, fmt -[[custom(2) [A]]]-> List U8) where fmt implements EncoderFormatting + # [A] -[[to_encoder_[A 0](0)]]-> Encoder fmt where fmt implements EncoderFormatting + # [A] -[[to_encoder_[A 0](0)]]-> (List U8, fmt -[[custom(2) [A]]]-> List U8) where fmt implements EncoderFormatting # Specialization lambda sets: - # @<1>: [[toEncoder_[A 0](0)]] + # @<1>: [[to_encoder_[A 0](0)]] # @<2>: [[custom(2) [A]]] - #Derived.toEncoder_[A 0] = + #Derived.to_encoder_[A 0] = \#Derived.tag -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes (when #Derived.tag is A -> tag "A" []) #Derived.fmt - "### + "## ) }) } @@ -336,24 +336,24 @@ fn tag_one_label_zero_args() { #[test] fn tag_one_label_two_args() { derive_test(ToEncoder, v!([A v!(U8) v!(STR)]), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for [A U8 Str] - # [A val val1] -[[toEncoder_[A 2](0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding - # [A val val1] -[[toEncoder_[A 2](0)]]-> (List U8, fmt -[[custom(4) [A val val1]]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # [A val val1] -[[to_encoder_[A 2](0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # [A val val1] -[[to_encoder_[A 2](0)]]-> (List U8, fmt -[[custom(4) [A val val1]]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_[A 2](0)]] + # @<1>: [[to_encoder_[A 2](0)]] # @<2>: [[custom(4) [A val val1]]] where val implements Encoding, val1 implements Encoding - #Derived.toEncoder_[A 2] = + #Derived.to_encoder_[A 2] = \#Derived.tag -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes (when #Derived.tag is A #Derived.2 #Derived.3 -> - tag "A" [toEncoder #Derived.2, toEncoder #Derived.3]) + tag "A" [to_encoder #Derived.2, to_encoder #Derived.3]) #Derived.fmt - "### + "## ) }) } @@ -364,31 +364,31 @@ fn tag_two_labels() { ToEncoder, v!([A v!(U8) v!(STR) v!(U16), B v!(STR)]), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for [A U8 Str U16, B Str] - # [A val val1 val1, B val1] -[[toEncoder_[A 3,B 1](0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding - # [A val val1 val1, B val1] -[[toEncoder_[A 3,B 1](0)]]-> (List U8, fmt -[[custom(6) [A val val1 val1, B val1]]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # [A val val1 val1, B val1] -[[to_encoder_[A 3,B 1](0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # [A val val1 val1, B val1] -[[to_encoder_[A 3,B 1](0)]]-> (List U8, fmt -[[custom(6) [A val val1 val1, B val1]]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_[A 3,B 1](0)]] + # @<1>: [[to_encoder_[A 3,B 1](0)]] # @<2>: [[custom(6) [A val val1 val1, B val1]]] where val implements Encoding, val1 implements Encoding - #Derived.toEncoder_[A 3,B 1] = + #Derived.to_encoder_[A 3,B 1] = \#Derived.tag -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes (when #Derived.tag is A #Derived.2 #Derived.3 #Derived.4 -> tag "A" [ - toEncoder #Derived.2, - toEncoder #Derived.3, - toEncoder #Derived.4, + to_encoder #Derived.2, + to_encoder #Derived.3, + to_encoder #Derived.4, ] - B #Derived.5 -> tag "B" [toEncoder #Derived.5]) + B #Derived.5 -> tag "B" [to_encoder #Derived.5]) #Derived.fmt - "### + "## ) }, ) @@ -400,25 +400,25 @@ fn recursive_tag_union() { ToEncoder, v!([Nil, Cons v!(U8) v!(^lst) ] as lst), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r##" # derived for [Cons U8 $rec, Nil] as $rec - # [Cons val val1, Nil] -[[toEncoder_[Cons 2,Nil 0](0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding - # [Cons val val1, Nil] -[[toEncoder_[Cons 2,Nil 0](0)]]-> (List U8, fmt -[[custom(4) [Cons val val1, Nil]]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # [Cons val val1, Nil] -[[to_encoder_[Cons 2,Nil 0](0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding + # [Cons val val1, Nil] -[[to_encoder_[Cons 2,Nil 0](0)]]-> (List U8, fmt -[[custom(4) [Cons val val1, Nil]]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding, val1 implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_[Cons 2,Nil 0](0)]] + # @<1>: [[to_encoder_[Cons 2,Nil 0](0)]] # @<2>: [[custom(4) [Cons val val1, Nil]]] where val implements Encoding, val1 implements Encoding - #Derived.toEncoder_[Cons 2,Nil 0] = + #Derived.to_encoder_[Cons 2,Nil 0] = \#Derived.tag -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes (when #Derived.tag is Cons #Derived.2 #Derived.3 -> - tag "Cons" [toEncoder #Derived.2, toEncoder #Derived.3] + tag "Cons" [to_encoder #Derived.2, to_encoder #Derived.3] Nil -> tag "Nil" []) #Derived.fmt - "### + "## ) }, ) @@ -427,22 +427,22 @@ fn recursive_tag_union() { #[test] fn list() { derive_test(ToEncoder, v!(Symbol::LIST_LIST v!(STR)), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for List Str - # List val -[[toEncoder_list(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding - # List val -[[toEncoder_list(0)]]-> (List U8, fmt -[[custom(4) (List val)]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding + # List val -[[to_encoder_list(0)]]-> Encoder fmt where fmt implements EncoderFormatting, val implements Encoding + # List val -[[to_encoder_list(0)]]-> (List U8, fmt -[[custom(4) (List val)]]-> List U8) where fmt implements EncoderFormatting, val implements Encoding # Specialization lambda sets: - # @<1>: [[toEncoder_list(0)]] + # @<1>: [[to_encoder_list(0)]] # @<2>: [[custom(4) (List val)]] where val implements Encoding - #Derived.toEncoder_list = + #Derived.to_encoder_list = \#Derived.lst -> custom \#Derived.bytes, #Derived.fmt -> - appendWith + append_with #Derived.bytes - (list #Derived.lst \#Derived.elem -> toEncoder #Derived.elem) + (list #Derived.lst \#Derived.elem -> to_encoder #Derived.elem) #Derived.fmt - "### + " ) }) } diff --git a/crates/compiler/test_derive/src/hash.rs b/crates/compiler/test_derive/src/hash.rs index 96a119199e4..39bc2e92f41 100644 --- a/crates/compiler/test_derive/src/hash.rs +++ b/crates/compiler/test_derive/src/hash.rs @@ -261,7 +261,7 @@ fn tag_one_label_newtype() { #[test] fn tag_two_labels() { derive_test(Hash, v!([A v!(U8) v!(STR) v!(U16), B v!(STR)]), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for [A U8 Str U16, B Str] # a, [A a1 a2 a3, B a3] -[[hash_[A 3,B 1](0)]]-> a where a implements Hasher, a1 implements Hash, a2 implements Hash, a3 implements Hash # a, [A a1 a2 a3, B a3] -[[hash_[A 3,B 1](0)]]-> a where a implements Hasher, a1 implements Hash, a2 implements Hash, a3 implements Hash @@ -272,10 +272,10 @@ fn tag_two_labels() { when #Derived.union is A #Derived.3 #Derived.4 #Derived.5 -> hash - (hash (hash (addU8 #Derived.hasher 0) #Derived.3) #Derived.4) + (hash (hash (add_u8 #Derived.hasher 0) #Derived.3) #Derived.4) #Derived.5 - B #Derived.6 -> hash (addU8 #Derived.hasher 1) #Derived.6 - "### + B #Derived.6 -> hash (add_u8 #Derived.hasher 1) #Derived.6 + " ) }) } @@ -283,7 +283,7 @@ fn tag_two_labels() { #[test] fn tag_two_labels_no_payloads() { derive_test(Hash, v!([A, B]), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for [A, B] # a, [A, B] -[[hash_[A 0,B 0](0)]]-> a where a implements Hasher # a, [A, B] -[[hash_[A 0,B 0](0)]]-> a where a implements Hasher @@ -292,9 +292,9 @@ fn tag_two_labels_no_payloads() { #Derived.hash_[A 0,B 0] = \#Derived.hasher, #Derived.union -> when #Derived.union is - A -> addU8 #Derived.hasher 0 - B -> addU8 #Derived.hasher 1 - "### + A -> add_u8 #Derived.hasher 0 + B -> add_u8 #Derived.hasher 1 + " ) }) } @@ -302,7 +302,7 @@ fn tag_two_labels_no_payloads() { #[test] fn recursive_tag_union() { derive_test(Hash, v!([Nil, Cons v!(U8) v!(^lst) ] as lst), |golden| { - assert_snapshot!(golden, @r###" + assert_snapshot!(golden, @r" # derived for [Cons U8 $rec, Nil] as $rec # a, [Cons a1 a2, Nil] -[[hash_[Cons 2,Nil 0](0)]]-> a where a implements Hasher, a1 implements Hash, a2 implements Hash # a, [Cons a1 a2, Nil] -[[hash_[Cons 2,Nil 0](0)]]-> a where a implements Hasher, a1 implements Hash, a2 implements Hash @@ -312,9 +312,9 @@ fn recursive_tag_union() { \#Derived.hasher, #Derived.union -> when #Derived.union is Cons #Derived.3 #Derived.4 -> - hash (hash (addU8 #Derived.hasher 0) #Derived.3) #Derived.4 - Nil -> addU8 #Derived.hasher 1 - "### + hash (hash (add_u8 #Derived.hasher 0) #Derived.3) #Derived.4 + Nil -> add_u8 #Derived.hasher 1 + " ) }) } diff --git a/crates/compiler/test_gen/src/gen_abilities.rs b/crates/compiler/test_gen/src/gen_abilities.rs index d8829ae0ad7..f8b43953b4e 100644 --- a/crates/compiler/test_gen/src/gen_abilities.rs +++ b/crates/compiler/test_gen/src/gen_abilities.rs @@ -48,13 +48,13 @@ fn hash_specialization_multiple_add() { MHash implements hash : a -> U64 where a implements MHash - Id := U64 implements [ MHash {hash: hashId} ] + Id := U64 implements [ MHash {hash: hash_id} ] - hashId = \@Id n -> n + hash_id = \@Id n -> n - One := {} implements [ MHash {hash: hashOne} ] + One := {} implements [ MHash {hash: hash_one} ] - hashOne = \@One _ -> 1 + hash_one = \@One _ -> 1 main = hash (@Id 1234) + hash (@One {}) "# @@ -80,8 +80,8 @@ fn alias_member_specialization() { hash = \@Id n -> n main = - aliasedMHash = hash - aliasedMHash (@Id 1234) + aliased_m_hash = hash + aliased_m_hash (@Id 1234) "# ), 1234, @@ -100,13 +100,13 @@ fn ability_constrained_in_non_member_usage() { MHash implements hash : a -> U64 where a implements MHash - mulMHashes : a, a -> U64 where a implements MHash - mulMHashes = \x, y -> hash x * hash y + mul_m_hashes : a, a -> U64 where a implements MHash + mul_m_hashes = \x, y -> hash x * hash y Id := U64 implements [MHash {hash}] hash = \@Id n -> n - result = mulMHashes (@Id 5) (@Id 7) + result = mul_m_hashes (@Id 5) (@Id 7) "# ), 35, @@ -125,12 +125,12 @@ fn ability_constrained_in_non_member_usage_inferred() { MHash implements hash : a -> U64 where a implements MHash - mulMHashes = \x, y -> hash x * hash y + mul_m_hashes = \x, y -> hash x * hash y Id := U64 implements [MHash {hash}] hash = \@Id n -> n - result = mulMHashes (@Id 5) (@Id 7) + result = mul_m_hashes (@Id 5) (@Id 7) "# ), 35, @@ -149,16 +149,16 @@ fn ability_constrained_in_non_member_multiple_specializations() { MHash implements hash : a -> U64 where a implements MHash - mulMHashes : a, b -> U64 where a implements MHash, b implements MHash - mulMHashes = \x, y -> hash x * hash y + mul_m_hashes : a, b -> U64 where a implements MHash, b implements MHash + mul_m_hashes = \x, y -> hash x * hash y - Id := U64 implements [MHash { hash: hashId }] - hashId = \@Id n -> n + Id := U64 implements [MHash { hash: hash_id }] + hash_id = \@Id n -> n - Three := {} implements [MHash { hash: hashThree }] - hashThree = \@Three _ -> 3 + Three := {} implements [MHash { hash: hash_three }] + hash_three = \@Three _ -> 3 - result = mulMHashes (@Id 100) (@Three {}) + result = mul_m_hashes (@Id 100) (@Three {}) "# ), 300, @@ -177,15 +177,15 @@ fn ability_constrained_in_non_member_multiple_specializations_inferred() { MHash implements hash : a -> U64 where a implements MHash - mulMHashes = \x, y -> hash x * hash y + mul_m_hashes = \x, y -> hash x * hash y - Id := U64 implements [MHash { hash: hashId }] - hashId = \@Id n -> n + Id := U64 implements [MHash { hash: hash_id }] + hash_id = \@Id n -> n - Three := {} implements [MHash { hash: hashThree }] - hashThree = \@Three _ -> 3 + Three := {} implements [MHash { hash: hash_three }] + hash_three = \@Three _ -> 3 - result = mulMHashes (@Id 100) (@Three {}) + result = mul_m_hashes (@Id 100) (@Three {}) "# ), 300, @@ -204,16 +204,16 @@ fn ability_used_as_type_still_compiles() { MHash implements hash : a -> U64 where a implements MHash - mulMHashes : MHash, MHash -> U64 - mulMHashes = \x, y -> hash x * hash y + mul_m_hashes : MHash, MHash -> U64 + mul_m_hashes = \x, y -> hash x * hash y - Id := U64 implements [MHash { hash: hashId }] - hashId = \@Id n -> n + Id := U64 implements [MHash { hash: hash_id }] + hash_id = \@Id n -> n - Three := {} implements [MHash { hash: hashThree }] - hashThree = \@Three _ -> 3 + Three := {} implements [MHash { hash: hash_three }] + hash_three = \@Three _ -> 3 - result = mulMHashes (@Id 100) (@Three {}) + result = mul_m_hashes (@Id 100) (@Three {}) "# ), 300, @@ -232,10 +232,10 @@ fn bounds_to_multiple_abilities() { Idempot implements idempot : a -> a where a implements Idempot Consume implements consume : a -> Str where a implements Consume - Hello := Str implements [Idempot { idempot: idempotHello }, Consume { consume: consumeHello }] + Hello := Str implements [Idempot { idempot: idempot_hello }, Consume { consume: consume_hello }] - idempotHello = \@Hello msg -> @Hello msg - consumeHello = \@Hello msg -> msg + idempot_hello = \@Hello msg -> @Hello msg + consume_hello = \@Hello msg -> msg lifecycle : a -> Str where a implements Idempot & Consume lifecycle = \x -> idempot x |> consume @@ -254,37 +254,37 @@ fn encode() { assert_evals_to!( indoc!( r#" - app "test" provides [myU8Bytes] to "./platform" + app "test" provides [my_u8_bytes] to "./platform" MEncoder fmt := List U8, fmt -> List U8 where fmt implements Format MEncoding implements - toEncoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format + to_encoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format Format implements u8 : U8 -> MEncoder fmt where fmt implements Format - appendWith : List U8, MEncoder fmt, fmt -> List U8 where fmt implements Format - appendWith = \lst, (@MEncoder doFormat), fmt -> doFormat lst fmt + append_with : List U8, MEncoder fmt, fmt -> List U8 where fmt implements Format + append_with = \lst, (@MEncoder do_format), fmt -> do_format lst fmt - toBytes : val, fmt -> List U8 where val implements MEncoding, fmt implements Format - toBytes = \val, fmt -> appendWith [] (toEncoder val) fmt + to_bytes : val, fmt -> List U8 where val implements MEncoding, fmt implements Format + to_bytes = \val, fmt -> append_with [] (to_encoder val) fmt Linear := {} implements [Format {u8}] u8 = \n -> @MEncoder (\lst, @Linear {} -> List.append lst n) - Rgba := { r : U8, g : U8, b : U8, a : U8 } implements [MEncoding {toEncoder}] + Rgba := { r : U8, g : U8, b : U8, a : U8 } implements [MEncoding {to_encoder}] - toEncoder = \@Rgba {r, g, b, a} -> + to_encoder = \@Rgba {r, g, b, a} -> @MEncoder \lst, fmt -> lst - |> appendWith (u8 r) fmt - |> appendWith (u8 g) fmt - |> appendWith (u8 b) fmt - |> appendWith (u8 a) fmt + |> append_with (u8 r) fmt + |> append_with (u8 g) fmt + |> append_with (u8 b) fmt + |> append_with (u8 a) fmt - myU8Bytes = toBytes (@Rgba { r: 106, g: 90, b: 205, a: 255 }) (@Linear {}) + my_u8_bytes = to_bytes (@Rgba { r: 106, g: 90, b: 205, a: 255 }) (@Linear {}) "# ), RocList::from_slice(&[106, 90, 205, 255]), @@ -311,16 +311,16 @@ fn decode() { MDecoderFormatting implements u8 : MDecoder U8 fmt where fmt implements MDecoderFormatting - decodeWith : List U8, MDecoder val fmt, fmt -> { result: Result val MDecodeError, rest: List U8 } where fmt implements MDecoderFormatting - decodeWith = \lst, (@MDecoder doDecode), fmt -> doDecode lst fmt + decode_with : List U8, MDecoder val fmt, fmt -> { result: Result val MDecodeError, rest: List U8 } where fmt implements MDecoderFormatting + decode_with = \lst, (@MDecoder doDecode), fmt -> doDecode lst fmt - fromBytes : List U8, fmt -> Result val MDecodeError + from_bytes : List U8, fmt -> Result val MDecodeError where fmt implements MDecoderFormatting, val implements MDecoding - fromBytes = \lst, fmt -> - when decodeWith lst decoder fmt is + from_bytes = \lst, fmt -> + when decode_with lst decoder fmt is { result, rest } -> Result.try result \val -> - if List.isEmpty rest + if List.is_empty rest then Ok val else Err (Leftover rest) @@ -329,18 +329,18 @@ fn decode() { u8 = @MDecoder \lst, @Linear {} -> when List.first lst is - Ok n -> { result: Ok n, rest: List.dropFirst lst 1 } + Ok n -> { result: Ok n, rest: List.drop_first lst 1 } Err _ -> { result: Err TooShort, rest: [] } MyU8 := U8 implements [MDecoding {decoder}] # impl MDecoding for MyU8 decoder = @MDecoder \lst, fmt -> - { result, rest } = decodeWith lst u8 fmt + { result, rest } = decode_with lst u8 fmt { result: Result.map result (\n -> @MyU8 n), rest } myU8 = - when fromBytes [15] (@Linear {}) is + when from_bytes [15] (@Linear {}) is Ok (@MyU8 n) -> n _ -> 27u8 "# @@ -360,14 +360,14 @@ fn encode_use_stdlib() { {TAG_LEN_ENCODER_FMT} - HelloWorld := {{}} implements [Encoding {{toEncoder}}] - toEncoder = \@HelloWorld {{}} -> + HelloWorld := {{}} implements [Encoding {{to_encoder}}] + to_encoder = \@HelloWorld {{}} -> Encode.custom \bytes, fmt -> bytes - |> Encode.appendWith (Encode.string "Hello, World!\n") fmt + |> Encode.append_with (Encode.string "Hello, World!\n") fmt main = - result = Str.fromUtf8 (Encode.toBytes (@HelloWorld {{}}) tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes (@HelloWorld {{}}) tag_len_fmt) when result is Ok s -> s _ -> "" @@ -388,11 +388,11 @@ fn encode_use_stdlib_without_wrapping_custom() { {TAG_LEN_ENCODER_FMT} - HelloWorld := {{}} implements [Encoding {{toEncoder}}] - toEncoder = \@HelloWorld {{}} -> Encode.string "Hello, World!\n" + HelloWorld := {{}} implements [Encoding {{to_encoder}}] + to_encoder = \@HelloWorld {{}} -> Encode.string "Hello, World!\n" main = - result = Str.fromUtf8 (Encode.toBytes (@HelloWorld {{}}) tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes (@HelloWorld {{}}) tag_len_fmt) when result is Ok s -> s _ -> "" @@ -417,7 +417,7 @@ fn encode_derive_to_encoder_for_opaque() { HelloWorld := {{ a: Str }} implements [Encoding] main = - result = Str.fromUtf8 (Encode.toBytes (@HelloWorld {{ a: "Hello, World!" }}) tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes (@HelloWorld {{ a: "Hello, World!" }}) tag_len_fmt) when result is Ok s -> s _ -> "" @@ -438,14 +438,14 @@ fn to_encoder_encode_custom_has_capture() { {TAG_LEN_ENCODER_FMT} - HelloWorld := Str implements [Encoding {{toEncoder}}] - toEncoder = \@HelloWorld s1 -> + HelloWorld := Str implements [Encoding {{to_encoder}}] + to_encoder = \@HelloWorld s1 -> Encode.custom \bytes, fmt -> bytes - |> Encode.appendWith (Encode.string s1) fmt + |> Encode.append_with (Encode.string s1) fmt main = - result = Str.fromUtf8 (Encode.toBytes (@HelloWorld "Hello, World!\n") tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes (@HelloWorld "Hello, World!\n") tag_len_fmt) when result is Ok s -> s _ -> "" @@ -482,7 +482,7 @@ mod encode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.fromUtf8 (Encode.toBytes "foo" tagLenFmt) is + when Str.from_utf8 (Encode.to_bytes "foo" tag_len_fmt) is Ok s -> s _ -> "" "# @@ -503,7 +503,7 @@ mod encode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.fromUtf8 (Encode.toBytes [1, 2, 3] tagLenFmt) is + when Str.from_utf8 (Encode.to_bytes [1, 2, 3] tag_len_fmt) is Ok s -> s _ -> "" "# @@ -524,7 +524,7 @@ mod encode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.fromUtf8 (Encode.toBytes Bool.false tagLenFmt) is + when Str.from_utf8 (Encode.to_bytes Bool.false tag_len_fmt) is Ok s -> s _ -> "" "# @@ -547,7 +547,7 @@ mod encode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.fromUtf8 (Encode.toBytes {}{} tagLenFmt) is + when Str.from_utf8 (Encode.to_bytes {}{} tag_len_fmt) is Ok s -> s _ -> "" "#, $num, stringify!($typ)), @@ -587,7 +587,7 @@ fn encode_derived_record_one_field_string() { {TAG_LEN_ENCODER_FMT} main = - result = Str.fromUtf8 (Encode.toBytes {{a: "foo"}} tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes {{a: "foo"}} tag_len_fmt) when result is Ok s -> s _ -> "" @@ -611,7 +611,7 @@ fn encode_derived_record_two_fields_strings() { main = rcd = {{a: "foo", b: "bar"}} - result = Str.fromUtf8 (Encode.toBytes rcd tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes rcd tag_len_fmt) when result is Ok s -> s _ -> "" @@ -635,8 +635,8 @@ fn encode_derived_nested_record_string() { main = rcd = {{a: {{b: "bar"}}}} - encoded = Encode.toBytes rcd tagLenFmt - result = Str.fromUtf8 encoded + encoded = Encode.to_bytes rcd tag_len_fmt + result = Str.from_utf8 encoded when result is Ok s -> s _ -> "" @@ -659,7 +659,7 @@ fn encode_derived_tag_one_payload_string() { main = x = A "foo" - result = Str.fromUtf8 (Encode.toBytes x tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes x tag_len_fmt) when result is Ok s -> s _ -> "" @@ -682,7 +682,7 @@ fn encode_derived_tag_two_payloads_string() { main = x = A "foo" "bar" - result = Str.fromUtf8 (Encode.toBytes x tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes x tag_len_fmt) when result is Ok s -> s _ -> "" @@ -705,8 +705,8 @@ fn encode_derived_nested_tag_string() { main = x = A (B "foo" "bar") - encoded = Encode.toBytes x tagLenFmt - result = Str.fromUtf8 encoded + encoded = Encode.to_bytes x tag_len_fmt + result = Str.from_utf8 encoded when result is Ok s -> s _ -> "" @@ -730,8 +730,8 @@ fn encode_derived_nested_record_tag_record() { main = x = {{a: (B ({{c: "foo"}}))}} - encoded = Encode.toBytes x tagLenFmt - result = Str.fromUtf8 encoded + encoded = Encode.to_bytes x tag_len_fmt + result = Str.from_utf8 encoded when result is Ok s -> s _ -> "" @@ -754,8 +754,8 @@ fn encode_derived_list_string() { main = lst = ["foo", "bar", "baz"] - encoded = Encode.toBytes lst tagLenFmt - result = Str.fromUtf8 encoded + encoded = Encode.to_bytes lst tag_len_fmt + result = Str.from_utf8 encoded when result is Ok s -> s _ -> "" @@ -779,8 +779,8 @@ fn encode_derived_list_of_records() { main = lst = [{{a: "foo"}}, {{a: "bar"}}, {{a: "baz"}}] - encoded = Encode.toBytes lst tagLenFmt - result = Str.fromUtf8 encoded + encoded = Encode.to_bytes lst tag_len_fmt + result = Str.from_utf8 encoded when result is Ok s -> s _ -> "" @@ -803,8 +803,8 @@ fn encode_derived_list_of_lists_of_strings() { main = lst = [["a", "b"], ["c", "d", "e"], ["f"]] - encoded = Encode.toBytes lst tagLenFmt - result = Str.fromUtf8 encoded + encoded = Encode.to_bytes lst tag_len_fmt + result = Str.from_utf8 encoded when result is Ok s -> s _ -> "" @@ -830,7 +830,7 @@ fn encode_derived_record_with_many_types() { fresh : [Fresh Str, Rotten Str] fresh = Fresh "tomatoes" rcd = {{actors: ["Idris Elba", "Mila Kunis"], year: 2004u16, rating: {{average: 7u8, min: 1u8, max: 10u8, sentiment: fresh}}}} - result = Str.fromUtf8 (Encode.toBytes rcd tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes rcd tag_len_fmt) when result is Ok s -> s _ -> "" @@ -855,7 +855,7 @@ fn encode_derived_tuple_two_fields() { main = tup = ("foo", 10u8) - result = Str.fromUtf8 (Encode.toBytes tup tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes tup tag_len_fmt) when result is Ok s -> s _ -> "" @@ -878,7 +878,7 @@ fn encode_derived_tuple_of_tuples() { main = tup = ( ("foo", 10u8), (23u8, "bar", 15u8) ) - result = Str.fromUtf8 (Encode.toBytes tup tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes tup tag_len_fmt) when result is Ok s -> s _ -> "" @@ -905,7 +905,7 @@ fn encode_derived_generic_record_with_different_field_types() { q = @Q {{a: 10u32, b: "fieldb"}} main = - result = Str.fromUtf8 (Encode.toBytes q tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes q tag_len_fmt) when result is Ok s -> s _ -> "" @@ -932,7 +932,7 @@ fn encode_derived_generic_tag_with_different_field_types() { q = @Q (B 67) main = - result = Str.fromUtf8 (Encode.toBytes q tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes q tag_len_fmt) when result is Ok s -> s _ -> "" @@ -955,8 +955,8 @@ fn specialize_unique_newtype_records() { {TAG_LEN_ENCODER_FMT} main = - when Str.fromUtf8 (Encode.toBytes {{a: Bool.true}} tagLenFmt) is - Ok s -> when Str.fromUtf8 (Encode.toBytes {{b: Bool.true}} tagLenFmt) is + when Str.from_utf8 (Encode.to_bytes {{a: Bool.true}} tag_len_fmt) is + Ok s -> when Str.from_utf8 (Encode.to_bytes {{b: Bool.true}} tag_len_fmt) is Ok t -> "$(s)$(t)" _ -> "" _ -> "" @@ -982,14 +982,14 @@ fn decode_use_stdlib() { myDecoder = Decode.custom \bytes, fmt -> - when Decode.decodeWith bytes Decode.u8 fmt is + when Decode.decode_with bytes Decode.u8 fmt is {{result, rest}} -> when result is Ok n -> {{result: Ok (@MyNum n), rest}} Err e -> {{result: Err e, rest}} main = - when Decode.fromBytes [110, 49, 53, 32] tagLenFmt is + when Decode.from_bytes [110, 49, 53, 32] tag_len_fmt is Ok (@MyNum n) -> n _ -> 101 "# @@ -1015,7 +1015,7 @@ fn decode_derive_decoder_for_opaque() { HelloWorld := {{ a: Str }} implements [Decoding] main = - when Str.toUtf8 "r1 s1 a s13 Hello, World! " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "r1 s1 a s13 Hello, World! " |> Decode.from_bytes tag_len_fmt is Ok (@HelloWorld {{a}}) -> a _ -> "FAIL" "# @@ -1037,13 +1037,13 @@ fn decode_use_stdlib_custom_list() { MyNumList := List U8 implements [Decoding {{decoder: myDecoder}}] myDecoder = Decode.custom \bytes, fmt -> - when Decode.decodeWith bytes (Decode.list Decode.u8) fmt is + when Decode.decode_with bytes (Decode.list Decode.u8) fmt is {{result, rest}} -> when result is Ok lst -> {{result: Ok (@MyNumList lst), rest}} Err e -> {{result: Err e, rest}} main = - when Str.toUtf8 "l3 n1 n2 n3 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "l3 n1 n2 n3 " |> Decode.from_bytes tag_len_fmt is Ok (@MyNumList lst) -> lst _ -> [] "# @@ -1080,7 +1080,7 @@ mod decode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "s3 foo " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "s3 foo " |> Decode.from_bytes tag_len_fmt is Ok s -> s _ -> "" "# @@ -1102,10 +1102,10 @@ mod decode_immediate { {TAG_LEN_ENCODER_FMT} main = - input = Str.toUtf8 "l3 n1 n2 n3 " + input = Str.to_utf8 "l3 n1 n2 n3 " expected = [1,2,3] - actual = Decode.fromBytes input tagLenFmt |> Result.withDefault [] + actual = Decode.from_bytes input tag_len_fmt |> Result.with_default [] actual == expected "# @@ -1126,7 +1126,7 @@ mod decode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "n0 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "n0 " |> Decode.from_bytes tag_len_fmt is Ok s -> s _ -> Bool.true "# @@ -1149,7 +1149,7 @@ mod decode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "n{} " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "n{} " |> Decode.from_bytes tag_len_fmt is Ok n -> n _ -> 101{} "#, @@ -1189,7 +1189,7 @@ mod decode_immediate { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "n17.23 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "n17.23 " |> Decode.from_bytes tag_len_fmt is Ok n -> n _ -> 101dec "# @@ -1212,8 +1212,8 @@ fn decode_list_of_strings() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "l3 s1 a s1 b s1 c " |> Decode.fromBytes tagLenFmt is - Ok l -> Str.joinWith l "," + when Str.to_utf8 "l3 s1 a s1 b s1 c " |> Decode.from_bytes tag_len_fmt is + Ok l -> Str.join_with l "," _ -> "" "# ), @@ -1235,8 +1235,8 @@ fn encode_then_decode_list_of_strings() { {TAG_LEN_ENCODER_FMT} main = - when Encode.toBytes ["a", "b", "c"] tagLenFmt |> Decode.fromBytes tagLenFmt is - Ok l -> Str.joinWith l "," + when Encode.to_bytes ["a", "b", "c"] tag_len_fmt |> Decode.from_bytes tag_len_fmt is + Ok l -> Str.join_with l "," _ -> "something went wrong" "# ), @@ -1258,8 +1258,8 @@ fn encode_then_decode_list_of_lists_of_strings() { {TAG_LEN_ENCODER_FMT} main = - when Encode.toBytes [["a", "b"], ["c", "d", "e"], ["f"]] tagLenFmt |> Decode.fromBytes tagLenFmt is - Ok list -> (List.map list \inner -> Str.joinWith inner ",") |> Str.joinWith ";" + when Encode.to_bytes [["a", "b"], ["c", "d", "e"], ["f"]] tag_len_fmt |> Decode.from_bytes tag_len_fmt is + Ok list -> (List.map list \inner -> Str.join_with inner ",") |> Str.join_with ";" _ -> "something went wrong" "# ), @@ -1283,7 +1283,7 @@ fn decode_record_two_fields() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "r2 s6 second s2 cd s5 first s2 ab " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "r2 s6 second s2 cd s5 first s2 ab " |> Decode.from_bytes tag_len_fmt is Ok {{first: "ab", second: "cd"}} -> "abcd" _ -> "something went wrong" "# @@ -1307,7 +1307,7 @@ fn decode_record_two_fields_string_and_int() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "r2 s5 first s2 ab s6 second n10 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "r2 s5 first s2 ab s6 second n10 " |> Decode.from_bytes tag_len_fmt is Ok {{first: "ab", second: 10u8}} -> "ab10" _ -> "something went wrong" "# @@ -1331,7 +1331,7 @@ fn decode_record_two_fields_string_and_string_infer() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "r2 s5 first s2 ab s6 second s2 cd " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "r2 s5 first s2 ab s6 second s2 cd " |> Decode.from_bytes tag_len_fmt is Ok {{first, second}} -> Str.concat first second _ -> "something went wrong" "# @@ -1355,7 +1355,7 @@ fn decode_record_two_fields_string_and_string_infer_local_var() { {TAG_LEN_ENCODER_FMT} main = - decoded = Str.toUtf8 "r2 s5 first s2 ab s6 second s2 cd " |> Decode.fromBytes tagLenFmt + decoded = Str.to_utf8 "r2 s5 first s2 ab s6 second s2 cd " |> Decode.from_bytes tag_len_fmt when decoded is Ok rcd -> Str.concat rcd.first rcd.second _ -> "something went wrong" @@ -1380,7 +1380,7 @@ fn decode_record_two_fields_string_and_string_infer_local_var_destructured() { {TAG_LEN_ENCODER_FMT} main = - decoded = Str.toUtf8 "r2 s5 first s2 ab s6 second s2 cd " |> Decode.fromBytes tagLenFmt + decoded = Str.to_utf8 "r2 s5 first s2 ab s6 second s2 cd " |> Decode.from_bytes tag_len_fmt when decoded is Ok {{first, second}} -> Str.concat first second _ -> "something went wrong" @@ -1402,7 +1402,7 @@ fn decode_empty_record() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "r0 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "r0 " |> Decode.from_bytes tag_len_fmt is Ok {{}} -> "empty" _ -> "something went wrong" "# @@ -1427,7 +1427,7 @@ fn decode_record_of_record() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "r2 s5 other r2 s3 one s1 b s3 two n10 s5 outer r1 s5 inner s1 a " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "r2 s5 other r2 s3 one s1 b s3 two n10 s5 outer r1 s5 inner s1 a " |> Decode.from_bytes tag_len_fmt is Ok {{outer: {{inner: "a"}}, other: {{one: "b", two: 10u8}}}} -> "ab10" _ -> "something went wrong" "# @@ -1451,7 +1451,7 @@ fn decode_tuple_two_elements() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "l2 s2 ab n10 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "l2 s2 ab n10 " |> Decode.from_bytes tag_len_fmt is Ok ("ab", 10u8) -> "abcd" _ -> "something went wrong" "# @@ -1475,7 +1475,7 @@ fn decode_tuple_of_tuples() { {TAG_LEN_ENCODER_FMT} main = - when Str.toUtf8 "l2 l2 s2 ab n10 l2 s2 cd n25 " |> Decode.fromBytes tagLenFmt is + when Str.to_utf8 "l2 l2 s2 ab n10 l2 s2 cd n25 " |> Decode.from_bytes tag_len_fmt is Ok ( ("ab", 10u8), ("cd", 25u8) ) -> "abcd" _ -> "something went wrong" "# @@ -1498,53 +1498,53 @@ mod hash { const TEST_HASHER: &str = indoc!( r" THasher := List U8 implements [Hasher { - addBytes: tAddBytes, - addU8: tAddU8, - addU16: tAddU16, - addU32: tAddU32, - addU64: tAddU64, - addU128: tAddU128, - complete: tComplete, + add_bytes: t_add_bytes, + add_u8: t_add_u8, + add_u16: t_add_u16, + add_u32: t_add_u32, + add_u64: t_add_u64, + add_u128: t_add_u128, + complete: t_complete, }] # ignores endian-ness - byteAt = \n, shift -> - Num.bitwiseAnd (Num.shiftRightBy n (shift * 8)) 0xFF - |> Num.toU8 + byte_at = \n, shift -> + Num.bitwise_and (Num.shift_right_by n (shift * 8)) 0xFF + |> Num.to_u8 do8 = \total, n -> total - |> List.append (byteAt n 0) + |> List.append (byte_at n 0) do16 = \total, n -> total - |> do8 (n |> Num.toU8) - |> do8 (Num.shiftRightBy n 8 |> Num.toU8) + |> do8 (n |> Num.to_u8) + |> do8 (Num.shift_right_by n 8 |> Num.to_u8) do32 = \total, n -> total - |> do16 (n |> Num.toU16) - |> do16 (Num.shiftRightBy n 16 |> Num.toU16) + |> do16 (n |> Num.to_u16) + |> do16 (Num.shift_right_by n 16 |> Num.to_u16) do64 = \total, n -> total - |> do32 (n |> Num.toU32) - |> do32 (Num.shiftRightBy n 32 |> Num.toU32) + |> do32 (n |> Num.to_u32) + |> do32 (Num.shift_right_by n 32 |> Num.to_u32) do128 = \total, n -> total - |> do64 (n |> Num.toU64) - |> do64 (Num.shiftRightBy n 64 |> Num.toU64) - - tAddBytes = \@THasher total, bytes -> @THasher (List.concat total bytes) - tAddU8 = \@THasher total, n -> @THasher (do8 total n) - tAddU16 = \@THasher total, n -> @THasher (do16 total n) - tAddU32 = \@THasher total, n -> @THasher (do32 total n) - tAddU64 = \@THasher total, n -> @THasher (do64 total n) - tAddU128 = \@THasher total, n -> @THasher (do128 total n) - tComplete = \@THasher _ -> Num.maxU64 - - tRead = \@THasher bytes -> bytes + |> do64 (n |> Num.to_u64) + |> do64 (Num.shift_right_by n 64 |> Num.to_u64) + + t_add_bytes = \@THasher total, bytes -> @THasher (List.concat total bytes) + t_add_u8 = \@THasher total, n -> @THasher (do8 total n) + t_add_u16 = \@THasher total, n -> @THasher (do16 total n) + t_add_u32 = \@THasher total, n -> @THasher (do32 total n) + t_add_u64 = \@THasher total, n -> @THasher (do64 total n) + t_add_u128 = \@THasher total, n -> @THasher (do128 total n) + t_complete = \@THasher _ -> Num.max_u64 + + t_read = \@THasher bytes -> bytes " ); @@ -1559,7 +1559,7 @@ mod hash { main = @THasher [] |> Hash.hash ({}) - |> tRead + |> t_read "# ), TEST_HASHER, input, @@ -1618,7 +1618,7 @@ mod hash { #[test] fn u16() { assert_evals_to!( - &build_test("Num.maxU16 - 1"), + &build_test("Num.max_u16 - 1"), RocList::from_slice(&[254, 255]), RocList ) @@ -1636,7 +1636,7 @@ mod hash { #[test] fn u32() { assert_evals_to!( - &build_test("Num.maxU32 - 1"), + &build_test("Num.max_u32 - 1"), RocList::from_slice(&[254, 255, 255, 255]), RocList ) @@ -1654,7 +1654,7 @@ mod hash { #[test] fn u64() { assert_evals_to!( - &build_test("Num.maxU64 - 1"), + &build_test("Num.max_u64 - 1"), RocList::from_slice(&[254, 255, 255, 255, 255, 255, 255, 255]), RocList ) @@ -1676,7 +1676,7 @@ mod hash { #[cfg(not(feature = "gen-wasm"))] // shr not implemented for U128 fn u128() { assert_evals_to!( - &build_test("Num.maxU128 - 1"), + &build_test("Num.max_u128 - 1"), RocList::from_slice(&[ 254, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255 ]), @@ -1818,7 +1818,7 @@ mod hash { main = @THasher [] |> Hash.hash a - |> tRead + |> t_read "# ), TEST_HASHER, @@ -1850,7 +1850,7 @@ mod hash { @THasher [] |> Hash.hash a |> Hash.hash b - |> tRead + |> t_read "# ), TEST_HASHER, @@ -1879,7 +1879,7 @@ mod hash { main = @THasher [] |> Hash.hash l - |> tRead + |> t_read "# ), TEST_HASHER, @@ -1914,7 +1914,7 @@ mod hash { main = @THasher [] |> Hash.hash a - |> tRead + |> t_read "# ), TEST_HASHER, @@ -1943,7 +1943,7 @@ mod hash { main = @THasher [] |> Hash.hash a - |> tRead + |> t_read "# ), TEST_HASHER, @@ -1981,7 +1981,7 @@ mod hash { |> Hash.hash a |> Hash.hash b |> Hash.hash c - |> tRead + |> t_read "# ), TEST_HASHER, @@ -2016,7 +2016,7 @@ mod hash { main = @THasher [] |> Hash.hash c - |> tRead + |> t_read "# ), TEST_HASHER, @@ -2047,7 +2047,7 @@ mod hash { main = @THasher [] |> Hash.hash q - |> tRead + |> t_read "# ), TEST_HASHER, @@ -2093,15 +2093,15 @@ mod eq { r#" app "test" provides [main] to "./platform" - LyingEq := U8 implements [Eq {isEq}] + LyingEq := U8 implements [Eq {is_eq}] - isEq = \@LyingEq m, @LyingEq n -> m != n + is_eq = \@LyingEq m, @LyingEq n -> m != n main = a = @LyingEq 10 b = @LyingEq 5 c = @LyingEq 5 - if Bool.isEq a b && !(Bool.isEq b c) then + if Bool.is_eq a b && !(Bool.is_eq b c) then "okay" else "fail" @@ -2119,11 +2119,11 @@ mod eq { r#" app "test" provides [main] to "./platform" - Q := ({} -> Str) implements [Eq {isEq: isEqQ}] + Q := ({} -> Str) implements [Eq {is_eq: is_eq_q}] - isEqQ = \@Q _, @Q _ -> Bool.true + is_eq_q = \@Q _, @Q _ -> Bool.true - main = isEqQ (@Q \{} -> "a") (@Q \{} -> "a") + main = is_eq_q (@Q \{} -> "a") (@Q \{} -> "a") "# ), true, @@ -2139,11 +2139,11 @@ mod eq { r#" app "test" provides [main] to "./platform" - Q := ({} -> Str) implements [Eq {isEq: isEqQ}] + Q := ({} -> Str) implements [Eq {is_eq: is_eq_q}] - isEqQ = \@Q f1, @Q f2 -> (f1 {} == f2 {}) + is_eq_q = \@Q f1, @Q f2 -> (f1 {} == f2 {}) - main = isEqQ (@Q \{} -> "a") (@Q \{} -> "a") + main = is_eq_q (@Q \{} -> "a") (@Q \{} -> "a") "# ), true, @@ -2158,7 +2158,7 @@ mod eq { r#" app "test" provides [main] to "./platform" - main = Bool.isEq 10u8 10u8 + main = Bool.is_eq 10u8 10u8 "# ), true, @@ -2195,12 +2195,12 @@ fn issue_4772_weakened_monomorphic_destructure() { {TAG_LEN_ENCODER_FMT} - getNumber = - {{ result, rest }} = Decode.fromBytesPartial (Str.toUtf8 "s4 1234 ") tagLenFmt + get_number = + {{ result, rest }} = Decode.from_bytes_partial (Str.to_utf8 "s4 1234 ") tag_len_fmt when result is Ok val -> - when Str.toI64 val is + when Str.to_i64 val is Ok number -> Ok {{ val : number, input : rest }} Err InvalidNumStr -> @@ -2210,7 +2210,7 @@ fn issue_4772_weakened_monomorphic_destructure() { Err (ParsingFailure "not a number") main = - getNumber |> Result.map .val |> Result.withDefault 0 + get_number |> Result.map .val |> Result.with_default 0 "# ), 1234i64, @@ -2241,9 +2241,9 @@ mod inspect { app "test" provides [main] to "./platform" main = [ - Inspect.toStr Bool.true, - Inspect.toStr Bool.false, - ] |> Str.joinWith ", " + Inspect.to_str Bool.true, + Inspect.to_str Bool.false, + ] |> Str.join_with ", " "# ), RocStr::from("Bool.true, Bool.false"), @@ -2260,22 +2260,22 @@ mod inspect { app "test" provides [main] to "./platform" main = [ - Inspect.toStr 0, # Num a - Inspect.toStr 1u8, # U8 - Inspect.toStr 2i8, # I8 - Inspect.toStr 3u16, # U16 - Inspect.toStr 4i16, # I16 - Inspect.toStr 5u32, # U32 - Inspect.toStr 6i32, # I32 - Inspect.toStr 7u64, # U64 - Inspect.toStr 8i64, # I64 - Inspect.toStr 9u128, # U128 - Inspect.toStr 10i128, # I128 - Inspect.toStr 0.5, # Frac a - Inspect.toStr 1.5f32, # F32 - Inspect.toStr 2.2f64, # F64 - Inspect.toStr (1.1dec + 2.2), # Dec - ] |> Str.joinWith ", " + Inspect.to_str 0, # Num a + Inspect.to_str 1u8, # U8 + Inspect.to_str 2i8, # I8 + Inspect.to_str 3u16, # U16 + Inspect.to_str 4i16, # I16 + Inspect.to_str 5u32, # U32 + Inspect.to_str 6i32, # I32 + Inspect.to_str 7u64, # U64 + Inspect.to_str 8i64, # I64 + Inspect.to_str 9u128, # U128 + Inspect.to_str 10i128, # I128 + Inspect.to_str 0.5, # Frac a + Inspect.to_str 1.5f32, # F32 + Inspect.to_str 2.2f64, # F64 + Inspect.to_str (1.1dec + 2.2), # Dec + ] |> Str.join_with ", " "# ), RocStr::from("0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 0.5, 1.5, 2.2, 3.3"), @@ -2292,12 +2292,12 @@ mod inspect { app "test" provides [main] to "./platform" main = [ - Inspect.toStr [0, 1, 2], # List (Num *) - Inspect.toStr [1, 0x2, 3], # List (Int *) - Inspect.toStr [0.1 + 0.2, 0.4], # List (Frac *) - Inspect.toStr [1u8, 2u8], # List U8 - Inspect.toStr ["foo"], # List Str - ] |> Str.joinWith ", " + Inspect.to_str [0, 1, 2], # List (Num *) + Inspect.to_str [1, 0x2, 3], # List (Int *) + Inspect.to_str [0.1 + 0.2, 0.4], # List (Frac *) + Inspect.to_str [1u8, 2u8], # List U8 + Inspect.to_str ["foo"], # List Str + ] |> Str.join_with ", " "# ), RocStr::from("[0, 1, 2], [1, 2, 3], [0.3, 0.4], [1, 2], [\"foo\"]"), @@ -2314,10 +2314,10 @@ mod inspect { app "test" provides [main] to "./platform" main = [ - Inspect.toStr "", - Inspect.toStr "a small string", - Inspect.toStr "an extraordinarily long string - so long it's on the heap!", - ] |> Str.joinWith ", " + Inspect.to_str "", + Inspect.to_str "a small string", + Inspect.to_str "an extraordinarily long string - so long it's on the heap!", + ] |> Str.join_with ", " "# ), RocStr::from( @@ -2337,7 +2337,7 @@ mod inspect { Op := {} - main = Inspect.toStr (@Op {}) + main = Inspect.to_str (@Op {}) "# ), RocStr::from(r""), @@ -2355,7 +2355,7 @@ mod inspect { Op := {} - late = \a -> Inspect.toStr a + late = \a -> Inspect.to_str a main = late (@Op {}) "# diff --git a/crates/compiler/test_gen/src/gen_compare.rs b/crates/compiler/test_gen/src/gen_compare.rs index 7e2f31dc932..621d9458fe2 100644 --- a/crates/compiler/test_gen/src/gen_compare.rs +++ b/crates/compiler/test_gen/src/gen_compare.rs @@ -291,10 +291,10 @@ fn eq_expr() { Expr : [Add Expr Expr, Mul Expr Expr, Val I64, Var I64] x : Expr - x = Val 0 + x = Val(0) y : Expr - y = Val 0 + y = Val(0) x == y "# @@ -331,10 +331,10 @@ fn eq_linked_list() { LinkedList a : [Nil, Cons a (LinkedList a)] x : LinkedList I64 - x = Cons 1 Nil + x = Cons(1, Nil) y : LinkedList I64 - y = Cons 1 Nil + y = Cons(1, Nil) x == y "# @@ -349,10 +349,10 @@ fn eq_linked_list() { LinkedList a : [Nil, Cons a (LinkedList a)] x : LinkedList I64 - x = Cons 1 (Cons 2 Nil) + x = Cons(1, Cons(2, Nil)) y : LinkedList I64 - y = Cons 1 (Cons 2 Nil) + y = Cons(1, Cons(2, Nil)) x == y "# @@ -371,10 +371,10 @@ fn eq_linked_list_false() { LinkedList a : [Nil, Cons a (LinkedList a)] x : LinkedList I64 - x = Cons 1 Nil + x = Cons(1, Nil) y : LinkedList I64 - y = Cons 1 (Cons 2 Nil) + y = Cons(1, Cons(2, Nil)) y == x "# @@ -394,20 +394,20 @@ fn eq_linked_list_long() { LinkedList a : [Nil, Cons a (LinkedList a)] - prependOnes = \n, tail -> + prepend_ones = \n, tail -> if n == 0 then tail else - prependOnes (n-1) (Cons 1 tail) + prepend_ones (n-1) (Cons 1 tail) main = n = 100_000 # be careful, can make a noticeble difference to test_gen total time! x : LinkedList I64 - x = prependOnes n (Cons 999 Nil) + x = prepend_ones n (Cons 999 Nil) y : LinkedList I64 - y = prependOnes n (Cons 123 Nil) + y = prepend_ones n (Cons 123 Nil) y == x "# diff --git a/crates/compiler/test_gen/src/gen_dict.rs b/crates/compiler/test_gen/src/gen_dict.rs index a9d71357405..2e1de654373 100644 --- a/crates/compiler/test_gen/src/gen_dict.rs +++ b/crates/compiler/test_gen/src/gen_dict.rs @@ -111,7 +111,7 @@ fn dict_nonempty_remove() { empty |> Dict.remove 42 |> Dict.len - |> Num.toI64 + |> Num.to_i64 " ), 0, @@ -128,7 +128,7 @@ fn dict_nonempty_get() { empty : Dict.Dict I64 F64 empty = Dict.insert (Dict.empty {}) 42 1.23 - withDefault = \x, def -> + with_default = \x, def -> when x is Ok v -> v Err _ -> def @@ -136,7 +136,7 @@ fn dict_nonempty_get() { empty |> Dict.insert 42 1.23f64 |> Dict.get 42 - |> withDefault 0 + |> with_default 0 " ), 1.23, @@ -146,15 +146,15 @@ fn dict_nonempty_get() { assert_evals_to!( indoc!( r" - withDefault = \x, def -> - when x is + with_default = \x, def -> + when x is Ok v -> v Err _ -> def Dict.empty {} |> Dict.insert 42 1.23f64 |> Dict.get 43 - |> withDefault 0 + |> with_default 0 " ), 0.0, @@ -168,15 +168,15 @@ fn keys() { assert_evals_to!( indoc!( r" - myDict : Dict.Dict I64 I64 - myDict = + my_dict : Dict.Dict I64 I64 + my_dict = Dict.empty {} |> Dict.insert 0 100 |> Dict.insert 1 100 |> Dict.insert 2 100 - Dict.keys myDict + Dict.keys my_dict " ), RocList::from_slice(&[0, 1, 2]), @@ -190,15 +190,15 @@ fn values() { assert_evals_to!( indoc!( r" - myDict : Dict.Dict I64 I64 - myDict = + my_dict : Dict.Dict I64 I64 + my_dict = Dict.empty {} |> Dict.insert 0 100 |> Dict.insert 1 200 |> Dict.insert 2 300 - Dict.values myDict + Dict.values my_dict " ), RocList::from_slice(&[100, 200, 300]), @@ -212,12 +212,12 @@ fn from_list_with_fold_simple() { assert_evals_to!( indoc!( r" - myDict : Dict.Dict I64 I64 - myDict = + my_dict : Dict.Dict I64 I64 + my_dict = [1,2,3] |> List.walk (Dict.empty {}) (\accum, value -> Dict.insert accum value value) - Dict.values myDict + Dict.values my_dict " ), RocList::from_slice(&[1, 2, 3]), @@ -238,13 +238,13 @@ fn from_list_with_fold_reallocates() { else accum - myDict : Dict.Dict I64 I64 - myDict = + my_dict : Dict.Dict I64 I64 + my_dict = # 25 elements (8 + 16 + 1) is guaranteed to overflow/reallocate at least twice range 0 25 [] |> List.walk (Dict.empty {}) (\accum, value -> Dict.insert accum value value) - Dict.values myDict + Dict.values my_dict " ), RocList::from_slice(&[ @@ -261,12 +261,12 @@ fn small_str_keys() { assert_evals_to!( indoc!( r#" - myDict : Dict.Dict Str I64 - myDict = + my_dict : Dict.Dict Str I64 + my_dict = Dict.empty {} |> Dict.insert "a" 100 - Dict.keys myDict + Dict.keys my_dict "# ), RocList::from_slice(&["a".into()]), @@ -280,14 +280,14 @@ fn big_str_keys() { assert_evals_to!( indoc!( r#" - myDict : Dict.Dict Str I64 - myDict = + my_dict : Dict.Dict Str I64 + my_dict = Dict.empty {} |> Dict.insert "Leverage agile frameworks to provide a robust" 100 |> Dict.insert "synopsis for high level overviews. Iterative approaches" 200 |> Dict.insert "to corporate strategy foster collaborative thinking to" 300 - Dict.keys myDict + Dict.keys my_dict "# ), RocList::from_slice(&[ @@ -305,14 +305,14 @@ fn big_str_values() { assert_evals_to!( indoc!( r#" - myDict : Dict.Dict I64 Str - myDict = + my_dict : Dict.Dict I64 Str + my_dict = Dict.empty {} |> Dict.insert 100 "Leverage agile frameworks to provide a robust" |> Dict.insert 200 "synopsis for high level overviews. Iterative approaches" |> Dict.insert 300 "to corporate strategy foster collaborative thinking to" - Dict.values myDict + Dict.values my_dict "# ), RocList::from_slice(&[ @@ -330,15 +330,15 @@ fn unit_values() { assert_evals_to!( indoc!( r" - myDict : Dict.Dict I64 {} - myDict = + my_dict : Dict.Dict I64 {} + my_dict = Dict.empty {} |> Dict.insert 0 {} |> Dict.insert 1 {} |> Dict.insert 2 {} |> Dict.insert 3 {} - Num.toI64 (Dict.len myDict) + Num.to_i64 (Dict.len my_dict) " ), 4, @@ -352,11 +352,11 @@ fn single() { assert_evals_to!( indoc!( r" - myDict : Dict.Dict I64 {} - myDict = + my_dict : Dict.Dict I64 {} + my_dict = Dict.single 12345 {} - Num.toI64 (Dict.len myDict) + Num.to_i64 (Dict.len my_dict) " ), 1, @@ -370,12 +370,12 @@ fn insert_all() { assert_evals_to!( indoc!( r" - myDict : Dict I64 {} - myDict = - Dict.insertAll (Dict.single 0 {}) (Dict.single 1 {}) + my_dict : Dict I64 {} + my_dict = + Dict.insert_all (Dict.single 0 {}) (Dict.single 1 {}) - Dict.len myDict - |> Num.toI64 + Dict.len my_dict + |> Num.to_i64 " ), 2, @@ -389,12 +389,12 @@ fn insert_all_prefer_second() { assert_evals_to!( indoc!( r" - myDict : Dict.Dict I64 I64 - myDict = + my_dict : Dict.Dict I64 I64 + my_dict = (Dict.single 0 100) - |> Dict.insertAll (Dict.single 0 200) + |> Dict.insert_all (Dict.single 0 200) - Dict.values myDict + Dict.values my_dict " ), RocList::from_slice(&[200]), @@ -424,9 +424,9 @@ fn keep_shared() { |> Dict.insert 2 {} |> Dict.insert 4 {} - Dict.keepShared dict1 dict2 + Dict.keep_shared dict1 dict2 |> Dict.len - |> Num.toI64 + |> Num.to_i64 " ), 2, @@ -456,7 +456,7 @@ fn keep_shared_value_must_match() { |> Dict.insert 2 2 |> Dict.insert 4 300 - Dict.keepShared dict1 dict2 + Dict.keep_shared dict1 dict2 |> Dict.values " ), @@ -487,9 +487,9 @@ fn remove_all() { |> Dict.insert 2 {} |> Dict.insert 4 {} - Dict.removeAll dict1 dict2 + Dict.remove_all dict1 dict2 |> Dict.len - |> Num.toI64 + |> Num.to_i64 " ), 3, @@ -519,7 +519,7 @@ fn remove_all_prefer_first() { |> Dict.insert 2 200 |> Dict.insert 4 300 - Dict.removeAll dict1 dict2 + Dict.remove_all dict1 dict2 |> Dict.values " ), diff --git a/crates/compiler/test_gen/src/gen_erased.rs b/crates/compiler/test_gen/src/gen_erased.rs index de089d30979..f5b509730a9 100644 --- a/crates/compiler/test_gen/src/gen_erased.rs +++ b/crates/compiler/test_gen/src/gen_erased.rs @@ -34,7 +34,7 @@ fn multi_branch_capturing() { f = \t, s -> if t then \{} -> 15u64 - else \{} -> Str.countUtf8Bytes s + else \{} -> Str.count_utf8_bytes s main = ((f Bool.true "abc") {}, (f Bool.false "abc") {}) "# diff --git a/crates/compiler/test_gen/src/gen_list.rs b/crates/compiler/test_gen/src/gen_list.rs index 59f4805091a..cea420c42dd 100644 --- a/crates/compiler/test_gen/src/gen_list.rs +++ b/crates/compiler/test_gen/src/gen_list.rs @@ -226,22 +226,22 @@ fn list_append_basic() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_take_first() { assert_evals_to!( - "List.takeFirst [1, 2, 3] 2", + "List.take_first [1, 2, 3] 2", RocList::from_slice(&[1, 2]), RocList ); assert_evals_to!( - "List.takeFirst [1, 2, 3] 0", + "List.take_first [1, 2, 3] 0", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.takeFirst [] 1", + "List.take_first [] 1", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.takeFirst [1,2] 5", + "List.take_first [1,2] 5", RocList::from_slice(&[1, 2]), RocList ); @@ -251,22 +251,22 @@ fn list_take_first() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_take_last() { assert_evals_to!( - "List.takeLast [1, 2, 3] 2", + "List.take_last [1, 2, 3] 2", RocList::from_slice(&[2, 3]), RocList ); assert_evals_to!( - "List.takeLast [1, 2, 3] 0", + "List.take_last [1, 2, 3] 0", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.takeLast [] 1", + "List.take_last [] 1", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.takeLast [1,2] 5", + "List.take_last [1,2] 5", RocList::from_slice(&[1, 2]), RocList ); @@ -318,7 +318,7 @@ fn list_map_try_ok() { assert_evals_to!( // No transformation r" - List.mapTry [1, 2, 3] \elem -> Ok elem + List.map_try [1, 2, 3] \elem -> Ok elem ", // Result I64 [] is unwrapped to just I64 RocList::::from_slice(&[1, 2, 3]), @@ -327,8 +327,8 @@ fn list_map_try_ok() { assert_evals_to!( // Transformation r#" - List.mapTry [1, 2, 3] \num -> - str = Num.toStr (num * 2) + List.map_try [1, 2, 3] \num -> + str = Num.to_str (num * 2) Ok "$(str)!" "#, @@ -349,7 +349,7 @@ fn list_map_try_err() { assert_evals_to!( r" - List.mapTry [1, 2, 3] \_ -> Err -1 + List.map_try [1, 2, 3] \_ -> Err -1 ", RocResult::err(-1), RocResult, i64> @@ -358,7 +358,7 @@ fn list_map_try_err() { assert_evals_to!( // If any element returns Err, the whole thing returns Err r" - List.mapTry [1, 2, 3] \num -> + List.map_try [1, 2, 3] \num -> if num > 2 then Err -1 else @@ -374,7 +374,7 @@ fn list_map_try_err() { fn list_split_at() { assert_evals_to!( r" - list = List.splitAt [1, 2, 3] 0 + list = List.split_at [1, 2, 3] 0 list.before ", RocList::::from_slice(&[]), @@ -382,7 +382,7 @@ fn list_split_at() { ); assert_evals_to!( r" - list = List.splitAt [1, 2, 3] 0 + list = List.split_at [1, 2, 3] 0 list.others ", RocList::from_slice(&[1, 2, 3]), @@ -390,13 +390,13 @@ fn list_split_at() { ); assert_evals_to!( r" - List.splitAt [1, 2, 3] 1 + List.split_at [1, 2, 3] 1 ", (RocList::from_slice(&[1]), RocList::from_slice(&[2, 3])), (RocList, RocList,) ); assert_evals_to!( - "List.splitAt [1, 2, 3] 3", + "List.split_at [1, 2, 3] 3", ( RocList::from_slice(&[1, 2, 3]), RocList::::from_slice(&[]), @@ -404,7 +404,7 @@ fn list_split_at() { (RocList, RocList,) ); assert_evals_to!( - "List.splitAt [1, 2, 3] 4", + "List.split_at [1, 2, 3] 4", ( RocList::from_slice(&[1, 2, 3]), RocList::::from_slice(&[]), @@ -412,7 +412,7 @@ fn list_split_at() { (RocList, RocList,) ); assert_evals_to!( - "List.splitAt [] 1", + "List.split_at [] 1", ( RocList::::from_slice(&[]), RocList::::from_slice(&[]), @@ -426,14 +426,14 @@ fn list_split_at() { fn list_split_on() { assert_evals_to!( r" - List.splitOn [] 1 + List.split_on [] 1 ", RocList::>::from_slice(&[RocList::::from_slice(&[])]), RocList> ); assert_evals_to!( r" - List.splitOn [1] 1 + List.split_on [1] 1 ", RocList::>::from_slice(&[ RocList::::from_slice(&[]), @@ -443,14 +443,14 @@ fn list_split_on() { ); assert_evals_to!( r" - List.splitOn [1, 2, 3] 47 + List.split_on [1, 2, 3] 47 ", RocList::>::from_slice(&[RocList::::from_slice(&[1, 2, 3])]), RocList> ); assert_evals_to!( r" - List.splitOn [1, 2, 3, 4, 5] 3 + List.split_on [1, 2, 3, 4, 5] 3 ", RocList::>::from_slice(&[ RocList::::from_slice(&[1, 2]), @@ -460,7 +460,7 @@ fn list_split_on() { ); assert_evals_to!( r" - List.splitOn [1, 0, 1, 0, 1] 1 + List.split_on [1, 0, 1, 0, 1] 1 ", RocList::>::from_slice(&[ RocList::::from_slice(&[]), @@ -472,7 +472,7 @@ fn list_split_on() { ); assert_evals_to!( r" - List.splitOn [1, 0, 1, 0, 1] 0 + List.split_on [1, 0, 1, 0, 1] 0 ", RocList::>::from_slice(&[ RocList::::from_slice(&[1]), @@ -488,28 +488,28 @@ fn list_split_on() { fn list_split_on_list() { assert_evals_to!( r" - List.splitOnList [] [] + List.split_on_list [] [] ", RocList::>::from_slice(&[RocList::::from_slice(&[])]), RocList> ); assert_evals_to!( r" - List.splitOnList [] [1, 2, 3] + List.split_on_list [] [1, 2, 3] ", RocList::>::from_slice(&[RocList::::from_slice(&[]),]), RocList> ); assert_evals_to!( r" - List.splitOnList [1, 2, 3] [] + List.split_on_list [1, 2, 3] [] ", RocList::>::from_slice(&[RocList::::from_slice(&[1, 2, 3]),]), RocList> ); assert_evals_to!( r" - List.splitOnList [1] [1] + List.split_on_list [1] [1] ", RocList::>::from_slice(&[ RocList::::from_slice(&[]), @@ -519,14 +519,14 @@ fn list_split_on_list() { ); assert_evals_to!( r" - List.splitOnList [1, 2, 3] [47] + List.split_on_list [1, 2, 3] [47] ", RocList::>::from_slice(&[RocList::::from_slice(&[1, 2, 3])]), RocList> ); assert_evals_to!( r" - List.splitOnList [1, 2, 3, 4, 5] [2, 3] + List.split_on_list [1, 2, 3, 4, 5] [2, 3] ", RocList::>::from_slice(&[ RocList::::from_slice(&[1]), @@ -536,7 +536,7 @@ fn list_split_on_list() { ); assert_evals_to!( r" - List.splitOnList [1, 0, 1, 0, 1] [1] + List.split_on_list [1, 0, 1, 0, 1] [1] ", RocList::>::from_slice(&[ RocList::::from_slice(&[]), @@ -553,7 +553,7 @@ fn list_split_on_list() { fn list_split_first() { assert_evals_to!( r" - List.splitFirst [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 + List.split_first [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 |> Result.map .before ", RocResult::ok(RocList::::from_slice(&[2, 3])), @@ -561,7 +561,7 @@ fn list_split_first() { ); assert_evals_to!( r" - List.splitFirst [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 + List.split_first [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 |> Result.map .after ", RocResult::ok(RocList::::from_slice(&[4, 0, 6, 0, 8, 9])), @@ -569,13 +569,13 @@ fn list_split_first() { ); assert_evals_to!( - "List.splitFirst [1, 2, 3] 0", + "List.split_first [1, 2, 3] 0", RocResult::err(()), RocResult<(RocList, RocList), ()> ); assert_evals_to!( - "List.splitFirst [] 1", + "List.split_first [] 1", RocResult::err(()), RocResult<(RocList, RocList), ()> ); @@ -586,7 +586,7 @@ fn list_split_first() { fn list_split_last() { assert_evals_to!( r" - List.splitLast [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 + List.split_last [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 |> Result.map .before ", RocResult::ok(RocList::::from_slice(&[2, 3, 0, 4, 0, 6])), @@ -594,7 +594,7 @@ fn list_split_last() { ); assert_evals_to!( r" - List.splitLast [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 + List.split_last [2, 3, 0, 4, 0, 6, 0, 8, 9] 0 |> Result.map .after ", RocResult::ok(RocList::::from_slice(&[8, 9])), @@ -602,13 +602,13 @@ fn list_split_last() { ); assert_evals_to!( - "List.splitLast [1, 2, 3] 0", + "List.split_last [1, 2, 3] 0", RocResult::err(()), RocResult<(RocList, RocList), ()> ); assert_evals_to!( - "List.splitLast [] 1", + "List.split_last [] 1", RocResult::err(()), RocResult<(RocList, RocList), ()> ); @@ -618,7 +618,7 @@ fn list_split_last() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn list_chunks_of() { assert_evals_to!( - "List.chunksOf [1, 2, 3, 4, 5, 6, 7, 8] 3", + "List.chunks_of [1, 2, 3, 4, 5, 6, 7, 8] 3", RocList::>::from_slice(&[ RocList::from_slice(&[1, 2, 3]), RocList::from_slice(&[4, 5, 6]), @@ -628,19 +628,19 @@ fn list_chunks_of() { ); assert_evals_to!( - "List.chunksOf [1, 2, 3, 4] 5", + "List.chunks_of [1, 2, 3, 4] 5", RocList::>::from_slice(&[RocList::from_slice(&[1, 2, 3, 4]),]), RocList> ); assert_evals_to!( - "List.chunksOf [1, 2, 3] 0", + "List.chunks_of [1, 2, 3] 0", RocList::>::from_slice(&[]), RocList> ); assert_evals_to!( - "List.chunksOf [] 5", + "List.chunks_of [] 5", RocList::>::from_slice(&[]), RocList> ); @@ -650,17 +650,17 @@ fn list_chunks_of() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_drop_first() { assert_evals_to!( - "List.dropFirst [1,2,3] 2", + "List.drop_first [1,2,3] 2", RocList::from_slice(&[3]), RocList ); assert_evals_to!( - "List.dropFirst [] 1", + "List.drop_first [] 1", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.dropFirst [1,2] 5", + "List.drop_first [1,2] 5", RocList::::from_slice(&[]), RocList ); @@ -670,27 +670,27 @@ fn list_drop_first() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_drop_at() { assert_evals_to!( - "List.dropAt [1, 2, 3] 0", + "List.drop_at [1, 2, 3] 0", RocList::from_slice(&[2, 3]), RocList ); assert_evals_to!( - "List.dropAt [1, 2, 3] 1", + "List.drop_at [1, 2, 3] 1", RocList::from_slice(&[1, 3]), RocList ); assert_evals_to!( - "List.dropAt [0, 0, 0] 3", + "List.drop_at [0, 0, 0] 3", RocList::from_slice(&[0, 0, 0]), RocList ); assert_evals_to!( - "List.dropAt [] 1", + "List.drop_at [] 1", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.dropAt [0] 0", + "List.drop_at [0] 0", RocList::::from_slice(&[]), RocList ); @@ -728,7 +728,7 @@ fn list_drop_at_shared() { list : List I64 list = [if Bool.true then 4 else 4, 5, 6] - { newList: List.dropAt list 0, original: list } + { new_list: List.drop_at list 0, original: list } " ), ( @@ -750,7 +750,7 @@ fn list_drop_if_empty_list_of_int() { empty : List I64 empty = [] - List.dropIf empty \_ -> Bool.true + List.drop_if empty \_ -> Bool.true " ), RocList::::from_slice(&[]), @@ -764,10 +764,10 @@ fn list_drop_if_empty_list() { assert_evals_to!( indoc!( r" - alwaysTrue : I64 -> Bool - alwaysTrue = \_ -> Bool.true + always_true : I64 -> Bool + always_true = \_ -> Bool.true - List.dropIf [] alwaysTrue + List.drop_if [] always_true " ), RocList::::from_slice(&[]), @@ -781,7 +781,7 @@ fn list_drop_if_always_false_for_non_empty_list() { assert_evals_to!( indoc!( r" - List.dropIf [1,2,3,4,5,6,7,8] (\_ -> Bool.false) + List.drop_if [1,2,3,4,5,6,7,8] (\_ -> Bool.false) " ), RocList::from_slice(&[1, 2, 3, 4, 5, 6, 7, 8]), @@ -795,7 +795,7 @@ fn list_drop_if_always_true_for_non_empty_list() { assert_evals_to!( indoc!( r" - List.dropIf [1,2,3,4,5,6,7,8] (\_ -> Bool.true) + List.drop_if [1,2,3,4,5,6,7,8] (\_ -> Bool.true) " ), RocList::::from_slice(&[]), @@ -809,7 +809,7 @@ fn list_drop_if_geq3() { assert_evals_to!( indoc!( r" - List.dropIf [1,2,3,4,5,6,7,8] (\n -> n >= 3) + List.drop_if [1,2,3,4,5,6,7,8] (\n -> n >= 3) " ), RocList::from_slice(&[1, 2]), @@ -823,7 +823,7 @@ fn list_drop_if_string_eq() { assert_evals_to!( indoc!( r#" - List.dropIf ["x", "y", "x"] (\s -> s == "y") + List.drop_if ["x", "y", "x"] (\s -> s == "y") "# ), RocList::from_slice(&[RocStr::from("x"), RocStr::from("x")]), @@ -835,17 +835,17 @@ fn list_drop_if_string_eq() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_drop_last() { assert_evals_to!( - "List.dropLast [1, 2, 3] 1", + "List.drop_last [1, 2, 3] 1", RocList::from_slice(&[1, 2]), RocList ); assert_evals_to!( - "List.dropLast [] 5", + "List.drop_last [] 5", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.dropLast [0] 0", + "List.drop_last [0] 0", RocList::::from_slice(&[0]), RocList ); @@ -860,7 +860,7 @@ fn list_drop_last_mutable() { list : List I64 list = [if Bool.true then 4 else 4, 5, 6] - { newList: List.dropLast list 1, original: list } + { new_list: List.drop_last list 1, original: list } " ), ( @@ -921,11 +921,11 @@ fn list_append_to_empty_list_of_int() { assert_evals_to!( indoc!( r" - initThrees : List I64 - initThrees = + init_threes : List I64 + init_threes = [] - List.append (List.append initThrees 3) 3 + List.append (List.append init_threes 3) 3 " ), RocList::from_slice(&[3, 3]), @@ -1067,7 +1067,7 @@ fn list_walk_backwards_empty_all_inline() { assert_evals_to!( indoc!( r" - List.walkBackwards [0x1] 0 \state, elem -> state + elem + List.walk_backwards [0x1] 0 \state, elem -> state + elem " ), 1, @@ -1081,7 +1081,7 @@ fn list_walk_backwards_empty_all_inline() { empty = [] - List.walkBackwards empty 0 \state, elem -> state + elem + List.walk_backwards empty 0 \state, elem -> state + elem " ), 0, @@ -1093,13 +1093,13 @@ fn list_walk_backwards_empty_all_inline() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_walk_backwards_with_str() { assert_evals_to!( - r#"List.walkBackwards ["x", "y", "z"] "<" Str.concat"#, + r#"List.walk_backwards ["x", "y", "z"] "<" Str.concat"#, RocStr::from(" when b is Zero -> { r & zeroes: r.zeroes + 1 } One -> { r & ones: r.ones + 1 } - finalCounts = List.walkBackwards byte initialCounts acc + final_counts = List.walk_backwards byte initial_counts acc - finalCounts.ones * 10 + finalCounts.zeroes + final_counts.ones * 10 + final_counts.zeroes " ), 35, @@ -1158,7 +1158,7 @@ fn list_walk_subtraction() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_walk_until_sum() { - assert_evals_to!(r"List.walkUntil [1, 2] 0 \a,b -> Continue (a + b)", 3, i64); + assert_evals_to!(r"List.walk_until [1, 2] 0 \a,b -> Continue (a + b)", 3, i64); } #[test] @@ -1166,14 +1166,14 @@ fn list_walk_until_sum() { fn list_walk_with_index_until_sum() { assert_evals_to!( r" - List.walkWithIndexUntil [5, 7, 2, 3] 0 (\state, elem, index -> + List.walk_with_index_until [5, 7, 2, 3] 0 (\state, elem, index -> if elem % 2 == 0 then Break state else # Convert to I64 to sidestep weird bug with WASM codegen - a = Num.toI64 elem - b = Num.toI64 index - c = Num.toI64 state + a = Num.to_i64 elem + b = Num.to_i64 index + c = Num.to_i64 state Continue (a + b + c) ) ", @@ -1191,11 +1191,11 @@ fn list_walk_implements_position() { find : List a, a -> Option U64 where a implements Eq find = \list, needle -> - findHelp list needle + find_help list needle |> .v - findHelp = \list, needle -> - List.walkUntil list { n: 0, v: None } \{ n, v }, element -> + find_help = \list, needle -> + List.walk_until list { n: 0, v: None } \{ n, v }, element -> if element == needle then Break { n, v: Some n } else @@ -1216,13 +1216,13 @@ fn list_walk_until_even_prefix_sum() { assert_evals_to!( r" helper = \a, b -> - if Num.isEven b then + if Num.is_even b then Continue (a + b) else Break a - List.walkUntil [2, 4, 8, 9] 0 helper", + List.walk_until [2, 4, 8, 9] 0 helper", 2 + 4 + 8, i64 ); @@ -1231,7 +1231,7 @@ fn list_walk_until_even_prefix_sum() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_walk_from_sum() { - assert_evals_to!(r"List.walkFrom [1, 2, 3] 1 0 Num.add", 5, i64); + assert_evals_to!(r"List.walk_from [1, 2, 3] 1 0 Num.add", 5, i64); } #[test] @@ -1244,7 +1244,7 @@ fn list_keep_if_empty_list_of_int() { empty = [] - List.keepIf empty \_ -> Bool.true + List.keep_if empty \_ -> Bool.true " ), RocList::::from_slice(&[]), @@ -1258,12 +1258,12 @@ fn list_keep_if_empty_list() { assert_evals_to!( indoc!( r" - alwaysTrue : I64 -> Bool - alwaysTrue = \_ -> + always_true : I64 -> Bool + always_true = \_ -> Bool.true - List.keepIf [] alwaysTrue + List.keep_if [] always_true " ), RocList::::from_slice(&[]), @@ -1277,15 +1277,15 @@ fn list_keep_if_always_true_for_non_empty_list() { assert_evals_to!( indoc!( r" - alwaysTrue : I64 -> Bool - alwaysTrue = \_ -> + always_true : I64 -> Bool + always_true = \_ -> Bool.true - oneThroughEight : List I64 - oneThroughEight = + one_through_eight : List I64 + one_through_eight = [1,2,3,4,5,6,7,8] - List.keepIf oneThroughEight alwaysTrue + List.keep_if one_through_eight always_true " ), RocList::from_slice(&[1, 2, 3, 4, 5, 6, 7, 8]), @@ -1299,11 +1299,11 @@ fn list_keep_if_always_false_for_non_empty_list() { assert_evals_to!( indoc!( r" - alwaysFalse : I64 -> Bool - alwaysFalse = \_ -> + always_false : I64 -> Bool + always_false = \_ -> Bool.false - List.keepIf [1,2,3,4,5,6,7,8] alwaysFalse + List.keep_if [1,2,3,4,5,6,7,8] always_false " ), RocList::::from_slice(&[]), @@ -1317,11 +1317,11 @@ fn list_keep_if_one() { assert_evals_to!( indoc!( r" - intIsLessThanThree : I64 -> Bool - intIsLessThanThree = \i -> + int_is_less_than_three : I64 -> Bool + int_is_less_than_three = \i -> i < 3 - List.keepIf [1,2,3,4,5,6,7,8] intIsLessThanThree + List.keep_if [1,2,3,4,5,6,7,8] int_is_less_than_three " ), RocList::from_slice(&[1, 2]), @@ -1335,7 +1335,7 @@ fn list_keep_if_str_is_hello() { assert_evals_to!( indoc!( r#" - List.keepIf ["x", "y", "x"] (\x -> x == "x") + List.keep_if ["x", "y", "x"] (\x -> x == "x") "# ), RocList::from_slice(&[RocStr::from("x"), RocStr::from("x")]), @@ -1349,7 +1349,7 @@ fn list_count_if_empty_list() { assert_evals_to!( indoc!( r" - List.countIf [] \_ -> Bool.true + List.count_if [] \_ -> Bool.true " ), 0, @@ -1363,15 +1363,15 @@ fn list_count_if_always_true_for_non_empty_list() { assert_evals_to!( indoc!( r" - alwaysTrue : I64 -> Bool - alwaysTrue = \_ -> + always_true : I64 -> Bool + always_true = \_ -> Bool.true - oneThroughEight : List I64 - oneThroughEight = + one_through_eight : List I64 + one_through_eight = [1,2,3,4,5,6,7,8] - List.countIf oneThroughEight alwaysTrue + List.count_if one_through_eight always_true " ), 8, @@ -1385,11 +1385,11 @@ fn list_count_if_always_false_for_non_empty_list() { assert_evals_to!( indoc!( r" - alwaysFalse : I64 -> Bool - alwaysFalse = \_ -> + always_false : I64 -> Bool + always_false = \_ -> Bool.false - List.countIf [1,2,3,4,5,6,7,8] alwaysFalse + List.count_if [1,2,3,4,5,6,7,8] always_false " ), 0, @@ -1403,11 +1403,11 @@ fn list_count_if_condition() { assert_evals_to!( indoc!( r" - intIsLessThanThree : I64 -> Bool - intIsLessThanThree = \i -> + int_is_less_than_three : I64 -> Bool + int_is_less_than_three = \i -> i < 3 - List.countIf [1,2,3,4,5,6,7,8] intIsLessThanThree + List.count_if [1,2,3,4,5,6,7,8] int_is_less_than_three " ), 2, @@ -1421,7 +1421,7 @@ fn list_count_if_str() { assert_evals_to!( indoc!( r#" - List.countIf ["x", "y", "x"] (\x -> x == "x") + List.count_if ["x", "y", "x"] (\x -> x == "x") "# ), 2, @@ -1453,11 +1453,11 @@ fn list_map_on_non_empty_list() { assert_evals_to!( indoc!( r" - nonEmpty : List I64 - nonEmpty = + non_empty : List I64 + non_empty = [1] - List.map nonEmpty (\x -> x) + List.map non_empty (\x -> x) " ), RocList::from_slice(&[1]), @@ -1471,11 +1471,11 @@ fn list_map_changes_input() { assert_evals_to!( indoc!( r" - nonEmpty : List I64 - nonEmpty = + non_empty : List I64 + non_empty = [1] - List.map nonEmpty (\x -> x + 1) + List.map non_empty (\x -> x + 1) " ), RocList::from_slice(&[2]), @@ -1489,11 +1489,11 @@ fn list_map_on_big_list() { assert_evals_to!( indoc!( r" - nonEmpty : List I64 - nonEmpty = + non_empty : List I64 + non_empty = [1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5] - List.map nonEmpty (\x -> x * 2) + List.map non_empty (\x -> x * 2) " ), RocList::from_slice(&[ @@ -1509,12 +1509,12 @@ fn list_map_with_type_change() { assert_evals_to!( indoc!( r" - nonEmpty : List I64 - nonEmpty = + non_empty : List I64 + non_empty = [1, 1, -4, 1, 2] - List.map nonEmpty (\x -> x > 0) + List.map non_empty (\x -> x > 0) " ), RocList::from_slice(&[true, true, false, true, true]), @@ -1528,15 +1528,15 @@ fn list_map_using_defined_function() { assert_evals_to!( indoc!( r" - nonEmpty : List I64 - nonEmpty = + non_empty : List I64 + non_empty = [2, 2, -4, 2, 3] - greaterThanOne : I64 -> Bool - greaterThanOne = \i -> + greater_than_one : I64 -> Bool + greater_than_one = \i -> i > 1 - List.map nonEmpty greaterThanOne + List.map non_empty greater_than_one " ), RocList::from_slice(&[true, true, false, true, true]), @@ -1857,11 +1857,11 @@ fn list_repeat() { assert_evals_to!( indoc!( r" - noStrs : List Str - noStrs = + no_strs : List Str + no_strs = [] - List.repeat noStrs 2 + List.repeat no_strs 2 " ), RocList::from_slice(&[RocList::::default(), RocList::default()]), @@ -1897,11 +1897,11 @@ fn list_reverse_empty_list_of_int() { assert_evals_to!( indoc!( r" - emptyList : List I64 - emptyList = + empty_list : List I64 + empty_list = [] - List.reverse emptyList + List.reverse empty_list " ), RocList::::from_slice(&[]), @@ -1935,15 +1935,15 @@ fn list_concat_two_empty_lists_of_int() { assert_evals_to!( indoc!( r" - firstList : List I64 - firstList = + first_list : List I64 + first_list = [] - secondList : List I64 - secondList = + second_list : List I64 + second_list = [] - List.concat firstList secondList + List.concat first_list second_list " ), RocList::::from_slice(&[]), @@ -2106,11 +2106,11 @@ fn fn_int_list_len() { assert_evals_to!( indoc!( r" - getLen = \list -> List.len list + get_len = \list -> List.len list nums = [2, 4, 6, 8] - getLen nums + get_len nums " ), 4, @@ -2121,13 +2121,13 @@ fn fn_int_list_len() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn int_list_is_empty() { - assert_evals_to!("List.isEmpty [12, 9, 6, 3]", false, bool); + assert_evals_to!("List.is_empty [12, 9, 6, 3]", false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn empty_list_is_empty() { - assert_evals_to!("List.isEmpty []", true, bool); + assert_evals_to!("List.is_empty []", true, bool); } #[test] @@ -2527,10 +2527,10 @@ fn gen_wrap_len() { assert_evals_to!( indoc!( r" - wrapLen = \list -> + wrap_len = \list -> [List.len list] - wrapLen [1, 7, 9] + wrap_len [1, 7, 9] " ), RocList::from_slice(&[3]), @@ -2544,10 +2544,10 @@ fn gen_wrap_first() { assert_evals_to!( indoc!( r" - wrapFirst = \list -> + wrap_first = \list -> [List.first list] - wrapFirst [1, 2] + wrap_first [1, 2] " ), RocList::from_slice(&[1]), @@ -2590,10 +2590,10 @@ fn gen_swap() { swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set i atJ - |> List.set j atI + |> List.set i at_j + |> List.set j at_i _ -> [] @@ -2619,17 +2619,17 @@ fn gen_quicksort() { quicksort : List (Num a) -> List (Num a) quicksort = \list -> n = List.len list - quicksortHelp list 0 (n - 1) + quicksort_help list 0 (n - 1) - quicksortHelp : List (Num a), U64, U64 -> List (Num a) - quicksortHelp = \list, low, high -> + quicksort_help : List (Num a), U64, U64 -> List (Num a) + quicksort_help = \list, low, high -> if low < high then when partition low high list is - Pair partitionIndex partitioned -> + Pair partition_index partitioned -> partitioned - |> quicksortHelp low (Num.subSaturated partitionIndex 1) - |> quicksortHelp (partitionIndex + 1) high + |> quicksort_help low (Num.sub_saturated partition_index 1) + |> quicksort_help (partition_index + 1) high else list @@ -2637,35 +2637,35 @@ fn gen_quicksort() { swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set i atJ - |> List.set j atI + |> List.set i at_j + |> List.set j at_i _ -> [] partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] - partition = \low, high, initialList -> - when List.get initialList high is + partition = \low, high, initial_list -> + when List.get initial_list high is Ok pivot -> - when partitionHelp low low initialList high pivot is - Pair newI newList -> - Pair newI (swap newI high newList) + when partition_help low low initial_list high pivot is + Pair new_i new_list -> + Pair new_i (swap new_i high new_list) Err _ -> - Pair low initialList + Pair low initial_list - partitionHelp : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] - partitionHelp = \i, j, list, high, pivot -> + partition_help : U64, U64, List (Num a), U64, (Num a) -> [Pair U64 (List (Num a))] + partition_help = \i, j, list, high, pivot -> if j < high then when List.get list j is Ok value -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap i j list) high pivot + partition_help (i + 1) (j + 1) (swap i j list) high pivot else - partitionHelp i (j + 1) list high pivot + partition_help i (j + 1) list high pivot Err _ -> Pair i list @@ -2692,17 +2692,17 @@ fn quicksort() { quicksort : List (Num a) -> List (Num a) quicksort = \list -> - quicksortHelp list 0 (List.len list - 1) + quicksort_help list 0 (List.len list - 1) - quicksortHelp : List (Num a), U64, U64 -> List (Num a) - quicksortHelp = \list, low, high -> + quicksort_help : List (Num a), U64, U64 -> List (Num a) + quicksort_help = \list, low, high -> if low < high then when partition low high list is - Pair partitionIndex partitioned -> + Pair partition_index partitioned -> partitioned - |> quicksortHelp low (Num.subSaturated partitionIndex 1) - |> quicksortHelp (partitionIndex + 1) high + |> quicksort_help low (Num.sub_saturated partition_index 1) + |> quicksort_help (partition_index + 1) high else list @@ -2710,36 +2710,36 @@ fn quicksort() { swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set i atJ - |> List.set j atI + |> List.set i at_j + |> List.set j at_i _ -> [] partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] - partition = \low, high, initialList -> - when List.get initialList high is + partition = \low, high, initial_list -> + when List.get initial_list high is Ok pivot -> - when partitionHelp low low initialList high pivot is - Pair newI newList -> - Pair newI (swap newI high newList) + when partition_help low low initial_list high pivot is + Pair new_i new_list -> + Pair new_i (swap new_i high new_list) Err _ -> - Pair low initialList + Pair low initial_list - partitionHelp : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] - partitionHelp = \i, j, list, high, pivot -> + partition_help : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] + partition_help = \i, j, list, high, pivot -> # if j < high then if Bool.false then when List.get list j is Ok value -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap i j list) high pivot + partition_help (i + 1) (j + 1) (swap i j list) high pivot else - partitionHelp i (j + 1) list high pivot + partition_help i (j + 1) list high pivot Err _ -> Pair i list @@ -2768,17 +2768,17 @@ fn quicksort_singleton() { quicksort : List (Num a) -> List (Num a) quicksort = \list -> - quicksortHelp list 0 (List.len list - 1) + quicksort_help list 0 (List.len list - 1) - quicksortHelp : List (Num a), U64, U64 -> List (Num a) - quicksortHelp = \list, low, high -> + quicksort_help : List (Num a), U64, U64 -> List (Num a) + quicksort_help = \list, low, high -> if low < high then when partition low high list is - Pair partitionIndex partitioned -> + Pair partition_index partitioned -> partitioned - |> quicksortHelp low (Num.subSaturated partitionIndex 1) - |> quicksortHelp (partitionIndex + 1) high + |> quicksort_help low (Num.sub_saturated partition_index 1) + |> quicksort_help (partition_index + 1) high else list @@ -2786,35 +2786,35 @@ fn quicksort_singleton() { swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set i atJ - |> List.set j atI + |> List.set i at_j + |> List.set j at_i _ -> [] partition : U64, U64, List (Num a) -> [Pair U64 (List (Num a))] - partition = \low, high, initialList -> - when List.get initialList high is + partition = \low, high, initial_list -> + when List.get initial_list high is Ok pivot -> - when partitionHelp low low initialList high pivot is - Pair newI newList -> - Pair newI (swap newI high newList) + when partition_help low low initial_list high pivot is + Pair new_i new_list -> + Pair new_i (swap new_i high new_list) Err _ -> - Pair low initialList + Pair low initial_list - partitionHelp : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] - partitionHelp = \i, j, list, high, pivot -> + partition_help : U64, U64, List (Num a), U64, Num a -> [Pair U64 (List (Num a))] + partition_help = \i, j, list, high, pivot -> if j < high then when List.get list j is Ok value -> if value <= pivot then - partitionHelp (i + 1) (j + 1) (swap i j list) high pivot + partition_help (i + 1) (j + 1) (swap i j list) high pivot else - partitionHelp i (j + 1) list high pivot + partition_help i (j + 1) list high pivot Err _ -> Pair i list @@ -3047,13 +3047,13 @@ fn list_product() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_keep_void() { assert_evals_to!( - "List.keepOks [] (\\x -> x)", + "List.keep_oks [] (\\x -> x)", RocList::from_slice(&[]), RocList<()> ); assert_evals_to!( - "List.keepErrs [] (\\x -> x)", + "List.keep_errs [] (\\x -> x)", RocList::from_slice(&[]), RocList<()> ); @@ -3063,22 +3063,22 @@ fn list_keep_void() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_keep_oks() { assert_evals_to!( - "List.keepOks [Ok {}, Ok {}] (\\x -> x)", + "List.keep_oks [Ok {}, Ok {}] (\\x -> x)", RocList::from_slice(&[(), ()]), RocList<()> ); assert_evals_to!( - "List.keepOks [1,2] (\\x -> Ok x)", + "List.keep_oks [1,2] (\\x -> Ok x)", RocList::from_slice(&[1, 2]), RocList ); assert_evals_to!( - "List.keepOks [1,2] (\\x -> Num.remChecked x 2)", + "List.keep_oks [1,2] (\\x -> Num.rem_checked x 2)", RocList::from_slice(&[1, 0]), RocList ); assert_evals_to!( - "List.keepOks [Ok 1, Err 2] (\\x -> x)", + "List.keep_oks [Ok 1, Err 2] (\\x -> x)", RocList::from_slice(&[1]), RocList ); @@ -3088,19 +3088,19 @@ fn list_keep_oks() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_keep_errs() { assert_evals_to!( - "List.keepErrs [Err {}, Err {}] (\\x -> x)", + "List.keep_errs [Err {}, Err {}] (\\x -> x)", RocList::from_slice(&[(), ()]), RocList<()> ); assert_evals_to!( - "List.keepErrs [1,2] (\\x -> Err x)", + "List.keep_errs [1,2] (\\x -> Err x)", RocList::from_slice(&[1, 2]), RocList ); assert_evals_to!( indoc!( r" - List.keepErrs [0,1,2] (\x -> Num.remChecked x 0 |> Result.mapErr (\_ -> 32)) + List.keep_errs [0,1,2] (\x -> Num.rem_checked x 0 |> Result.map_err (\_ -> 32)) " ), RocList::from_slice(&[32, 32, 32]), @@ -3108,7 +3108,7 @@ fn list_keep_errs() { ); assert_evals_to!( - "List.keepErrs [Ok 1, Err 2] (\\x -> x)", + "List.keep_errs [Ok 1, Err 2] (\\x -> x)", RocList::from_slice(&[2]), RocList ); @@ -3118,7 +3118,7 @@ fn list_keep_errs() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_map_with_index() { assert_evals_to!( - "List.mapWithIndex [0,0,0] (\\x, index -> Num.intCast index + x)", + "List.map_with_index [0,0,0] (\\x, index -> Num.int_cast index + x)", RocList::from_slice(&[0, 1, 2]), RocList ); @@ -3136,7 +3136,7 @@ fn cleanup_because_exception() { five : I64 five = 5 - five + Num.maxI64 + 3 + (Num.intCast (List.len x)) + five + Num.max_i64 + 3 + (Num.int_cast (List.len x)) " ), 9, @@ -3148,17 +3148,17 @@ fn cleanup_because_exception() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_sort_with() { assert_evals_to!( - "List.sortWith [] Num.compare", + "List.sort_with [] Num.compare", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.sortWith [4,3,2,1] Num.compare", + "List.sort_with [4,3,2,1] Num.compare", RocList::from_slice(&[1, 2, 3, 4]), RocList ); assert_evals_to!( - "List.sortWith [1,2,3,4] (\\a,b -> Num.compare b a)", + "List.sort_with [1,2,3,4] (\\a,b -> Num.compare b a)", RocList::from_slice(&[4, 3, 2, 1]), RocList ); @@ -3168,12 +3168,12 @@ fn list_sort_with() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_sort_asc() { assert_evals_to!( - "List.sortAsc []", + "List.sort_asc []", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.sortAsc [4,3,2,1]", + "List.sort_asc [4,3,2,1]", RocList::from_slice(&[1, 2, 3, 4]), RocList ); @@ -3183,12 +3183,12 @@ fn list_sort_asc() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_sort_desc() { assert_evals_to!( - "List.sortDesc []", + "List.sort_desc []", RocList::::from_slice(&[]), RocList ); assert_evals_to!( - "List.sortDesc [1,2,3,4]", + "List.sort_desc [1,2,3,4]", RocList::from_slice(&[4, 3, 2, 1]), RocList ); @@ -3224,7 +3224,7 @@ fn list_all_empty_with_unknown_element_type() { } #[test] -// This doesn't work on Windows. If you make it return a `bool`, e.g. with `|> Str.isEmpty` at the end, +// This doesn't work on Windows. If you make it return a `bool`, e.g. with `|> Str.is_empty` at the end, // then it works. We don't know what the problem is here! #[cfg(all( not(target_family = "windows"), @@ -3256,7 +3256,7 @@ fn map_with_index_multi_record() { assert_evals_to!( indoc!( r" - List.mapWithIndex [{ x: {}, y: {} }] \_, _ -> {} + List.map_with_index [{ x: {}, y: {} }] \_, _ -> {} " ), RocList::from_slice(&[((), ())]), @@ -3271,17 +3271,17 @@ fn empty_list_of_function_type() { assert_evals_to!( indoc!( r#" - myList : List (Str -> Str) - myList = [] + my_list : List (Str -> Str) + my_list = [] - myClosure : Str -> Str - myClosure = \_ -> "bar" + my_closure : Str -> Str + my_closure = \_ -> "bar" choose = if Bool.false then - myList + my_list else - [myClosure] + [my_closure] when List.get choose 0 is Ok f -> f "foo" @@ -3299,7 +3299,7 @@ fn list_join_map() { assert_evals_to!( indoc!( r#" - List.joinMap ["guava,apple,pear", "bailey,cyrus"] (\s -> Str.splitOn s ",") + List.join_map ["guava,apple,pear", "bailey,cyrus"] (\s -> Str.split_on s ",") "# ), RocList::from_slice(&[ @@ -3319,7 +3319,7 @@ fn list_join_map_empty() { assert_evals_to!( indoc!( r#" - List.joinMap [] (\s -> Str.splitOn s ",") + List.join_map [] (\s -> Str.split_on s ",") "# ), RocList::from_slice(&[]), @@ -3333,7 +3333,7 @@ fn list_find() { assert_evals_to!( indoc!( r#" - when List.findFirst ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 1) is + when List.find_first ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 1) is Ok v -> v Err _ -> "not found" "# @@ -3345,7 +3345,7 @@ fn list_find() { assert_evals_to!( indoc!( r#" - when List.findLast ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 1) is + when List.find_last ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 1) is Ok v -> v Err _ -> "not found" "# @@ -3361,7 +3361,7 @@ fn list_find_not_found() { assert_evals_to!( indoc!( r#" - when List.findFirst ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_first ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> "not found" "# @@ -3373,7 +3373,7 @@ fn list_find_not_found() { assert_evals_to!( indoc!( r#" - when List.findLast ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_last ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> "not found" "# @@ -3389,7 +3389,7 @@ fn list_find_empty_typed_list() { assert_evals_to!( indoc!( r#" - when List.findFirst [] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_first [] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> "not found" "# @@ -3401,7 +3401,7 @@ fn list_find_empty_typed_list() { assert_evals_to!( indoc!( r#" - when List.findLast [] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_last [] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> "not found" "# @@ -3417,7 +3417,7 @@ fn list_find_empty_layout() { assert_evals_to!( indoc!( r" - List.findFirst [] \_ -> Bool.true + List.find_first [] \_ -> Bool.true " ), // [Ok [], Err [NotFound]] gets unwrapped all the way to just [NotFound], @@ -3429,7 +3429,7 @@ fn list_find_empty_layout() { assert_evals_to!( indoc!( r" - List.findLast [] \_ -> Bool.true + List.find_last [] \_ -> Bool.true " ), // [Ok [], Err [NotFound]] gets unwrapped all the way to just [NotFound], @@ -3445,7 +3445,7 @@ fn list_find_index() { assert_evals_to!( indoc!( r#" - when List.findFirstIndex ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 1) is + when List.find_first_index ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 1) is Ok v -> v Err _ -> 999 "# @@ -3457,7 +3457,7 @@ fn list_find_index() { assert_evals_to!( indoc!( r#" - when List.findLastIndex ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 1) is + when List.find_last_index ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 1) is Ok v -> v Err _ -> 999 "# @@ -3473,7 +3473,7 @@ fn list_find_index_not_found() { assert_evals_to!( indoc!( r#" - when List.findFirstIndex ["a", "bc", "def", "g"] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_first_index ["a", "bc", "def", "g"] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> 999 "# @@ -3485,7 +3485,7 @@ fn list_find_index_not_found() { assert_evals_to!( indoc!( r#" - when List.findLastIndex ["a", "bc", "def"] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_last_index ["a", "bc", "def"] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> 999 "# @@ -3501,7 +3501,7 @@ fn list_find_index_empty_typed_list() { assert_evals_to!( indoc!( r" - when List.findFirstIndex [] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_first_index [] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> 999 " @@ -3513,7 +3513,7 @@ fn list_find_index_empty_typed_list() { assert_evals_to!( indoc!( r" - when List.findLastIndex [] (\s -> Str.countUtf8Bytes s > 5) is + when List.find_last_index [] (\s -> Str.count_utf8_bytes s > 5) is Ok v -> v Err _ -> 999 " @@ -3529,7 +3529,7 @@ fn list_ends_with_empty() { assert_evals_to!( indoc!( r" - List.endsWith [] [] + List.ends_with [] [] " ), true, @@ -3539,7 +3539,7 @@ fn list_ends_with_empty() { assert_evals_to!( indoc!( r#" - List.endsWith ["a"] [] + List.ends_with ["a"] [] "# ), true, @@ -3549,7 +3549,7 @@ fn list_ends_with_empty() { assert_evals_to!( indoc!( r#" - List.endsWith [] ["a"] + List.ends_with [] ["a"] "# ), false, @@ -3563,7 +3563,7 @@ fn list_ends_with_nonempty() { assert_evals_to!( indoc!( r#" - List.endsWith ["a", "bc", "def"] ["def"] + List.ends_with ["a", "bc", "def"] ["def"] "# ), true, @@ -3573,7 +3573,7 @@ fn list_ends_with_nonempty() { assert_evals_to!( indoc!( r#" - List.endsWith ["a", "bc", "def"] ["bc", "def"] + List.ends_with ["a", "bc", "def"] ["bc", "def"] "# ), true, @@ -3583,7 +3583,7 @@ fn list_ends_with_nonempty() { assert_evals_to!( indoc!( r#" - List.endsWith ["a", "bc", "def"] ["a"] + List.ends_with ["a", "bc", "def"] ["a"] "# ), false, @@ -3593,7 +3593,7 @@ fn list_ends_with_nonempty() { assert_evals_to!( indoc!( r#" - List.endsWith ["a", "bc", "def"] [""] + List.ends_with ["a", "bc", "def"] [""] "# ), false, @@ -3607,7 +3607,7 @@ fn list_starts_with_empty() { assert_evals_to!( indoc!( r" - List.startsWith [] [] + List.starts_with [] [] " ), true, @@ -3617,7 +3617,7 @@ fn list_starts_with_empty() { assert_evals_to!( indoc!( r#" - List.startsWith ["a"] [] + List.starts_with ["a"] [] "# ), true, @@ -3627,7 +3627,7 @@ fn list_starts_with_empty() { assert_evals_to!( indoc!( r#" - List.startsWith [] ["a"] + List.starts_with [] ["a"] "# ), false, @@ -3641,7 +3641,7 @@ fn list_starts_with_nonempty() { assert_evals_to!( indoc!( r#" - List.startsWith ["a", "bc", "def"] ["a"] + List.starts_with ["a", "bc", "def"] ["a"] "# ), true, @@ -3651,7 +3651,7 @@ fn list_starts_with_nonempty() { assert_evals_to!( indoc!( r#" - List.startsWith ["a", "bc", "def"] ["a", "bc"] + List.starts_with ["a", "bc", "def"] ["a", "bc"] "# ), true, @@ -3661,7 +3661,7 @@ fn list_starts_with_nonempty() { assert_evals_to!( indoc!( r#" - List.startsWith ["a", "bc", "def"] ["def"] + List.starts_with ["a", "bc", "def"] ["def"] "# ), false, @@ -3671,7 +3671,7 @@ fn list_starts_with_nonempty() { assert_evals_to!( indoc!( r#" - List.startsWith ["a", "bc", "def"] [""] + List.starts_with ["a", "bc", "def"] [""] "# ), false, @@ -3705,7 +3705,7 @@ fn with_capacity() { indoc!( r" l : List U64 - l = List.withCapacity 10 + l = List.with_capacity 10 l " @@ -3724,7 +3724,7 @@ fn with_capacity_append() { assert_evals_to!( indoc!( r" - List.withCapacity 10 + List.with_capacity 10 |> List.append 0u64 |> List.append 1u64 |> List.append 2u64 @@ -3783,7 +3783,7 @@ fn release_excess_capacity() { indoc!( r" List.reserve [] 15 - |> List.releaseExcessCapacity + |> List.release_excess_capacity " ), (0, RocList::empty()), @@ -3799,7 +3799,7 @@ fn release_excess_capacity_with_len() { indoc!( r" List.reserve [1] 50 - |> List.releaseExcessCapacity + |> List.release_excess_capacity " ), (1, RocList::from_slice(&[1])), @@ -3814,7 +3814,7 @@ fn release_excess_capacity_empty() { assert_evals_to!( indoc!( r" - List.releaseExcessCapacity [] + List.release_excess_capacity [] " ), (0, RocList::empty()), @@ -3864,10 +3864,10 @@ fn issue_3571_lowlevel_call_function_with_bool_lambda_set() { apply : List (a -> b), List a -> List b apply = \funs, vals -> - initial = List.withCapacity ((List.len funs) * (List.len vals)) - List.walk funs initial \state, fun -> - mappedVals = List.map vals fun - List.concat state mappedVals + initial = List.with_capacity ((List.len funs) * (List.len vals)) + List.walk funs initial \state, fun -> + mapped_vals = List.map vals fun + List.concat state mapped_vals add2 : Str -> Str add2 = \x -> "added $(x)" @@ -3878,7 +3878,7 @@ fn issue_3571_lowlevel_call_function_with_bool_lambda_set() { foo = [add2, mul2] bar = ["1", "2", "3", "4"] - main = foo |> apply bar |> Str.joinWith ", " + main = foo |> apply bar |> Str.join_with ", " "# ), RocStr::from("added 1, added 2, added 3, added 4, multiplied 1, multiplied 2, multiplied 3, multiplied 4"), @@ -3930,11 +3930,11 @@ fn list_walk_backwards_implements_position() { find : List a, a -> Option U64 where a implements Eq find = \list, needle -> - findHelp list needle + find_help list needle |> .v - findHelp = \list, needle -> - List.walkBackwardsUntil list { n: 0, v: None } \{ n, v }, element -> + find_help = \list, needle -> + List.walk_backwards_until list { n: 0, v: None } \{ n, v }, element -> if element == needle then Break { n, v: Some n } else @@ -3953,7 +3953,7 @@ fn list_walk_backwards_implements_position() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_walk_backwards_until_sum() { assert_evals_to!( - r"List.walkBackwardsUntil [1, 2] 0 \a,b -> Continue (a + b)", + r"List.walk_backwards_until [1, 2] 0 \a,b -> Continue (a + b)", 3, i64 ); @@ -3965,13 +3965,13 @@ fn list_walk_backwards_until_even_prefix_sum() { assert_evals_to!( r" helper = \a, b -> - if Num.isEven b then + if Num.is_even b then Continue (a + b) else Break a - List.walkBackwardsUntil [9, 8, 4, 2] 0 helper", + List.walk_backwards_until [9, 8, 4, 2] 0 helper", 2 + 4 + 8, i64 ); @@ -3981,7 +3981,7 @@ fn list_walk_backwards_until_even_prefix_sum() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn list_walk_from_until_sum() { assert_evals_to!( - r"List.walkFromUntil [1, 2, 3, 4] 2 0 \a,b -> Continue (a + b)", + r"List.walk_from_until [1, 2, 3, 4] 2 0 \a,b -> Continue (a + b)", 7, i64 ); @@ -3992,13 +3992,13 @@ fn list_walk_from_until_sum() { fn concat_unique_to_nonunique_overlapping_issue_4697() { assert_evals_to!( r" - # originalList is shared, but others is unique. - # When we concat originalList with others, others should be re-used. + # original_list is shared, but others is unique. + # When we concat original_list with others, others should be re-used. - originalList = [1u8] + original_list = [1u8] others = [2u8, 3u8, 4u8] - new = List.concat originalList others - {a: originalList, b: new} + new = List.concat original_list others + {a: original_list, b: new} ", ( RocList::from_slice(&[1u8]), @@ -4014,13 +4014,13 @@ fn list_walk_from_even_prefix_sum() { assert_evals_to!( r" helper = \a, b -> - if Num.isEven b then + if Num.is_even b then Continue (a + b) else Break a - List.walkFromUntil [2, 4, 8, 9] 1 0 helper", + List.walk_from_until [2, 4, 8, 9] 1 0 helper", 4 + 8, i64 ); @@ -4281,7 +4281,7 @@ mod pattern_match { fn list_concat_utf8() { assert_evals_to!( r#" - List.concatUtf8 [1, 2, 3, 4] "🐦" + List.concat_utf8 [1, 2, 3, 4] "🐦" "#, RocList::from_slice(&[1u8, 2, 3, 4, 240, 159, 144, 166]), RocList diff --git a/crates/compiler/test_gen/src/gen_num.rs b/crates/compiler/test_gen/src/gen_num.rs index b3d50dd07d3..e374c061d41 100644 --- a/crates/compiler/test_gen/src/gen_num.rs +++ b/crates/compiler/test_gen/src/gen_num.rs @@ -482,13 +482,13 @@ fn f64_sqrt_checked_0() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn f64_sqrt_checked_positive() { - assert_evals_to!("Num.sqrtChecked 100f64", RocResult::ok(10.0), RocResult); + assert_evals_to!("Num.sqrt_checked 100f64", RocResult::ok(10.0), RocResult); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn f64_sqrt_checked_negative() { - assert_evals_to!("Num.sqrtChecked -1f64", RocResult::err(()), RocResult); + assert_evals_to!("Num.sqrt_checked -1f64", RocResult::err(()), RocResult); } #[test] @@ -500,13 +500,13 @@ fn f64_log() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn f64_log_checked_one() { - assert_evals_to!("Num.logChecked 1f64", RocResult::ok(0.0), RocResult); + assert_evals_to!("Num.log_checked 1f64", RocResult::ok(0.0), RocResult); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn f64_log_checked_zero() { - assert_evals_to!("Num.logChecked 0f64", RocResult::err(()), RocResult); + assert_evals_to!("Num.log_checked 0f64", RocResult::err(()), RocResult); } #[test] @@ -531,8 +531,8 @@ fn f64_abs() { assert_evals_to!("Num.abs -4.7f64", 4.7, f64); assert_evals_to!("Num.abs 5.8f64", 5.8, f64); - assert_evals_to!("Num.abs Num.maxF64", f64::MAX, f64); - assert_evals_to!("Num.abs Num.minF64", f64::MAX, f64); + assert_evals_to!("Num.abs Num.max_f64", f64::MAX, f64); + assert_evals_to!("Num.abs Num.min_f64", f64::MAX, f64); } #[test] @@ -541,8 +541,8 @@ fn f32_abs() { assert_evals_to!("Num.abs -4.7f32", 4.7, f32); assert_evals_to!("Num.abs 5.8f32", 5.8, f32); - assert_evals_to!("Num.abs Num.maxF32", f32::MAX, f32); - assert_evals_to!("Num.abs Num.minF32", f32::MAX, f32); + assert_evals_to!("Num.abs Num.max_f32", f32::MAX, f32); + assert_evals_to!("Num.abs Num.min_f32", f32::MAX, f32); } #[test] @@ -556,8 +556,8 @@ fn i64_abs() { assert_evals_to!("Num.abs 1", 1, i64); assert_evals_to!("Num.abs 9_000_000_000_000", 9_000_000_000_000, i64); assert_evals_to!("Num.abs -9_000_000_000_000", 9_000_000_000_000, i64); - assert_evals_to!("Num.abs Num.maxI64", i64::MAX, i64); - assert_evals_to!("Num.abs (Num.minI64 + 1)", -(i64::MIN + 1), i64); + assert_evals_to!("Num.abs Num.max_i64", i64::MAX, i64); + assert_evals_to!("Num.abs (Num.min_i64 + 1)", -(i64::MIN + 1), i64); } #[test] @@ -588,7 +588,7 @@ fn abs_min_int_overflow() { assert_evals_to!( indoc!( r" - Num.abs Num.minI64 + Num.abs Num.min_i64 " ), 0, @@ -602,7 +602,7 @@ fn gen_if_fn() { assert_evals_to!( indoc!( r" - limitedNegate = \num -> + limited_negate = \num -> x = if num == 1 then -1 @@ -612,7 +612,7 @@ fn gen_if_fn() { num x - limitedNegate 1 + limited_negate 1 " ), -1, @@ -701,7 +701,7 @@ fn gen_div_checked_f64() { assert_evals_to!( indoc!( r" - when Num.divChecked 48 2f64 is + when Num.div_checked 48 2f64 is Ok val -> val Err _ -> -1 " @@ -717,7 +717,7 @@ fn gen_div_checked_by_zero_f64() { assert_evals_to!( indoc!( r" - when Num.divChecked 47 0f64 is + when Num.div_checked 47 0f64 is Ok val -> val Err _ -> -1 " @@ -759,7 +759,7 @@ fn gen_div_checked_dec() { y : Dec y = 3 - when Num.divChecked x y is + when Num.div_checked x y is Ok val -> val Err _ -> -1 " @@ -780,7 +780,7 @@ fn gen_div_checked_by_zero_dec() { y : Dec y = 0 - when Num.divChecked x y is + when Num.div_checked x y is Ok val -> val Err _ -> -1 " @@ -810,7 +810,7 @@ fn gen_div_dec_by_zero() { fn gen_div_ceil_by_zero() { assert_evals_to!( r" - Num.divCeil 5 0 == 0 + Num.div_ceil 5 0 == 0 ", false, bool @@ -909,11 +909,11 @@ fn gen_wrap_int_neq() { assert_evals_to!( indoc!( r" - wrappedNotEq : a, a -> Bool where a implements Eq - wrappedNotEq = \num1, num2 -> + wrapped_not_eq : a, a -> Bool where a implements Eq + wrapped_not_eq = \num1, num2 -> num1 != num2 - wrappedNotEq 2 3 + wrapped_not_eq 2 3 " ), true, @@ -1172,7 +1172,7 @@ fn gen_div_by_zero_i64() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_div_checked_i64() { assert_evals_to!( - "Num.divTruncChecked 1000 10", + "Num.div_trunc_checked 1000 10", RocResult::ok(100), RocResult ); @@ -1182,7 +1182,7 @@ fn gen_div_checked_i64() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_div_checked_by_zero_i64() { assert_evals_to!( - "Num.divTruncChecked 1000 0", + "Num.div_trunc_checked 1000 0", RocResult::err(()), RocResult ); @@ -1205,7 +1205,7 @@ fn gen_rem_div_by_zero_i64() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_rem_checked_i64() { assert_evals_to!( - "Num.remChecked 42 40", + "Num.rem_checked 42 40", RocResult::ok(2), RocResult ); @@ -1215,7 +1215,7 @@ fn gen_rem_checked_i64() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_rem_checked_div_by_zero_i64() { assert_evals_to!( - "Num.remChecked 8 0", + "Num.rem_checked 8 0", RocResult::err(()), RocResult ); @@ -1224,67 +1224,67 @@ fn gen_rem_checked_div_by_zero_i64() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_positive_i64() { - assert_evals_to!("Num.isPositive 0", false, bool); - assert_evals_to!("Num.isPositive 1", true, bool); - assert_evals_to!("Num.isPositive -5", false, bool); + assert_evals_to!("Num.is_positive 0", false, bool); + assert_evals_to!("Num.is_positive 1", true, bool); + assert_evals_to!("Num.is_positive -5", false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_negative_i64() { - assert_evals_to!("Num.isNegative 0", false, bool); - assert_evals_to!("Num.isNegative 3", false, bool); - assert_evals_to!("Num.isNegative -2", true, bool); + assert_evals_to!("Num.is_negative 0", false, bool); + assert_evals_to!("Num.is_negative 3", false, bool); + assert_evals_to!("Num.is_negative -2", true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_positive_f64() { - assert_evals_to!("Num.isPositive 0.0", false, bool); - assert_evals_to!("Num.isPositive 4.7", true, bool); - assert_evals_to!("Num.isPositive -8.5", false, bool); + assert_evals_to!("Num.is_positive 0.0", false, bool); + assert_evals_to!("Num.is_positive 4.7", true, bool); + assert_evals_to!("Num.is_positive -8.5", false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_negative_f64() { - assert_evals_to!("Num.isNegative 0.0", false, bool); - assert_evals_to!("Num.isNegative 9.9", false, bool); - assert_evals_to!("Num.isNegative -4.4", true, bool); + assert_evals_to!("Num.is_negative 0.0", false, bool); + assert_evals_to!("Num.is_negative 9.9", false, bool); + assert_evals_to!("Num.is_negative -4.4", true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_zero_i64() { - assert_evals_to!("Num.isZero 0", true, bool); - assert_evals_to!("Num.isZero 0_0", true, bool); - assert_evals_to!("Num.isZero 1", false, bool); + assert_evals_to!("Num.is_zero 0", true, bool); + assert_evals_to!("Num.is_zero 0_0", true, bool); + assert_evals_to!("Num.is_zero 1", false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_zero_f64() { - assert_evals_to!("Num.isZero 0.0f64", true, bool); + assert_evals_to!("Num.is_zero 0.0f64", true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_zero_dec() { - assert_evals_to!("Num.isZero 0.0dec", true, bool); + assert_evals_to!("Num.is_zero 0.0dec", true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_odd() { - assert_evals_to!("Num.isOdd 4", false, bool); - assert_evals_to!("Num.isOdd 5", true, bool); + assert_evals_to!("Num.is_odd 4", false, bool); + assert_evals_to!("Num.is_odd 5", true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_even() { - assert_evals_to!("Num.isEven 6", true, bool); - assert_evals_to!("Num.isEven 7", false, bool); + assert_evals_to!("Num.is_even 6", true, bool); + assert_evals_to!("Num.is_even 7", false, bool); } #[test] @@ -1331,25 +1331,25 @@ fn tan() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn bitwise_and() { - assert_evals_to!("Num.bitwiseAnd 20 20", 20, i64); - assert_evals_to!("Num.bitwiseAnd 25 10", 8, i64); - assert_evals_to!("Num.bitwiseAnd 200 0", 0, i64); + assert_evals_to!("Num.bitwise_and 20 20", 20, i64); + assert_evals_to!("Num.bitwise_and 25 10", 8, i64); + assert_evals_to!("Num.bitwise_and 200 0", 0, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn bitwise_xor() { - assert_evals_to!("Num.bitwiseXor 20 20", 0, i64); - assert_evals_to!("Num.bitwiseXor 15 14", 1, i64); - assert_evals_to!("Num.bitwiseXor 7 15", 8, i64); - assert_evals_to!("Num.bitwiseXor 200 0", 200, i64); + assert_evals_to!("Num.bitwise_xor 20 20", 0, i64); + assert_evals_to!("Num.bitwise_xor 15 14", 1, i64); + assert_evals_to!("Num.bitwise_xor 7 15", 8, i64); + assert_evals_to!("Num.bitwise_xor 200 0", 200, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn bitwise_or() { - assert_evals_to!("Num.bitwiseOr 1 1", 1, i64); - assert_evals_to!("Num.bitwiseOr 1 2", 3, i64); + assert_evals_to!("Num.bitwise_or 1 1", 1, i64); + assert_evals_to!("Num.bitwise_or 1 2", 3, i64); } #[test] @@ -1507,21 +1507,25 @@ fn gte_f64() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn gen_is_approx_eq() { - assert_evals_to!("Num.isApproxEq 1e10f64 1.00001e10f64 {}", true, bool); - assert_evals_to!("Num.isApproxEq 1e-7f64 1e-8f64 {}", false, bool); - assert_evals_to!("Num.isApproxEq 1e-8f32 1e-9f32 {}", true, bool); - assert_evals_to!("Num.isApproxEq 1e10f64 1.0001e10f64 {}", false, bool); - assert_evals_to!("Num.isApproxEq 1.0f32 1.0 {}", true, bool); - assert_evals_to!("Num.isApproxEq (1f64 / 0.0) (1f64 / 0.0) {}", true, bool); - assert_evals_to!("Num.isApproxEq (0f64 / 0.0) (0f64 / 0.0) {}", false, bool); - assert_evals_to!("Num.isApproxEq 1e-8f64 0f64 {}", true, bool); - assert_evals_to!("Num.isApproxEq 1e-7f64 0f64 {}", false, bool); - assert_evals_to!("Num.isApproxEq 1e-100f64 0f64 { atol: 0f64 }", false, bool); - assert_evals_to!("Num.isApproxEq 1e-7f64 0f64 { atol: 0f64 }", false, bool); - assert_evals_to!("Num.isApproxEq 1e-10f64 1e-20f64 {}", true, bool); - assert_evals_to!("Num.isApproxEq 1e-10f64 0f64 {}", true, bool); - assert_evals_to!( - "Num.isApproxEq 1e-10f64 0.999999e-10f64 { atol: 0f64 }", + assert_evals_to!("Num.is_approx_eq 1e10f64 1.00001e10f64 {}", true, bool); + assert_evals_to!("Num.is_approx_eq 1e-7f64 1e-8f64 {}", false, bool); + assert_evals_to!("Num.is_approx_eq 1e-8f32 1e-9f32 {}", true, bool); + assert_evals_to!("Num.is_approx_eq 1e10f64 1.0001e10f64 {}", false, bool); + assert_evals_to!("Num.is_approx_eq 1.0f32 1.0 {}", true, bool); + assert_evals_to!("Num.is_approx_eq (1f64 / 0.0) (1f64 / 0.0) {}", true, bool); + assert_evals_to!("Num.is_approx_eq (0f64 / 0.0) (0f64 / 0.0) {}", false, bool); + assert_evals_to!("Num.is_approx_eq 1e-8f64 0f64 {}", true, bool); + assert_evals_to!("Num.is_approx_eq 1e-7f64 0f64 {}", false, bool); + assert_evals_to!( + "Num.is_approx_eq 1e-100f64 0f64 { atol: 0f64 }", + false, + bool + ); + assert_evals_to!("Num.is_approx_eq 1e-7f64 0f64 { atol: 0f64 }", false, bool); + assert_evals_to!("Num.is_approx_eq 1e-10f64 1e-20f64 {}", true, bool); + assert_evals_to!("Num.is_approx_eq 1e-10f64 0f64 {}", true, bool); + assert_evals_to!( + "Num.is_approx_eq 1e-10f64 0.999999e-10f64 { atol: 0f64 }", true, bool ); @@ -1616,36 +1620,36 @@ fn tail_call_elimination() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_negate() { assert_evals_to!("Num.neg 123i8", -123, i8); - assert_evals_to!("Num.neg Num.maxI8", -i8::MAX, i8); - assert_evals_to!("Num.neg (Num.minI8 + 1)", i8::MAX, i8); + assert_evals_to!("Num.neg Num.max_i8", -i8::MAX, i8); + assert_evals_to!("Num.neg (Num.min_i8 + 1)", i8::MAX, i8); assert_evals_to!("Num.neg 123i16", -123, i16); - assert_evals_to!("Num.neg Num.maxI16", -i16::MAX, i16); - assert_evals_to!("Num.neg (Num.minI16 + 1)", i16::MAX, i16); + assert_evals_to!("Num.neg Num.max_i16", -i16::MAX, i16); + assert_evals_to!("Num.neg (Num.min_i16 + 1)", i16::MAX, i16); assert_evals_to!("Num.neg 123i32", -123, i32); - assert_evals_to!("Num.neg Num.maxI32", -i32::MAX, i32); - assert_evals_to!("Num.neg (Num.minI32 + 1)", i32::MAX, i32); + assert_evals_to!("Num.neg Num.max_i32", -i32::MAX, i32); + assert_evals_to!("Num.neg (Num.min_i32 + 1)", i32::MAX, i32); assert_evals_to!("Num.neg 123", -123, i64); - assert_evals_to!("Num.neg Num.maxI64", -i64::MAX, i64); - assert_evals_to!("Num.neg (Num.minI64 + 1)", i64::MAX, i64); + assert_evals_to!("Num.neg Num.max_i64", -i64::MAX, i64); + assert_evals_to!("Num.neg (Num.min_i64 + 1)", i64::MAX, i64); assert_evals_to!("Num.neg 12.3f32", -12.3, f32); assert_evals_to!("Num.neg 0.0f32", -0.0, f32); - assert_evals_to!("Num.neg Num.maxF32", -f32::MAX, f32); - assert_evals_to!("Num.neg Num.minF32", -f32::MIN, f32); - assert_evals_to!("Num.neg Num.infinityF32", -f32::INFINITY, f32); + assert_evals_to!("Num.neg Num.max_f32", -f32::MAX, f32); + assert_evals_to!("Num.neg Num.min_f32", -f32::MIN, f32); + assert_evals_to!("Num.neg Num.infinity_f32", -f32::INFINITY, f32); // can't test equality for nan - assert_evals_to!("Num.isNaN (Num.neg Num.nanF32)", true, bool); + assert_evals_to!("Num.is_nan (Num.neg Num.nan_f32)", true, bool); assert_evals_to!("Num.neg 12.3f64", -12.3, f64); assert_evals_to!("Num.neg 0.0f64", -0.0, f64); - assert_evals_to!("Num.neg Num.maxF64", -f64::MAX, f64); - assert_evals_to!("Num.neg Num.minF64", -f64::MIN, f64); - assert_evals_to!("Num.neg Num.infinityF64", -f64::INFINITY, f64); + assert_evals_to!("Num.neg Num.max_f64", -f64::MAX, f64); + assert_evals_to!("Num.neg Num.min_f64", -f64::MIN, f64); + assert_evals_to!("Num.neg Num.infinity_f64", -f64::INFINITY, f64); // can't test equality for nan - assert_evals_to!("Num.isNaN (Num.neg Num.nanF64)", true, bool); + assert_evals_to!("Num.is_nan (Num.neg Num.nan_f64)", true, bool); assert_evals_to!("Num.neg 123dec", RocDec::from(-123), RocDec); // 0 is signless, unlike f32/f64 @@ -1661,7 +1665,7 @@ fn neg_min_int_overflow() { assert_evals_to!( indoc!( r" - Num.neg Num.minI64 + Num.neg Num.min_i64 " ), 0, @@ -1675,9 +1679,9 @@ fn gen_wrap_int_neg() { assert_evals_to!( indoc!( r" - wrappedNeg = \num -> -num + wrapped_neg = \num -> -num - wrappedNeg 3 + wrapped_neg 3 " ), -3, @@ -1705,13 +1709,13 @@ fn gen_basic_fn() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn int_to_float() { - assert_evals_to!("Num.toFrac 0x9", RocDec::from(9i32), RocDec); + assert_evals_to!("Num.to_frac 0x9", RocDec::from(9i32), RocDec); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_to_frac() { - assert_evals_to!("Num.toFrac 9", RocDec::from(9i32), RocDec); + assert_evals_to!("Num.to_frac 9", RocDec::from(9i32), RocDec); } #[test] @@ -1724,7 +1728,7 @@ fn num_to_frac_f64_to_f32() { f64 = 9.0 f32 : F32 - f32 = Num.toFrac f64 + f32 = Num.to_frac f64 f32 " ), @@ -1744,7 +1748,7 @@ fn num_to_frac_f32_to_f32() { arg = 9.0 ret : F32 - ret = Num.toFrac arg + ret = Num.to_frac arg ret " ), @@ -1764,7 +1768,7 @@ fn num_to_frac_f64_to_f64() { arg = 9.0 ret : F64 - ret = Num.toFrac arg + ret = Num.to_frac arg ret " ), @@ -1784,7 +1788,7 @@ fn num_to_frac_f32_to_f64() { f32 = 9.0 f64 : F64 - f64 = Num.toFrac f32 + f64 = Num.to_frac f32 f64 " ), @@ -1800,7 +1804,7 @@ fn float_to_float() { indoc!( r" x : F64 - x = Num.toFrac 0.5f64 + x = Num.to_frac 0.5f64 x " @@ -1813,29 +1817,29 @@ fn float_to_float() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn frac_is_nan() { - assert_evals_to!("Num.isNaN (0 / 0f64)", true, bool); - assert_evals_to!("Num.isNaN (1 / 0f64)", false, bool); - assert_evals_to!("Num.isNaN 42f64", false, bool); - assert_evals_to!("Num.isNaN 42dec", false, bool); + assert_evals_to!("Num.is_nan (0 / 0f64)", true, bool); + assert_evals_to!("Num.is_nan (1 / 0f64)", false, bool); + assert_evals_to!("Num.is_nan 42f64", false, bool); + assert_evals_to!("Num.is_nan 42dec", false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn frac_is_infinite() { - assert_evals_to!("Num.isInfinite (1 / 0f64)", true, bool); - assert_evals_to!("Num.isInfinite (-1 / 0f64)", true, bool); - assert_evals_to!("Num.isInfinite (0 / 0f64)", false, bool); - assert_evals_to!("Num.isInfinite 42f64", false, bool); - assert_evals_to!("Num.isInfinite 42dec", false, bool); + assert_evals_to!("Num.is_infinite (1 / 0f64)", true, bool); + assert_evals_to!("Num.is_infinite (-1 / 0f64)", true, bool); + assert_evals_to!("Num.is_infinite (0 / 0f64)", false, bool); + assert_evals_to!("Num.is_infinite 42f64", false, bool); + assert_evals_to!("Num.is_infinite 42dec", false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn frac_is_finite() { - assert_evals_to!("Num.isFinite 42f64", true, bool); - assert_evals_to!("Num.isFinite (1 / 0f64)", false, bool); - assert_evals_to!("Num.isFinite (0 / 0f64)", false, bool); - assert_evals_to!("Num.isFinite 42dec", true, bool); + assert_evals_to!("Num.is_finite 42f64", true, bool); + assert_evals_to!("Num.is_finite (1 / 0f64)", false, bool); + assert_evals_to!("Num.is_finite (0 / 0f64)", false, bool); + assert_evals_to!("Num.is_finite 42dec", true, bool); } #[test] @@ -1923,14 +1927,14 @@ fn floor_dec() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn pow_int() { - assert_evals_to!("Num.powInt 2 3", 8, i64); + assert_evals_to!("Num.pow_int 2 3", 8, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] #[should_panic(expected = r#"Roc failed with message: "Integer raised to power overflowed!"#)] fn pow_int_overflow() { - assert_evals_to!("Num.powInt 2u8 8", 0, u8); + assert_evals_to!("Num.pow_int 2u8 8", 0, u8); } #[test] @@ -1950,7 +1954,7 @@ fn int_add_overflow() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn int_add_checked_ok() { assert_evals_to!( - "Num.addChecked 1 2", + "Num.add_checked 1 2", RocResult::ok(3), RocResult ); @@ -1960,7 +1964,7 @@ fn int_add_checked_ok() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn int_add_checked_err() { assert_evals_to!( - "Num.addChecked 9_223_372_036_854_775_807 1", + "Num.add_checked 9_223_372_036_854_775_807 1", RocResult::err(()), RocResult ); @@ -1970,7 +1974,7 @@ fn int_add_checked_err() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn float_add_checked_pass() { assert_evals_to!( - "Num.addChecked 1.0 0.0f64", + "Num.add_checked 1.0 0.0f64", RocResult::ok(1.0), RocResult ); @@ -1980,7 +1984,7 @@ fn float_add_checked_pass() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn float_add_checked_fail() { assert_evals_to!( - "Num.addChecked 1.7976931348623157e308f64 1.7976931348623157e308", + "Num.add_checked 1.7976931348623157e308f64 1.7976931348623157e308", RocResult::err(()), RocResult ); @@ -1999,38 +2003,38 @@ fn float_add_overflow() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn add_wrap() { - assert_evals_to!("Num.addWrap 255u8 10u8", 9u8, u8); - assert_evals_to!("Num.addWrap 127i8 10i8", -119i8, i8); - assert_evals_to!("Num.addWrap -127i8 -10i8", 119i8, i8); - assert_evals_to!("Num.addWrap 65535u16 10", 9u16, u16); - assert_evals_to!("Num.addWrap 32767i16 10", -32759i16, i16); - assert_evals_to!("Num.addWrap -32767i16 -10", 32759i16, i16); - assert_evals_to!("Num.addWrap 4294967295u32 10", 9u32, u32); - assert_evals_to!("Num.addWrap 2147483647i32 10", -2147483639i32, i32); - assert_evals_to!("Num.addWrap -2147483647i32 -10", 2147483639i32, i32); - assert_evals_to!("Num.addWrap 18446744073709551615u64 10", 9u64, u64); - assert_evals_to!( - "Num.addWrap 9223372036854775807i64 10", + assert_evals_to!("Num.add_wrap 255u8 10u8", 9u8, u8); + assert_evals_to!("Num.add_wrap 127i8 10i8", -119i8, i8); + assert_evals_to!("Num.add_wrap -127i8 -10i8", 119i8, i8); + assert_evals_to!("Num.add_wrap 65535u16 10", 9u16, u16); + assert_evals_to!("Num.add_wrap 32767i16 10", -32759i16, i16); + assert_evals_to!("Num.add_wrap -32767i16 -10", 32759i16, i16); + assert_evals_to!("Num.add_wrap 4294967295u32 10", 9u32, u32); + assert_evals_to!("Num.add_wrap 2147483647i32 10", -2147483639i32, i32); + assert_evals_to!("Num.add_wrap -2147483647i32 -10", 2147483639i32, i32); + assert_evals_to!("Num.add_wrap 18446744073709551615u64 10", 9u64, u64); + assert_evals_to!( + "Num.add_wrap 9223372036854775807i64 10", -9223372036854775799i64, i64 ); assert_evals_to!( - "Num.addWrap -9223372036854775807i64 -10", + "Num.add_wrap -9223372036854775807i64 -10", 9223372036854775799i64, i64 ); assert_evals_to!( - "Num.addWrap 340282366920938463463374607431768211455u128 10", + "Num.add_wrap 340282366920938463463374607431768211455u128 10", U128::from(9u128), U128 ); assert_evals_to!( - "Num.addWrap 170141183460469231731687303715884105727i128 10", + "Num.add_wrap 170141183460469231731687303715884105727i128 10", I128::from(-170141183460469231731687303715884105719i128), I128 ); assert_evals_to!( - "Num.addWrap -170141183460469231731687303715884105727i128 -10", + "Num.add_wrap -170141183460469231731687303715884105727i128 -10", I128::from(170141183460469231731687303715884105719i128), I128 ); @@ -2039,85 +2043,85 @@ fn add_wrap() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn add_saturated() { - assert_evals_to!("Num.addSaturated 200u8 200u8", 255u8, u8); - assert_evals_to!("Num.addSaturated 100i8 100i8", 127i8, i8); - assert_evals_to!("Num.addSaturated -100i8 -100i8", -128i8, i8); - assert_evals_to!("Num.addSaturated 40000u16 40000u16", 65535u16, u16); - assert_evals_to!("Num.addSaturated 20000i16 20000i16", 32767i16, i16); - assert_evals_to!("Num.addSaturated -20000i16 -20000i16", -32768i16, i16); - assert_evals_to!( - "Num.addSaturated 3000000000u32 3000000000u32", + assert_evals_to!("Num.add_saturated 200u8 200u8", 255u8, u8); + assert_evals_to!("Num.add_saturated 100i8 100i8", 127i8, i8); + assert_evals_to!("Num.add_saturated -100i8 -100i8", -128i8, i8); + assert_evals_to!("Num.add_saturated 40000u16 40000u16", 65535u16, u16); + assert_evals_to!("Num.add_saturated 20000i16 20000i16", 32767i16, i16); + assert_evals_to!("Num.add_saturated -20000i16 -20000i16", -32768i16, i16); + assert_evals_to!( + "Num.add_saturated 3000000000u32 3000000000u32", 4294967295u32, u32 ); assert_evals_to!( - "Num.addSaturated 2000000000i32 2000000000i32", + "Num.add_saturated 2000000000i32 2000000000i32", 2147483647i32, i32 ); assert_evals_to!( - "Num.addSaturated -2000000000i32 -2000000000i32", + "Num.add_saturated -2000000000i32 -2000000000i32", -2147483648i32, i32 ); assert_evals_to!( - "Num.addSaturated 10000000000000000000u64 10000000000000000000u64", + "Num.add_saturated 10000000000000000000u64 10000000000000000000u64", 18446744073709551615u64, u64 ); assert_evals_to!( - "Num.addSaturated 5000000000000000000i64 5000000000000000000i64 ", + "Num.add_saturated 5000000000000000000i64 5000000000000000000i64 ", 9223372036854775807i64, i64 ); assert_evals_to!( - "Num.addSaturated -5000000000000000000i64 -5000000000000000000i64 ", + "Num.add_saturated -5000000000000000000i64 -5000000000000000000i64 ", -9223372036854775808i64, i64 ); assert_evals_to!( - "Num.addSaturated 200000000000000000000000000000000000000u128 200000000000000000000000000000000000000u128", + "Num.add_saturated 200000000000000000000000000000000000000u128 200000000000000000000000000000000000000u128", U128::from(340282366920938463463374607431768211455u128), U128 ); assert_evals_to!( - "Num.addSaturated 100000000000000000000000000000000000000i128 100000000000000000000000000000000000000i128", + "Num.add_saturated 100000000000000000000000000000000000000i128 100000000000000000000000000000000000000i128", I128::from(170141183460469231731687303715884105727i128), I128 ); assert_evals_to!( - "Num.addSaturated -100000000000000000000000000000000000000i128 -100000000000000000000000000000000000000i128", + "Num.add_saturated -100000000000000000000000000000000000000i128 -100000000000000000000000000000000000000i128", I128::from(-170141183460469231731687303715884105728i128), I128 ); assert_evals_to!( - "Num.addSaturated Num.maxF32 Num.maxF32", + "Num.add_saturated Num.max_f32 Num.max_f32", std::f32::INFINITY, f32 ); assert_evals_to!( - "Num.addSaturated Num.minF32 Num.minF32", + "Num.add_saturated Num.min_f32 Num.min_f32", std::f32::NEG_INFINITY, f32 ); assert_evals_to!( - "Num.addSaturated Num.maxF64 Num.maxF64", + "Num.add_saturated Num.max_f64 Num.max_f64", std::f64::INFINITY, f64 ); assert_evals_to!( - "Num.addSaturated Num.minF64 Num.minF64", + "Num.add_saturated Num.min_f64 Num.min_f64", std::f64::NEG_INFINITY, f64 ); assert_evals_to!( - "Num.addSaturated 170_141_183_460_469_231_731dec 1", + "Num.add_saturated 170_141_183_460_469_231_731dec 1", RocDec::from_str("170141183460469231731.687303715884105727").unwrap(), RocDec ); assert_evals_to!( - "Num.addSaturated -170_141_183_460_469_231_731dec -1", + "Num.add_saturated -170_141_183_460_469_231_731dec -1", RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(), RocDec ); @@ -2137,13 +2141,13 @@ fn float_sub_overflow() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn int_sub_checked() { assert_evals_to!( - "Num.subChecked 5 2", + "Num.sub_checked 5 2", RocResult::ok(3), RocResult ); assert_evals_to!( - "Num.subChecked Num.minI64 1 ", + "Num.sub_checked Num.min_i64 1 ", RocResult::err(()), RocResult ); @@ -2153,13 +2157,13 @@ fn int_sub_checked() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn float_sub_checked() { assert_evals_to!( - "Num.subChecked 1.0 0.0f64", + "Num.sub_checked 1.0 0.0f64", RocResult::ok(1.0), RocResult ); assert_evals_to!( - "Num.subChecked -1.7976931348623157e308f64 1.7976931348623157e308", + "Num.sub_checked -1.7976931348623157e308f64 1.7976931348623157e308", RocResult::err(()), RocResult ); @@ -2175,38 +2179,38 @@ fn int_sub_overflow() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn sub_wrap() { - assert_evals_to!("Num.subWrap 1u8 10u8", 247u8, u8); - assert_evals_to!("Num.subWrap 127i8 -10i8", -119i8, i8); - assert_evals_to!("Num.subWrap -127i8 10i8", 119i8, i8); - assert_evals_to!("Num.subWrap 1u16 10", 65527u16, u16); - assert_evals_to!("Num.subWrap 32767i16 -10", -32759i16, i16); - assert_evals_to!("Num.subWrap -32767i16 10", 32759i16, i16); - assert_evals_to!("Num.subWrap 1u32 10", 4294967287u32, u32); - assert_evals_to!("Num.subWrap 2147483647i32 -10", -2147483639i32, i32); - assert_evals_to!("Num.subWrap -2147483647i32 10", 2147483639i32, i32); - assert_evals_to!("Num.subWrap 1u64 10", 18446744073709551607u64, u64); - assert_evals_to!( - "Num.subWrap 9223372036854775807i64 -10", + assert_evals_to!("Num.sub_wrap 1u8 10u8", 247u8, u8); + assert_evals_to!("Num.sub_wrap 127i8 -10i8", -119i8, i8); + assert_evals_to!("Num.sub_wrap -127i8 10i8", 119i8, i8); + assert_evals_to!("Num.sub_wrap 1u16 10", 65527u16, u16); + assert_evals_to!("Num.sub_wrap 32767i16 -10", -32759i16, i16); + assert_evals_to!("Num.sub_wrap -32767i16 10", 32759i16, i16); + assert_evals_to!("Num.sub_wrap 1u32 10", 4294967287u32, u32); + assert_evals_to!("Num.sub_wrap 2147483647i32 -10", -2147483639i32, i32); + assert_evals_to!("Num.sub_wrap -2147483647i32 10", 2147483639i32, i32); + assert_evals_to!("Num.sub_wrap 1u64 10", 18446744073709551607u64, u64); + assert_evals_to!( + "Num.sub_wrap 9223372036854775807i64 -10", -9223372036854775799i64, i64 ); assert_evals_to!( - "Num.subWrap -9223372036854775807i64 10", + "Num.sub_wrap -9223372036854775807i64 10", 9223372036854775799i64, i64 ); assert_evals_to!( - "Num.subWrap 1u128 10", + "Num.sub_wrap 1u128 10", U128::from(340282366920938463463374607431768211447u128), U128 ); assert_evals_to!( - "Num.subWrap 170141183460469231731687303715884105727i128 -10", + "Num.sub_wrap 170141183460469231731687303715884105727i128 -10", I128::from(-170141183460469231731687303715884105719i128), I128 ); assert_evals_to!( - "Num.subWrap -170141183460469231731687303715884105727i128 10", + "Num.sub_wrap -170141183460469231731687303715884105727i128 10", I128::from(170141183460469231731687303715884105719i128), I128 ); @@ -2215,73 +2219,73 @@ fn sub_wrap() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn sub_saturated() { - assert_evals_to!("Num.subSaturated 1u8 10u8", 0u8, u8); - assert_evals_to!("Num.subSaturated 100i8 -100i8", 127i8, i8); - assert_evals_to!("Num.subSaturated -100i8 100i8", -128i8, i8); - assert_evals_to!("Num.subSaturated 1u16 10u16", 0u16, u16); - assert_evals_to!("Num.subSaturated 20000i16 -20000i16", 32767i16, i16); - assert_evals_to!("Num.subSaturated -20000i16 20000i16", -32768i16, i16); - assert_evals_to!("Num.subSaturated 1u32 10u32", 0u32, u32); - assert_evals_to!( - "Num.subSaturated 2000000000i32 -2000000000i32", + assert_evals_to!("Num.sub_saturated 1u8 10u8", 0u8, u8); + assert_evals_to!("Num.sub_saturated 100i8 -100i8", 127i8, i8); + assert_evals_to!("Num.sub_saturated -100i8 100i8", -128i8, i8); + assert_evals_to!("Num.sub_saturated 1u16 10u16", 0u16, u16); + assert_evals_to!("Num.sub_saturated 20000i16 -20000i16", 32767i16, i16); + assert_evals_to!("Num.sub_saturated -20000i16 20000i16", -32768i16, i16); + assert_evals_to!("Num.sub_saturated 1u32 10u32", 0u32, u32); + assert_evals_to!( + "Num.sub_saturated 2000000000i32 -2000000000i32", 2147483647i32, i32 ); assert_evals_to!( - "Num.subSaturated -2000000000i32 2000000000i32", + "Num.sub_saturated -2000000000i32 2000000000i32", -2147483648i32, i32 ); - assert_evals_to!("Num.subSaturated 1u64 10u64", 0u64, u64); + assert_evals_to!("Num.sub_saturated 1u64 10u64", 0u64, u64); assert_evals_to!( - "Num.subSaturated 5000000000000000000i64 -5000000000000000000i64 ", + "Num.sub_saturated 5000000000000000000i64 -5000000000000000000i64 ", 9223372036854775807i64, i64 ); assert_evals_to!( - "Num.subSaturated -5000000000000000000i64 5000000000000000000i64 ", + "Num.sub_saturated -5000000000000000000i64 5000000000000000000i64 ", -9223372036854775808i64, i64 ); - assert_evals_to!("Num.subSaturated 1u128 10", U128::from(0u128), U128); + assert_evals_to!("Num.sub_saturated 1u128 10", U128::from(0u128), U128); assert_evals_to!( - "Num.subSaturated 100000000000000000000000000000000000000i128 -100000000000000000000000000000000000000i128", + "Num.sub_saturated 100000000000000000000000000000000000000i128 -100000000000000000000000000000000000000i128", I128::from(170141183460469231731687303715884105727i128), I128 ); assert_evals_to!( - "Num.subSaturated -100000000000000000000000000000000000000i128 100000000000000000000000000000000000000i128", + "Num.sub_saturated -100000000000000000000000000000000000000i128 100000000000000000000000000000000000000i128", I128::from(-170141183460469231731687303715884105728i128), I128 ); assert_evals_to!( - "Num.subSaturated Num.maxF32 -Num.maxF32", + "Num.sub_saturated Num.max_f32 -Num.max_f32", std::f32::INFINITY, f32 ); assert_evals_to!( - "Num.subSaturated Num.minF32 -Num.minF32", + "Num.sub_saturated Num.min_f32 -Num.min_f32", std::f32::NEG_INFINITY, f32 ); assert_evals_to!( - "Num.subSaturated Num.maxF64 -Num.maxF64", + "Num.sub_saturated Num.max_f64 -Num.max_f64", std::f64::INFINITY, f64 ); assert_evals_to!( - "Num.subSaturated Num.minF64 -Num.minF64", + "Num.sub_saturated Num.min_f64 -Num.min_f64", std::f64::NEG_INFINITY, f64 ); assert_evals_to!( - "Num.subSaturated 170_141_183_460_469_231_731dec -1", + "Num.sub_saturated 170_141_183_460_469_231_731dec -1", RocDec::from_str("170141183460469231731.687303715884105727").unwrap(), RocDec ); assert_evals_to!( - "Num.subSaturated -170_141_183_460_469_231_731dec 1", + "Num.sub_saturated -170_141_183_460_469_231_731dec 1", RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(), RocDec ); @@ -2317,13 +2321,13 @@ fn float_negative_mul_overflow() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn int_mul_checked() { assert_evals_to!( - "Num.mulChecked 20 2", + "Num.mul_checked 20 2", RocResult::ok(40), RocResult:: ); assert_evals_to!( - "Num.mulChecked Num.maxI64 2", + "Num.mul_checked Num.max_i64 2", RocResult::err(()), RocResult:: ); @@ -2333,13 +2337,13 @@ fn int_mul_checked() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn float_mul_checked() { assert_evals_to!( - "Num.mulChecked 20.0 2.0f64", + "Num.mul_checked 20.0 2.0f64", RocResult::ok(40.0), RocResult:: ); assert_evals_to!( - "Num.mulChecked 1.7976931348623157e308f64 2", + "Num.mul_checked 1.7976931348623157e308f64 2", RocResult::err(()), RocResult:: ); @@ -2348,34 +2352,34 @@ fn float_mul_checked() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn mul_wrap() { - assert_evals_to!("Num.mulWrap 255u8 2", 254u8, u8); - assert_evals_to!("Num.mulWrap 127i8 2", -2i8, i8); - assert_evals_to!("Num.mulWrap -127i8 2", 2i8, i8); - assert_evals_to!("Num.mulWrap 65535u16 2", 65534u16, u16); - assert_evals_to!("Num.mulWrap 32767i16 2", -2i16, i16); - assert_evals_to!("Num.mulWrap -32767i16 2", 2i16, i16); - assert_evals_to!("Num.mulWrap 4294967295u32 2", 4294967294u32, u32); - assert_evals_to!("Num.mulWrap 2147483647i32 2", -2i32, i32); - assert_evals_to!("Num.mulWrap -2147483647i32 2", 2i32, i32); - assert_evals_to!( - "Num.mulWrap 18446744073709551615u64 2", + assert_evals_to!("Num.mul_wrap 255u8 2", 254u8, u8); + assert_evals_to!("Num.mul_wrap 127i8 2", -2i8, i8); + assert_evals_to!("Num.mul_wrap -127i8 2", 2i8, i8); + assert_evals_to!("Num.mul_wrap 65535u16 2", 65534u16, u16); + assert_evals_to!("Num.mul_wrap 32767i16 2", -2i16, i16); + assert_evals_to!("Num.mul_wrap -32767i16 2", 2i16, i16); + assert_evals_to!("Num.mul_wrap 4294967295u32 2", 4294967294u32, u32); + assert_evals_to!("Num.mul_wrap 2147483647i32 2", -2i32, i32); + assert_evals_to!("Num.mul_wrap -2147483647i32 2", 2i32, i32); + assert_evals_to!( + "Num.mul_wrap 18446744073709551615u64 2", 18446744073709551614u64, u64 ); - assert_evals_to!("Num.mulWrap 9223372036854775807i64 2", -2i64, i64); - assert_evals_to!("Num.mulWrap -9223372036854775807i64 2", 2i64, i64); + assert_evals_to!("Num.mul_wrap 9223372036854775807i64 2", -2i64, i64); + assert_evals_to!("Num.mul_wrap -9223372036854775807i64 2", 2i64, i64); assert_evals_to!( - "Num.mulWrap 340282366920938463463374607431768211455u128 2", + "Num.mul_wrap 340282366920938463463374607431768211455u128 2", U128::from(340282366920938463463374607431768211454u128), U128 ); assert_evals_to!( - "Num.mulWrap 170141183460469231731687303715884105727i128 2", + "Num.mul_wrap 170141183460469231731687303715884105727i128 2", I128::from(-2i128), I128 ); assert_evals_to!( - "Num.mulWrap -170141183460469231731687303715884105727i128 2", + "Num.mul_wrap -170141183460469231731687303715884105727i128 2", I128::from(2i128), I128 ); @@ -2383,59 +2387,67 @@ fn mul_wrap() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn mul_saturated() { - assert_evals_to!("Num.mulSaturated 200u8 2", 255u8, u8); - assert_evals_to!("Num.mulSaturated 100i8 2", 127i8, i8); - assert_evals_to!("Num.mulSaturated -100i8 2", -128i8, i8); - assert_evals_to!("Num.mulSaturated 40000u16 2", 65535u16, u16); - assert_evals_to!("Num.mulSaturated 20000i16 2", 32767i16, i16); - assert_evals_to!("Num.mulSaturated -20000i16 2", -32768i16, i16); - assert_evals_to!("Num.mulSaturated 3000000000u32 2", 4294967295u32, u32); - assert_evals_to!("Num.mulSaturated 2000000000i32 2", 2147483647i32, i32); - assert_evals_to!("Num.mulSaturated -2000000000i32 2", -2147483648i32, i32); - assert_evals_to!( - "Num.mulSaturated 10000000000000000000u64 2", + assert_evals_to!("Num.mul_saturated 200u8 2", 255u8, u8); + assert_evals_to!("Num.mul_saturated 100i8 2", 127i8, i8); + assert_evals_to!("Num.mul_saturated -100i8 2", -128i8, i8); + assert_evals_to!("Num.mul_saturated 40000u16 2", 65535u16, u16); + assert_evals_to!("Num.mul_saturated 20000i16 2", 32767i16, i16); + assert_evals_to!("Num.mul_saturated -20000i16 2", -32768i16, i16); + assert_evals_to!("Num.mul_saturated 3000000000u32 2", 4294967295u32, u32); + assert_evals_to!("Num.mul_saturated 2000000000i32 2", 2147483647i32, i32); + assert_evals_to!("Num.mul_saturated -2000000000i32 2", -2147483648i32, i32); + assert_evals_to!( + "Num.mul_saturated 10000000000000000000u64 2", 18446744073709551615u64, u64 ); assert_evals_to!( - "Num.mulSaturated 5000000000000000000i64 2", + "Num.mul_saturated 5000000000000000000i64 2", 9223372036854775807i64, i64 ); assert_evals_to!( - "Num.mulSaturated -5000000000000000000i64 2", + "Num.mul_saturated -5000000000000000000i64 2", -9223372036854775808i64, i64 ); assert_evals_to!( - "Num.mulSaturated 200000000000000000000000000000000000000u128 2", + "Num.mul_saturated 200000000000000000000000000000000000000u128 2", U128::from(340282366920938463463374607431768211455u128), U128 ); assert_evals_to!( - "Num.mulSaturated 100000000000000000000000000000000000000i128 2", + "Num.mul_saturated 100000000000000000000000000000000000000i128 2", I128::from(170141183460469231731687303715884105727i128), I128 ); assert_evals_to!( - "Num.mulSaturated -100000000000000000000000000000000000000i128 2", + "Num.mul_saturated -100000000000000000000000000000000000000i128 2", I128::from(-170141183460469231731687303715884105728i128), I128 ); - assert_evals_to!("Num.mulSaturated Num.maxF32 2", std::f32::INFINITY, f32); - assert_evals_to!("Num.mulSaturated Num.minF32 2", std::f32::NEG_INFINITY, f32); - assert_evals_to!("Num.mulSaturated Num.maxF64 2", std::f64::INFINITY, f64); - assert_evals_to!("Num.mulSaturated Num.minF64 2", std::f64::NEG_INFINITY, f64); + assert_evals_to!("Num.mul_saturated Num.max_f32 2", std::f32::INFINITY, f32); + assert_evals_to!( + "Num.mul_saturated Num.min_f32 2", + std::f32::NEG_INFINITY, + f32 + ); + assert_evals_to!("Num.mul_saturated Num.max_f64 2", std::f64::INFINITY, f64); + assert_evals_to!( + "Num.mul_saturated Num.min_f64 2", + std::f64::NEG_INFINITY, + f64 + ); // TODO: This doesn't work anywhere? It returns -1.374607431768211456 : Dec ? /* assert_evals_to!( - "Num.mulSaturated 170_141_183_460_469_231_731dec 2", + "Num.mul_saturated 170_141_183_460_469_231_731dec 2", RocDec::from_str("170141183460469231731.687303715884105727").unwrap(), RocDec ); assert_evals_to!( - "Num.mulSaturated -170_141_183_460_469_231_731dec 2", + "Num.mul_saturated -170_141_183_460_469_231_731dec 2", RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(), RocDec ); @@ -2445,10 +2457,10 @@ fn mul_saturated() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn shift_left_by() { - assert_evals_to!("Num.shiftLeftBy 0b0000_0001 0", 0b0000_0001, i64); - assert_evals_to!("Num.shiftLeftBy 0b0000_0001 1", 0b0000_0010, i64); - assert_evals_to!("Num.shiftLeftBy 0b0000_0011 2", 0b0000_1100, i64); - assert_evals_to!("Num.shiftLeftBy 2u16 2", 8, u16); + assert_evals_to!("Num.shift_left_by 0b0000_0001 0", 0b0000_0001, i64); + assert_evals_to!("Num.shift_left_by 0b0000_0001 1", 0b0000_0010, i64); + assert_evals_to!("Num.shift_left_by 0b0000_0011 2", 0b0000_1100, i64); + assert_evals_to!("Num.shift_left_by 2u16 2", 8, u16); } #[test] @@ -2458,36 +2470,36 @@ fn shift_right_by() { let is_llvm_release_mode = cfg!(feature = "gen-llvm") && !cfg!(debug_assertions); - assert_evals_to!("Num.shiftRightBy 0b0100_0000i8 2", 0b0001_0000i8, i8); - assert_evals_to!("Num.shiftRightBy 0b1110_0000u8 1", 0b1111_0000u8, u8); - assert_evals_to!("Num.shiftRightBy 0b1100_0000u8 2", 0b1111_0000u8, u8); - assert_evals_to!("Num.shiftRightBy 0b0100_0000u8 12", 0b0000_0000u8, u8); + assert_evals_to!("Num.shift_right_by 0b0100_0000i8 2", 0b0001_0000i8, i8); + assert_evals_to!("Num.shift_right_by 0b1110_0000u8 1", 0b1111_0000u8, u8); + assert_evals_to!("Num.shift_right_by 0b1100_0000u8 2", 0b1111_0000u8, u8); + assert_evals_to!("Num.shift_right_by 0b0100_0000u8 12", 0b0000_0000u8, u8); // LLVM in release mode returns 0 instead of -1 for some reason if !is_llvm_release_mode { - assert_evals_to!("Num.shiftRightBy 0b1000_0000u8 12", 0b1111_1111u8, u8); + assert_evals_to!("Num.shift_right_by 0b1000_0000u8 12", 0b1111_1111u8, u8); } - assert_evals_to!("Num.shiftRightBy 12 0", 12, i64); - assert_evals_to!("Num.shiftRightBy 12 1", 6, i64); - assert_evals_to!("Num.shiftRightBy -12 1", -6, i64); - assert_evals_to!("Num.shiftRightBy 12 8", 0, i64); - assert_evals_to!("Num.shiftRightBy -12 8", -1, i64); - assert_evals_to!("Num.shiftRightBy 0 0", 0, i64); - assert_evals_to!("Num.shiftRightBy 0 1", 0, i64); - - assert_evals_to!("Num.shiftRightBy 12i32 0", 12, i32); - assert_evals_to!("Num.shiftRightBy 12i32 1", 6, i32); - assert_evals_to!("Num.shiftRightBy -12i32 1", -6, i32); - assert_evals_to!("Num.shiftRightBy 12i32 8", 0, i32); - assert_evals_to!("Num.shiftRightBy -12i32 8", -1, i32); - - assert_evals_to!("Num.shiftRightBy 12i8 0", 12, i8); - assert_evals_to!("Num.shiftRightBy 12i8 1", 6, i8); - assert_evals_to!("Num.shiftRightBy -12i8 1", -6, i8); - assert_evals_to!("Num.shiftRightBy 12i8 8", 0, i8); + assert_evals_to!("Num.shift_right_by 12 0", 12, i64); + assert_evals_to!("Num.shift_right_by 12 1", 6, i64); + assert_evals_to!("Num.shift_right_by -12 1", -6, i64); + assert_evals_to!("Num.shift_right_by 12 8", 0, i64); + assert_evals_to!("Num.shift_right_by -12 8", -1, i64); + assert_evals_to!("Num.shift_right_by 0 0", 0, i64); + assert_evals_to!("Num.shift_right_by 0 1", 0, i64); + + assert_evals_to!("Num.shift_right_by 12i32 0", 12, i32); + assert_evals_to!("Num.shift_right_by 12i32 1", 6, i32); + assert_evals_to!("Num.shift_right_by -12i32 1", -6, i32); + assert_evals_to!("Num.shift_right_by 12i32 8", 0, i32); + assert_evals_to!("Num.shift_right_by -12i32 8", -1, i32); + + assert_evals_to!("Num.shift_right_by 12i8 0", 12, i8); + assert_evals_to!("Num.shift_right_by 12i8 1", 6, i8); + assert_evals_to!("Num.shift_right_by -12i8 1", -6, i8); + assert_evals_to!("Num.shift_right_by 12i8 8", 0, i8); if !is_llvm_release_mode { - assert_evals_to!("Num.shiftRightBy -12i8 8", -1, i8); + assert_evals_to!("Num.shift_right_by -12i8 8", -1, i8); } } @@ -2495,10 +2507,10 @@ fn shift_right_by() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn shift_right_zf_by() { // Logical Right Shift - assert_evals_to!("Num.shiftRightZfBy 0b1100_0000u8 2", 0b0011_0000u8, u8); - assert_evals_to!("Num.shiftRightZfBy 0b0000_0010u8 1", 0b0000_0001u8, u8); - assert_evals_to!("Num.shiftRightZfBy 0b0000_1100u8 2", 0b0000_0011u8, u8); - assert_evals_to!("Num.shiftRightZfBy 0b1000_0000u8 12", 0b0000_0000u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b1100_0000u8 2", 0b0011_0000u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b0000_0010u8 1", 0b0000_0001u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b0000_1100u8 2", 0b0000_0011u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b1000_0000u8 12", 0b0000_0000u8, u8); } #[test] @@ -2506,28 +2518,28 @@ fn shift_right_zf_by() { fn shift_right_cast_i8() { // arithmetic assert_evals_to!( - "Num.shiftRightBy (Num.toI8 0b1100_0000u8) 2", + "Num.shift_right_by (Num.to_i8 0b1100_0000u8) 2", 0b1111_0000u8 as i8, i8 ); // logical assert_evals_to!( - "Num.shiftRightZfBy (Num.toI8 0b1100_0000u8) 2", + "Num.shift_right_zf_by (Num.to_i8 0b1100_0000u8) 2", 0b0011_0000i8, i8 ); - assert_evals_to!("Num.shiftRightZfBy 0b1100_0000u8 2", 0b0011_0000u8, u8); - assert_evals_to!("Num.shiftRightZfBy 0b0000_0010u8 1", 0b0000_0001u8, u8); - assert_evals_to!("Num.shiftRightZfBy 0b0000_1100u8 2", 0b0000_0011u8, u8); - assert_evals_to!("Num.shiftRightZfBy 0b1000_0000u8 12", 0b0000_0000u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b1100_0000u8 2", 0b0011_0000u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b0000_0010u8 1", 0b0000_0001u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b0000_1100u8 2", 0b0000_0011u8, u8); + assert_evals_to!("Num.shift_right_zf_by 0b1000_0000u8 12", 0b0000_0000u8, u8); assert_evals_to!( - "Num.shiftRightZfBy 0xffff_0000_0000_0000_0000_0000_0000_ffffu128 4", + "Num.shift_right_zf_by 0xffff_0000_0000_0000_0000_0000_0000_ffffu128 4", 0x0fff_f000_0000_0000_0000_0000_0000_0fffu128, u128 ); assert_evals_to!( - "Num.shiftRightZfBy 0xaaaa_0000_0000_bbbb_ffff_ffff_ffff_ffffu128 68", + "Num.shift_right_zf_by 0xaaaa_0000_0000_bbbb_ffff_ffff_ffff_ffffu128 68", 0x0000_0000_0000_0000_0aaa_a000_0000_0bbbu128, u128 ); @@ -2536,133 +2548,133 @@ fn shift_right_cast_i8() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_i128() { - assert_evals_to!("Num.minI128", I128::from(i128::MIN), I128); + assert_evals_to!("Num.min_i128", I128::from(i128::MIN), I128); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_i128() { - assert_evals_to!("Num.maxI128", I128::from(i128::MAX), I128); + assert_evals_to!("Num.max_i128", I128::from(i128::MAX), I128); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_i64() { - assert_evals_to!("Num.minI64", i64::MIN, i64); + assert_evals_to!("Num.min_i64", i64::MIN, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_i64() { - assert_evals_to!("Num.maxI64", i64::MAX, i64); + assert_evals_to!("Num.max_i64", i64::MAX, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_u64() { - assert_evals_to!("Num.minU64", u64::MIN, u64); + assert_evals_to!("Num.min_u64", u64::MIN, u64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_u64() { - assert_evals_to!("Num.maxU64", u64::MAX, u64); + assert_evals_to!("Num.max_u64", u64::MAX, u64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_i32() { - assert_evals_to!("Num.minI32", i32::MIN, i32); + assert_evals_to!("Num.min_i32", i32::MIN, i32); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_i32() { - assert_evals_to!("Num.maxI32", i32::MAX, i32); + assert_evals_to!("Num.max_i32", i32::MAX, i32); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_u32() { - assert_evals_to!("Num.minU32", u32::MIN, u32); + assert_evals_to!("Num.min_u32", u32::MIN, u32); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_u32() { - assert_evals_to!("Num.maxU32", u32::MAX, u32); + assert_evals_to!("Num.max_u32", u32::MAX, u32); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_i16() { - assert_evals_to!("Num.minI16", i16::MIN, i16); + assert_evals_to!("Num.min_i16", i16::MIN, i16); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_i16() { - assert_evals_to!("Num.maxI16", i16::MAX, i16); + assert_evals_to!("Num.max_i16", i16::MAX, i16); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_u16() { - assert_evals_to!("Num.minU16", u16::MIN, u16); + assert_evals_to!("Num.min_u16", u16::MIN, u16); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_u16() { - assert_evals_to!("Num.maxU16", u16::MAX, u16); + assert_evals_to!("Num.max_u16", u16::MAX, u16); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_i8() { - assert_evals_to!("Num.minI8", i8::MIN, i8); + assert_evals_to!("Num.min_i8", i8::MIN, i8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_i8() { - assert_evals_to!("Num.maxI8", i8::MAX, i8); + assert_evals_to!("Num.max_i8", i8::MAX, i8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_u8() { - assert_evals_to!("Num.minU8", u8::MIN, u8); + assert_evals_to!("Num.min_u8", u8::MIN, u8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_u8() { - assert_evals_to!("Num.maxU8", u8::MAX, u8); + assert_evals_to!("Num.max_u8", u8::MAX, u8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_f64() { - assert_evals_to!("Num.maxF64", f64::MAX, f64); + assert_evals_to!("Num.max_f64", f64::MAX, f64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_f64() { - assert_evals_to!("Num.minF64", f64::MIN, f64); + assert_evals_to!("Num.min_f64", f64::MIN, f64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn max_f32() { - assert_evals_to!("Num.maxF32", f32::MAX, f32); + assert_evals_to!("Num.max_f32", f32::MAX, f32); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn min_f32() { - assert_evals_to!("Num.minF32", f32::MIN, f32); + assert_evals_to!("Num.min_f32", f32::MIN, f32); } macro_rules! num_conversion_tests { @@ -2677,19 +2689,19 @@ macro_rules! num_conversion_tests { } num_conversion_tests! { - "Num.toI8", i8, ( + "Num.to_i8", i8, ( to_i8_same_width, "15u8", 15, ["gen-wasm", "gen-dev"] to_i8_truncate, "115i32", 115, ["gen-wasm", "gen-dev"] to_i8_truncate_wraps, "500i32", -12, ["gen-wasm", "gen-dev"] ) - "Num.toI16", i16, ( + "Num.to_i16", i16, ( to_i16_same_width, "15u16", 15, ["gen-wasm", "gen-dev"] to_i16_extend, "15i8", 15, ["gen-wasm", "gen-dev"] to_i16_sign_extend_i8, "-15i8", -15, ["gen-wasm", "gen-dev"] to_i16_truncate, "115i32", 115, ["gen-wasm", "gen-dev"] to_i16_truncate_wraps, "60000i32", -5536, ["gen-wasm", "gen-dev"] ) - "Num.toI32", i32, ( + "Num.to_i32", i32, ( to_i32_same_width, "15u32", 15, ["gen-wasm", "gen-dev"] to_i32_extend, "15i8", 15, ["gen-wasm", "gen-dev"] to_i32_sign_extend_i8, "-15i8", -15, ["gen-wasm", "gen-dev"] @@ -2697,7 +2709,7 @@ num_conversion_tests! { to_i32_truncate, "115i64", 115, ["gen-wasm", "gen-dev"] to_i32_truncate_wraps, "5000000000i64", 705032704, ["gen-wasm", "gen-dev"] ) - "Num.toI64", i64, ( + "Num.to_i64", i64, ( to_i64_same_width, "15u64", 15, ["gen-wasm", "gen-dev"] to_i64_extend, "15i8", 15, ["gen-wasm", "gen-dev"] to_i64_sign_extend_i8, "-15i8", -15, ["gen-wasm", "gen-dev"] @@ -2706,39 +2718,39 @@ num_conversion_tests! { to_i64_truncate, "115i128", 115 to_i64_truncate_wraps, "10_000_000_000_000_000_000i128", -8446744073709551616 ) - "Num.toI128", i128, ( + "Num.to_i128", i128, ( to_i128_same_width, "15u128", 15, ["gen-dev"] to_i128_extend, "15i8", 15 ) - "Num.toU8", u8, ( + "Num.to_u8", u8, ( to_u8_same_width, "15i8", 15, ["gen-wasm", "gen-dev"] to_u8_truncate, "115i32", 115, ["gen-wasm", "gen-dev"] to_u8_truncate_wraps, "500i32", 244, ["gen-wasm", "gen-dev"] ) - "Num.toU16", u16, ( + "Num.to_u16", u16, ( to_u16_same_width, "15i16", 15, ["gen-wasm", "gen-dev"] to_u16_extend, "15i8", 15, ["gen-wasm", "gen-dev"] to_u16_truncate, "115i32", 115, ["gen-wasm", "gen-dev"] to_u16_truncate_wraps, "600000000i32", 17920, ["gen-wasm", "gen-dev"] ) - "Num.toU32", u32, ( + "Num.to_u32", u32, ( to_u32_same_width, "15i32", 15, ["gen-wasm", "gen-dev"] to_u32_extend, "15i8", 15, ["gen-wasm", "gen-dev"] to_u32_truncate, "115i64", 115, ["gen-wasm", "gen-dev"] to_u32_truncate_wraps, "5000000000000000000i64", 1156841472, ["gen-wasm", "gen-dev"] ) - "Num.toU64", u64, ( + "Num.to_u64", u64, ( to_u64_same_width, "15i64", 15, ["gen-wasm", "gen-dev"] to_u64_extend, "15i8", 15, ["gen-wasm", "gen-dev"] to_u64_truncate, "115i128", 115 to_u64_truncate_wraps, "10_000_000_000_000_000_000_000i128", 1864712049423024128 ) - "Num.toU128", u128, ( + "Num.to_u128", u128, ( to_u128_same_width, "15i128", 15, ["gen-dev"] to_u128_extend, "15i8", 15 to_u128_big, "11562537357600483583u64", 11562537357600483583, ["gen-dev"] ) - "Num.toF32", f32, ( + "Num.to_f32", f32, ( to_f32_from_i8, "15i8", 15.0, ["gen-wasm", "gen-dev"] to_f32_from_i16, "15i16", 15.0, ["gen-wasm", "gen-dev"] to_f32_from_i32, "15i32", 15.0, ["gen-wasm", "gen-dev"] @@ -2752,7 +2764,7 @@ num_conversion_tests! { to_f32_from_f32, "1.5f32", 1.5, ["gen-wasm", "gen-dev"] to_f32_from_f64, "1.5f64", 1.5, ["gen-wasm", "gen-dev"] ) - "Num.toF64", f64, ( + "Num.to_f64", f64, ( to_f64_from_i8, "15i8", 15.0, ["gen-wasm", "gen-dev"] to_f64_from_i16, "15i16", 15.0, ["gen-wasm", "gen-dev"] to_f64_from_i32, "15i32", 15.0, ["gen-wasm", "gen-dev"] @@ -2782,14 +2794,14 @@ macro_rules! to_int_checked_tests { n } }; - let input = format!("Result.withDefault ({} {}) {}", $fn, $input, sentinel); + let input = format!("Result.with_default ({} {}) {}", $fn, $input, sentinel); assert_evals_to!(&input, expected, $typ) } )*)*} } to_int_checked_tests! { - "Num.toI8Checked", i8, ( + "Num.to_i8_checked", i8, ( to_i8_checked_same, "15i8", 15 to_i8_checked_same_width_unsigned_fits, "15u8", 15 to_i8_checked_same_width_unsigned_oob, "128u8", None @@ -2800,7 +2812,7 @@ to_int_checked_tests! { to_i8_checked_larger_width_unsigned_fits_pos, "15u16", 15 to_i8_checked_larger_width_unsigned_oob_pos, "128u16", None ) - "Num.toI16Checked", i16, ( + "Num.to_i16_checked", i16, ( to_i16_checked_smaller_width_pos, "15i8", 15 to_i16_checked_smaller_width_neg, "-15i8", -15 to_i16_checked_same, "15i16", 15 @@ -2813,7 +2825,7 @@ to_int_checked_tests! { to_i16_checked_larger_width_unsigned_fits_pos, "15u32", 15 to_i16_checked_larger_width_unsigned_oob_pos, "32768u32", None ) - "Num.toI32Checked", i32, ( + "Num.to_i32_checked", i32, ( to_i32_checked_smaller_width_pos, "15i8", 15 to_i32_checked_smaller_width_neg, "-15i8", -15 to_i32_checked_same, "15i32", 15 @@ -2826,7 +2838,7 @@ to_int_checked_tests! { to_i32_checked_larger_width_unsigned_fits_pos, "15u64", 15 to_i32_checked_larger_width_unsigned_oob_pos, "2147483648u64", None ) - "Num.toI64Checked", i64, ( + "Num.to_i64_checked", i64, ( to_i64_checked_smaller_width_pos, "15i8", 15 to_i64_checked_smaller_width_neg, "-15i8", -15 to_i64_checked_same, "15i64", 15 @@ -2839,7 +2851,7 @@ to_int_checked_tests! { to_i64_checked_larger_width_unsigned_fits_pos, "15u128", 15 to_i64_checked_larger_width_unsigned_oob_pos, "9223372036854775808u128", None ) - "Num.toU8Checked", u8, ( + "Num.to_u8_checked", u8, ( to_u8_checked_same, "15u8", 15 to_u8_checked_same_width_signed_fits, "15i8", 15 to_u8_checked_same_width_signed_oob, "-1i8", None @@ -2849,7 +2861,7 @@ to_int_checked_tests! { to_u8_checked_larger_width_unsigned_fits_pos, "15u16", 15 to_u8_checked_larger_width_unsigned_oob_pos, "256u16", None ) - "Num.toU16Checked", u16, ( + "Num.to_u16_checked", u16, ( to_u16_checked_smaller_width_pos, "15i8", 15 to_u16_checked_smaller_width_neg_oob, "-15i8", None to_u16_checked_same, "15u16", 15 @@ -2861,7 +2873,7 @@ to_int_checked_tests! { to_u16_checked_larger_width_unsigned_fits_pos, "15u32", 15 to_u16_checked_larger_width_unsigned_oob_pos, "65536u32", None ) - "Num.toU32Checked", u32, ( + "Num.to_u32_checked", u32, ( to_u32_checked_smaller_width_pos, "15i8", 15 to_u32_checked_smaller_width_neg_oob, "-15i8", None to_u32_checked_same, "15u32", 15 @@ -2873,7 +2885,7 @@ to_int_checked_tests! { to_u32_checked_larger_width_unsigned_fits_pos, "15u64", 15 to_u32_checked_larger_width_unsigned_oob_pos, "4294967296u64", None ) - "Num.toU64Checked", u64, ( + "Num.to_u64_checked", u64, ( to_u64_checked_smaller_width_pos, "15i8", 15 to_u64_checked_smaller_width_neg_oob, "-15i8", None to_u64_checked_same, "15u64", 15 @@ -2888,34 +2900,34 @@ to_int_checked_tests! { } fn wrap_with_default(test_roc_code: &str) -> String { - format!("Result.withDefault ({}) 123454321", test_roc_code) + format!("Result.with_default ({}) 123454321", test_roc_code) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_i128_checked_smaller_width_pos() { - let test_roc_code = wrap_with_default("Num.toI128Checked 15i8"); + let test_roc_code = wrap_with_default("Num.to_i128_checked 15i8"); assert_evals_to!(&test_roc_code, I128::from(15), I128) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_i128_checked_smaller_width_neg() { - let test_roc_code = wrap_with_default("Num.toI128Checked -15i8"); + let test_roc_code = wrap_with_default("Num.to_i128_checked -15i8"); assert_evals_to!(&test_roc_code, I128::from(-15), I128) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_i128_checked_same() { - let test_roc_code = wrap_with_default("Num.toI128Checked 15i128"); + let test_roc_code = wrap_with_default("Num.to_i128_checked 15i128"); assert_evals_to!(&test_roc_code, I128::from(15), I128) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_i128_checked_same_width_unsigned_fits() { - let test_roc_code = wrap_with_default("Num.toI128Checked 15u128"); + let test_roc_code = wrap_with_default("Num.to_i128_checked 15u128"); assert_evals_to!(&test_roc_code, I128::from(15), I128) } @@ -2923,42 +2935,42 @@ fn to_i128_checked_same_width_unsigned_fits() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_i128_checked_same_width_unsigned_oob() { let test_roc_code = - "Result.isErr (Num.toI128Checked 170141183460469231731687303715884105728u128)"; + "Result.is_err (Num.to_i128_checked 170141183460469231731687303715884105728u128)"; assert_evals_to!(&test_roc_code, true, bool) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_u128_checked_smaller_width_pos() { - let test_roc_code = wrap_with_default("Num.toU128Checked 15i8"); + let test_roc_code = wrap_with_default("Num.to_u128_checked 15i8"); assert_evals_to!(&test_roc_code, U128::from(15), U128) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_u128_checked_smaller_width_neg_oob() { - let test_roc_code = "Result.isErr (Num.toU128Checked -15i8)"; + let test_roc_code = "Result.is_err (Num.to_u128_checked -15i8)"; assert_evals_to!(&test_roc_code, true, bool) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_u128_checked_same() { - let test_roc_code = wrap_with_default("Num.toU128Checked 15u128"); + let test_roc_code = wrap_with_default("Num.to_u128_checked 15u128"); assert_evals_to!(&test_roc_code, U128::from(15), U128) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_u128_checked_same_width_signed_fits() { - let test_roc_code = wrap_with_default("Num.toU128Checked 15i128"); + let test_roc_code = wrap_with_default("Num.to_u128_checked 15i128"); assert_evals_to!(&test_roc_code, U128::from(15), U128) } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm"))] fn to_u128_checked_same_width_signed_oob() { - let test_roc_code = "Result.isErr (Num.toU128Checked -1i128)"; + let test_roc_code = "Result.is_err (Num.to_u128_checked -1i128)"; assert_evals_to!(&test_roc_code, true, bool) } @@ -2966,35 +2978,35 @@ fn to_u128_checked_same_width_signed_oob() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn is_multiple_of_signed() { // true - assert_evals_to!("Num.isMultipleOf 5 1", true, bool); - assert_evals_to!("Num.isMultipleOf 5 -1", true, bool); - assert_evals_to!("Num.isMultipleOf 0 0", true, bool); - assert_evals_to!("Num.isMultipleOf 0 1", true, bool); - assert_evals_to!("Num.isMultipleOf 0 -1", true, bool); + assert_evals_to!("Num.is_multiple_of 5 1", true, bool); + assert_evals_to!("Num.is_multiple_of 5 -1", true, bool); + assert_evals_to!("Num.is_multiple_of 0 0", true, bool); + assert_evals_to!("Num.is_multiple_of 0 1", true, bool); + assert_evals_to!("Num.is_multiple_of 0 -1", true, bool); // false - assert_evals_to!("Num.isMultipleOf 5 2", false, bool); - assert_evals_to!("Num.isMultipleOf 5 0", false, bool); + assert_evals_to!("Num.is_multiple_of 5 2", false, bool); + assert_evals_to!("Num.is_multiple_of 5 0", false, bool); // overflow - assert_evals_to!("Num.isMultipleOf -9223372036854775808 -1", true, bool); + assert_evals_to!("Num.is_multiple_of -9223372036854775808 -1", true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn is_multiple_of_unsigned() { // true - assert_evals_to!("Num.isMultipleOf 5u8 1", true, bool); - assert_evals_to!("Num.isMultipleOf 0u8 0", true, bool); - assert_evals_to!("Num.isMultipleOf 0u8 1", true, bool); - assert_evals_to!("Num.isMultipleOf 0u8 0xFF", true, bool); + assert_evals_to!("Num.is_multiple_of 5u8 1", true, bool); + assert_evals_to!("Num.is_multiple_of 0u8 0", true, bool); + assert_evals_to!("Num.is_multiple_of 0u8 1", true, bool); + assert_evals_to!("Num.is_multiple_of 0u8 0xFF", true, bool); // false - assert_evals_to!("Num.isMultipleOf 5u8 2", false, bool); - assert_evals_to!("Num.isMultipleOf 5u8 0", false, bool); + assert_evals_to!("Num.is_multiple_of 5u8 2", false, bool); + assert_evals_to!("Num.is_multiple_of 5u8 0", false, bool); // unsigned result is different from signed - assert_evals_to!("Num.isMultipleOf 5u8 0xFF", false, bool); - assert_evals_to!("Num.isMultipleOf 0xFCu8 0xFE", false, bool); + assert_evals_to!("Num.is_multiple_of 5u8 0xFF", false, bool); + assert_evals_to!("Num.is_multiple_of 0xFCu8 0xFE", false, bool); } #[test] @@ -3048,15 +3060,23 @@ fn when_on_i16() { fn num_to_str() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr 1234", RocStr::from("1234"), RocStr); - assert_evals_to!(r"Num.toStr 0", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr -1", RocStr::from("-1"), RocStr); + assert_evals_to!(r"Num.to_str 1234", RocStr::from("1234"), RocStr); + assert_evals_to!(r"Num.to_str 0", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str -1", RocStr::from("-1"), RocStr); let max = format!("{}", i64::MAX); - assert_evals_to!(r"Num.toStr Num.maxI64", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_i64", + RocStr::from(max.as_str()), + RocStr + ); let min = format!("{}", i64::MIN); - assert_evals_to!(r"Num.toStr Num.minI64", RocStr::from(min.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.min_i64", + RocStr::from(min.as_str()), + RocStr + ); } #[test] @@ -3064,12 +3084,12 @@ fn num_to_str() { fn num_to_str_u8() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr 0u8", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1u8", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10u8", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str 0u8", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1u8", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10u8", RocStr::from("10"), RocStr); let max = format!("{}", u8::MAX); - assert_evals_to!(r"Num.toStr Num.maxU8", RocStr::from(max.as_str()), RocStr); + assert_evals_to!(r"Num.to_str Num.max_u8", RocStr::from(max.as_str()), RocStr); } #[test] @@ -3077,12 +3097,16 @@ fn num_to_str_u8() { fn num_to_str_u16() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr 0u16", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1u16", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10u16", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str 0u16", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1u16", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10u16", RocStr::from("10"), RocStr); let max = format!("{}", u16::MAX); - assert_evals_to!(r"Num.toStr Num.maxU16", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_u16", + RocStr::from(max.as_str()), + RocStr + ); } #[test] @@ -3090,12 +3114,16 @@ fn num_to_str_u16() { fn num_to_str_u32() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr 0u32", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1u32", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10u32", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str 0u32", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1u32", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10u32", RocStr::from("10"), RocStr); let max = format!("{}", u32::MAX); - assert_evals_to!(r"Num.toStr Num.maxU32", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_u32", + RocStr::from(max.as_str()), + RocStr + ); } #[test] @@ -3103,12 +3131,16 @@ fn num_to_str_u32() { fn num_to_str_u64() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr 0u64", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1u64", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10u64", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str 0u64", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1u64", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10u64", RocStr::from("10"), RocStr); let max = format!("{}", u64::MAX); - assert_evals_to!(r"Num.toStr Num.maxU64", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_u64", + RocStr::from(max.as_str()), + RocStr + ); } #[test] @@ -3116,17 +3148,17 @@ fn num_to_str_u64() { fn num_to_str_i8() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10i8", RocStr::from("-10"), RocStr); - assert_evals_to!(r"Num.toStr -1i8", RocStr::from("-1"), RocStr); - assert_evals_to!(r"Num.toStr 0i8", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1i8", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10i8", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str -10i8", RocStr::from("-10"), RocStr); + assert_evals_to!(r"Num.to_str -1i8", RocStr::from("-1"), RocStr); + assert_evals_to!(r"Num.to_str 0i8", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1i8", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10i8", RocStr::from("10"), RocStr); let max = format!("{}", i8::MAX); - assert_evals_to!(r"Num.toStr Num.maxI8", RocStr::from(max.as_str()), RocStr); + assert_evals_to!(r"Num.to_str Num.max_i8", RocStr::from(max.as_str()), RocStr); let max = format!("{}", i8::MIN); - assert_evals_to!(r"Num.toStr Num.minI8", RocStr::from(max.as_str()), RocStr); + assert_evals_to!(r"Num.to_str Num.min_i8", RocStr::from(max.as_str()), RocStr); } #[test] @@ -3134,17 +3166,25 @@ fn num_to_str_i8() { fn num_to_str_i16() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10i16", RocStr::from("-10"), RocStr); - assert_evals_to!(r"Num.toStr -1i16", RocStr::from("-1"), RocStr); - assert_evals_to!(r"Num.toStr 0i16", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1i16", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10i16", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str -10i16", RocStr::from("-10"), RocStr); + assert_evals_to!(r"Num.to_str -1i16", RocStr::from("-1"), RocStr); + assert_evals_to!(r"Num.to_str 0i16", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1i16", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10i16", RocStr::from("10"), RocStr); let max = format!("{}", i16::MAX); - assert_evals_to!(r"Num.toStr Num.maxI16", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_i16", + RocStr::from(max.as_str()), + RocStr + ); let max = format!("{}", i16::MIN); - assert_evals_to!(r"Num.toStr Num.minI16", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.min_i16", + RocStr::from(max.as_str()), + RocStr + ); } #[test] @@ -3152,17 +3192,25 @@ fn num_to_str_i16() { fn num_to_str_i32() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10i32", RocStr::from("-10"), RocStr); - assert_evals_to!(r"Num.toStr -1i32", RocStr::from("-1"), RocStr); - assert_evals_to!(r"Num.toStr 0i32", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1i32", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10i32", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str -10i32", RocStr::from("-10"), RocStr); + assert_evals_to!(r"Num.to_str -1i32", RocStr::from("-1"), RocStr); + assert_evals_to!(r"Num.to_str 0i32", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1i32", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10i32", RocStr::from("10"), RocStr); let max = format!("{}", i32::MAX); - assert_evals_to!(r"Num.toStr Num.maxI32", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_i32", + RocStr::from(max.as_str()), + RocStr + ); let max = format!("{}", i32::MIN); - assert_evals_to!(r"Num.toStr Num.minI32", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.min_i32", + RocStr::from(max.as_str()), + RocStr + ); } #[test] @@ -3170,17 +3218,25 @@ fn num_to_str_i32() { fn num_to_str_i64() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10i64", RocStr::from("-10"), RocStr); - assert_evals_to!(r"Num.toStr -1i64", RocStr::from("-1"), RocStr); - assert_evals_to!(r"Num.toStr 0i64", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1i64", RocStr::from("1"), RocStr); - assert_evals_to!(r"Num.toStr 10i64", RocStr::from("10"), RocStr); + assert_evals_to!(r"Num.to_str -10i64", RocStr::from("-10"), RocStr); + assert_evals_to!(r"Num.to_str -1i64", RocStr::from("-1"), RocStr); + assert_evals_to!(r"Num.to_str 0i64", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1i64", RocStr::from("1"), RocStr); + assert_evals_to!(r"Num.to_str 10i64", RocStr::from("10"), RocStr); let max = format!("{}", i64::MAX); - assert_evals_to!(r"Num.toStr Num.maxI64", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.max_i64", + RocStr::from(max.as_str()), + RocStr + ); let max = format!("{}", i64::MIN); - assert_evals_to!(r"Num.toStr Num.minI64", RocStr::from(max.as_str()), RocStr); + assert_evals_to!( + r"Num.to_str Num.min_i64", + RocStr::from(max.as_str()), + RocStr + ); } #[test] @@ -3188,21 +3244,21 @@ fn num_to_str_i64() { fn num_to_str_f32() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10.75f32", RocStr::from("-10.75"), RocStr); - assert_evals_to!(r"Num.toStr -1.75f32", RocStr::from("-1.75"), RocStr); - assert_evals_to!(r"Num.toStr 0f32", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1.75f32", RocStr::from("1.75"), RocStr); - assert_evals_to!(r"Num.toStr 10.75f32", RocStr::from("10.75"), RocStr); + assert_evals_to!(r"Num.to_str -10.75f32", RocStr::from("-10.75"), RocStr); + assert_evals_to!(r"Num.to_str -1.75f32", RocStr::from("-1.75"), RocStr); + assert_evals_to!(r"Num.to_str 0f32", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1.75f32", RocStr::from("1.75"), RocStr); + assert_evals_to!(r"Num.to_str 10.75f32", RocStr::from("10.75"), RocStr); assert_evals_to!( - r"Num.toStr Num.maxF32", + r"Num.to_str Num.max_f32", f32::MAX, RocStr, |roc_str: RocStr| { roc_str.as_str().parse::().unwrap() } ); assert_evals_to!( - r"Num.toStr Num.minF32", + r"Num.to_str Num.min_f32", f32::MIN, RocStr, |roc_str: RocStr| { roc_str.as_str().parse::().unwrap() } @@ -3214,20 +3270,20 @@ fn num_to_str_f32() { fn num_to_str_f64() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10.75f64", RocStr::from("-10.75"), RocStr); - assert_evals_to!(r"Num.toStr -1.75f64", RocStr::from("-1.75"), RocStr); - assert_evals_to!(r"Num.toStr 0f64", RocStr::from("0"), RocStr); - assert_evals_to!(r"Num.toStr 1.75f64", RocStr::from("1.75"), RocStr); - assert_evals_to!(r"Num.toStr 10.75f64", RocStr::from("10.75"), RocStr); + assert_evals_to!(r"Num.to_str -10.75f64", RocStr::from("-10.75"), RocStr); + assert_evals_to!(r"Num.to_str -1.75f64", RocStr::from("-1.75"), RocStr); + assert_evals_to!(r"Num.to_str 0f64", RocStr::from("0"), RocStr); + assert_evals_to!(r"Num.to_str 1.75f64", RocStr::from("1.75"), RocStr); + assert_evals_to!(r"Num.to_str 10.75f64", RocStr::from("10.75"), RocStr); assert_evals_to!( - r"Num.toStr Num.maxF64", + r"Num.to_str Num.max_f64", RocStr::from(f64::MAX.to_string().as_str()), RocStr ); assert_evals_to!( - r"Num.toStr Num.minF64", + r"Num.to_str Num.min_f64", RocStr::from(f64::MIN.to_string().as_str()), RocStr ); @@ -3238,20 +3294,20 @@ fn num_to_str_f64() { fn num_to_str_dec() { use roc_std::RocStr; - assert_evals_to!(r"Num.toStr -10.75dec", RocStr::from("-10.75"), RocStr); - assert_evals_to!(r"Num.toStr -1.75dec", RocStr::from("-1.75"), RocStr); - assert_evals_to!(r"Num.toStr 0dec", RocStr::from("0.0"), RocStr); - assert_evals_to!(r"Num.toStr 1.75dec", RocStr::from("1.75"), RocStr); - assert_evals_to!(r"Num.toStr 10.75dec", RocStr::from("10.75"), RocStr); + assert_evals_to!(r"Num.to_str -10.75dec", RocStr::from("-10.75"), RocStr); + assert_evals_to!(r"Num.to_str -1.75dec", RocStr::from("-1.75"), RocStr); + assert_evals_to!(r"Num.to_str 0dec", RocStr::from("0.0"), RocStr); + assert_evals_to!(r"Num.to_str 1.75dec", RocStr::from("1.75"), RocStr); + assert_evals_to!(r"Num.to_str 10.75dec", RocStr::from("10.75"), RocStr); assert_evals_to!( - r"Num.toStr 170141183460469.105727dec", + r"Num.to_str 170141183460469.105727dec", RocStr::from("170141183460469.105727"), RocStr ); assert_evals_to!( - r"Num.toStr -170141183460469.105727dec", + r"Num.to_str -170141183460469.105727dec", RocStr::from("-170141183460469.105727"), RocStr ); @@ -3409,7 +3465,7 @@ fn to_float_f32() { n = 100 f : F32 - f = Num.toFrac n + f = Num.to_frac n f " ), @@ -3428,7 +3484,7 @@ fn to_float_f64() { n = 100 f : F64 - f = Num.toFrac n + f = Num.to_frac n f " ), @@ -3444,7 +3500,7 @@ fn upcast_of_int_is_zext() { assert_evals_to!( indoc!( r" - Num.toU16 0b1000_0000u8 + Num.to_u16 0b1000_0000u8 " ), 128, @@ -3459,7 +3515,7 @@ fn upcast_of_int_checked_is_zext() { assert_evals_to!( indoc!( r" - when Num.toU16Checked 0b1000_0000u8 is + when Num.to_u16_checked 0b1000_0000u8 is Ok 128u16 -> 1u8 _ -> 0u8 " @@ -3706,49 +3762,49 @@ fn condition_polymorphic_num_becomes_float() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_count_leading_zero_bits() { - assert_evals_to!(r"Num.countLeadingZeroBits 0b0010_1000u8", 2, u8); - assert_evals_to!(r"Num.countLeadingZeroBits 0b0010_1000u16", 10, u8); - assert_evals_to!(r"Num.countLeadingZeroBits 0b0010_1000u32", 26, u8); - assert_evals_to!(r"Num.countLeadingZeroBits 0b0010_1000u64", 58, u8); + assert_evals_to!(r"Num.count_leading_zero_bits 0b0010_1000u8", 2, u8); + assert_evals_to!(r"Num.count_leading_zero_bits 0b0010_1000u16", 10, u8); + assert_evals_to!(r"Num.count_leading_zero_bits 0b0010_1000u32", 26, u8); + assert_evals_to!(r"Num.count_leading_zero_bits 0b0010_1000u64", 58, u8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_count_trailing_zero_bits() { - assert_evals_to!(r"Num.countTrailingZeroBits 0b0010_1000u8", 3, u8); - assert_evals_to!(r"Num.countTrailingZeroBits 0b0010_0000u16", 5, u8); - assert_evals_to!(r"Num.countTrailingZeroBits 0u32", 32, u8); - assert_evals_to!(r"Num.countTrailingZeroBits 0b0010_1111u64", 0, u8); + assert_evals_to!(r"Num.count_trailing_zero_bits 0b0010_1000u8", 3, u8); + assert_evals_to!(r"Num.count_trailing_zero_bits 0b0010_0000u16", 5, u8); + assert_evals_to!(r"Num.count_trailing_zero_bits 0u32", 32, u8); + assert_evals_to!(r"Num.count_trailing_zero_bits 0b0010_1111u64", 0, u8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_count_one_bits() { - assert_evals_to!(r"Num.countOneBits 0b0010_1000u8", 2, u8); - assert_evals_to!(r"Num.countOneBits 0b0010_0000u16", 1, u8); - assert_evals_to!(r"Num.countOneBits 0u32", 0, u8); - assert_evals_to!(r"Num.countOneBits 0b0010_1111u64", 5, u8); + assert_evals_to!(r"Num.count_one_bits 0b0010_1000u8", 2, u8); + assert_evals_to!(r"Num.count_one_bits 0b0010_0000u16", 1, u8); + assert_evals_to!(r"Num.count_one_bits 0u32", 0, u8); + assert_evals_to!(r"Num.count_one_bits 0b0010_1111u64", 5, u8); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_abs_diff_int() { - assert_evals_to!(r"Num.absDiff 0u8 0u8", 0, u8); - assert_evals_to!(r"Num.absDiff 1u8 2u8", 1, u8); - assert_evals_to!(r"Num.absDiff 2u8 1u8", 1, u8); - assert_evals_to!(r"Num.absDiff -1 1", 2, i64); - assert_evals_to!(r"Num.absDiff 1 -1", 2, i64); - assert_evals_to!(r"Num.absDiff Num.minI64 -1", i64::MAX, i64); + assert_evals_to!(r"Num.abs_diff 0u8 0u8", 0, u8); + assert_evals_to!(r"Num.abs_diff 1u8 2u8", 1, u8); + assert_evals_to!(r"Num.abs_diff 2u8 1u8", 1, u8); + assert_evals_to!(r"Num.abs_diff -1 1", 2, i64); + assert_evals_to!(r"Num.abs_diff 1 -1", 2, i64); + assert_evals_to!(r"Num.abs_diff Num.min_i64 -1", i64::MAX, i64); } #[test] #[cfg(feature = "gen-llvm")] fn num_abs_diff_large_bits() { - assert_evals_to!(r"Num.absDiff 0u128 0u128", U128::from(0), U128); - assert_evals_to!(r"Num.absDiff 1u128 2u128", U128::from(1), U128); - assert_evals_to!(r"Num.absDiff -1i128 1i128", I128::from(2), I128); + assert_evals_to!(r"Num.abs_diff 0u128 0u128", U128::from(0), U128); + assert_evals_to!(r"Num.abs_diff 1u128 2u128", U128::from(1), U128); + assert_evals_to!(r"Num.abs_diff -1i128 1i128", I128::from(2), I128); assert_evals_to!( - r"Num.absDiff Num.minI128 -1i128", + r"Num.abs_diff Num.min_i128 -1i128", I128::from(i128::MAX), I128 ); @@ -3757,38 +3813,38 @@ fn num_abs_diff_large_bits() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_abs_diff_float() { - assert_evals_to!(r"Num.absDiff 0.0f64 0.0", 0.0, f64); - assert_evals_to!(r"Num.absDiff 1.0f64 2.0", 1.0, f64); - assert_evals_to!(r"Num.absDiff 2.0f64 1.0", 1.0, f64); - assert_evals_to!(r"Num.absDiff -1.0f64 1.0", 2.0, f64); - assert_evals_to!(r"Num.absDiff 1.0f64 -1.0", 2.0, f64); + assert_evals_to!(r"Num.abs_diff 0.0f64 0.0", 0.0, f64); + assert_evals_to!(r"Num.abs_diff 1.0f64 2.0", 1.0, f64); + assert_evals_to!(r"Num.abs_diff 2.0f64 1.0", 1.0, f64); + assert_evals_to!(r"Num.abs_diff -1.0f64 1.0", 2.0, f64); + assert_evals_to!(r"Num.abs_diff 1.0f64 -1.0", 2.0, f64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] #[should_panic(expected = r#"Roc failed with message: "Integer subtraction overflowed!"#)] fn num_abs_max_overflow() { - assert_evals_to!(r"Num.absDiff Num.maxI64 -1", 0, i64); + assert_evals_to!(r"Num.abs_diff Num.max_i64 -1", 0, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] #[should_panic(expected = r#"Roc failed with message: "Integer subtraction overflowed!"#)] fn num_abs_int_min_overflow() { - assert_evals_to!(r"Num.absDiff Num.minI64 0", 0, i64); + assert_evals_to!(r"Num.abs_diff Num.min_i64 0", 0, i64); } #[test] #[cfg(feature = "gen-llvm")] #[should_panic(expected = r#"Roc failed with message: "Integer subtraction overflowed!"#)] fn num_abs_large_bits_min_overflow() { - assert_evals_to!(r"Num.absDiff Num.minI128 0", I128::from(0), I128); + assert_evals_to!(r"Num.abs_diff Num.min_i128 0", I128::from(0), I128); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn num_abs_float_overflow() { - assert_evals_to!("Num.absDiff Num.maxF64 Num.minF64", f64::INFINITY, f64); + assert_evals_to!("Num.abs_diff Num.max_f64 Num.min_f64", f64::INFINITY, f64); } #[test] @@ -3821,7 +3877,7 @@ fn add_checked_dec() { assert_evals_to!( indoc!( r" - Num.addChecked 2.0dec 4.0dec + Num.add_checked 2.0dec 4.0dec " ), RocResult::ok(RocDec::from(6)), @@ -3835,7 +3891,7 @@ fn sub_checked_dec() { assert_evals_to!( indoc!( r" - Num.subChecked 5.0dec 2.0dec + Num.sub_checked 5.0dec 2.0dec " ), RocResult::ok(RocDec::from(3)), @@ -3849,7 +3905,7 @@ fn mul_checked_dec() { assert_evals_to!( indoc!( r" - Num.mulChecked 5.0dec 2.0dec + Num.mul_checked 5.0dec 2.0dec " ), RocResult::ok(RocDec::from_str("10.0").unwrap()), @@ -3864,7 +3920,7 @@ fn mul_checked_u128() { indoc!( r" x : Result U128 [ Overflow ] - x = Num.mulChecked 5u128 2u128 + x = Num.mul_checked 5u128 2u128 x " @@ -3881,7 +3937,7 @@ fn sub_checked_u128() { indoc!( r" x : Result U128 [ Overflow ] - x = Num.subChecked 5u128 2u128 + x = Num.sub_checked 5u128 2u128 x " @@ -3898,7 +3954,7 @@ fn add_checked_u128() { indoc!( r" x : Result U128 [ Overflow ] - x = Num.addChecked 5u128 2u128 + x = Num.add_checked 5u128 2u128 x " @@ -3916,8 +3972,8 @@ fn num_min() { assert_evals_to!(r"Num.min 2 1", 1, i64); assert_evals_to!(r"Num.min 2 -2", -2, i64); assert_evals_to!(r"Num.min -2 2", -2, i64); - assert_evals_to!(r"Num.min Num.minI64 Num.maxI64", i64::MIN, i64); - assert_evals_to!(r"Num.min Num.maxI64 Num.minI64", i64::MIN, i64); + assert_evals_to!(r"Num.min Num.min_i64 Num.max_i64", i64::MIN, i64); + assert_evals_to!(r"Num.min Num.max_i64 Num.min_i64", i64::MIN, i64); } #[test] @@ -3928,30 +3984,30 @@ fn num_max() { assert_evals_to!(r"Num.max 2 1", 2, i64); assert_evals_to!(r"Num.max 2 -2", 2, i64); assert_evals_to!(r"Num.max -2 2", 2, i64); - assert_evals_to!(r"Num.max Num.minI64 Num.maxI64", i64::MAX, i64); - assert_evals_to!(r"Num.max Num.maxI64 Num.minI64", i64::MAX, i64); + assert_evals_to!(r"Num.max Num.min_i64 Num.max_i64", i64::MAX, i64); + assert_evals_to!(r"Num.max Num.max_i64 Num.min_i64", i64::MAX, i64); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn with_decimal_point() { assert_evals_to!( - r"Num.withDecimalPoint 0", + r"Num.with_decimal_point 0", RocDec::from_str("0").unwrap(), RocDec ); assert_evals_to!( - r"Num.withDecimalPoint 123000000000000000000", + r"Num.with_decimal_point 123000000000000000000", RocDec::from_str("123.0").unwrap(), RocDec ); assert_evals_to!( - r"Num.withDecimalPoint Num.maxI128", + r"Num.with_decimal_point Num.max_i128", RocDec::from_str("170141183460469231731.687303715884105727").unwrap(), RocDec ); assert_evals_to!( - r"Num.withDecimalPoint Num.minI128", + r"Num.with_decimal_point Num.min_i128", RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(), RocDec ); @@ -3961,22 +4017,22 @@ fn with_decimal_point() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn without_decimal_point() { assert_evals_to!( - r"Num.withoutDecimalPoint 0", + r"Num.without_decimal_point 0", RocDec::from_str("0").unwrap(), RocDec ); assert_evals_to!( - r"Num.withoutDecimalPoint 123.000000000000000000", + r"Num.without_decimal_point 123.000000000000000000", I128::from(123000000000000000000), I128 ); assert_evals_to!( - r"Num.withoutDecimalPoint 170141183460469231731.687303715884105727", + r"Num.without_decimal_point 170141183460469231731.687303715884105727", I128::from(i128::MAX), I128 ); assert_evals_to!( - r"Num.withoutDecimalPoint -170141183460469231731.687303715884105728", + r"Num.without_decimal_point -170141183460469231731.687303715884105728", I128::from(i128::MIN), I128 ); @@ -3985,14 +4041,14 @@ fn without_decimal_point() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn f32_to_parts() { - assert_evals_to!(r"Num.f32ToParts 0", (0, 0, false), (u32, u8, bool)); + assert_evals_to!(r"Num.f32_to_parts 0", (0, 0, false), (u32, u8, bool)); assert_evals_to!( - r"Num.f32ToParts Num.maxF32", + r"Num.f32_to_parts Num.max_f32", (0x7FFFFF, 0xFE, false), (u32, u8, bool) ); assert_evals_to!( - r"Num.f32ToParts Num.minF32", + r"Num.f32_to_parts Num.min_f32", (0x7FFFFF, 0xFE, true), (u32, u8, bool) ); @@ -4001,14 +4057,14 @@ fn f32_to_parts() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn f64_to_parts() { - assert_evals_to!(r"Num.f64ToParts 0", (0, 0, false), (u64, u16, bool)); + assert_evals_to!(r"Num.f64_to_parts 0", (0, 0, false), (u64, u16, bool)); assert_evals_to!( - r"Num.f64ToParts Num.maxF64", + r"Num.f64_to_parts Num.max_f64", (0xFFFFFFFFFFFFF, 0x7FE, false), (u64, u16, bool) ); assert_evals_to!( - r"Num.f64ToParts Num.minF64", + r"Num.f64_to_parts Num.min_f64", (0xFFFFFFFFFFFFF, 0x7FE, true), (u64, u16, bool) ); @@ -4019,7 +4075,7 @@ fn f64_to_parts() { fn f32_from_parts() { assert_evals_to!( r" - Num.f32FromParts { + Num.f32_from_parts { sign: Bool.false, exponent: 0, fraction: 0 @@ -4029,7 +4085,7 @@ fn f32_from_parts() { ); assert_evals_to!( r" - Num.f32FromParts { + Num.f32_from_parts { sign: Bool.false, exponent: 0xFE, fraction: 0x7FFFFF @@ -4039,7 +4095,7 @@ fn f32_from_parts() { ); assert_evals_to!( r" - Num.f32FromParts { + Num.f32_from_parts { sign: Bool.true, exponent: 0xFE, fraction: 0x7FFFFF @@ -4054,7 +4110,7 @@ fn f32_from_parts() { fn f64_from_parts() { assert_evals_to!( r" - Num.f64FromParts { + Num.f64_from_parts { sign: Bool.false, exponent: 0, fraction: 0 @@ -4064,7 +4120,7 @@ fn f64_from_parts() { ); assert_evals_to!( r" - Num.f64FromParts { + Num.f64_from_parts { sign: Bool.false, exponent: 0x7FE, fraction: 0xFFFFFFFFFFFFF @@ -4074,7 +4130,7 @@ fn f64_from_parts() { ); assert_evals_to!( r" - Num.f64FromParts { + Num.f64_from_parts { sign: Bool.true, exponent: 0x7FE, fraction: 0xFFFFFFFFFFFFF @@ -4093,7 +4149,7 @@ fn from_bool_true() { bool : Bool bool = Bool.true - Num.fromBool bool + Num.from_bool bool " ), 1, @@ -4110,7 +4166,7 @@ fn from_bool_false() { bool : Bool bool = Bool.false - Num.fromBool bool + Num.from_bool bool " ), 0, @@ -4121,32 +4177,32 @@ fn from_bool_false() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn nan_f32() { - assert_evals_to!(r"Num.nanF32", true, f32, |f: f32| f.is_nan()); + assert_evals_to!(r"Num.nan_f32", true, f32, |f: f32| f.is_nan()); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn nan_f64() { - assert_evals_to!(r"Num.nanF64", true, f64, |f: f64| f.is_nan()); + assert_evals_to!(r"Num.nan_f64", true, f64, |f: f64| f.is_nan()); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn infinity_f32() { - assert_evals_to!(r"Num.infinityF32", f32::INFINITY, f32); + assert_evals_to!(r"Num.infinity_f32", f32::INFINITY, f32); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev", feature = "gen-wasm"))] fn infinity_f64() { - assert_evals_to!(r"Num.infinityF64", f64::INFINITY, f64); + assert_evals_to!(r"Num.infinity_f64", f64::INFINITY, f64); } #[allow(clippy::non_minimal_cfg)] #[test] #[cfg(any(feature = "gen-llvm"))] fn cast_signed_unsigned() { - assert_evals_to!(r"Num.toI16 255u8", 255, i16); - assert_evals_to!(r"Num.toU16 127i8", 127, u16); - assert_evals_to!(r"Num.toU8 127i8", 127, u8); - assert_evals_to!(r"Num.toI8 127u8", 127, i8); + assert_evals_to!(r"Num.to_i16 255u8", 255, i16); + assert_evals_to!(r"Num.to_u16 127i8", 127, u16); + assert_evals_to!(r"Num.to_u8 127i8", 127, u8); + assert_evals_to!(r"Num.to_i8 127u8", 127, i8); } diff --git a/crates/compiler/test_gen/src/gen_panic.rs b/crates/compiler/test_gen/src/gen_panic.rs index b39c945b76a..10e790da6be 100644 --- a/crates/compiler/test_gen/src/gen_panic.rs +++ b/crates/compiler/test_gen/src/gen_panic.rs @@ -55,14 +55,14 @@ fn crash_in_call() { r#" app "test" provides [main] to "./platform" - getInfallible = \result -> when result is + get_infallible = \result -> when result is Ok x -> x _ -> crash "turns out this was fallible" main = x : [Ok U64, Err Str] x = Err "" - getInfallible x + get_infallible x "# ), 1u64, diff --git a/crates/compiler/test_gen/src/gen_primitives.rs b/crates/compiler/test_gen/src/gen_primitives.rs index fdad8eb2d3b..36130badbf4 100644 --- a/crates/compiler/test_gen/src/gen_primitives.rs +++ b/crates/compiler/test_gen/src/gen_primitives.rs @@ -310,11 +310,11 @@ fn return_unnamed_fn() { indoc!( r" wrapper = \{} -> - alwaysFloatIdentity : Int * -> (Frac a -> Frac a) - alwaysFloatIdentity = \_ -> + always_float_identity : Int * -> (Frac a -> Frac a) + always_float_identity = \_ -> (\a -> a) - (alwaysFloatIdentity 2) 1.23f64 + (always_float_identity 2) 1.23f64 wrapper {} " @@ -330,13 +330,13 @@ fn gen_when_fn() { assert_evals_to!( indoc!( r" - limitedNegate = \num -> + limited_negate = \num -> when num is 1 -> -1 -1 -> 1 _ -> num - limitedNegate 1 + limited_negate 1 " ), -1, @@ -944,7 +944,7 @@ fn when_peano() { } #[test] -// This doesn't work on Windows. If you make it return a Result.withDefault 0 (so it's returning +// This doesn't work on Windows. If you make it return a Result.with_default 0 (so it's returning // an integer instead of a Result), then it works on Windows, suggesting this is a C ABI issue. // We should try this out on Windows again after making adjustments to the Result C ABI! #[cfg(all( @@ -956,17 +956,17 @@ fn overflow_frees_list() { assert_evals_to!( indoc!( r" - myList = [1,2,3] + my_list = [1,2,3] # integer overflow; must use the list so it is defined before the overflow # the list will then be freed in a cleanup block n : I64 - n = 9_223_372_036_854_775_807 + (Num.intCast (List.len myList)) + n = 9_223_372_036_854_775_807 + (Num.int_cast (List.len my_list)) index : U64 - index = Num.intCast n + index = Num.int_cast n - List.get myList index + List.get my_list index " ), (3, 0), @@ -1117,7 +1117,7 @@ fn specialize_closure() { y = [1] f = \{} -> x - g = \{} -> x + Num.intCast (List.len y) + g = \{} -> x + Num.int_cast (List.len y) [f, g] @@ -1147,8 +1147,8 @@ fn io_poc_effect() { succeed : a -> Effect a succeed = \x -> @Effect \{} -> x - runEffect : Effect a -> a - runEffect = \@Effect thunk -> thunk {} + run_effect : Effect a -> a + run_effect = \@Effect thunk -> thunk {} foo : Effect F64 foo = @@ -1156,7 +1156,7 @@ fn io_poc_effect() { main : F64 main = - runEffect foo + run_effect foo "# ), @@ -1180,12 +1180,12 @@ fn io_poc_desugared() { foo = succeed 1.23 - # runEffect : ({} -> a) -> a - runEffect = \thunk -> thunk "" + # run_effect : ({} -> a) -> a + run_effect = \thunk -> thunk "" main : F64 main = - runEffect foo + run_effect foo "# ), 1.23, @@ -1274,8 +1274,8 @@ fn linked_list_is_singleton() { empty : {} -> ConsList a empty = \{} -> Nil - isSingleton : ConsList a -> Bool - isSingleton = \list -> + is_singleton : ConsList a -> Bool + is_singleton = \list -> when list is Cons _ Nil -> Bool.true @@ -1285,10 +1285,10 @@ fn linked_list_is_singleton() { main : Bool main = - myList : ConsList I64 - myList = empty {} + my_list : ConsList I64 + my_list = empty {} - isSingleton myList + is_singleton my_list "# ), false, @@ -1309,8 +1309,8 @@ fn linked_list_is_empty_1() { empty : {} -> ConsList a empty = \{} -> Nil - isEmpty : ConsList a -> Bool - isEmpty = \list -> + is_empty : ConsList a -> Bool + is_empty = \list -> when list is Cons _ _ -> Bool.false @@ -1320,10 +1320,10 @@ fn linked_list_is_empty_1() { main : Bool main = - myList : ConsList U8 - myList = empty {} + my_list : ConsList U8 + my_list = empty {} - isEmpty myList + is_empty my_list "# ), true, @@ -1341,8 +1341,8 @@ fn linked_list_is_empty_2() { ConsList a : [Cons a (ConsList a), Nil] - isEmpty : ConsList a -> Bool - isEmpty = \list -> + is_empty : ConsList a -> Bool + is_empty = \list -> when list is Cons _ _ -> Bool.false @@ -1352,10 +1352,10 @@ fn linked_list_is_empty_2() { main : Bool main = - myList : ConsList I64 - myList = Cons 0x1 Nil + my_list : ConsList I64 + my_list = Cons 0x1 Nil - isEmpty myList + is_empty my_list "# ), false, @@ -1428,57 +1428,57 @@ fn rbtree_insert() { insert : Key k, v, RedBlackTree (Key k) v -> RedBlackTree (Key k) v insert = \key, value, dict -> - when insertHelp key value dict is + when insert_help key value dict is Node Red k v l r -> Node Black k v l r x -> x - insertHelp : (Key k), v, RedBlackTree (Key k) v -> RedBlackTree (Key k) v - insertHelp = \key, value, dict -> + insert_help : (Key k), v, RedBlackTree (Key k) v -> RedBlackTree (Key k) v + insert_help = \key, value, dict -> when dict is Empty -> # New nodes are always red. If it violates the rules, it will be fixed # when balancing. Node Red key value Empty Empty - Node nColor nKey nValue nLeft nRight -> - when Num.compare key nKey is + Node n_color n_key n_value n_left n_right -> + when Num.compare key n_key is LT -> - balance nColor nKey nValue (insertHelp key value nLeft) nRight + balance n_color n_key n_value (insert_help key value n_left) n_right EQ -> - Node nColor nKey value nLeft nRight + Node n_color n_key value n_left n_right GT -> - balance nColor nKey nValue nLeft (insertHelp key value nRight) + balance n_color n_key n_value n_left (insert_help key value n_right) balance : NodeColor, k, v, RedBlackTree k v, RedBlackTree k v -> RedBlackTree k v balance = \color, key, value, left, right -> when right is - Node Red rK rV rLeft rRight -> + Node Red r_k r_v r_left r_right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node Red key value - (Node Black lK lV lLeft lRight) - (Node Black rK rV rLeft rRight) + (Node Black l_k l_v l_left l_right) + (Node Black r_k r_v r_left r_right) _ -> - Node color rK rV (Node Red key value left rLeft) rRight + Node color r_k r_v (Node Red key value left r_left) r_right _ -> when left is - Node Red lK lV (Node Red llK llV llLeft llRight) lRight -> + Node Red l_k l_v (Node Red ll_k ll_v ll_left ll_right) l_right -> Node Red - lK - lV - (Node Black llK llV llLeft llRight) - (Node Black key value lRight right) + l_k + l_v + (Node Black ll_k ll_v ll_left ll_right) + (Node Black key value l_right right) _ -> Node color key value left right @@ -1545,8 +1545,8 @@ fn rbtree_layout_issue() { # balance : NodeColor, k, v, RedBlackTree k v -> RedBlackTree k v balance = \color, key, value, right -> when right is - Node Red _ _ rLeft rRight -> - Node color key value rLeft rRight + Node Red _ _ r_left r_right -> + Node color key value r_left r_right _ -> @@ -1579,7 +1579,7 @@ fn rbtree_balance_mono_problem() { // constraint generation where the specialization required by `main` does not fix the // problem. As a result, the first argument is dropped and we run into issues down the line // - // concretely, the `rRight` symbol will not be defined + // concretely, the `r_right` symbol will not be defined assert_evals_to!( indoc!( r#" @@ -1592,18 +1592,18 @@ fn rbtree_balance_mono_problem() { # balance : NodeColor, k, v, RedBlackTree k v, RedBlackTree k v -> RedBlackTree k v balance = \color, key, value, left, right -> when right is - Node Red rK rV rLeft rRight -> + Node Red r_k r_v r_left r_right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node Red key value - (Node Black lK lV lLeft lRight) - (Node Black rK rV rLeft rRight) + (Node Black l_k l_v l_left l_right) + (Node Black r_k r_v r_left r_right) _ -> - Node color rK rV (Node Red key value left rLeft) rRight + Node color r_k r_v (Node Red key value left r_left) r_right _ -> Empty @@ -1639,28 +1639,28 @@ fn rbtree_balance_full() { balance : NodeColor, k, v, RedBlackTree k v, RedBlackTree k v -> RedBlackTree k v balance = \color, key, value, left, right -> when right is - Node Red rK rV rLeft rRight -> + Node Red r_k r_v r_left r_right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node Red key value - (Node Black lK lV lLeft lRight) - (Node Black rK rV rLeft rRight) + (Node Black l_k l_v l_left l_right) + (Node Black r_k r_v r_left r_right) _ -> - Node color rK rV (Node Red key value left rLeft) rRight + Node color r_k r_v (Node Red key value left r_left) r_right _ -> when left is - Node Red lK lV (Node Red llK llV llLeft llRight) lRight -> + Node Red l_k l_v (Node Red ll_k ll_v ll_left ll_right) l_right -> Node Red - lK - lV - (Node Black llK llV llLeft llRight) - (Node Black key value lRight right) + l_k + l_v + (Node Black ll_k ll_v ll_left ll_right) + (Node Black key value l_right right) _ -> Node color key value left right @@ -1876,26 +1876,26 @@ fn task_always_twice() { Effect a := {} -> a - effectAlways : a -> Effect a - effectAlways = \x -> + effect_always : a -> Effect a + effect_always = \x -> inner = \{} -> x @Effect inner - effectAfter : Effect a, (a -> Effect b) -> Effect b - effectAfter = \(@Effect thunk), transform -> transform (thunk {}) + effect_after : Effect a, (a -> Effect b) -> Effect b + effect_after = \(@Effect thunk), transform -> transform (thunk {}) MyTask a err : Effect (Result a err) always : a -> MyTask a * - always = \x -> effectAlways (Ok x) + always = \x -> effect_always (Ok x) fail : err -> MyTask * err - fail = \x -> effectAlways (Err x) + fail = \x -> effect_always (Err x) after : MyTask a err, (a -> MyTask b err) -> MyTask b err after = \task, transform -> - effectAfter task \res -> + effect_after task \res -> when res is Ok x -> transform x Err e -> fail e @@ -1980,27 +1980,27 @@ fn todo_bad_error_message() { Effect a := {} -> a - effectAlways : a -> Effect a - effectAlways = \x -> + effect_always : a -> Effect a + effect_always = \x -> inner = \{} -> x @Effect inner - effectAfter : Effect a, (a -> Effect b) -> Effect b - effectAfter = \(@Effect thunk), transform -> transform (thunk {}) + effect_after : Effect a, (a -> Effect b) -> Effect b + effect_after = \(@Effect thunk), transform -> transform (thunk {}) MyTask a err : Effect (Result a err) always : a -> MyTask a (Frac *) - always = \x -> effectAlways (Ok x) + always = \x -> effect_always (Ok x) # the problem is that this restricts to `MyTask {} *` fail : err -> MyTask {} err - fail = \x -> effectAlways (Err x) + fail = \x -> effect_always (Err x) after : MyTask a err, (a -> MyTask b err) -> MyTask b err after = \task, transform -> - effectAfter task \res -> + effect_after task \res -> when res is Ok x -> transform x # but here it must be `forall b. MyTask b {}` @@ -2024,9 +2024,9 @@ fn hof_conditional() { assert_evals_to!( indoc!( r" - passTrue = \f -> f Bool.true + pass_true = \f -> f Bool.true - passTrue (\trueVal -> if trueVal then Bool.false else Bool.true) + pass_true (\true_val -> if true_val then Bool.false else Bool.true) " ), 0, @@ -2097,10 +2097,10 @@ fn fingertree_basic() { when some is One y -> More (Two x y) q u Two y z -> More (Three x y z) q u - Three y z w -> More (Two x y) (consTuple (Pair z w) q) u + Three y z w -> More (Two x y) (cons_tuple (Pair z w) q) u - consTuple : Tuple a, Seq (Tuple a) -> Seq (Tuple a) - consTuple = \a, b -> cons a b + cons_tuple : Tuple a, Seq (Tuple a) -> Seq (Tuple a) + cons_tuple = \a, b -> cons a b main : Bool main = @@ -2201,11 +2201,11 @@ fn nullable_eval_cfold() { Expr : [Var, Val I64, Add Expr Expr, Mul Expr Expr] - mkExpr : I64, I64 -> Expr - mkExpr = \n , v -> + mk_expr : I64, I64 -> Expr + mk_expr = \n , v -> when n is 0 -> if v == 0 then Var else Val v - _ -> Add (mkExpr (n-1) (v+1)) (mkExpr (n-1) (max (v-1) 0)) + _ -> Add (mk_expr (n-1) (v+1)) (mk_expr (n-1) (max (v-1) 0)) max : I64, I64 -> I64 max = \a, b -> if a > b then a else b @@ -2219,7 +2219,7 @@ fn nullable_eval_cfold() { Mul l r -> eval l * eval r main : I64 - main = eval (mkExpr 3 1) + main = eval (mk_expr 3 1) "# ), 11, @@ -2247,8 +2247,8 @@ fn nested_switch() { Val v -> v ZAdd l r -> eval l + eval r - constFolding : Expr -> Expr - constFolding = \e -> + const_folding : Expr -> Expr + const_folding = \e -> when e is ZAdd e1 e2 -> when Pair e1 e2 is @@ -2263,7 +2263,7 @@ fn nested_switch() { expr = ZAdd (Val 3) (ZAdd (Val 4) (Val 5)) main : I64 - main = eval (constFolding expr) + main = eval (const_folding expr) "# ), 12, @@ -2653,7 +2653,7 @@ fn mirror_llvm_alignment_padding() { p1 = {name : "test1", test: 1 == 1 } List.map [p1, p1] (\{ test } -> if test then "pass" else "fail") - |> Str.joinWith "\n" + |> Str.join_with "\n" "# ), @@ -2675,9 +2675,9 @@ fn lambda_set_bool() { main : I64 main = - oneOfResult = List.map [p1, p2] (\p -> p 42) + one_of_result = List.map [p1, p2] (\p -> p 42) - when oneOfResult is + when one_of_result is _ -> 32 "# @@ -2701,9 +2701,9 @@ fn lambda_set_byte() { main : I64 main = - oneOfResult = List.map [p1, p2, p3] (\p -> p 42) + one_of_result = List.map [p1, p2, p3] (\p -> p 42) - when oneOfResult is + when one_of_result is _ -> 32 "# @@ -2729,9 +2729,9 @@ fn lambda_set_struct_byte() { p1 = (\u -> r == u) foobarbaz = (\p -> p Green) - oneOfResult = List.map [p1, p1] foobarbaz + one_of_result = List.map [p1, p1] foobarbaz - when oneOfResult is + when one_of_result is _ -> 32 "# @@ -2760,9 +2760,9 @@ fn lambda_set_enum_byte_byte() { p1 = (\u -> r == u) p2 = (\u -> g == u) - oneOfResult = List.map [p1, p2] (\p -> p Green) + one_of_result = List.map [p1, p2] (\p -> p Green) - when oneOfResult is + when one_of_result is _ -> 32 "# @@ -2782,14 +2782,14 @@ fn list_walk_until() { app "test" provides [main] to "./platform" - satisfyA : {} -> List {} - satisfyA = \_ -> [] + satisfy_a : {} -> List {} + satisfy_a = \_ -> [] - oneOfResult = - List.walkUntil [satisfyA] [] \_, _ -> Break [] + one_of_result = + List.walk_until [satisfy_a] [] \_, _ -> Break [] main = - when oneOfResult is + when one_of_result is _ -> 32 "# ), @@ -2811,11 +2811,11 @@ fn int_literal_not_specialized_with_annotation() { satisfy : (U8 -> Str) -> Str satisfy = \_ -> "foo" - myEq : a, a -> Str - myEq = \_, _ -> "bar" + my_eq : a, a -> Str + my_eq = \_, _ -> "bar" p1 : Num * -> Str - p1 = (\u -> myEq u 64) + p1 = (\u -> my_eq u 64) when satisfy p1 is _ -> 32 @@ -2839,10 +2839,10 @@ fn int_literal_not_specialized_no_annotation() { satisfy : (U8 -> Str) -> Str satisfy = \_ -> "foo" - myEq : a, a -> Str - myEq = \_, _ -> "bar" + my_eq : a, a -> Str + my_eq = \_, _ -> "bar" - p1 = (\u -> myEq u 64) + p1 = (\u -> my_eq u 64) when satisfy p1 is _ -> 32 @@ -2868,9 +2868,9 @@ fn unresolved_tvar_when_capture_is_unused() { r = 1 p1 = (\_ -> r == 1) - oneOfResult = List.map [p1] (\p -> p Green) + one_of_result = List.map [p1] (\p -> p Green) - when oneOfResult is + when one_of_result is _ -> 32 "# @@ -2891,7 +2891,7 @@ fn value_not_exposed_hits_panic() { main : I64 main = - Str.toInt 32 + Str.to_int 32 "# ), 32, @@ -2974,7 +2974,7 @@ fn do_pass_bool_byte_closure_layout() { any: Parser U8 any = \inp -> when List.first inp is - Ok u -> [Pair u (List.dropFirst inp 1)] + Ok u -> [Pair u (List.drop_first inp 1)] _ -> [] @@ -2991,12 +2991,12 @@ fn do_pass_bool_byte_closure_layout() { else Break accum - List.walkUntil (any input) [] walker + List.walk_until (any input) [] walker - oneOf : List (Parser a) -> Parser a - oneOf = \parserList -> + one_of : List (Parser a) -> Parser a + one_of = \parserList -> \input -> walker = \accum, p -> output = p input @@ -3006,20 +3006,20 @@ fn do_pass_bool_byte_closure_layout() { else Continue accum - List.walkUntil parserList [] walker + List.walk_until parserList [] walker - satisfyA = satisfy (\u -> u == 97) # recognize 97 - satisfyB = satisfy (\u -> u == 98) # recognize 98 + satisfy_a = satisfy (\u -> u == 97) # recognize 97 + satisfy_b = satisfy (\u -> u == 98) # recognize 98 - test1 = if List.len ((oneOf [satisfyA, satisfyB]) [97, 98, 99, 100] ) == 1 then "PASS" else "FAIL" - test2 = if List.len ((oneOf [satisfyA, satisfyB]) [98, 99, 100, 97] ) == 1 then "PASS" else "FAIL" - test3 = if List.len ((oneOf [satisfyB , satisfyA]) [98, 99, 100, 97] ) == 1 then "PASS" else "FAIL" - test4 = if List.len ((oneOf [satisfyA, satisfyB]) [99, 100, 101] ) == 0 then "PASS" else "FAIL" + test1 = if List.len ((one_of [satisfy_a, satisfy_b]) [97, 98, 99, 100] ) == 1 then "PASS" else "FAIL" + test2 = if List.len ((one_of [satisfy_a, satisfy_b]) [98, 99, 100, 97] ) == 1 then "PASS" else "FAIL" + test3 = if List.len ((one_of [satisfy_b , satisfy_a]) [98, 99, 100, 97] ) == 1 then "PASS" else "FAIL" + test4 = if List.len ((one_of [satisfy_a, satisfy_b]) [99, 100, 101] ) == 0 then "PASS" else "FAIL" main : Str - main = [test1, test2, test3, test4] |> Str.joinWith ", " + main = [test1, test2, test3, test4] |> Str.join_with ", " "# ), RocStr::from("PASS, PASS, PASS, PASS"), @@ -3108,23 +3108,23 @@ fn nested_rigid_tag_union() { #[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))] fn call_that_needs_closure_parameter() { // here both p2 is lifted to the top-level, which means that `list` must be - // passed to it from `manyAux`. + // passed to it from `many_aux`. assert_evals_to!( indoc!( r#" Step state a : [Loop state, Done a] - manyAux : List a -> [Pair (Step (List a) (List a))] - manyAux = \list -> + many_aux : List a -> [Pair (Step (List a) (List a))] + many_aux = \list -> p2 = \_ -> Pair (Done list) p2 "foo" - manyAuxTest = (manyAux []) == Pair (Loop [97]) + many_aux_test = (many_aux []) == Pair (Loop [97]) - runTest = \t -> if t then "PASS" else "FAIL" + run_test = \t -> if t then "PASS" else "FAIL" - runTest manyAuxTest + run_test many_aux_test "# ), RocStr::from("FAIL"), @@ -3168,17 +3168,17 @@ fn recursively_build_effect() { "$(hi), $(name)!" main = - when nestHelp 4 is + when nest_help 4 is _ -> greeting - nestHelp : I64 -> XEffect {} - nestHelp = \m -> + nest_help : I64 -> XEffect {} + nest_help = \m -> when m is 0 -> always {} _ -> - always {} |> after \_ -> nestHelp (m - 1) + always {} |> after \_ -> nest_help (m - 1) XEffect a := {} -> a @@ -3208,13 +3208,13 @@ fn polymophic_expression_captured_inside_closure() { r#" app "test" provides [main] to "./platform" - asU8 : U8 -> U8 - asU8 = \_ -> 30 + as_u8 : U8 -> U8 + as_u8 = \_ -> 30 main = a = 15 f = \{} -> - asU8 a + as_u8 a f {} "# @@ -3231,9 +3231,9 @@ fn issue_2322() { indoc!( r" double = \x -> x * 2 - doubleBind = \x -> (\_ -> double x) - doubleThree = doubleBind 3 - doubleThree {} + double_bind = \x -> (\_ -> double x) + double_three = double_bind 3 + double_three {} " ), 6, @@ -3458,10 +3458,10 @@ fn closure_called_in_its_defining_scope() { g : Str g = "hello world" - getG : {} -> Str - getG = \{} -> g + get_g : {} -> Str + get_g = \{} -> g - getG {} + get_g {} "# ), RocStr::from("hello world"), @@ -3483,11 +3483,11 @@ fn issue_2894() { g : { x : U32 } g = { x: 1u32 } - getG : {} -> { x : U32 } - getG = \{} -> g + get_g : {} -> { x : U32 } + get_g = \{} -> g h : {} -> U32 - h = \{} -> (getG {}).x + h = \{} -> (get_g {}).x h {} "# @@ -3548,7 +3548,7 @@ fn polymorphic_lambda_set_multiple_specializations() { f = if Bool.true then id1 else id2 f z - (id 9u8) + Num.toU8 (id 16u16) + (id 9u8) + Num.to_u8 (id 16u16) " ), 25, @@ -3585,19 +3585,19 @@ fn mutual_recursion_top_level_defs() { r#" app "test" provides [ main ] to "./platform" - isEven = \n -> + is_even = \n -> when n is 0 -> Bool.true 1 -> Bool.false - _ -> isOdd (n - 1) + _ -> is_odd (n - 1) - isOdd = \n -> + is_odd = \n -> when n is 0 -> Bool.false 1 -> Bool.true - _ -> isEven (n - 1) + _ -> is_even (n - 1) - main = isOdd 11 + main = is_odd 11 "# ), true, @@ -3633,7 +3633,7 @@ fn lambda_capture_niche_u64_vs_u8_capture() { capture : _ -> ({} -> Str) capture = \val -> \{} -> - Num.toStr val + Num.to_str val x : Bool x = Bool.true @@ -3661,7 +3661,7 @@ fn lambda_capture_niches_with_other_lambda_capture() { capture : _ -> ({} -> Str) capture = \val -> \{} -> - Num.toStr val + Num.to_str val capture2 = \val -> \{} -> val @@ -3694,7 +3694,7 @@ fn lambda_capture_niches_with_non_capturing_function() { capture : _ -> ({} -> Str) capture = \val -> \{} -> - Num.toStr val + Num.to_str val triv = \{} -> "triv" @@ -4058,9 +4058,9 @@ fn transient_captures() { r#" x = "abc" - getX = \{} -> x + get_x = \{} -> x - h = \{} -> getX {} + h = \{} -> get_x {} h {} "# @@ -4076,9 +4076,9 @@ fn transient_captures_after_def_ordering() { assert_evals_to!( indoc!( r#" - h = \{} -> getX {} + h = \{} -> get_x {} - getX = \{} -> x + get_x = \{} -> x x = "abc" @@ -4098,11 +4098,11 @@ fn deep_transient_capture_chain() { r#" z = "abc" - getX = \{} -> getY {} - getY = \{} -> getZ {} - getZ = \{} -> z + get_x = \{} -> get_y {} + get_y = \{} -> get_z {} + get_z = \{} -> z - h = \{} -> getX {} + h = \{} -> get_x {} h {} "# @@ -4123,13 +4123,13 @@ fn deep_transient_capture_chain_with_multiple_captures() { y = "y" z = "z" - getX = \{} -> Str.concat x (getY {}) - getY = \{} -> Str.concat y (getZ {}) - getZ = \{} -> z + get_x = \{} -> Str.concat x (get_y {}) + get_y = \{} -> Str.concat y (get_z {}) + get_z = \{} -> z - getH = \{} -> Str.concat h (getX {}) + get_h = \{} -> Str.concat h (get_x {}) - getH {} + get_h {} "# ), RocStr::from("hxyz"), @@ -4145,13 +4145,13 @@ fn transient_captures_from_outer_scope() { r#" x = "abc" - getX = \{} -> x + get_x = \{} -> x - innerScope = - h = \{} -> getX {} + inner_scope = + h = \{} -> get_x {} h {} - innerScope + inner_scope "# ), RocStr::from("abc"), @@ -4191,13 +4191,13 @@ fn int_let_generalization() { assert_evals_to!( indoc!( r#" - manyAux : {} -> I32 - manyAux = \_ -> + many_aux : {} -> I32 + many_aux = \_ -> output = \_ -> 42 output {} - when manyAux {} is + when many_aux {} is _ -> "done" "# ), @@ -4281,18 +4281,18 @@ fn issue_4712() { v2 = "cd" apply : Parser (a -> Str), a -> Parser Str - apply = \fnParser, valParser -> + apply = \fn_parser, val_parser -> \{} -> - (fnParser {}) (valParser) + (fn_parser {}) (val_parser) map : a, (a -> Str) -> Parser Str - map = \simpleParser, transform -> - apply (\{} -> transform) simpleParser + map = \simple_parser, transform -> + apply (\{} -> transform) simple_parser gen = \{} -> [ map v1 (\{} -> "ab"), map v2 (\s -> s) ] |> List.map (\f -> f {}) - |> Str.joinWith "," + |> Str.join_with "," main = gen {} "# @@ -4370,11 +4370,11 @@ fn function_specialization_information_in_lambda_set_thunk() { r#" app "test" provides [main] to "./platform" - andThen = \{} -> + and_then = \{} -> x = 10u8 - \newFn -> Num.add (newFn {}) x + \new_fn -> Num.add (new_fn {}) x - between = andThen {} + between = and_then {} main = between \{} -> between \{} -> 10u8 "# @@ -4392,13 +4392,13 @@ fn function_specialization_information_in_lambda_set_thunk_independent_defs() { r#" app "test" provides [main] to "./platform" - andThen = \{} -> + and_then = \{} -> x = 10u8 - \newFn -> Num.add (newFn {}) x + \new_fn -> Num.add (new_fn {}) x - between1 = andThen {} + between1 = and_then {} - between2 = andThen {} + between2 = and_then {} main = between1 \{} -> between2 \{} -> 10u8 "# @@ -4439,14 +4439,14 @@ fn recursive_lambda_set_resolved_only_upon_specialization() { r#" app "test" provides [main] to "./platform" - factCPS = \n, cont -> + fact_cps = \n, cont -> if n == 0 then cont 1 else - factCPS (n - 1) \value -> cont (n * value) + fact_cps (n - 1) \value -> cont (n * value) main = - factCPS 5u64 \x -> x + fact_cps 5u64 \x -> x "# ), 120, @@ -4499,28 +4499,28 @@ fn reset_recursive_type_wraps_in_named_type() { main : Str main = - newList = mapLinkedList (Cons 1 (Cons 2 (Cons 3 Nil))) (\x -> x + 1) - printLinkedList newList Num.toStr + new_list = map_linked_list (Cons 1 (Cons 2 (Cons 3 Nil))) (\x -> x + 1) + print_linked_list new_list Num.to_str LinkedList a : [Cons a (LinkedList a), Nil] - mapLinkedList : LinkedList a, (a -> b) -> LinkedList b - mapLinkedList = \linkedList, f -> when linkedList is + map_linked_list : LinkedList a, (a -> b) -> LinkedList b + map_linked_list = \linked_list, f -> when linked_list is Nil -> Nil Cons x xs -> s = if Bool.true then "true" else "false" expect s == "true" - Cons (f x) (mapLinkedList xs f) + Cons (f x) (map_linked_list xs f) - printLinkedList : LinkedList a, (a -> Str) -> Str - printLinkedList = \linkedList, f -> - when linkedList is + print_linked_list : LinkedList a, (a -> Str) -> Str + print_linked_list = \linked_list, f -> + when linked_list is Nil -> "Nil" Cons x xs -> - strX = f x - strXs = printLinkedList xs f - "Cons $(strX) ($(strXs))" + str_x = f x + str_xs = print_linked_list xs f + "Cons $(str_x) ($(str_xs))" "# ), RocStr::from("Cons 2 (Cons 3 (Cons 4 (Nil)))"), @@ -4643,12 +4643,12 @@ fn issue_6139_contains() { seen else # node = "B" - nextNode = stepNode node + next_node = step_node node # node = "C" - buggy nextNode (List.append seen node) + buggy next_node (List.append seen node) - stepNode = \node -> + step_node = \node -> when node is "A" -> "B" "B" -> "C" @@ -4676,15 +4676,15 @@ fn issue_6139_prefixes() { indoc!( r#" prefixes = \str, soFar -> - if Str.isEmpty str then + if Str.is_empty str then soFar else graphemes = - Str.toUtf8 str - |> List.map \c -> Str.fromUtf8 [c] |> Result.withDefault "" - remaining = List.dropFirst graphemes 1 - next = Str.joinWith remaining "" + Str.to_utf8 str + |> List.map \c -> Str.from_utf8 [c] |> Result.with_default "" + remaining = List.drop_first graphemes 1 + next = Str.join_with remaining "" prefixes next (List.append soFar str) diff --git a/crates/compiler/test_gen/src/gen_records.rs b/crates/compiler/test_gen/src/gen_records.rs index 23552198420..5ba7ca33b82 100644 --- a/crates/compiler/test_gen/src/gen_records.rs +++ b/crates/compiler/test_gen/src/gen_records.rs @@ -113,9 +113,9 @@ fn fn_record() { assert_evals_to!( indoc!( r#" - getRec = \x -> { y: "foo", x, z: 19 } + get_rec = \x -> { y: "foo", x, z: 19 } - (getRec 15).x + (get_rec 15).x "# ), 15, @@ -1005,10 +1005,10 @@ fn update_the_only_field() { foo = 4 - newModel : Model - newModel = { model & foo } + new_model : Model + new_model = { model & foo } - newModel.foo + new_model.foo " ), 4, @@ -1095,9 +1095,9 @@ fn generalized_accessor() { assert_evals_to!( indoc!( r#" - returnFoo = .foo + return_foo = .foo - returnFoo { foo: "foo" } + return_foo { foo: "foo" } "# ), RocStr::from("foo"), @@ -1113,11 +1113,11 @@ fn update_record_that_is_a_thunk() { r#" app "test" provides [main] to "./platform" - main = Num.toStr fromOriginal.birds + main = Num.to_str from_original.birds original = { birds: 5, iguanas: 7, zebras: 2, goats: 1 } - fromOriginal = { original & birds: 4, iguanas: 3 } + from_original = { original & birds: 4, iguanas: 3 } "# ), RocStr::from("4"), @@ -1133,11 +1133,11 @@ fn update_record_that_is_a_thunk_single_field() { r#" app "test" provides [main] to "./platform" - main = Num.toStr fromOriginal.birds + main = Num.to_str from_original.birds original = { birds: 5 } - fromOriginal = { original & birds: 4 } + from_original = { original & birds: 4 } "# ), RocStr::from("4"), diff --git a/crates/compiler/test_gen/src/gen_refcount.rs b/crates/compiler/test_gen/src/gen_refcount.rs index 0e50e1b2ca4..66b2249dbf6 100644 --- a/crates/compiler/test_gen/src/gen_refcount.rs +++ b/crates/compiler/test_gen/src/gen_refcount.rs @@ -39,7 +39,7 @@ fn str_dealloc() { r#" s = Str.concat "A long enough string " "to be heap-allocated" - Str.isEmpty s + Str.is_empty s "# ), bool, @@ -55,7 +55,7 @@ fn str_to_utf8() { r#" s = Str.concat "A long enough string " "to be heap-allocated" - Str.toUtf8 s + Str.to_utf8 s "# ), RocStr, @@ -73,8 +73,8 @@ fn str_from_utf8() { r#" s = Str.concat "A long enough string " "to be heap-allocated" - Str.toUtf8 s - |> Str.fromUtf8 + Str.to_utf8 s + |> Str.from_utf8 "# ), RocStr, @@ -92,7 +92,7 @@ fn str_to_utf8_dealloc() { r#" s = Str.concat "A long enough string " "to be heap-allocated" - Str.toUtf8 s + Str.to_utf8 s |> List.len "# ), @@ -185,7 +185,7 @@ fn list_str_drop_first() { r#" s = Str.concat "A long enough string " "to be heap-allocated" list = [s, s, s] - List.dropFirst list 1 + List.drop_first list 1 "# ), RocList>, @@ -206,7 +206,7 @@ fn list_str_take_first() { r#" s = Str.concat "A long enough string " "to be heap-allocated" list = [s, s, s] - List.takeFirst list 1 + List.take_first list 1 "# ), RocList>, @@ -226,7 +226,7 @@ fn list_str_split_on() { r#" s = Str.concat "A long enough string " "to be heap-allocated" list = [s, s, s] - List.splitAt list 1 + List.split_at list 1 "# ), (RocList, RocList), @@ -245,7 +245,7 @@ fn list_str_split_on_zero() { r#" s = Str.concat "A long enough string " "to be heap-allocated" list = [s, s, s] - List.splitAt list 0 + List.split_at list 0 "# ), (RocList, RocList), @@ -265,7 +265,7 @@ fn list_get() { s = Str.concat "A long enough string " "to be heap-allocated" i1 = [s, s, s] List.get i1 1 - |> Result.withDefault "" + |> Result.with_default "" "# ), RocStr, @@ -284,7 +284,7 @@ fn list_map() { r#" s = Str.concat "A long enough string " "to be heap-allocated" i1 = [s, s, s] - List.map i1 Str.toUtf8 + List.map i1 Str.to_utf8 "# ), RocList, @@ -304,7 +304,7 @@ fn list_map_dealloc() { r#" s = Str.concat "A long enough string " "to be heap-allocated" i1 = [s, s, s] - List.map i1 Str.toUtf8 + List.map i1 Str.to_utf8 |> List.len "# ), @@ -689,17 +689,17 @@ fn union_linked_list_long_dec() { LinkedList a : [Nil, Cons a (LinkedList a)] - prependOnes = \n, tail -> + prepend_ones = \n, tail -> if n == 0 then tail else - prependOnes (n-1) (Cons 1 tail) + prepend_ones (n-1) (Cons 1 tail) main = n = 1_000 linked : LinkedList I64 - linked = prependOnes n Nil + linked = prepend_ones n Nil when linked is Cons x _ -> x @@ -801,8 +801,8 @@ fn reset_reuse_alignment_8() { Val v -> v ZAdd l r -> eval l + eval r - constFolding : Expr -> Expr - constFolding = \e -> + const_folding : Expr -> Expr + const_folding = \e -> when e is ZAdd e1 e2 -> when Pair e1 e2 is @@ -817,7 +817,7 @@ fn reset_reuse_alignment_8() { expr = ZAdd (Val 4) (Val 5) main : I64 - main = eval (constFolding expr) + main = eval (const_folding expr) "# ), i64, @@ -837,8 +837,8 @@ fn basic_cli_parser() { r#" in = "d" - |> Str.toUtf8 - |> List.keepOks \c -> Str.fromUtf8 [c] + |> Str.to_utf8 + |> List.keep_oks \c -> Str.from_utf8 [c] out = when in is diff --git a/crates/compiler/test_gen/src/gen_result.rs b/crates/compiler/test_gen/src/gen_result.rs index f9160a73a09..e46045dff6f 100644 --- a/crates/compiler/test_gen/src/gen_result.rs +++ b/crates/compiler/test_gen/src/gen_result.rs @@ -21,7 +21,7 @@ fn with_default_ok() { result : Result I64 {} result = Ok 12345 - Result.withDefault result 0 + Result.with_default result 0 " ), 12345, @@ -38,7 +38,7 @@ fn with_default_err() { result : Result I64 {} result = Err {} - Result.withDefault result 0 + Result.with_default result 0 " ), 0, @@ -57,7 +57,7 @@ fn result_map() { result |> Result.map (\x -> x + 1) - |> Result.withDefault 0 + |> Result.with_default 0 " ), 3, @@ -72,7 +72,7 @@ fn result_map() { result |> Result.map (\x -> x + 1) - |> Result.withDefault 0 + |> Result.with_default 0 " ), 0, @@ -89,7 +89,7 @@ fn result_map_err() { result : Result {} I64 result = Err 2 - when Result.mapErr result (\x -> x + 1) is + when Result.map_err result (\x -> x + 1) is Err n -> n Ok _ -> 0 " @@ -104,7 +104,7 @@ fn result_map_err() { result : Result {} I64 result = Ok {} - when Result.mapErr result (\x -> x + 1) is + when Result.map_err result (\x -> x + 1) is Err n -> n Ok _ -> 0 " @@ -121,7 +121,7 @@ fn err_type_var() { indoc!( r" Result.map (Ok 3) (\x -> x + 1) - |> Result.withDefault -1 + |> Result.with_default -1 " ), 4, @@ -139,7 +139,7 @@ fn err_type_var_annotation() { ok = Ok 3 Result.map ok (\x -> x + 1) - |> Result.withDefault -1 + |> Result.with_default -1 " ), 4, @@ -157,7 +157,7 @@ fn err_empty_tag_union() { ok = Ok 3 Result.map ok (\x -> x + 1) - |> Result.withDefault -1 + |> Result.with_default -1 " ), 4, @@ -174,7 +174,7 @@ fn is_ok() { result : Result I64 {} result = Ok 2 - Result.isOk result + Result.is_ok result " ), true, @@ -187,7 +187,7 @@ fn is_ok() { result : Result I64 {} result = Err {} - Result.isOk result + Result.is_ok result " ), false, @@ -204,7 +204,7 @@ fn is_err() { result : Result I64 {} result = Ok 2 - Result.isErr result + Result.is_err result " ), false, @@ -217,7 +217,7 @@ fn is_err() { result : Result I64 {} result = Err {} - Result.isErr result + Result.is_err result " ), true, @@ -284,7 +284,7 @@ fn roc_result_err() { fn issue_2583_specialize_errors_behind_unified_branches() { assert_evals_to!( r#" - if Bool.true then List.first [15] else Str.toI64 "" + if Bool.true then List.first [15] else Str.to_i64 "" "#, RocResult::ok(15i64), RocResult @@ -331,7 +331,7 @@ fn roc_result_after_err() { r#" result : Result Str I64 result = - Result.onErr (Ok "already a string") \num -> + Result.on_err (Ok "already a string") \num -> if num < 0 then Ok "negative!" else Err -num result @@ -345,7 +345,7 @@ fn roc_result_after_err() { r#" result : Result Str I64 result = - Result.onErr (Err 100) \num -> + Result.on_err (Err 100) \num -> if num < 0 then Ok "negative!" else Err -num result @@ -364,7 +364,7 @@ fn roc_result_map_both() { result : Result I64 I64 result = Ok 42 - result |> Result.mapBoth Num.toStr Num.toStr + result |> Result.map_both Num.to_str Num.to_str "# ), RocResult::ok(RocStr::from("42")), @@ -377,7 +377,7 @@ fn roc_result_map_both() { result : Result I64 I64 result = Err 24 - result |> Result.mapBoth Num.toStr Num.toStr + result |> Result.map_both Num.to_str Num.to_str "# ), RocResult::err(RocStr::from("24")), diff --git a/crates/compiler/test_gen/src/gen_return.rs b/crates/compiler/test_gen/src/gen_return.rs index b35ac895a47..9b62fa45e2d 100644 --- a/crates/compiler/test_gen/src/gen_return.rs +++ b/crates/compiler/test_gen/src/gen_return.rs @@ -25,13 +25,13 @@ fn early_return_nested_ifs() { r#" app "test" provides [main] to "./platform" - displayN = \n -> - first = Num.toStr n + display_n = \n -> + first = Num.to_str n second = if n == 1 then return "early 1" else - third = Num.toStr (n + 1) + third = Num.to_str (n + 1) if n == 2 then return "early 2" else @@ -40,7 +40,7 @@ fn early_return_nested_ifs() { "$(first), $(second)" main : List Str - main = List.map [1, 2, 3] displayN + main = List.map [1, 2, 3] display_n "# ), RocList::from_slice(&[ @@ -60,15 +60,15 @@ fn early_return_nested_whens() { r#" app "test" provides [main] to "./platform" - displayN = \n -> - first = Num.toStr n + display_n = \n -> + first = Num.to_str n second = when n is 1 -> return "early 1" _ -> - third = Num.toStr (n + 1) + third = Num.to_str (n + 1) when n is 2 -> return "early 2" @@ -79,7 +79,7 @@ fn early_return_nested_whens() { "$(first), $(second)" main : List Str - main = List.map [1, 2, 3] displayN + main = List.map [1, 2, 3] display_n "# ), RocList::from_slice(&[ @@ -134,18 +134,18 @@ fn early_return_annotated_function() { r#" app "test" provides [main] to "./platform" - failIfLessThanFive : U64 -> Result {} [LessThanFive] - failIfLessThanFive = \n -> + fail_if_less_than_five : U64 -> Result {} [LessThanFive] + fail_if_less_than_five = \n -> if n < 5 then Err LessThanFive else Ok {} - validateInput : Str -> Result U64 [InvalidNumStr, LessThanFive] - validateInput = \str -> - num = try Str.toU64 str + validate_input : Str -> Result U64 [InvalidNumStr, LessThanFive] + validate_input = \str -> + num = try Str.to_u64 str - when failIfLessThanFive num is + when fail_if_less_than_five num is Err err -> return Err err @@ -155,8 +155,8 @@ fn early_return_annotated_function() { main : List Str main = ["abc", "3", "7"] - |> List.map validateInput - |> List.map Inspect.toStr + |> List.map validate_input + |> List.map Inspect.to_str "# ), RocList::from_slice(&[ @@ -176,18 +176,18 @@ fn early_return_nested_annotated_function() { r#" app "test" provides [main] to "./platform" - validateInput : Str -> Result U64 [InvalidNumStr, LessThanFive] - validateInput = \str -> - failIfLessThanFive : U64 -> Result {} [LessThanFive] - failIfLessThanFive = \n -> + validate_input : Str -> Result U64 [InvalidNumStr, LessThanFive] + validate_input = \str -> + fail_if_less_than_five : U64 -> Result {} [LessThanFive] + fail_if_less_than_five = \n -> if n < 5 then Err LessThanFive else Ok {} - num = try Str.toU64 str + num = try Str.to_u64 str - when failIfLessThanFive num is + when fail_if_less_than_five num is Err err -> return Err err @@ -197,8 +197,8 @@ fn early_return_nested_annotated_function() { main : List Str main = ["abc", "3", "7"] - |> List.map validateInput - |> List.map Inspect.toStr + |> List.map validate_input + |> List.map Inspect.to_str "# ), RocList::from_slice(&[ @@ -218,39 +218,39 @@ fn early_return_annotated_recursive_function() { r#" app "test" provides [main] to "./platform" - mightCallSecond : U64 -> Result U64 _ - mightCallSecond = \num -> - nextNum = + might_call_second : U64 -> Result U64 _ + might_call_second = \num -> + next_num = if num < 5 then return Err LessThanFive else num - 1 - mightCallFirst nextNum + might_call_first next_num - mightCallFirst : U64 -> Result U64 _ - mightCallFirst = \num -> - nextNum = + might_call_first : U64 -> Result U64 _ + might_call_first = \num -> + next_num = if num < 10 then return Err LessThanTen else num * 2 - if nextNum > 25 then - Ok nextNum + if next_num > 25 then + Ok next_num else - mightCallSecond nextNum + might_call_second next_num main : List Str main = [ - mightCallSecond 3, - mightCallSecond 7, - mightCallSecond 20, - mightCallFirst 7, - mightCallFirst 15, + might_call_second 3, + might_call_second 7, + might_call_second 20, + might_call_first 7, + might_call_first 15, ] - |> List.map Inspect.toStr + |> List.map Inspect.to_str "# ), RocList::from_slice(&[ diff --git a/crates/compiler/test_gen/src/gen_set.rs b/crates/compiler/test_gen/src/gen_set.rs index d3571ad965f..dd500f3384c 100644 --- a/crates/compiler/test_gen/src/gen_set.rs +++ b/crates/compiler/test_gen/src/gen_set.rs @@ -49,7 +49,7 @@ fn single_to_list() { assert_evals_to!( indoc!( r" - Set.toList (Set.single 42) + Set.to_list (Set.single 42) " ), RocList::from_slice(&[42]), @@ -59,7 +59,7 @@ fn single_to_list() { assert_evals_to!( indoc!( r" - Set.toList (Set.single 1) + Set.to_list (Set.single 1) " ), RocList::from_slice(&[1]), @@ -77,7 +77,7 @@ fn insert() { |> Set.insert 0 |> Set.insert 1 |> Set.insert 2 - |> Set.toList + |> Set.to_list " ), RocList::from_slice(&[0, 1, 2]), @@ -96,7 +96,7 @@ fn remove() { |> Set.insert 1 |> Set.remove 1 |> Set.remove 2 - |> Set.toList + |> Set.to_list " ), RocList::from_slice(&[0]), @@ -111,13 +111,13 @@ fn union() { indoc!( r" set1 : Set.Set I64 - set1 = Set.fromList [1,2] + set1 = Set.from_list [1,2] set2 : Set.Set I64 - set2 = Set.fromList [1,3,4] + set2 = Set.from_list [1,3,4] Set.union set1 set2 - |> Set.toList + |> Set.to_list " ), RocList::from_slice(&[1, 3, 4, 2]), @@ -132,13 +132,13 @@ fn difference() { indoc!( r" set1 : Set.Set I64 - set1 = Set.fromList [1,2] + set1 = Set.from_list [1,2] set2 : Set.Set I64 - set2 = Set.fromList [1,3,4] + set2 = Set.from_list [1,3,4] Set.difference set1 set2 - |> Set.toList + |> Set.to_list " ), RocList::from_slice(&[2]), @@ -153,13 +153,13 @@ fn intersection() { indoc!( r" set1 : Set.Set I64 - set1 = Set.fromList [1,2] + set1 = Set.from_list [1,2] set2 : Set.Set I64 - set2 = Set.fromList [1,3,4] + set2 = Set.from_list [1,3,4] Set.intersection set1 set2 - |> Set.toList + |> Set.to_list " ), RocList::from_slice(&[1]), @@ -173,7 +173,7 @@ fn walk_sum() { assert_evals_to!( indoc!( r" - Set.walk (Set.fromList [1,2,3]) 0 (\x, y -> x + y) + Set.walk (Set.from_list [1,2,3]) 0 (\x, y -> x + y) " ), 6, @@ -187,7 +187,7 @@ fn contains() { assert_evals_to!( indoc!( r" - Set.contains (Set.fromList [1,3,4]) 4 + Set.contains (Set.from_list [1,3,4]) 4 " ), true, @@ -197,7 +197,7 @@ fn contains() { assert_evals_to!( indoc!( r" - Set.contains (Set.fromList [1,3,4]) 2 + Set.contains (Set.from_list [1,3,4]) 2 " ), false, @@ -212,8 +212,8 @@ fn from_list() { indoc!( r" [1,2,2,3,1,4] - |> Set.fromList - |> Set.toList + |> Set.from_list + |> Set.to_list " ), RocList::from_slice(&[1, 2, 3, 4]), @@ -227,8 +227,8 @@ fn from_list() { empty = [] empty - |> Set.fromList - |> Set.toList + |> Set.from_list + |> Set.to_list " ), RocList::::default(), @@ -244,8 +244,8 @@ fn from_list_void() { indoc!( r" [] - |> Set.fromList - |> Set.toList + |> Set.from_list + |> Set.to_list " ), RocList::::default(), @@ -259,7 +259,7 @@ fn to_list_empty() { assert_evals_to!( indoc!( r" - Set.toList (Set.empty {}) + Set.to_list (Set.empty {}) " ), RocList::::default(), @@ -277,10 +277,10 @@ fn from_list_result() { x = Ok "foo" [x] - |> Set.fromList - |> Set.toList + |> Set.from_list + |> Set.to_list |> List.len - |> Num.toI64 + |> Num.to_i64 "# ), 1, @@ -298,10 +298,10 @@ fn resolve_set_eq_issue_4671() { main = s1 : Set U8 - s1 = Set.fromList [1, 2, 3] + s1 = Set.from_list [1, 2, 3] s2 : Set U8 - s2 = Set.fromList [3, 2, 1] + s2 = Set.from_list [3, 2, 1] s1 == s2 "# diff --git a/crates/compiler/test_gen/src/gen_str.rs b/crates/compiler/test_gen/src/gen_str.rs index 1ea116fe739..15984196a4b 100644 --- a/crates/compiler/test_gen/src/gen_str.rs +++ b/crates/compiler/test_gen/src/gen_str.rs @@ -55,7 +55,7 @@ fn str_split_on_empty_delimiter() { assert_evals_to!( indoc!( r#" - List.len (Str.splitOn "hello" "") + List.len (Str.split_on "hello" "") "# ), 1, @@ -65,9 +65,9 @@ fn str_split_on_empty_delimiter() { assert_evals_to!( indoc!( r#" - when List.first (Str.splitOn "JJJ" "") is + when List.first (Str.split_on "JJJ" "") is Ok str -> - Str.countUtf8Bytes str + Str.count_utf8_bytes str _ -> 1729 @@ -85,7 +85,7 @@ fn str_split_on_bigger_delimiter_small_str() { assert_evals_to!( indoc!( r#" - List.len (Str.splitOn "hello" "JJJJ there") + List.len (Str.split_on "hello" "JJJJ there") "# ), 1, @@ -95,9 +95,9 @@ fn str_split_on_bigger_delimiter_small_str() { assert_evals_to!( indoc!( r#" - when List.first (Str.splitOn "JJJ" "JJJJ there") is + when List.first (Str.split_on "JJJ" "JJJJ there") is Ok str -> - Str.countUtf8Bytes str + Str.count_utf8_bytes str _ -> 1729 @@ -115,7 +115,7 @@ fn str_split_on_str_concat_repeated() { assert_evals_to!( indoc!( r#" - when List.first (Str.splitOn "JJJJJ" "JJJJ there") is + when List.first (Str.split_on "JJJJJ" "JJJJ there") is Ok str -> str |> Str.concat str @@ -137,7 +137,7 @@ fn str_split_on_str_concat_repeated() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_split_on_small_str_bigger_delimiter() { assert_evals_to!( - indoc!(r#"Str.splitOn "JJJ" "0123456789abcdefghi""#), + indoc!(r#"Str.split_on "JJJ" "0123456789abcdefghi""#), RocList::from_slice(&[RocStr::from("JJJ")]), RocList ); @@ -149,7 +149,7 @@ fn str_split_on_big_str_small_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn "01234567789abcdefghi?01234567789abcdefghi" "?" + Str.split_on "01234567789abcdefghi?01234567789abcdefghi" "?" "# ), RocList::from_slice(&[ @@ -162,7 +162,7 @@ fn str_split_on_big_str_small_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn "01234567789abcdefghi 3ch 01234567789abcdefghi" "3ch" + Str.split_on "01234567789abcdefghi 3ch 01234567789abcdefghi" "3ch" "# ), RocList::from_slice(&[ @@ -179,7 +179,7 @@ fn str_split_on_small_str_small_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn "J!J!J" "!" + Str.split_on "J!J!J" "!" "# ), RocList::from_slice(&[RocStr::from("J"), RocStr::from("J"), RocStr::from("J")]), @@ -193,7 +193,7 @@ fn str_split_on_bigger_delimiter_big_strs() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "string to split is shorter" "than the delimiter which happens to be very very long" "# @@ -209,7 +209,7 @@ fn str_split_on_empty_strs() { assert_evals_to!( indoc!( r#" - Str.splitOn "" "" + Str.split_on "" "" "# ), RocList::from_slice(&[RocStr::from("")]), @@ -223,7 +223,7 @@ fn str_split_on_minimal_example() { assert_evals_to!( indoc!( r#" - Str.splitOn "a," "," + Str.split_on "a," "," "# ), RocList::from_slice(&[RocStr::from("a"), RocStr::from("")]), @@ -237,7 +237,7 @@ fn str_split_on_small_str_big_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "1---- ---- ---- ---- ----2---- ---- ---- ---- ----" "---- ---- ---- ---- ----" |> List.len @@ -250,7 +250,7 @@ fn str_split_on_small_str_big_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "1---- ---- ---- ---- ----2---- ---- ---- ---- ----" "---- ---- ---- ---- ----" "# @@ -266,7 +266,7 @@ fn str_split_on_small_str_20_char_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "3|-- -- -- -- -- -- |4|-- -- -- -- -- -- |" "|-- -- -- -- -- -- |" "# @@ -499,14 +499,14 @@ fn str_concat_empty() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn small_str_is_empty() { - assert_evals_to!(r#"Str.isEmpty "abc""#, false, bool); + assert_evals_to!(r#"Str.is_empty "abc""#, false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn big_str_is_empty() { assert_evals_to!( - r#"Str.isEmpty "this is more than 23 chars long""#, + r#"Str.is_empty "this is more than 23 chars long""#, false, bool ); @@ -515,32 +515,32 @@ fn big_str_is_empty() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn empty_str_is_empty() { - assert_evals_to!(r#"Str.isEmpty """#, true, bool); + assert_evals_to!(r#"Str.is_empty """#, true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_starts_with() { - assert_evals_to!(r#"Str.startsWith "hello world" "hell""#, true, bool); - assert_evals_to!(r#"Str.startsWith "hello world" """#, true, bool); - assert_evals_to!(r#"Str.startsWith "nope" "hello world""#, false, bool); - assert_evals_to!(r#"Str.startsWith "hell" "hello world""#, false, bool); - assert_evals_to!(r#"Str.startsWith "" "hello world""#, false, bool); + assert_evals_to!(r#"Str.starts_with "hello world" "hell""#, true, bool); + assert_evals_to!(r#"Str.starts_with "hello world" """#, true, bool); + assert_evals_to!(r#"Str.starts_with "nope" "hello world""#, false, bool); + assert_evals_to!(r#"Str.starts_with "hell" "hello world""#, false, bool); + assert_evals_to!(r#"Str.starts_with "" "hello world""#, false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_ends_with() { - assert_evals_to!(r#"Str.endsWith "hello world" "world""#, true, bool); - assert_evals_to!(r#"Str.endsWith "nope" "hello world""#, false, bool); - assert_evals_to!(r#"Str.endsWith "" "hello world""#, false, bool); + assert_evals_to!(r#"Str.ends_with "hello world" "world""#, true, bool); + assert_evals_to!(r#"Str.ends_with "nope" "hello world""#, false, bool); + assert_evals_to!(r#"Str.ends_with "" "hello world""#, false, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_starts_with_same_big_str() { assert_evals_to!( - r#"Str.startsWith "123456789123456789" "123456789123456789""#, + r#"Str.starts_with "123456789123456789" "123456789123456789""#, true, bool ); @@ -550,7 +550,7 @@ fn str_starts_with_same_big_str() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_starts_with_different_big_str() { assert_evals_to!( - r#"Str.startsWith "12345678912345678910" "123456789123456789""#, + r#"Str.starts_with "12345678912345678910" "123456789123456789""#, true, bool ); @@ -559,18 +559,18 @@ fn str_starts_with_different_big_str() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_starts_with_same_small_str() { - assert_evals_to!(r#"Str.startsWith "1234" "1234""#, true, bool); + assert_evals_to!(r#"Str.starts_with "1234" "1234""#, true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_starts_with_different_small_str() { - assert_evals_to!(r#"Str.startsWith "1234" "12""#, true, bool); + assert_evals_to!(r#"Str.starts_with "1234" "12""#, true, bool); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_starts_with_false_small_str() { - assert_evals_to!(r#"Str.startsWith "1234" "23""#, false, bool); + assert_evals_to!(r#"Str.starts_with "1234" "23""#, false, bool); } #[test] @@ -579,7 +579,7 @@ fn str_from_utf8_pass_single_ascii() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97] is + when Str.from_utf8 [97] is Ok val -> val Err _ -> "" "# @@ -595,7 +595,7 @@ fn str_from_utf8_pass_many_ascii() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 99, 0x7E] is + when Str.from_utf8 [97, 98, 99, 0x7E] is Ok val -> val Err _ -> "" "# @@ -611,7 +611,7 @@ fn str_from_utf8_pass_single_unicode() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xE2, 0x88, 0x86] is + when Str.from_utf8 [0xE2, 0x88, 0x86] is Ok val -> val Err _ -> "" "# @@ -627,7 +627,7 @@ fn str_from_utf8_pass_many_unicode() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xE2, 0x88, 0x86, 0xC5, 0x93, 0xC2, 0xAC] is + when Str.from_utf8 [0xE2, 0x88, 0x86, 0xC5, 0x93, 0xC2, 0xAC] is Ok val -> val Err _ -> "" "# @@ -643,7 +643,7 @@ fn str_from_utf8_pass_single_grapheme() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xF0, 0x9F, 0x92, 0x96] is + when Str.from_utf8 [0xF0, 0x9F, 0x92, 0x96] is Ok val -> val Err _ -> "" "# @@ -659,7 +659,7 @@ fn str_from_utf8_pass_many_grapheme() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xF0, 0x9F, 0x92, 0x96, 0xF0, 0x9F, 0xA4, 0xA0, 0xF0, 0x9F, 0x9A, 0x80] is + when Str.from_utf8 [0xF0, 0x9F, 0x92, 0x96, 0xF0, 0x9F, 0xA4, 0xA0, 0xF0, 0x9F, 0x9A, 0x80] is Ok val -> val Err _ -> "" "# @@ -675,7 +675,7 @@ fn str_from_utf8_pass_all() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xF0, 0x9F, 0x92, 0x96, 98, 0xE2, 0x88, 0x86] is + when Str.from_utf8 [0xF0, 0x9F, 0x92, 0x96, 98, 0xE2, 0x88, 0x86] is Ok val -> val Err _ -> "" "# @@ -691,9 +691,9 @@ fn str_from_utf8_fail_invalid_start_byte() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 0x80, 99] is - Err (BadUtf8 {problem: InvalidStartByte, index: byteIndex}) -> - if byteIndex == 2 then + when Str.from_utf8 [97, 98, 0x80, 99] is + Err (BadUtf8 {problem: InvalidStartByte, index: byte_index}) -> + if byte_index == 2 then "a" else "b" @@ -711,9 +711,9 @@ fn str_from_utf8_fail_unexpected_end_of_sequence() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 99, 0xC2] is - Err (BadUtf8 {problem: UnexpectedEndOfSequence, index: byteIndex}) -> - if byteIndex == 3 then + when Str.from_utf8 [97, 98, 99, 0xC2] is + Err (BadUtf8 {problem: UnexpectedEndOfSequence, index: byte_index}) -> + if byte_index == 3 then "a" else "b" @@ -731,9 +731,9 @@ fn str_from_utf8_fail_expected_continuation() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 99, 0xC2, 0x00] is - Err (BadUtf8 {problem: ExpectedContinuation, index: byteIndex}) -> - if byteIndex == 3 then + when Str.from_utf8 [97, 98, 99, 0xC2, 0x00] is + Err (BadUtf8 {problem: ExpectedContinuation, index: byte_index}) -> + if byte_index == 3 then "a" else "b" @@ -751,9 +751,9 @@ fn str_from_utf8_fail_overlong_encoding() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 0xF0, 0x80, 0x80, 0x80] is - Err (BadUtf8 {problem: OverlongEncoding, index: byteIndex}) -> - if byteIndex == 1 then + when Str.from_utf8 [97, 0xF0, 0x80, 0x80, 0x80] is + Err (BadUtf8 {problem: OverlongEncoding, index: byte_index}) -> + if byte_index == 1 then "a" else "b" @@ -771,9 +771,9 @@ fn str_from_utf8_fail_codepoint_too_large() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 0xF4, 0x90, 0x80, 0x80] is - Err (BadUtf8 {problem: CodepointTooLarge, index: byteIndex}) -> - if byteIndex == 1 then + when Str.from_utf8 [97, 0xF4, 0x90, 0x80, 0x80] is + Err (BadUtf8 {problem: CodepointTooLarge, index: byte_index}) -> + if byte_index == 1 then "a" else "b" @@ -791,9 +791,9 @@ fn str_from_utf8_fail_surrogate_half() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 0xED, 0xA0, 0x80] is - Err (BadUtf8 {problem: EncodesSurrogateHalf, index: byteIndex}) -> - if byteIndex == 2 then + when Str.from_utf8 [97, 98, 0xED, 0xA0, 0x80] is + Err (BadUtf8 {problem: EncodesSurrogateHalf, index: byte_index}) -> + if byte_index == 2 then "a" else "b" @@ -841,19 +841,19 @@ fn nested_recursive_literal() { expr : Expr expr = Add (Add (Val 3) (Val 1)) (Add (Val 1) (Var 1)) - printExpr : Expr -> Str - printExpr = \e -> + print_expr : Expr -> Str + print_expr = \e -> when e is Add a b -> "Add (" - |> Str.concat (printExpr a) + |> Str.concat (print_expr a) |> Str.concat ") (" - |> Str.concat (printExpr b) + |> Str.concat (print_expr b) |> Str.concat ")" - Val v -> "Val " |> Str.concat (Num.toStr v) - Var v -> "Var " |> Str.concat (Num.toStr v) + Val v -> "Val " |> Str.concat (Num.to_str v) + Var v -> "Var " |> Str.concat (Num.to_str v) - printExpr expr + print_expr expr "# ), RocStr::from("Add (Add (Val 3) (Val 1)) (Add (Val 1) (Var 1))"), @@ -865,7 +865,7 @@ fn nested_recursive_literal() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_join_comma_small() { assert_evals_to!( - r#"Str.joinWith ["1", "2"] ", " "#, + r#"Str.join_with ["1", "2"] ", " "#, RocStr::from("1, 2"), RocStr ); @@ -875,7 +875,7 @@ fn str_join_comma_small() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_join_comma_big() { assert_evals_to!( - r#"Str.joinWith ["10000000", "2000000", "30000000"] ", " "#, + r#"Str.join_with ["10000000", "2000000", "30000000"] ", " "#, RocStr::from("10000000, 2000000, 30000000"), RocStr ); @@ -884,19 +884,19 @@ fn str_join_comma_big() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_join_comma_single() { - assert_evals_to!(r#"Str.joinWith ["1"] ", " "#, RocStr::from("1"), RocStr); + assert_evals_to!(r#"Str.join_with ["1"] ", " "#, RocStr::from("1"), RocStr); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_to_utf8() { assert_evals_to!( - r#"Str.toUtf8 "hello""#, + r#"Str.to_utf8 "hello""#, RocList::from_slice(&[104, 101, 108, 108, 111]), RocList ); assert_evals_to!( - r#"Str.toUtf8 "this is a long string""#, + r#"Str.to_utf8 "this is a long string""#, RocList::from_slice(&[ 116, 104, 105, 115, 32, 105, 115, 32, 97, 32, 108, 111, 110, 103, 32, 115, 116, 114, 105, 110, 103 @@ -912,10 +912,10 @@ fn str_from_utf8() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -931,11 +931,11 @@ fn str_from_utf8_slice() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" |> List.sublist { start: 1, len: 4 } - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -951,11 +951,11 @@ fn str_from_utf8_slice_not_end() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" |> List.sublist { start: 1, len: 3 } - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -971,12 +971,12 @@ fn str_from_utf8_order_does_not_matter() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" |> List.sublist { start: 1, len: 3 } - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String - Err _ -> "Str.fromUtf8 returned Err instead of Ok!" + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string + Err _ -> "Str.from_utf8 returned Err instead of Ok!" "# ), RocStr::from("ell"), @@ -1139,14 +1139,14 @@ fn str_trim_small_to_small_shared() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_start_small_blank_string() { - assert_evals_to!(indoc!(r#"Str.trimStart " ""#), RocStr::from(""), RocStr); + assert_evals_to!(indoc!(r#"Str.trim_start " ""#), RocStr::from(""), RocStr); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_start_small_to_small() { assert_evals_to!( - indoc!(r#"Str.trimStart " hello world ""#), + indoc!(r#"Str.trim_start " hello world ""#), RocStr::from("hello world "), RocStr ); @@ -1156,7 +1156,7 @@ fn str_trim_start_small_to_small() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_start_large_to_large_unique() { assert_evals_to!( - indoc!(r#"Str.trimStart (Str.concat " " "hello world from a large string ")"#), + indoc!(r#"Str.trim_start (Str.concat " " "hello world from a large string ")"#), RocStr::from("hello world from a large string "), RocStr ); @@ -1166,7 +1166,7 @@ fn str_trim_start_large_to_large_unique() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_start_large_to_small_unique() { assert_evals_to!( - indoc!(r#"Str.trimStart (Str.concat " " "hello world ")"#), + indoc!(r#"Str.trim_start (Str.concat " " "hello world ")"#), RocStr::from("hello world "), RocStr ); @@ -1181,7 +1181,7 @@ fn str_trim_start_large_to_large_shared() { original : Str original = " hello world world " - { trimmed: Str.trimStart original, original: original } + { trimmed: Str.trim_start original, original: original } "# ), ( @@ -1201,7 +1201,7 @@ fn str_trim_start_large_to_small_shared() { original : Str original = " hello world " - { trimmed: Str.trimStart original, original: original } + { trimmed: Str.trim_start original, original: original } "# ), ( @@ -1221,7 +1221,7 @@ fn str_trim_start_small_to_small_shared() { original : Str original = " hello world " - { trimmed: Str.trimStart original, original: original } + { trimmed: Str.trim_start original, original: original } "# ), (RocStr::from(" hello world "), RocStr::from("hello world "),), @@ -1232,14 +1232,14 @@ fn str_trim_start_small_to_small_shared() { #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_end_small_blank_string() { - assert_evals_to!(indoc!(r#"Str.trimEnd " ""#), RocStr::from(""), RocStr); + assert_evals_to!(indoc!(r#"Str.trim_end " ""#), RocStr::from(""), RocStr); } #[test] #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_end_small_to_small() { assert_evals_to!( - indoc!(r#"Str.trimEnd " hello world ""#), + indoc!(r#"Str.trim_end " hello world ""#), RocStr::from(" hello world"), RocStr ); @@ -1249,7 +1249,7 @@ fn str_trim_end_small_to_small() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_end_large_to_large_unique() { assert_evals_to!( - indoc!(r#"Str.trimEnd (Str.concat " hello world from a large string" " ")"#), + indoc!(r#"Str.trim_end (Str.concat " hello world from a large string" " ")"#), RocStr::from(" hello world from a large string"), RocStr ); @@ -1259,7 +1259,7 @@ fn str_trim_end_large_to_large_unique() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_trim_end_large_to_small_unique() { assert_evals_to!( - indoc!(r#"Str.trimEnd (Str.concat " hello world" " ")"#), + indoc!(r#"Str.trim_end (Str.concat " hello world" " ")"#), RocStr::from(" hello world"), RocStr ); @@ -1274,7 +1274,7 @@ fn str_trim_end_large_to_large_shared() { original : Str original = " hello world world " - { trimmed: Str.trimEnd original, original: original } + { trimmed: Str.trim_end original, original: original } "# ), ( @@ -1294,7 +1294,7 @@ fn str_trim_end_large_to_small_shared() { original : Str original = " hello world " - { trimmed: Str.trimEnd original, original: original } + { trimmed: Str.trim_end original, original: original } "# ), ( @@ -1314,7 +1314,7 @@ fn str_trim_end_small_to_small_shared() { original : Str original = " hello world " - { trimmed: Str.trimEnd original, original: original } + { trimmed: Str.trim_end original, original: original } "# ), (RocStr::from(" hello world "), RocStr::from(" hello world"),), @@ -1328,7 +1328,7 @@ fn str_to_nat() { assert_evals_to!( indoc!( r#" - Str.toU64 "1" + Str.to_u64 "1" "# ), RocResult::ok(1), @@ -1342,7 +1342,7 @@ fn str_to_i128() { assert_evals_to!( indoc!( r#" - Str.toI128 "1" + Str.to_i128 "1" "# ), RocResult::ok(I128::from(1)), @@ -1356,7 +1356,7 @@ fn str_to_u128() { assert_evals_to!( indoc!( r#" - Str.toU128 "1" + Str.to_u128 "1" "# ), RocResult::ok(U128::from(1)), @@ -1371,7 +1371,7 @@ fn str_to_i64() { assert_evals_to!( indoc!( r#" - Str.toI64 "1" + Str.to_i64 "1" "# ), RocResult::ok(1), @@ -1385,7 +1385,7 @@ fn str_to_u64() { assert_evals_to!( indoc!( r#" - Str.toU64 "1" + Str.to_u64 "1" "# ), RocResult::ok(1), @@ -1399,7 +1399,7 @@ fn str_to_i32() { assert_evals_to!( indoc!( r#" - Str.toI32 "1" + Str.to_i32 "1" "# ), RocResult::ok(1), @@ -1413,7 +1413,7 @@ fn str_to_u32() { assert_evals_to!( indoc!( r#" - Str.toU32 "1" + Str.to_u32 "1" "# ), RocResult::ok(1), @@ -1427,7 +1427,7 @@ fn str_to_i16() { assert_evals_to!( indoc!( r#" - Str.toI16 "1" + Str.to_i16 "1" "# ), RocResult::ok(1), @@ -1441,7 +1441,7 @@ fn str_to_u16() { assert_evals_to!( indoc!( r#" - Str.toU16 "1" + Str.to_u16 "1" "# ), RocResult::ok(1), @@ -1455,7 +1455,7 @@ fn str_to_i8() { assert_evals_to!( indoc!( r#" - Str.toI8 "1" + Str.to_i8 "1" "# ), RocResult::ok(1), @@ -1469,7 +1469,7 @@ fn str_to_u8() { assert_evals_to!( indoc!( r#" - Str.toU8 "1" + Str.to_u8 "1" "# ), RocResult::ok(1), @@ -1483,7 +1483,7 @@ fn str_to_f64() { assert_evals_to!( indoc!( r#" - when Str.toF64 "1.0" is + when Str.to_f64 "1.0" is Ok n -> n Err _ -> 0 @@ -1500,7 +1500,7 @@ fn str_to_f32() { assert_evals_to!( indoc!( r#" - when Str.toF32 "1.0" is + when Str.to_f32 "1.0" is Ok n -> n Err _ -> 0 @@ -1519,7 +1519,7 @@ fn str_to_dec() { assert_evals_to!( indoc!( r#" - when Str.toDec "1.0" is + when Str.to_dec "1.0" is Ok n -> n Err _ -> 0 @@ -1552,7 +1552,7 @@ fn str_split_on_first_one_char() { assert_evals_to!( indoc!( r#" - Str.splitFirst "foo/bar/baz" "/" + Str.split_first "foo/bar/baz" "/" "# ), // the result is a { before, after } record, and because of @@ -1568,7 +1568,7 @@ fn str_split_on_first_multiple_chars() { assert_evals_to!( indoc!( r#" - Str.splitFirst "foo//bar//baz" "//" + Str.split_first "foo//bar//baz" "//" "# ), RocResult::ok((RocStr::from("bar//baz"), RocStr::from("foo"))), @@ -1582,7 +1582,7 @@ fn str_split_on_first_entire_input() { assert_evals_to!( indoc!( r#" - Str.splitFirst "foo" "foo" + Str.split_first "foo" "foo" "# ), RocResult::ok((RocStr::from(""), RocStr::from(""))), @@ -1596,7 +1596,7 @@ fn str_split_on_first_not_found() { assert_evals_to!( indoc!( r#" - Str.splitFirst "foo" "bar" + Str.split_first "foo" "bar" "# ), RocResult::err(()), @@ -1610,7 +1610,7 @@ fn str_split_on_last_one_char() { assert_evals_to!( indoc!( r#" - Str.splitLast"foo/bar/baz" "/" + Str.split_last "foo/bar/baz" "/" "# ), RocResult::ok((RocStr::from("baz"), RocStr::from("foo/bar"))), @@ -1624,7 +1624,7 @@ fn str_split_on_last_multiple_chars() { assert_evals_to!( indoc!( r#" - Str.splitLast "foo//bar//baz" "//" + Str.split_last "foo//bar//baz" "//" "# ), RocResult::ok((RocStr::from("baz"), RocStr::from("foo//bar"))), @@ -1638,7 +1638,7 @@ fn str_split_on_last_entire_input() { assert_evals_to!( indoc!( r#" - Str.splitLast "foo" "foo" + Str.split_last "foo" "foo" "# ), RocResult::ok((RocStr::from(""), RocStr::from(""))), @@ -1652,7 +1652,7 @@ fn str_split_on_last_not_found() { assert_evals_to!( indoc!( r#" - Str.splitLast "foo" "bar" + Str.split_last "foo" "bar" "# ), RocResult::err(()), @@ -1664,7 +1664,7 @@ fn str_split_on_last_not_found() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_split_on_overlapping_substring_1() { assert_evals_to!( - r#"Str.splitOn "aaa" "aa""#, + r#"Str.split_on "aaa" "aa""#, RocList::from_slice(&[RocStr::from(""), RocStr::from("a")]), RocList ); @@ -1674,7 +1674,7 @@ fn str_split_on_overlapping_substring_1() { #[cfg(any(feature = "gen-llvm", feature = "gen-dev"))] fn str_split_on_overlapping_substring_2() { assert_evals_to!( - r#"Str.splitOn "aaaa" "aa""#, + r#"Str.split_on "aaaa" "aa""#, RocList::from_slice(&[RocStr::from(""), RocStr::from(""), RocStr::from("")]), RocList ); @@ -1688,7 +1688,7 @@ fn str_walk_utf8() { // Reverse the bytes indoc!( r#" - Str.walkUtf8 "abcd" [] (\list, byte -> List.prepend list byte) + Str.walk_utf8 "abcd" [] (\list, byte -> List.prepend list byte) "# ), RocList::from_slice(&[b'd', b'c', b'b', b'a']), @@ -1699,7 +1699,7 @@ fn str_walk_utf8() { assert_evals_to!( indoc!( r#" - Str.walkUtf8 "abcd" [] (\list, byte -> List.prepend list byte) + Str.walk_utf8 "abcd" [] (\list, byte -> List.prepend list byte) "# ), RocList::from_slice(&[b'd', b'c', b'b', b'a']), @@ -1713,7 +1713,7 @@ fn str_walk_utf8_with_index() { assert_evals_to!( indoc!( r#" - Str.walkUtf8WithIndex "abcd" [] (\list, byte, index -> List.append list (Pair index byte)) + Str.walk_utf8_with_index "abcd" [] (\list, byte, index -> List.append list (Pair index byte)) "# ), RocList::from_slice(&[(0, b'a'), (1, b'b'), (2, b'c'), (3, b'd')]), @@ -1792,7 +1792,7 @@ fn with_capacity() { assert_evals_to!( indoc!( r#" - Str.withCapacity 10 + Str.with_capacity 10 "# ), RocStr::from(""), @@ -1806,7 +1806,7 @@ fn with_capacity_concat() { assert_evals_to!( indoc!( r#" - Str.withCapacity 10 |> Str.concat "Forty-two" + Str.with_capacity 10 |> Str.concat "Forty-two" "# ), RocStr::from("Forty-two"), @@ -1820,7 +1820,7 @@ fn str_with_prefix() { assert_evals_to!( indoc!( r#" - Str.withPrefix "world!" "Hello " + Str.with_prefix "world!" "Hello " "# ), RocStr::from("Hello world!"), @@ -1830,7 +1830,7 @@ fn str_with_prefix() { assert_evals_to!( indoc!( r#" - "two" |> Str.withPrefix "Forty " + "two" |> Str.with_prefix "Forty " "# ), RocStr::from("Forty two"), @@ -1888,7 +1888,7 @@ fn release_excess_capacity() { indoc!( r#" Str.reserve "" 50 - |> Str.releaseExcessCapacity + |> Str.release_excess_capacity "# ), (RocStr::empty().capacity(), RocStr::empty()), @@ -1905,7 +1905,7 @@ fn release_excess_capacity_with_len() { r#" "123456789012345678901234567890" |> Str.reserve 50 - |> Str.releaseExcessCapacity + |> Str.release_excess_capacity "# ), (30, "123456789012345678901234567890".into()), @@ -1920,7 +1920,7 @@ fn release_excess_capacity_empty() { assert_evals_to!( indoc!( r#" - Str.releaseExcessCapacity "" + Str.release_excess_capacity "" "# ), (RocStr::empty().capacity(), RocStr::empty()), @@ -1994,7 +1994,7 @@ fn str_contains_self() { fn str_drop_prefix() { assert_evals_to!( r#" - Str.dropPrefix "" "foo" + Str.drop_prefix "" "foo" "#, RocStr::from(""), RocStr @@ -2002,7 +2002,7 @@ fn str_drop_prefix() { assert_evals_to!( r#" - Str.dropPrefix "bar" "foo" + Str.drop_prefix "bar" "foo" "#, RocStr::from("bar"), RocStr @@ -2010,7 +2010,7 @@ fn str_drop_prefix() { assert_evals_to!( r#" - Str.dropPrefix "foobar" "foo" + Str.drop_prefix "foobar" "foo" "#, RocStr::from("bar"), RocStr @@ -2018,7 +2018,7 @@ fn str_drop_prefix() { assert_evals_to!( r#" - Str.dropPrefix "fooBarThisIsDefinitelyAReallyLongAndNotaShortString" "foo" + Str.drop_prefix "fooBarThisIsDefinitelyAReallyLongAndNotaShortString" "foo" "#, RocStr::from("BarThisIsDefinitelyAReallyLongAndNotaShortString"), RocStr @@ -2030,7 +2030,7 @@ fn str_drop_prefix() { fn str_drop_suffix() { assert_evals_to!( r#" - Str.dropSuffix "" "foo" + Str.drop_suffix "" "foo" "#, RocStr::from(""), RocStr @@ -2038,7 +2038,7 @@ fn str_drop_suffix() { assert_evals_to!( r#" - Str.dropSuffix "bar" "foo" + Str.drop_suffix "bar" "foo" "#, RocStr::from("bar"), RocStr @@ -2046,7 +2046,7 @@ fn str_drop_suffix() { assert_evals_to!( r#" - Str.dropSuffix "barfoo" "foo" + Str.drop_suffix "barfoo" "foo" "#, RocStr::from("bar"), RocStr @@ -2054,7 +2054,7 @@ fn str_drop_suffix() { assert_evals_to!( r#" - Str.dropSuffix "BarThisIsDefinitelyAReallyLongAndNotaShortStringfoo" "foo" + Str.drop_suffix "BarThisIsDefinitelyAReallyLongAndNotaShortStringfoo" "foo" "#, RocStr::from("BarThisIsDefinitelyAReallyLongAndNotaShortString"), RocStr diff --git a/crates/compiler/test_gen/src/gen_tags.rs b/crates/compiler/test_gen/src/gen_tags.rs index df25fae4460..71611fb1df9 100644 --- a/crates/compiler/test_gen/src/gen_tags.rs +++ b/crates/compiler/test_gen/src/gen_tags.rs @@ -349,14 +349,14 @@ fn maybe_is_just_not_nested() { Maybe a : [Just a, Nothing] - isJust : Maybe a -> Bool - isJust = \list -> + is_just : Maybe a -> Bool + is_just = \list -> when list is Nothing -> Bool.false Just _ -> Bool.true main = - isJust (Just 42) + is_just (Just 42) "# ), true, @@ -372,13 +372,13 @@ fn maybe_is_just_nested() { r" Maybe a : [Just a, Nothing] - isJust : Maybe a -> Bool - isJust = \list -> + is_just : Maybe a -> Bool + is_just = \list -> when list is Nothing -> Bool.false Just _ -> Bool.true - isJust (Just 42) + is_just (Just 42) " ), true, @@ -415,7 +415,7 @@ fn if_guard_vanilla() { r#" when "fooz" is s if s == "foo" -> [] - s -> Str.toUtf8 s + s -> Str.to_utf8 s "# ), RocList::from_slice(b"fooz"), @@ -1078,7 +1078,7 @@ fn applied_tag_function_result() { x : List (Result Str *) x = List.map ["a", "b"] Ok - List.keepOks x (\y -> y) + List.keep_oks x (\y -> y) "# ), RocList::from_slice(&[(RocStr::from("a")), (RocStr::from("b"))]), @@ -1217,19 +1217,19 @@ fn monomorphized_tag_with_polymorphic_arg() { a = \{} -> A wrap = \{} -> Wrapped (a {}) - useWrap1 : [Wrapped [A], Other] -> U8 - useWrap1 = + use_wrap1 : [Wrapped [A], Other] -> U8 + use_wrap1 = \w -> when w is Wrapped A -> 2 Other -> 3 - useWrap2 : [Wrapped [A, B]] -> U8 - useWrap2 = + use_wrap2 : [Wrapped [A, B]] -> U8 + use_wrap2 = \w -> when w is Wrapped A -> 5 Wrapped B -> 7 - if Bool.true then useWrap1 (wrap {}) else useWrap2 (wrap {}) + if Bool.true then use_wrap1 (wrap {}) else use_wrap2 (wrap {}) "# ), 2, @@ -1251,19 +1251,19 @@ fn monomorphized_tag_with_polymorphic_and_monomorphic_arg() { poly = \{} -> A wrap = \{} -> Wrapped (poly {}) mono - useWrap1 : [Wrapped [A] U8, Other] -> U8 - useWrap1 = + use_wrap1 : [Wrapped [A] U8, Other] -> U8 + use_wrap1 = \w -> when w is Wrapped A n -> n Other -> 0 - useWrap2 : [Wrapped [A, B] U8] -> U8 - useWrap2 = + use_wrap2 : [Wrapped [A, B] U8] -> U8 + use_wrap2 = \w -> when w is Wrapped A n -> n Wrapped B _ -> 0 - useWrap1 (wrap {}) * useWrap2 (wrap {}) + use_wrap1 (wrap {}) * use_wrap2 (wrap {}) "# ), 225, @@ -1443,8 +1443,8 @@ fn issue_1162() { balance : a, RBTree a -> RBTree a balance = \key, left -> when left is - Node _ _ lRight -> - Node key lRight Empty + Node _ _ l_right -> + Node key l_right Empty _ -> Empty @@ -1489,8 +1489,8 @@ fn issue_2725_alias_polymorphic_lambda() { indoc!( r" wrap = \value -> Tag value - wrapIt = wrap - wrapIt 42 + wrap_it = wrap + wrap_it 42 " ), 42, // Tag is a newtype, it gets unwrapped @@ -1508,12 +1508,12 @@ fn opaque_assign_to_symbol() { Variable := U8 - fromUtf8 : U8 -> Result Variable [InvalidVariableUtf8] - fromUtf8 = \char -> + from_utf8 : U8 -> Result Variable [InvalidVariableUtf8] + from_utf8 = \char -> Ok (@Variable char) out = - when fromUtf8 98 is + when from_utf8 98 is Ok (@Variable n) -> n _ -> 1 "# @@ -1616,9 +1616,9 @@ fn issue_3261_non_nullable_unwrapped_recursive_union_at_index() { foo : Named foo = Named "outer" [Named "inner" []] - Named name outerList = foo + Named name outer_list = foo - {name, outerList}.name + {name, outer_list}.name "# ), RocStr::from("outer"), @@ -1888,7 +1888,7 @@ fn issue_2165_recursive_tag_destructure() { x = Ctor { rec: [] } when x is - Ctor { rec } -> Num.toStr (List.len rec) + Ctor { rec } -> Num.to_str (List.len rec) " ), RocStr::from("0"), @@ -1902,13 +1902,13 @@ fn tag_union_let_generalization() { assert_evals_to!( indoc!( r#" - manyAux : {} -> [ Loop, Done ] - manyAux = \_ -> + many_aux : {} -> [ Loop, Done ] + many_aux = \_ -> output = Done output - when manyAux {} is + when many_aux {} is Loop -> "loop" Done -> "done" "# @@ -1929,13 +1929,13 @@ fn fit_recursive_union_in_struct_into_recursive_pointer() { Next { item: Str, rest: NonEmpty }, ] - nonEmpty = + non_empty = a = "abcdefgh" b = @NonEmpty (First "ijkl") c = Next { item: a, rest: b } @NonEmpty c - when nonEmpty is + when non_empty is @NonEmpty (Next r) -> r.item _ -> "" "# @@ -2026,15 +2026,15 @@ fn unify_types_with_fixed_fixpoints_outside_fixing_region() { job = \inputs -> @Job (Job inputs) - helloWorld : Job - helloWorld = + hello_world : Job + hello_world = @Job ( Job [ @Input (FromJob greeting []) ] ) greeting : Job greeting = job [] - main = (\_ -> "OKAY") helloWorld + main = (\_ -> "OKAY") hello_world "# ), RocStr::from("OKAY"), @@ -2137,17 +2137,17 @@ fn nullable_wrapped_with_nullable_not_last_index() { OneOrMore Parser, ] - toIdParser : Parser -> Str - toIdParser = \parser -> + to_id_parser : Parser -> Str + to_id_parser = \parser -> when parser is OneOrMore _ -> "a" Keyword _ -> "b" CharLiteral -> "c" main = - toIdParser (OneOrMore CharLiteral) - |> Str.concat (toIdParser (Keyword "try")) - |> Str.concat (toIdParser CharLiteral) + to_id_parser (OneOrMore CharLiteral) + |> Str.concat (to_id_parser (Keyword "try")) + |> Str.concat (to_id_parser CharLiteral) "# ), RocStr::from("abc"), @@ -2165,9 +2165,9 @@ fn refcount_nullable_unwrapped_needing_no_refcount_issue_5027() { Effect : {} -> Str - after = \effect, buildNext -> + after = \effect, build_next -> \{} -> - when buildNext (effect {}) is + when build_next (effect {}) is thunk -> thunk {} line : Effect diff --git a/crates/compiler/test_gen/src/gen_tuples.rs b/crates/compiler/test_gen/src/gen_tuples.rs index 1cef7ff7052..7ff0c17b265 100644 --- a/crates/compiler/test_gen/src/gen_tuples.rs +++ b/crates/compiler/test_gen/src/gen_tuples.rs @@ -93,9 +93,9 @@ fn fn_tuple() { assert_evals_to!( indoc!( r#" - getRec = \x -> ("foo", x, 19) + get_rec = \x -> ("foo", x, 19) - (getRec 15).1 + (get_rec 15).1 "# ), 15, diff --git a/crates/compiler/test_gen/src/helpers/debug-wasm-test.html b/crates/compiler/test_gen/src/helpers/debug-wasm-test.html index 47b25a0a1bf..6b42a5f491c 100644 --- a/crates/compiler/test_gen/src/helpers/debug-wasm-test.html +++ b/crates/compiler/test_gen/src/helpers/debug-wasm-test.html @@ -174,7 +174,7 @@

Steps

const rc_encoded = rc_pointers.map((ptr) => ptr && deref(ptr)); const rc_encoded_hex = rc_encoded.map((x) => - x ? x.toString(16) : "(deallocated)" + x ? x.to_string(16) : "(deallocated)" ); const rc_values = rc_encoded.map((x) => x && x - 0x80000000 + 1); diff --git a/crates/compiler/test_gen/src/wasm_str.rs b/crates/compiler/test_gen/src/wasm_str.rs index 0f7b35aa287..64ba72eadc8 100644 --- a/crates/compiler/test_gen/src/wasm_str.rs +++ b/crates/compiler/test_gen/src/wasm_str.rs @@ -19,7 +19,7 @@ fn str_split_on_empty_delimiter() { assert_evals_to!( indoc!( r#" - List.len (Str.splitOn "hello" "") + List.len (Str.split_on "hello" "") "# ), 1, @@ -32,7 +32,7 @@ fn str_split_on_bigger_delimiter_small_str() { assert_evals_to!( indoc!( r#" - List.len (Str.splitOn "hello" "JJJJ there") + List.len (Str.split_on "hello" "JJJJ there") "# ), 1, @@ -45,7 +45,7 @@ fn str_split_on_str_concat_repeated() { assert_evals_to!( indoc!( r#" - when List.first (Str.splitOn "JJJJJ" "JJJJ there") is + when List.first (Str.split_on "JJJJJ" "JJJJ there") is Ok str -> str |> Str.concat str @@ -70,7 +70,7 @@ fn str_split_on_small_str_bigger_delimiter() { r#" when List.first - (Str.splitOn "JJJ" "0123456789abcdefghi") + (Str.split_on "JJJ" "0123456789abcdefghi") is Ok str -> str _ -> "" @@ -86,7 +86,7 @@ fn str_split_on_big_str_small_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn "01234567789abcdefghi?01234567789abcdefghi" "?" + Str.split_on "01234567789abcdefghi?01234567789abcdefghi" "?" "# ), RocList::from_slice(&[ @@ -99,7 +99,7 @@ fn str_split_on_big_str_small_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn "01234567789abcdefghi 3ch 01234567789abcdefghi" "3ch" + Str.split_on "01234567789abcdefghi 3ch 01234567789abcdefghi" "3ch" "# ), RocList::from_slice(&[ @@ -115,7 +115,7 @@ fn str_split_on_small_str_small_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn "J!J!J" "!" + Str.split_on "J!J!J" "!" "# ), RocList::from_slice(&[RocStr::from("J"), RocStr::from("J"), RocStr::from("J")]), @@ -128,7 +128,7 @@ fn str_split_on_bigger_delimiter_big_strs() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "string to split is shorter" "than the delimiter which happens to be very very long" "# @@ -143,7 +143,7 @@ fn str_split_on_empty_strs() { assert_evals_to!( indoc!( r#" - Str.splitOn "" "" + Str.split_on "" "" "# ), RocList::from_slice(&[RocStr::from("")]), @@ -156,7 +156,7 @@ fn str_split_on_minimal_example() { assert_evals_to!( indoc!( r#" - Str.splitOn "a," "," + Str.split_on "a," "," "# ), RocList::from_slice(&[RocStr::from("a"), RocStr::from("")]), @@ -169,7 +169,7 @@ fn str_split_on_small_str_big_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "1---- ---- ---- ---- ----2---- ---- ---- ---- ----" "---- ---- ---- ---- ----" |> List.len @@ -182,7 +182,7 @@ fn str_split_on_small_str_big_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "1---- ---- ---- ---- ----2---- ---- ---- ---- ----" "---- ---- ---- ---- ----" "# @@ -197,7 +197,7 @@ fn str_split_on_small_str_20_char_delimiter() { assert_evals_to!( indoc!( r#" - Str.splitOn + Str.split_on "3|-- -- -- -- -- -- |4|-- -- -- -- -- -- |" "|-- -- -- -- -- -- |" "# @@ -245,26 +245,26 @@ fn small_str_zeroed_literal() { r#" app "test" provides [main] to "./platform" - createStr = \isForRealThisTime -> - if isForRealThisTime then + create_str = \is_for_real_this_time -> + if is_for_real_this_time then "J" else "xxxxxxx" - functionWithReusedSpace = \isForRealThisTime -> + function_with_reused_space = \is_for_real_this_time -> # Different string value on each call, at the same memory location - # (Can't inline createStr without refcounting, which isn't implemented) - reusedSpace = createStr isForRealThisTime + # (Can't inline create_str without refcounting, which isn't implemented) + reused_space = create_str is_for_real_this_time # Unoptimised 'if' ensures that we don't just allocate in the caller's frame if Bool.true then - reusedSpace + reused_space else - reusedSpace + reused_space main = - garbage = functionWithReusedSpace Bool.false - functionWithReusedSpace Bool.true + garbage = function_with_reused_space Bool.false + function_with_reused_space Bool.true "# ), [ @@ -346,13 +346,13 @@ fn str_concat_empty() { #[test] fn small_str_is_empty() { - assert_evals_to!(r#"Str.isEmpty "abc""#, false, bool); + assert_evals_to!(r#"Str.is_empty "abc""#, false, bool); } #[test] fn big_str_is_empty() { assert_evals_to!( - r#"Str.isEmpty "this is more than 15 chars long""#, + r#"Str.is_empty "this is more than 15 chars long""#, false, bool ); @@ -360,29 +360,29 @@ fn big_str_is_empty() { #[test] fn empty_str_is_empty() { - assert_evals_to!(r#"Str.isEmpty """#, true, bool); + assert_evals_to!(r#"Str.is_empty """#, true, bool); } #[test] fn str_starts_with() { - assert_evals_to!(r#"Str.startsWith "hello world" "hell""#, true, bool); - assert_evals_to!(r#"Str.startsWith "hello world" """#, true, bool); - assert_evals_to!(r#"Str.startsWith "nope" "hello world""#, false, bool); - assert_evals_to!(r#"Str.startsWith "hell" "hello world""#, false, bool); - assert_evals_to!(r#"Str.startsWith "" "hello world""#, false, bool); + assert_evals_to!(r#"Str.starts_with "hello world" "hell""#, true, bool); + assert_evals_to!(r#"Str.starts_with "hello world" """#, true, bool); + assert_evals_to!(r#"Str.starts_with "nope" "hello world""#, false, bool); + assert_evals_to!(r#"Str.starts_with "hell" "hello world""#, false, bool); + assert_evals_to!(r#"Str.starts_with "" "hello world""#, false, bool); } #[test] fn str_ends_with() { - assert_evals_to!(r#"Str.endsWith "hello world" "world""#, true, bool); - assert_evals_to!(r#"Str.endsWith "nope" "hello world""#, false, bool); - assert_evals_to!(r#"Str.endsWith "" "hello world""#, false, bool); + assert_evals_to!(r#"Str.ends_with "hello world" "world""#, true, bool); + assert_evals_to!(r#"Str.ends_with "nope" "hello world""#, false, bool); + assert_evals_to!(r#"Str.ends_with "" "hello world""#, false, bool); } #[test] fn str_starts_with_same_big_str() { assert_evals_to!( - r#"Str.startsWith "123456789123456789" "123456789123456789""#, + r#"Str.starts_with "123456789123456789" "123456789123456789""#, true, bool ); @@ -391,7 +391,7 @@ fn str_starts_with_same_big_str() { #[test] fn str_starts_with_different_big_str() { assert_evals_to!( - r#"Str.startsWith "12345678912345678910" "123456789123456789""#, + r#"Str.starts_with "12345678912345678910" "123456789123456789""#, true, bool ); @@ -399,16 +399,16 @@ fn str_starts_with_different_big_str() { #[test] fn str_starts_with_same_small_str() { - assert_evals_to!(r#"Str.startsWith "1234" "1234""#, true, bool); + assert_evals_to!(r#"Str.starts_with "1234" "1234""#, true, bool); } #[test] fn str_starts_with_different_small_str() { - assert_evals_to!(r#"Str.startsWith "1234" "12""#, true, bool); + assert_evals_to!(r#"Str.starts_with "1234" "12""#, true, bool); } #[test] fn str_starts_with_false_small_str() { - assert_evals_to!(r#"Str.startsWith "1234" "23""#, false, bool); + assert_evals_to!(r#"Str.starts_with "1234" "23""#, false, bool); } #[test] @@ -416,7 +416,7 @@ fn str_from_utf8_pass_single_ascii() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97] is + when Str.from_utf8 [97] is Ok val -> val Err _ -> "" "# @@ -431,7 +431,7 @@ fn str_from_utf8_pass_many_ascii() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 99, 0x7E] is + when Str.from_utf8 [97, 98, 99, 0x7E] is Ok val -> val Err _ -> "" "# @@ -446,7 +446,7 @@ fn str_from_utf8_pass_single_unicode() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xE2, 0x88, 0x86] is + when Str.from_utf8 [0xE2, 0x88, 0x86] is Ok val -> val Err _ -> "" "# @@ -461,7 +461,7 @@ fn str_from_utf8_pass_many_unicode() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xE2, 0x88, 0x86, 0xC5, 0x93, 0xC2, 0xAC] is + when Str.from_utf8 [0xE2, 0x88, 0x86, 0xC5, 0x93, 0xC2, 0xAC] is Ok val -> val Err _ -> "" "# @@ -476,7 +476,7 @@ fn str_from_utf8_pass_single_grapheme() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xF0, 0x9F, 0x92, 0x96] is + when Str.from_utf8 [0xF0, 0x9F, 0x92, 0x96] is Ok val -> val Err _ -> "" "# @@ -491,7 +491,7 @@ fn str_from_utf8_pass_many_grapheme() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xF0, 0x9F, 0x92, 0x96, 0xF0, 0x9F, 0xA4, 0xA0, 0xF0, 0x9F, 0x9A, 0x80] is + when Str.from_utf8 [0xF0, 0x9F, 0x92, 0x96, 0xF0, 0x9F, 0xA4, 0xA0, 0xF0, 0x9F, 0x9A, 0x80] is Ok val -> val Err _ -> "" "# @@ -506,7 +506,7 @@ fn str_from_utf8_pass_all() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [0xF0, 0x9F, 0x92, 0x96, 98, 0xE2, 0x88, 0x86] is + when Str.from_utf8 [0xF0, 0x9F, 0x92, 0x96, 98, 0xE2, 0x88, 0x86] is Ok val -> val Err _ -> "" "# @@ -521,9 +521,9 @@ fn str_from_utf8_fail_invalid_start_byte() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 0x80, 99] is - Err (BadUtf8 {problem: InvalidStartByte, index: byteIndex}) -> - if byteIndex == 2 then + when Str.from_utf8 [97, 98, 0x80, 99] is + Err (BadUtf8 {problem: InvalidStartByte, index: byte_index}) -> + if byte_index == 2 then "a" else "b" @@ -540,9 +540,9 @@ fn str_from_utf8_fail_unexpected_end_of_sequence() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 99, 0xC2] is - Err (BadUtf8 {problem: UnexpectedEndOfSequence, index: byteIndex}) -> - if byteIndex == 3 then + when Str.from_utf8 [97, 98, 99, 0xC2] is + Err (BadUtf8 {problem: UnexpectedEndOfSequence, index: byte_index}) -> + if byte_index == 3 then "a" else "b" @@ -559,9 +559,9 @@ fn str_from_utf8_fail_expected_continuation() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 99, 0xC2, 0x00] is - Err (BadUtf8 {problem: ExpectedContinuation, index: byteIndex}) -> - if byteIndex == 3 then + when Str.from_utf8 [97, 98, 99, 0xC2, 0x00] is + Err (BadUtf8 {problem: ExpectedContinuation, index: byte_index}) -> + if byte_index == 3 then "a" else "b" @@ -578,9 +578,9 @@ fn str_from_utf8_fail_overlong_encoding() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 0xF0, 0x80, 0x80, 0x80] is - Err (BadUtf8 {problem: OverlongEncoding, index: byteIndex}) -> - if byteIndex == 1 then + when Str.from_utf8 [97, 0xF0, 0x80, 0x80, 0x80] is + Err (BadUtf8 {problem: OverlongEncoding, index: byte_index}) -> + if byte_index == 1 then "a" else "b" @@ -597,9 +597,9 @@ fn str_from_utf8_fail_codepoint_too_large() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 0xF4, 0x90, 0x80, 0x80] is - Err (BadUtf8 {problem: CodepointTooLarge, index: byteIndex}) -> - if byteIndex == 1 then + when Str.from_utf8 [97, 0xF4, 0x90, 0x80, 0x80] is + Err (BadUtf8 {problem: CodepointTooLarge, index: byte_index}) -> + if byte_index == 1 then "a" else "b" @@ -616,9 +616,9 @@ fn str_from_utf8_fail_surrogate_half() { assert_evals_to!( indoc!( r#" - when Str.fromUtf8 [97, 98, 0xED, 0xA0, 0x80] is - Err (BadUtf8 {problem: EncodesSurrogateHalf, index: byteIndex}) -> - if byteIndex == 2 then + when Str.from_utf8 [97, 98, 0xED, 0xA0, 0x80] is + Err (BadUtf8 {problem: EncodesSurrogateHalf, index: byte_index}) -> + if byte_index == 2 then "a" else "b" @@ -645,7 +645,7 @@ fn str_equality() { #[test] fn str_join_comma_small() { assert_evals_to!( - r#"Str.joinWith ["1", "2"] ", " "#, + r#"Str.join_with ["1", "2"] ", " "#, RocStr::from("1, 2"), RocStr ); @@ -654,7 +654,7 @@ fn str_join_comma_small() { #[test] fn str_join_comma_big() { assert_evals_to!( - r#"Str.joinWith ["10000000", "2000000", "30000000"] ", " "#, + r#"Str.join_with ["10000000", "2000000", "30000000"] ", " "#, RocStr::from("10000000, 2000000, 30000000"), RocStr ); @@ -662,18 +662,18 @@ fn str_join_comma_big() { #[test] fn str_join_comma_single() { - assert_evals_to!(r#"Str.joinWith ["1"] ", " "#, RocStr::from("1"), RocStr); + assert_evals_to!(r#"Str.join_with ["1"] ", " "#, RocStr::from("1"), RocStr); } #[test] fn str_to_utf8() { assert_evals_to!( - r#"Str.toUtf8 "hello""#, + r#"Str.to_utf8 "hello""#, RocList::from_slice(&[104, 101, 108, 108, 111]), RocList ); assert_evals_to!( - r#"Str.toUtf8 "this is a long string""#, + r#"Str.to_utf8 "this is a long string""#, RocList::from_slice(&[ 116, 104, 105, 115, 32, 105, 115, 32, 97, 32, 108, 111, 110, 103, 32, 115, 116, 114, 105, 110, 103 @@ -688,10 +688,10 @@ fn str_from_utf8() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -706,11 +706,11 @@ fn str_from_utf8_slice() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" |> List.sublist { start: 1, len: 4 } - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -725,11 +725,11 @@ fn str_from_utf8_slice_not_end() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" |> List.sublist { start: 1, len: 3 } - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -744,11 +744,11 @@ fn str_from_utf8_order_does_not_matter() { indoc!( r#" bytes = - Str.toUtf8 "hello" + Str.to_utf8 "hello" |> List.sublist { start: 1, len: 3 } - when Str.fromUtf8 bytes is - Ok utf8String -> utf8String + when Str.from_utf8 bytes is + Ok utf8_string -> utf8_string _ -> "" "# ), @@ -875,13 +875,13 @@ fn str_trim_small_to_small_shared() { #[test] fn str_trim_start_small_blank_string() { - assert_evals_to!(indoc!(r#"Str.trimStart " ""#), RocStr::from(""), RocStr); + assert_evals_to!(indoc!(r#"Str.trim_start " ""#), RocStr::from(""), RocStr); } #[test] fn str_trim_start_small_to_small() { assert_evals_to!( - indoc!(r#"Str.trimStart " hello ""#), + indoc!(r#"Str.trim_start " hello ""#), RocStr::from("hello "), RocStr ); @@ -890,7 +890,7 @@ fn str_trim_start_small_to_small() { #[test] fn str_trim_start_large_to_large_unique() { assert_evals_to!( - indoc!(r#"Str.trimStart (Str.concat " " "hello world from a large string ")"#), + indoc!(r#"Str.trim_start (Str.concat " " "hello world from a large string ")"#), RocStr::from("hello world from a large string "), RocStr ); @@ -899,7 +899,7 @@ fn str_trim_start_large_to_large_unique() { #[test] fn str_trim_start_large_to_small_unique() { assert_evals_to!( - indoc!(r#"Str.trimStart (Str.concat " " "hello ")"#), + indoc!(r#"Str.trim_start (Str.concat " " "hello ")"#), RocStr::from("hello "), RocStr ); @@ -907,13 +907,13 @@ fn str_trim_start_large_to_small_unique() { #[test] fn str_trim_end_small_blank_string() { - assert_evals_to!(indoc!(r#"Str.trimEnd " ""#), RocStr::from(""), RocStr); + assert_evals_to!(indoc!(r#"Str.trim_end " ""#), RocStr::from(""), RocStr); } #[test] fn str_trim_end_small_to_small() { assert_evals_to!( - indoc!(r#"Str.trimEnd " hello ""#), + indoc!(r#"Str.trim_end " hello ""#), RocStr::from(" hello"), RocStr ); @@ -922,7 +922,7 @@ fn str_trim_end_small_to_small() { #[test] fn str_trim_end_large_to_large_unique() { assert_evals_to!( - indoc!(r#"Str.trimEnd (Str.concat " hello world from a large string" " ")"#), + indoc!(r#"Str.trim_end (Str.concat " hello world from a large string" " ")"#), RocStr::from(" hello world from a large string"), RocStr ); @@ -931,7 +931,7 @@ fn str_trim_end_large_to_large_unique() { #[test] fn str_trim_end_large_to_small_unique() { assert_evals_to!( - indoc!(r#"Str.trimEnd (Str.concat " hello" " ")"#), + indoc!(r#"Str.trim_end (Str.concat " hello" " ")"#), RocStr::from(" hello"), RocStr ); @@ -945,7 +945,7 @@ fn str_trim_end_large_to_large_shared() { original : Str original = " hello world world " - { trimmed: Str.trimEnd original, original: original } + { trimmed: Str.trim_end original, original: original } "# ), ( @@ -964,7 +964,7 @@ fn str_trim_end_large_to_small_shared() { original : Str original = " hello " - { trimmed: Str.trimEnd original, original: original } + { trimmed: Str.trim_end original, original: original } "# ), (RocStr::from(" hello "), RocStr::from(" hello"),), @@ -980,7 +980,7 @@ fn str_trim_end_small_to_small_shared() { original : Str original = " hello " - { trimmed: Str.trimEnd original, original: original } + { trimmed: Str.trim_end original, original: original } "# ), (RocStr::from(" hello "), RocStr::from(" hello"),), @@ -993,7 +993,7 @@ fn str_to_i128() { assert_evals_to!( indoc!( r#" - when Str.toI128 "1" is + when Str.to_i128 "1" is Ok n -> n Err _ -> 0 "# @@ -1008,7 +1008,7 @@ fn str_to_u128() { assert_evals_to!( indoc!( r#" - when Str.toU128 "1" is + when Str.to_u128 "1" is Ok n -> n Err _ -> 0 "# @@ -1023,7 +1023,7 @@ fn str_to_i64() { assert_evals_to!( indoc!( r#" - when Str.toI64 "1" is + when Str.to_i64 "1" is Ok n -> n Err _ -> 0 "# @@ -1038,7 +1038,7 @@ fn str_to_u64() { assert_evals_to!( indoc!( r#" - when Str.toU64 "1" is + when Str.to_u64 "1" is Ok n -> n Err _ -> 0 "# @@ -1053,7 +1053,7 @@ fn str_to_i32() { assert_evals_to!( indoc!( r#" - when Str.toI32 "1" is + when Str.to_i32 "1" is Ok n -> n Err _ -> 0 "# @@ -1068,7 +1068,7 @@ fn str_to_u32() { assert_evals_to!( indoc!( r#" - when Str.toU32 "1" is + when Str.to_u32 "1" is Ok n -> n Err _ -> 0 "# @@ -1083,7 +1083,7 @@ fn str_to_i16() { assert_evals_to!( indoc!( r#" - when Str.toI16 "1" is + when Str.to_i16 "1" is Ok n -> n Err _ -> 0 "# @@ -1098,7 +1098,7 @@ fn str_to_u16() { assert_evals_to!( indoc!( r#" - when Str.toU16 "1" is + when Str.to_u16 "1" is Ok n -> n Err _ -> 0 "# @@ -1113,7 +1113,7 @@ fn str_to_i8() { assert_evals_to!( indoc!( r#" - when Str.toI8 "1" is + when Str.to_i8 "1" is Ok n -> n Err _ -> 0 "# @@ -1128,7 +1128,7 @@ fn str_to_u8() { assert_evals_to!( indoc!( r#" - when Str.toU8 "1" is + when Str.to_u8 "1" is Ok n -> n Err _ -> 0 "# @@ -1143,7 +1143,7 @@ fn str_to_f64() { assert_evals_to!( indoc!( r#" - when Str.toF64 "1.0" is + when Str.to_f64 "1.0" is Ok n -> n Err _ -> 0 "# @@ -1158,7 +1158,7 @@ fn str_to_f32() { assert_evals_to!( indoc!( r#" - when Str.toF32 "1.0" is + when Str.to_f32 "1.0" is Ok n -> n Err _ -> 0 "# @@ -1175,7 +1175,7 @@ fn str_to_dec() { assert_evals_to!( indoc!( r#" - when Str.toDec "1.0" is + when Str.to_dec "1.0" is Ok n -> n Err _ -> 0 "# diff --git a/crates/compiler/test_mono/generated/as_pattern_in_closure_arg.txt b/crates/compiler/test_mono/generated/as_pattern_in_closure_arg.txt deleted file mode 100644 index 5d25c983bf3..00000000000 --- a/crates/compiler/test_mono/generated/as_pattern_in_closure_arg.txt +++ /dev/null @@ -1,31 +0,0 @@ -procedure Num.19 (#Attr.2, #Attr.3): - let Num.282 : I64 = lowlevel NumAdd #Attr.2 #Attr.3; - ret Num.282; - -procedure Test.1 (Test.12): - let Test.6 : I64 = StructAtIndex 0 Test.12; - let Test.5 : I64 = StructAtIndex 1 Test.12; - let Test.3 : I64 = StructAtIndex 2 Test.12; - let Test.4 : I64 = StructAtIndex 3 Test.12; - let Test.18 : I64 = CallByName Num.19 Test.3 Test.5; - let Test.19 : I64 = CallByName Num.19 Test.4 Test.6; - let Test.17 : {I64, I64} = Struct {Test.18, Test.19}; - ret Test.17; - -procedure Test.2 (Test.9): - let Test.7 : I64 = StructAtIndex 2 Test.9; - let Test.8 : I64 = StructAtIndex 3 Test.9; - let Test.16 : {I64, I64} = CallByName Test.1 Test.9; - let Test.10 : I64 = StructAtIndex 0 Test.16; - let Test.11 : I64 = StructAtIndex 1 Test.16; - let Test.15 : {I64, I64, I64, I64} = Struct {Test.7, Test.8, Test.10, Test.11}; - ret Test.15; - -procedure Test.0 (): - let Test.20 : I64 = 4i64; - let Test.21 : I64 = 3i64; - let Test.22 : I64 = 1i64; - let Test.23 : I64 = 2i64; - let Test.14 : {I64, I64, I64, I64} = Struct {Test.20, Test.21, Test.22, Test.23}; - let Test.13 : {I64, I64, I64, I64} = CallByName Test.2 Test.14; - ret Test.13; diff --git a/crates/compiler/test_mono/generated/choose_correct_recursion_var_under_record.txt b/crates/compiler/test_mono/generated/choose_correct_recursion_var_under_record.txt index 4ff2c76757e..d7f2dcc7143 100644 --- a/crates/compiler/test_mono/generated/choose_correct_recursion_var_under_record.txt +++ b/crates/compiler/test_mono/generated/choose_correct_recursion_var_under_record.txt @@ -1,131 +1,14 @@ procedure Bool.1 (): - let Bool.24 : Int1 = false; - ret Bool.24; - -procedure List.100 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4): - joinpoint List.687 List.174 List.175 List.176 List.177 List.178: - let List.689 : Int1 = CallByName Num.22 List.177 List.178; - if List.689 then - let List.693 : [C List [C List *self, C *self], C [C List *self, C *self]] = CallByName List.66 List.174 List.177; - inc List.693; - let List.179 : List Str = CallByName List.283 List.175 List.693 List.176; - let List.692 : U64 = 1i64; - let List.691 : U64 = CallByName Num.51 List.177 List.692; - jump List.687 List.174 List.179 List.176 List.691 List.178; - else - dec List.174; - ret List.175; - in - inc #Derived_gen.0; - jump List.687 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4; - -procedure List.18 (List.171, List.172, List.173): - let List.685 : U64 = 0i64; - let List.686 : U64 = CallByName List.6 List.171; - let List.684 : List Str = CallByName List.100 List.171 List.172 List.173 List.685 List.686; - ret List.684; - -procedure List.2 (List.119, List.120): - let List.679 : U64 = CallByName List.6 List.119; - let List.675 : Int1 = CallByName Num.22 List.120 List.679; - if List.675 then - let List.677 : Str = CallByName List.66 List.119 List.120; - inc List.677; - let List.676 : [C {}, C Str] = TagId(1) List.677; - ret List.676; - else - let List.674 : {} = Struct {}; - let List.673 : [C {}, C Str] = TagId(0) List.674; - ret List.673; - -procedure List.283 (List.284, List.285, List.281): - let List.698 : Str = CallByName Test.10 List.285; - let List.697 : List Str = CallByName List.71 List.284 List.698; - ret List.697; - -procedure List.5 (List.280, List.281): - let List.282 : U64 = CallByName List.6 List.280; - let List.682 : List Str = CallByName List.68 List.282; - let List.681 : List Str = CallByName List.18 List.280 List.682 List.281; - ret List.681; - -procedure List.6 (#Attr.2): - let List.680 : U64 = lowlevel ListLenU64 #Attr.2; - ret List.680; - -procedure List.6 (#Attr.2): - let List.695 : U64 = lowlevel ListLenU64 #Attr.2; - ret List.695; - -procedure List.66 (#Attr.2, #Attr.3): - let List.678 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3; - ret List.678; - -procedure List.66 (#Attr.2, #Attr.3): - let List.694 : [C List [C List *self, C *self], C [C List *self, C *self]] = lowlevel ListGetUnsafe #Attr.2 #Attr.3; - ret List.694; - -procedure List.68 (#Attr.2): - let List.700 : List Str = lowlevel ListWithCapacity #Attr.2; - ret List.700; - -procedure List.71 (#Attr.2, #Attr.3): - let List.699 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3; - ret List.699; - -procedure List.9 (List.391): - let List.672 : U64 = 0i64; - let List.665 : [C {}, C Str] = CallByName List.2 List.391 List.672; - let List.669 : U8 = 1i64; - let List.670 : U8 = GetTagId List.665; - let List.671 : Int1 = lowlevel Eq List.669 List.670; - if List.671 then - let List.392 : Str = UnionAtIndex (Id 1) (Index 0) List.665; - let List.666 : [C {}, C Str] = TagId(1) List.392; - ret List.666; - else - dec List.665; - let List.668 : {} = Struct {}; - let List.667 : [C {}, C Str] = TagId(0) List.668; - ret List.667; - -procedure Num.22 (#Attr.2, #Attr.3): - let Num.284 : Int1 = lowlevel NumLt #Attr.2 #Attr.3; - ret Num.284; - -procedure Num.51 (#Attr.2, #Attr.3): - let Num.285 : U64 = lowlevel NumAddWrap #Attr.2 #Attr.3; - ret Num.285; - -procedure Result.5 (Result.14, Result.15): - let Result.63 : U8 = 1i64; - let Result.64 : U8 = GetTagId Result.14; - let Result.65 : Int1 = lowlevel Eq Result.63 Result.64; - if Result.65 then - dec Result.15; - let Result.16 : Str = UnionAtIndex (Id 1) (Index 0) Result.14; - ret Result.16; - else - dec Result.14; - ret Result.15; - -procedure Test.10 (Test.11): - let Test.12 : Str = CallByName Test.2 Test.11; - let Test.26 : Int1 = CallByName Bool.1; - if Test.26 then - ret Test.12; - else - dec Test.12; - let Test.25 : Str = "foo"; - ret Test.25; + let Bool.23 : Int1 = false; + ret Bool.23; procedure Test.2 (Test.6): - let Test.29 : U8 = 1i64; - let Test.30 : U8 = GetTagId Test.6; - let Test.31 : Int1 = lowlevel Eq Test.29 Test.30; - if Test.31 then + let Test.22 : U8 = 1i64; + let Test.23 : U8 = GetTagId Test.6; + let Test.24 : Int1 = lowlevel Eq Test.22 Test.23; + if Test.24 then let Test.7 : [C List *self, C *self] = UnionAtIndex (Id 1) (Index 0) Test.6; - joinpoint #Derived_gen.9: + joinpoint #Derived_gen.1: let Test.8 : Str = CallByName Test.2 Test.7; let Test.18 : Int1 = CallByName Bool.1; if Test.18 then @@ -135,37 +18,32 @@ procedure Test.2 (Test.6): let Test.17 : Str = "foo"; ret Test.17; in - let #Derived_gen.10 : Int1 = lowlevel RefCountIsUnique Test.6; - if #Derived_gen.10 then + let #Derived_gen.2 : Int1 = lowlevel RefCountIsUnique Test.6; + if #Derived_gen.2 then free Test.6; - jump #Derived_gen.9; + jump #Derived_gen.1; else inc Test.7; decref Test.6; - jump #Derived_gen.9; + jump #Derived_gen.1; else let Test.9 : List [C List [C List *self, C *self], C [C List *self, C *self]] = UnionAtIndex (Id 0) (Index 0) Test.6; - joinpoint #Derived_gen.11: - let Test.24 : {} = Struct {}; - let Test.23 : List Str = CallByName List.5 Test.9 Test.24; + joinpoint #Derived_gen.3: dec Test.9; - let Test.21 : [C {}, C Str] = CallByName List.9 Test.23; - dec Test.23; - let Test.22 : Str = "foo"; - let Test.20 : Str = CallByName Result.5 Test.21 Test.22; - ret Test.20; + let Test.21 : Str = "ValueNotExposed { module_name: ModuleName(IdentStr { string: \"Result\" }), ident: Ident(IdentStr { string: \"withDefault\" }), region: @662-680, exposed_values: ['is_err', 'on_err', 'map', 'map_err', 'with_default', 'try', 'is_ok', 'map_both', 'map2', 'on_err!'] }"; + Crash Test.21 in - let #Derived_gen.12 : Int1 = lowlevel RefCountIsUnique Test.6; - if #Derived_gen.12 then + let #Derived_gen.4 : Int1 = lowlevel RefCountIsUnique Test.6; + if #Derived_gen.4 then free Test.6; - jump #Derived_gen.11; + jump #Derived_gen.3; else inc Test.9; decref Test.6; - jump #Derived_gen.11; + jump #Derived_gen.3; procedure Test.0 (): - let Test.32 : List [C List [C List *self, C *self], C [C List *self, C *self]] = Array []; - let Test.15 : [C List *self, C *self] = TagId(0) Test.32; + let Test.25 : List [C List [C List *self, C *self], C [C List *self, C *self]] = Array []; + let Test.15 : [C List *self, C *self] = TagId(0) Test.25; let Test.14 : Str = CallByName Test.2 Test.15; ret Test.14; diff --git a/crates/compiler/test_mono/generated/dbg_expr.txt b/crates/compiler/test_mono/generated/dbg_expr.txt index 938b34b7b08..2d8c0f74809 100644 --- a/crates/compiler/test_mono/generated/dbg_expr.txt +++ b/crates/compiler/test_mono/generated/dbg_expr.txt @@ -1,38 +1,38 @@ -procedure Inspect.281 (Inspect.282, Inspect.280): - let Inspect.321 : Str = CallByName Num.96 Inspect.280; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.282 Inspect.321; - dec Inspect.321; - ret Inspect.320; +procedure Inspect.273 (Inspect.274, Inspect.272): + let Inspect.313 : Str = CallByName Num.96 Inspect.272; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.274 Inspect.313; + dec Inspect.313; + ret Inspect.312; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; procedure Inspect.5 (Inspect.150): - let Inspect.315 : I64 = CallByName Inspect.57 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.281 Inspect.311 Inspect.315; - ret Inspect.310; - -procedure Inspect.57 (Inspect.280): - let Inspect.316 : I64 = CallByName Inspect.30 Inspect.280; - ret Inspect.316; - -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.323 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.323; - -procedure Inspect.64 (Inspect.305): - ret Inspect.305; + let Inspect.307 : I64 = CallByName Inspect.57 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.273 Inspect.303 Inspect.307; + ret Inspect.302; + +procedure Inspect.57 (Inspect.272): + let Inspect.308 : I64 = CallByName Inspect.30 Inspect.272; + ret Inspect.308; + +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; + +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.19 (#Attr.2, #Attr.3): let Num.283 : I64 = lowlevel NumAdd #Attr.2 #Attr.3; diff --git a/crates/compiler/test_mono/generated/dbg_in_expect.txt b/crates/compiler/test_mono/generated/dbg_in_expect.txt index 1e94f298d2a..4e6bd826f2a 100644 --- a/crates/compiler/test_mono/generated/dbg_in_expect.txt +++ b/crates/compiler/test_mono/generated/dbg_in_expect.txt @@ -14,70 +14,66 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.24 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.24; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.340 : Str = "\""; - let Inspect.325 : Str = CallByName Inspect.63 Inspect.251 Inspect.340; - dec Inspect.340; - let Inspect.321 : Str = CallByName Inspect.252 Inspect.325 Inspect.249; - let Inspect.322 : Str = "\""; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.321 Inspect.322; - dec Inspect.322; - ret Inspect.320; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.338 : Str = "\u{feff}"; - let Inspect.339 : Str = "\\u(feff)"; - let Inspect.335 : Str = CallByName Str.45 Inspect.249 Inspect.338 Inspect.339; - dec Inspect.338; - dec Inspect.339; - let Inspect.336 : Str = "\u{200b}"; - let Inspect.337 : Str = "\\u(200b)"; - let Inspect.332 : Str = CallByName Str.45 Inspect.335 Inspect.336 Inspect.337; - dec Inspect.337; - dec Inspect.336; - let Inspect.333 : Str = "\u{200c}"; - let Inspect.334 : Str = "\\u(200c)"; - let Inspect.329 : Str = CallByName Str.45 Inspect.332 Inspect.333 Inspect.334; - dec Inspect.334; - dec Inspect.333; - let Inspect.330 : Str = "\u{200d}"; - let Inspect.331 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.329 Inspect.330 Inspect.331; - dec Inspect.330; - dec Inspect.331; - let Inspect.328 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.328; +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.317 : Str = "\""; + let Inspect.316 : Str = CallByName Inspect.63 Inspect.246 Inspect.317; + dec Inspect.317; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.316 Inspect.244; + let Inspect.313 : Str = "\""; + let Inspect.311 : Str = CallByName Inspect.63 Inspect.312 Inspect.313; + dec Inspect.313; + ret Inspect.311; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.47 (Inspect.249): - let Inspect.316 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.316; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; + +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; + +procedure Inspect.47 (Inspect.243): + let Inspect.327 : Str = "\u{feff}"; + let Inspect.328 : Str = "\\u(feff)"; + let Inspect.324 : Str = CallByName Str.45 Inspect.243 Inspect.327 Inspect.328; + dec Inspect.327; + dec Inspect.328; + let Inspect.325 : Str = "\u{200b}"; + let Inspect.326 : Str = "\\u(200b)"; + let Inspect.321 : Str = CallByName Str.45 Inspect.324 Inspect.325 Inspect.326; + dec Inspect.326; + dec Inspect.325; + let Inspect.322 : Str = "\u{200c}"; + let Inspect.323 : Str = "\\u(200c)"; + let Inspect.318 : Str = CallByName Str.45 Inspect.321 Inspect.322 Inspect.323; + dec Inspect.322; + dec Inspect.323; + let Inspect.319 : Str = "\u{200d}"; + let Inspect.320 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.318 Inspect.319 Inspect.320; + dec Inspect.319; + dec Inspect.320; + let Inspect.308 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.308; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName Inspect.47 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.250 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : Str = CallByName Inspect.47 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.245 Inspect.303 Inspect.307; + dec Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.324 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.324; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.20 (#Attr.2, #Attr.3): let Num.288 : U64 = lowlevel NumSub #Attr.2 #Attr.3; @@ -175,7 +171,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.341; ret Str.91; -procedure Str.56 (#Derived_gen.7, #Derived_gen.8, #Derived_gen.9, #Derived_gen.10): +procedure Str.56 (#Derived_gen.5, #Derived_gen.6, #Derived_gen.7, #Derived_gen.8): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -199,9 +195,9 @@ procedure Str.56 (#Derived_gen.7, #Derived_gen.8, #Derived_gen.9, #Derived_gen.1 dec Str.97; ret Str.255; in - inc #Derived_gen.9; - inc #Derived_gen.10; - jump Str.250 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9 #Derived_gen.10; + inc #Derived_gen.7; + inc #Derived_gen.8; + jump Str.250 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -211,7 +207,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3): +procedure Str.58 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -231,9 +227,9 @@ procedure Str.58 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3 let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.0; inc #Derived_gen.1; - jump Str.278 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3; + inc #Derived_gen.2; + jump Str.278 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/dbg_inside_string.txt b/crates/compiler/test_mono/generated/dbg_inside_string.txt index b2e9a4330cc..45395b4bdb7 100644 --- a/crates/compiler/test_mono/generated/dbg_inside_string.txt +++ b/crates/compiler/test_mono/generated/dbg_inside_string.txt @@ -10,70 +10,66 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.23 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.23; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.340 : Str = "\""; - let Inspect.325 : Str = CallByName Inspect.63 Inspect.251 Inspect.340; - dec Inspect.340; - let Inspect.321 : Str = CallByName Inspect.252 Inspect.325 Inspect.249; - let Inspect.322 : Str = "\""; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.321 Inspect.322; - dec Inspect.322; - ret Inspect.320; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.338 : Str = "\u{feff}"; - let Inspect.339 : Str = "\\u(feff)"; - let Inspect.335 : Str = CallByName Str.45 Inspect.249 Inspect.338 Inspect.339; - dec Inspect.338; - dec Inspect.339; - let Inspect.336 : Str = "\u{200b}"; - let Inspect.337 : Str = "\\u(200b)"; - let Inspect.332 : Str = CallByName Str.45 Inspect.335 Inspect.336 Inspect.337; - dec Inspect.337; - dec Inspect.336; - let Inspect.333 : Str = "\u{200c}"; - let Inspect.334 : Str = "\\u(200c)"; - let Inspect.329 : Str = CallByName Str.45 Inspect.332 Inspect.333 Inspect.334; - dec Inspect.334; - dec Inspect.333; - let Inspect.330 : Str = "\u{200d}"; - let Inspect.331 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.329 Inspect.330 Inspect.331; - dec Inspect.330; - dec Inspect.331; - let Inspect.328 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.328; +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.317 : Str = "\""; + let Inspect.316 : Str = CallByName Inspect.63 Inspect.246 Inspect.317; + dec Inspect.317; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.316 Inspect.244; + let Inspect.313 : Str = "\""; + let Inspect.311 : Str = CallByName Inspect.63 Inspect.312 Inspect.313; + dec Inspect.313; + ret Inspect.311; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.47 (Inspect.249): - let Inspect.316 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.316; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; + +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; + +procedure Inspect.47 (Inspect.243): + let Inspect.327 : Str = "\u{feff}"; + let Inspect.328 : Str = "\\u(feff)"; + let Inspect.324 : Str = CallByName Str.45 Inspect.243 Inspect.327 Inspect.328; + dec Inspect.327; + dec Inspect.328; + let Inspect.325 : Str = "\u{200b}"; + let Inspect.326 : Str = "\\u(200b)"; + let Inspect.321 : Str = CallByName Str.45 Inspect.324 Inspect.325 Inspect.326; + dec Inspect.326; + dec Inspect.325; + let Inspect.322 : Str = "\u{200c}"; + let Inspect.323 : Str = "\\u(200c)"; + let Inspect.318 : Str = CallByName Str.45 Inspect.321 Inspect.322 Inspect.323; + dec Inspect.322; + dec Inspect.323; + let Inspect.319 : Str = "\u{200d}"; + let Inspect.320 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.318 Inspect.319 Inspect.320; + dec Inspect.319; + dec Inspect.320; + let Inspect.308 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.308; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName Inspect.47 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.250 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : Str = CallByName Inspect.47 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.245 Inspect.303 Inspect.307; + dec Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.324 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.324; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.20 (#Attr.2, #Attr.3): let Num.288 : U64 = lowlevel NumSub #Attr.2 #Attr.3; @@ -171,7 +167,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.343; ret Str.91; -procedure Str.56 (#Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9): +procedure Str.56 (#Derived_gen.5, #Derived_gen.6, #Derived_gen.7, #Derived_gen.8): joinpoint Str.252 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.253 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -195,9 +191,9 @@ procedure Str.56 (#Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9 dec Str.97; ret Str.257; in + inc #Derived_gen.7; inc #Derived_gen.8; - inc #Derived_gen.9; - jump Str.252 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9; + jump Str.252 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -207,7 +203,7 @@ procedure Str.57 (Str.121, Str.122): let Str.278 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.279 Str.125; ret Str.278; -procedure Str.58 (#Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5): +procedure Str.58 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4): joinpoint Str.280 Str.126 Str.127 Str.128 Str.129: let Str.282 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.282 then @@ -227,9 +223,9 @@ procedure Str.58 (#Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5 let Str.281 : [C , C U64] = TagId(0) ; ret Str.281; in - inc #Derived_gen.3; + inc #Derived_gen.1; inc #Derived_gen.2; - jump Str.280 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5; + jump Str.280 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4; procedure Str.61 (Str.152, Str.153): let Str.310 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/dbg_nested_expr.txt b/crates/compiler/test_mono/generated/dbg_nested_expr.txt index 722f9f1da5b..c3b19c61fcb 100644 --- a/crates/compiler/test_mono/generated/dbg_nested_expr.txt +++ b/crates/compiler/test_mono/generated/dbg_nested_expr.txt @@ -1,38 +1,38 @@ -procedure Inspect.281 (Inspect.282, Inspect.280): - let Inspect.321 : Str = CallByName Num.96 Inspect.280; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.282 Inspect.321; - dec Inspect.321; - ret Inspect.320; +procedure Inspect.273 (Inspect.274, Inspect.272): + let Inspect.313 : Str = CallByName Num.96 Inspect.272; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.274 Inspect.313; + dec Inspect.313; + ret Inspect.312; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.327 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.326 : Str = CallByName Inspect.64 Inspect.327; - ret Inspect.326; + let Inspect.319 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.318 : Str = CallByName Inspect.64 Inspect.319; + ret Inspect.318; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; procedure Inspect.5 (Inspect.150): - let Inspect.315 : I64 = CallByName Inspect.57 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.281 Inspect.311 Inspect.315; - ret Inspect.310; - -procedure Inspect.57 (Inspect.280): - let Inspect.316 : I64 = CallByName Inspect.30 Inspect.280; - ret Inspect.316; - -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.323 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.323; - -procedure Inspect.64 (Inspect.305): - ret Inspect.305; + let Inspect.307 : I64 = CallByName Inspect.57 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.273 Inspect.303 Inspect.307; + ret Inspect.302; + +procedure Inspect.57 (Inspect.272): + let Inspect.308 : I64 = CallByName Inspect.30 Inspect.272; + ret Inspect.308; + +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; + +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.96 (#Attr.2): let Num.283 : Str = lowlevel NumToStr #Attr.2; diff --git a/crates/compiler/test_mono/generated/dbg_str_followed_by_number.txt b/crates/compiler/test_mono/generated/dbg_str_followed_by_number.txt index 19ca0b97ce0..5cc0a2fbe82 100644 --- a/crates/compiler/test_mono/generated/dbg_str_followed_by_number.txt +++ b/crates/compiler/test_mono/generated/dbg_str_followed_by_number.txt @@ -10,70 +10,66 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.23 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.23; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.340 : Str = "\""; - let Inspect.325 : Str = CallByName Inspect.63 Inspect.251 Inspect.340; - dec Inspect.340; - let Inspect.321 : Str = CallByName Inspect.252 Inspect.325 Inspect.249; - let Inspect.322 : Str = "\""; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.321 Inspect.322; - dec Inspect.322; - ret Inspect.320; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.338 : Str = "\u{feff}"; - let Inspect.339 : Str = "\\u(feff)"; - let Inspect.335 : Str = CallByName Str.45 Inspect.249 Inspect.338 Inspect.339; - dec Inspect.338; - dec Inspect.339; - let Inspect.336 : Str = "\u{200b}"; - let Inspect.337 : Str = "\\u(200b)"; - let Inspect.332 : Str = CallByName Str.45 Inspect.335 Inspect.336 Inspect.337; - dec Inspect.337; - dec Inspect.336; - let Inspect.333 : Str = "\u{200c}"; - let Inspect.334 : Str = "\\u(200c)"; - let Inspect.329 : Str = CallByName Str.45 Inspect.332 Inspect.333 Inspect.334; - dec Inspect.334; - dec Inspect.333; - let Inspect.330 : Str = "\u{200d}"; - let Inspect.331 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.329 Inspect.330 Inspect.331; - dec Inspect.330; - dec Inspect.331; - let Inspect.328 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.328; +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.317 : Str = "\""; + let Inspect.316 : Str = CallByName Inspect.63 Inspect.246 Inspect.317; + dec Inspect.317; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.316 Inspect.244; + let Inspect.313 : Str = "\""; + let Inspect.311 : Str = CallByName Inspect.63 Inspect.312 Inspect.313; + dec Inspect.313; + ret Inspect.311; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.47 (Inspect.249): - let Inspect.316 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.316; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; + +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; + +procedure Inspect.47 (Inspect.243): + let Inspect.327 : Str = "\u{feff}"; + let Inspect.328 : Str = "\\u(feff)"; + let Inspect.324 : Str = CallByName Str.45 Inspect.243 Inspect.327 Inspect.328; + dec Inspect.327; + dec Inspect.328; + let Inspect.325 : Str = "\u{200b}"; + let Inspect.326 : Str = "\\u(200b)"; + let Inspect.321 : Str = CallByName Str.45 Inspect.324 Inspect.325 Inspect.326; + dec Inspect.326; + dec Inspect.325; + let Inspect.322 : Str = "\u{200c}"; + let Inspect.323 : Str = "\\u(200c)"; + let Inspect.318 : Str = CallByName Str.45 Inspect.321 Inspect.322 Inspect.323; + dec Inspect.322; + dec Inspect.323; + let Inspect.319 : Str = "\u{200d}"; + let Inspect.320 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.318 Inspect.319 Inspect.320; + dec Inspect.319; + dec Inspect.320; + let Inspect.308 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.308; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName Inspect.47 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.250 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : Str = CallByName Inspect.47 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.245 Inspect.303 Inspect.307; + dec Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.324 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.324; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.20 (#Attr.2, #Attr.3): let Num.288 : U64 = lowlevel NumSub #Attr.2 #Attr.3; @@ -171,7 +167,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.341; ret Str.91; -procedure Str.56 (#Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9): +procedure Str.56 (#Derived_gen.5, #Derived_gen.6, #Derived_gen.7, #Derived_gen.8): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -195,9 +191,9 @@ procedure Str.56 (#Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9 dec Str.97; ret Str.255; in + inc #Derived_gen.7; inc #Derived_gen.8; - inc #Derived_gen.9; - jump Str.250 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9; + jump Str.250 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -207,7 +203,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5): +procedure Str.58 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -227,9 +223,9 @@ procedure Str.58 (#Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5 let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.3; + inc #Derived_gen.1; inc #Derived_gen.2; - jump Str.278 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5; + jump Str.278 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/dict.txt b/crates/compiler/test_mono/generated/dict.txt index b788c1cac07..67d35d20149 100644 --- a/crates/compiler/test_mono/generated/dict.txt +++ b/crates/compiler/test_mono/generated/dict.txt @@ -1,29 +1,29 @@ -procedure Dict.1 (Dict.731): - let Dict.740 : List {U32, U32} = Array []; - let Dict.741 : List {[], []} = Array []; - let Dict.742 : U64 = 0i64; +procedure Dict.1 (Dict.732): + let Dict.741 : List {U32, U32} = Array []; + let Dict.742 : List {[], []} = Array []; + let Dict.743 : U64 = 0i64; let Dict.51 : Float32 = CallByName Dict.51; let Dict.52 : U8 = CallByName Dict.52; - let Dict.739 : {List {U32, U32}, List {[], []}, U64, Float32, U8} = Struct {Dict.740, Dict.741, Dict.742, Dict.51, Dict.52}; - ret Dict.739; + let Dict.740 : {List {U32, U32}, List {[], []}, U64, Float32, U8} = Struct {Dict.741, Dict.742, Dict.743, Dict.51, Dict.52}; + ret Dict.740; -procedure Dict.4 (Dict.737): - let Dict.163 : List {[], []} = StructAtIndex 1 Dict.737; - let #Derived_gen.0 : List {U32, U32} = StructAtIndex 0 Dict.737; +procedure Dict.4 (Dict.738): + let Dict.163 : List {[], []} = StructAtIndex 1 Dict.738; + let #Derived_gen.0 : List {U32, U32} = StructAtIndex 0 Dict.738; dec #Derived_gen.0; - let Dict.738 : U64 = CallByName List.6 Dict.163; + let Dict.739 : U64 = CallByName List.6 Dict.163; dec Dict.163; - ret Dict.738; + ret Dict.739; procedure Dict.51 (): - let Dict.746 : Float32 = 0.8f64; - ret Dict.746; + let Dict.747 : Float32 = 0.8f64; + ret Dict.747; procedure Dict.52 (): - let Dict.744 : U8 = 64i64; - let Dict.745 : U8 = 3i64; - let Dict.743 : U8 = CallByName Num.75 Dict.744 Dict.745; - ret Dict.743; + let Dict.745 : U8 = 64i64; + let Dict.746 : U8 = 3i64; + let Dict.744 : U8 = CallByName Num.75 Dict.745 Dict.746; + ret Dict.744; procedure List.6 (#Attr.2): let List.665 : U64 = lowlevel ListLenU64 #Attr.2; diff --git a/crates/compiler/test_mono/generated/inspect_derived_dict.txt b/crates/compiler/test_mono/generated/inspect_derived_dict.txt index 76042382114..28569ff0278 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_dict.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_dict.txt @@ -42,705 +42,705 @@ procedure Bool.7 (Bool.19, Bool.20): let Bool.27 : Int1 = CallByName Bool.12 Bool.19 Bool.20; ret Bool.27; -procedure Dict.1 (Dict.731): - let Dict.893 : List {U32, U32} = Array []; - let Dict.894 : List {Str, I64} = Array []; - let Dict.895 : U64 = 0i64; +procedure Dict.1 (Dict.732): + let Dict.894 : List {U32, U32} = Array []; + let Dict.895 : List {Str, I64} = Array []; + let Dict.896 : U64 = 0i64; let Dict.51 : Float32 = CallByName Dict.51; let Dict.52 : U8 = CallByName Dict.52; - let Dict.892 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.893, Dict.894, Dict.895, Dict.51, Dict.52}; - ret Dict.892; - -procedure Dict.10 (Dict.732, Dict.186, Dict.187): - let Dict.185 : List {Str, I64} = StructAtIndex 1 Dict.732; - let #Derived_gen.78 : List {U32, U32} = StructAtIndex 0 Dict.732; - dec #Derived_gen.78; - let Dict.1109 : {Str, Int1} = CallByName List.18 Dict.185 Dict.186 Dict.187; + let Dict.893 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.894, Dict.895, Dict.896, Dict.51, Dict.52}; + ret Dict.893; + +procedure Dict.10 (Dict.733, Dict.186, Dict.187): + let Dict.185 : List {Str, I64} = StructAtIndex 1 Dict.733; + let #Derived_gen.70 : List {U32, U32} = StructAtIndex 0 Dict.733; + dec #Derived_gen.70; + let Dict.1110 : {Str, Int1} = CallByName List.18 Dict.185 Dict.186 Dict.187; dec Dict.185; - ret Dict.1109; - -procedure Dict.100 (Dict.545, Dict.546, Dict.547): - let Dict.1062 : U8 = CallByName Dict.22 Dict.545 Dict.546; - let Dict.548 : U64 = CallByName Num.133 Dict.1062; - let Dict.1061 : U8 = 1i64; - let Dict.1060 : U64 = CallByName Num.74 Dict.547 Dict.1061; - let Dict.1059 : U64 = CallByName Num.51 Dict.1060 Dict.546; - let Dict.1058 : U8 = CallByName Dict.22 Dict.545 Dict.1059; - let Dict.549 : U64 = CallByName Num.133 Dict.1058; - let Dict.1057 : U64 = 1i64; - let Dict.1056 : U64 = CallByName Num.75 Dict.547 Dict.1057; - let Dict.1055 : U64 = CallByName Num.51 Dict.1056 Dict.546; - let Dict.1054 : U8 = CallByName Dict.22 Dict.545 Dict.1055; - let Dict.550 : U64 = CallByName Num.133 Dict.1054; - let Dict.1053 : U8 = 16i64; - let Dict.1050 : U64 = CallByName Num.72 Dict.548 Dict.1053; - let Dict.1052 : U8 = 8i64; - let Dict.1051 : U64 = CallByName Num.72 Dict.549 Dict.1052; - let Dict.551 : U64 = CallByName Num.71 Dict.1050 Dict.1051; - let Dict.1049 : U64 = CallByName Num.71 Dict.551 Dict.550; - ret Dict.1049; + ret Dict.1110; + +procedure Dict.100 (Dict.546, Dict.547, Dict.548): + let Dict.1063 : U8 = CallByName Dict.22 Dict.546 Dict.547; + let Dict.549 : U64 = CallByName Num.133 Dict.1063; + let Dict.1062 : U8 = 1i64; + let Dict.1061 : U64 = CallByName Num.74 Dict.548 Dict.1062; + let Dict.1060 : U64 = CallByName Num.51 Dict.1061 Dict.547; + let Dict.1059 : U8 = CallByName Dict.22 Dict.546 Dict.1060; + let Dict.550 : U64 = CallByName Num.133 Dict.1059; + let Dict.1058 : U64 = 1i64; + let Dict.1057 : U64 = CallByName Num.75 Dict.548 Dict.1058; + let Dict.1056 : U64 = CallByName Num.51 Dict.1057 Dict.547; + let Dict.1055 : U8 = CallByName Dict.22 Dict.546 Dict.1056; + let Dict.551 : U64 = CallByName Num.133 Dict.1055; + let Dict.1054 : U8 = 16i64; + let Dict.1051 : U64 = CallByName Num.72 Dict.549 Dict.1054; + let Dict.1053 : U8 = 8i64; + let Dict.1052 : U64 = CallByName Num.72 Dict.550 Dict.1053; + let Dict.552 : U64 = CallByName Num.71 Dict.1051 Dict.1052; + let Dict.1050 : U64 = CallByName Num.71 Dict.552 Dict.551; + ret Dict.1050; procedure Dict.12 (Dict.158): - let Dict.891 : {} = Struct {}; - let Dict.739 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.1 Dict.891; - let Dict.740 : {} = Struct {}; - let Dict.738 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName List.18 Dict.158 Dict.739 Dict.740; - ret Dict.738; + let Dict.892 : {} = Struct {}; + let Dict.740 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.1 Dict.892; + let Dict.741 : {} = Struct {}; + let Dict.739 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName List.18 Dict.158 Dict.740 Dict.741; + ret Dict.739; procedure Dict.127 (Dict.128, Dict.126): - let Dict.1106 : {} = Struct {}; let Dict.1107 : {} = Struct {}; let Dict.1108 : {} = Struct {}; - let Dict.1105 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = CallByName Inspect.42 Dict.126 Dict.1106 Dict.1107 Dict.1108; - let Dict.1104 : Str = CallByName Inspect.31 Dict.1105 Dict.128; - ret Dict.1104; - -procedure Dict.159 (Dict.160, Dict.741): - let Dict.161 : Str = StructAtIndex 0 Dict.741; - let Dict.162 : I64 = StructAtIndex 1 Dict.741; - let Dict.742 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.8 Dict.160 Dict.161 Dict.162; - ret Dict.742; - -procedure Dict.188 (Dict.189, Dict.1111, Dict.187): - let Dict.190 : Str = StructAtIndex 0 Dict.1111; - let Dict.191 : I64 = StructAtIndex 1 Dict.1111; - let Dict.1113 : {Str, Int1} = CallByName Inspect.191 Dict.189 Dict.190 Dict.191 Dict.187; - ret Dict.1113; - -procedure Dict.20 (Dict.728): - let Dict.155 : U64 = StructAtIndex 2 Dict.728; - let #Derived_gen.81 : List {U32, U32} = StructAtIndex 0 Dict.728; - dec #Derived_gen.81; - let #Derived_gen.80 : List {Str, I64} = StructAtIndex 1 Dict.728; - dec #Derived_gen.80; + let Dict.1109 : {} = Struct {}; + let Dict.1106 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = CallByName Inspect.42 Dict.126 Dict.1107 Dict.1108 Dict.1109; + let Dict.1105 : Str = CallByName Inspect.31 Dict.1106 Dict.128; + ret Dict.1105; + +procedure Dict.159 (Dict.160, Dict.742): + let Dict.161 : Str = StructAtIndex 0 Dict.742; + let Dict.162 : I64 = StructAtIndex 1 Dict.742; + let Dict.743 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.8 Dict.160 Dict.161 Dict.162; + ret Dict.743; + +procedure Dict.188 (Dict.189, Dict.1112, Dict.187): + let Dict.190 : Str = StructAtIndex 0 Dict.1112; + let Dict.191 : I64 = StructAtIndex 1 Dict.1112; + let Dict.1114 : {Str, Int1} = CallByName Inspect.189 Dict.189 Dict.190 Dict.191 Dict.187; + ret Dict.1114; + +procedure Dict.20 (Dict.729): + let Dict.155 : U64 = StructAtIndex 2 Dict.729; + let #Derived_gen.73 : List {U32, U32} = StructAtIndex 0 Dict.729; + dec #Derived_gen.73; + let #Derived_gen.72 : List {Str, I64} = StructAtIndex 1 Dict.729; + dec #Derived_gen.72; ret Dict.155; procedure Dict.22 (#Attr.2, #Attr.3): - let Dict.773 : {U32, U32} = lowlevel ListGetUnsafe #Attr.2 #Attr.3; - ret Dict.773; + let Dict.774 : {U32, U32} = lowlevel ListGetUnsafe #Attr.2 #Attr.3; + ret Dict.774; procedure Dict.22 (#Attr.2, #Attr.3): - let Dict.789 : {Str, I64} = lowlevel ListGetUnsafe #Attr.2 #Attr.3; - ret Dict.789; + let Dict.790 : {Str, I64} = lowlevel ListGetUnsafe #Attr.2 #Attr.3; + ret Dict.790; procedure Dict.22 (#Attr.2, #Attr.3): - let Dict.952 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3; - ret Dict.952; + let Dict.953 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3; + ret Dict.953; procedure Dict.23 (#Attr.2): - let Dict.825 : U64 = lowlevel DictPseudoSeed #Attr.2; - ret Dict.825; - -procedure Dict.4 (Dict.737): - let Dict.163 : List {Str, I64} = StructAtIndex 1 Dict.737; - let #Derived_gen.77 : List {U32, U32} = StructAtIndex 0 Dict.737; - dec #Derived_gen.77; - let Dict.890 : U64 = CallByName List.6 Dict.163; + let Dict.826 : U64 = lowlevel DictPseudoSeed #Attr.2; + ret Dict.826; + +procedure Dict.4 (Dict.738): + let Dict.163 : List {Str, I64} = StructAtIndex 1 Dict.738; + let #Derived_gen.69 : List {U32, U32} = StructAtIndex 0 Dict.738; + dec #Derived_gen.69; + let Dict.891 : U64 = CallByName List.6 Dict.163; dec Dict.163; - ret Dict.890; - -procedure Dict.406 (Dict.407, Dict.848, Dict.409, Dict.405): - let Dict.408 : Str = StructAtIndex 0 Dict.848; - let Dict.853 : {U64, U32} = CallByName Dict.72 Dict.407 Dict.408 Dict.405; - let Dict.410 : U64 = StructAtIndex 0 Dict.853; - let Dict.411 : U32 = StructAtIndex 1 Dict.853; - let Dict.852 : U32 = CallByName Num.131 Dict.409; - let Dict.851 : {U32, U32} = Struct {Dict.852, Dict.411}; - let Dict.850 : List {U32, U32} = CallByName Dict.74 Dict.407 Dict.851 Dict.410; - ret Dict.850; + ret Dict.891; + +procedure Dict.407 (Dict.408, Dict.849, Dict.410, Dict.406): + let Dict.409 : Str = StructAtIndex 0 Dict.849; + let Dict.854 : {U64, U32} = CallByName Dict.72 Dict.408 Dict.409 Dict.406; + let Dict.411 : U64 = StructAtIndex 0 Dict.854; + let Dict.412 : U32 = StructAtIndex 1 Dict.854; + let Dict.853 : U32 = CallByName Num.131 Dict.410; + let Dict.852 : {U32, U32} = Struct {Dict.853, Dict.412}; + let Dict.851 : List {U32, U32} = CallByName Dict.74 Dict.408 Dict.852 Dict.411; + ret Dict.851; procedure Dict.43 (Dict.126): - let Dict.1101 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Inspect.30 Dict.126; - ret Dict.1101; + let Dict.1102 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Inspect.30 Dict.126; + ret Dict.1102; -procedure Dict.45 (#Derived_gen.50, #Derived_gen.51, #Derived_gen.52, #Derived_gen.53, #Derived_gen.54, #Derived_gen.55, #Derived_gen.56, #Derived_gen.57, #Derived_gen.58): - joinpoint Dict.744 Dict.228 Dict.229 Dict.230 Dict.231 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236: +procedure Dict.45 (#Derived_gen.39, #Derived_gen.40, #Derived_gen.41, #Derived_gen.42, #Derived_gen.43, #Derived_gen.44, #Derived_gen.45, #Derived_gen.46, #Derived_gen.47): + joinpoint Dict.745 Dict.228 Dict.229 Dict.230 Dict.231 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236: let Dict.237 : {U32, U32} = CallByName Dict.22 Dict.228 Dict.230; - let Dict.791 : U32 = StructAtIndex 1 Dict.237; - let Dict.779 : Int1 = CallByName Bool.11 Dict.231 Dict.791; - if Dict.779 then - let Dict.790 : U32 = StructAtIndex 0 Dict.237; - let Dict.788 : U64 = CallByName Num.133 Dict.790; - let Dict.787 : {Str, I64} = CallByName Dict.22 Dict.229 Dict.788; - let Dict.238 : Str = StructAtIndex 0 Dict.787; - let Dict.782 : Int1 = CallByName Bool.11 Dict.238 Dict.232; - if Dict.782 then - let Dict.786 : U32 = StructAtIndex 0 Dict.237; - let Dict.784 : U64 = CallByName Num.133 Dict.786; - let Dict.785 : {Str, I64} = Struct {Dict.232, Dict.233}; - let Dict.239 : List {Str, I64} = CallByName List.3 Dict.229 Dict.784 Dict.785; - let Dict.783 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.228, Dict.239, Dict.234, Dict.235, Dict.236}; - ret Dict.783; + let Dict.792 : U32 = StructAtIndex 1 Dict.237; + let Dict.780 : Int1 = CallByName Bool.11 Dict.231 Dict.792; + if Dict.780 then + let Dict.791 : U32 = StructAtIndex 0 Dict.237; + let Dict.789 : U64 = CallByName Num.133 Dict.791; + let Dict.788 : {Str, I64} = CallByName Dict.22 Dict.229 Dict.789; + let Dict.238 : Str = StructAtIndex 0 Dict.788; + let Dict.783 : Int1 = CallByName Bool.11 Dict.238 Dict.232; + if Dict.783 then + let Dict.787 : U32 = StructAtIndex 0 Dict.237; + let Dict.785 : U64 = CallByName Num.133 Dict.787; + let Dict.786 : {Str, I64} = Struct {Dict.232, Dict.233}; + let Dict.239 : List {Str, I64} = CallByName List.3 Dict.229 Dict.785 Dict.786; + let Dict.784 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.228, Dict.239, Dict.234, Dict.235, Dict.236}; + ret Dict.784; else - let Dict.781 : U64 = CallByName List.6 Dict.228; - let Dict.240 : U64 = CallByName Dict.75 Dict.230 Dict.781; + let Dict.782 : U64 = CallByName List.6 Dict.228; + let Dict.240 : U64 = CallByName Dict.75 Dict.230 Dict.782; let Dict.241 : U32 = CallByName Dict.55 Dict.231; - jump Dict.744 Dict.228 Dict.229 Dict.240 Dict.241 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236; + jump Dict.745 Dict.228 Dict.229 Dict.240 Dict.241 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236; else - let Dict.778 : U32 = StructAtIndex 1 Dict.237; - let Dict.758 : Int1 = CallByName Num.24 Dict.231 Dict.778; - if Dict.758 then - let Dict.777 : {Str, I64} = Struct {Dict.232, Dict.233}; - let Dict.242 : List {Str, I64} = CallByName List.4 Dict.229 Dict.777; - let Dict.775 : U64 = CallByName List.6 Dict.242; - let Dict.776 : U64 = 1i64; - let Dict.243 : U64 = CallByName Num.75 Dict.775 Dict.776; - let Dict.774 : U32 = CallByName Num.131 Dict.243; - let Dict.760 : {U32, U32} = Struct {Dict.774, Dict.231}; - let Dict.244 : List {U32, U32} = CallByName Dict.74 Dict.228 Dict.760 Dict.230; - let Dict.759 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.244, Dict.242, Dict.234, Dict.235, Dict.236}; - ret Dict.759; + let Dict.779 : U32 = StructAtIndex 1 Dict.237; + let Dict.759 : Int1 = CallByName Num.24 Dict.231 Dict.779; + if Dict.759 then + let Dict.778 : {Str, I64} = Struct {Dict.232, Dict.233}; + let Dict.242 : List {Str, I64} = CallByName List.4 Dict.229 Dict.778; + let Dict.776 : U64 = CallByName List.6 Dict.242; + let Dict.777 : U64 = 1i64; + let Dict.243 : U64 = CallByName Num.75 Dict.776 Dict.777; + let Dict.775 : U32 = CallByName Num.131 Dict.243; + let Dict.761 : {U32, U32} = Struct {Dict.775, Dict.231}; + let Dict.244 : List {U32, U32} = CallByName Dict.74 Dict.228 Dict.761 Dict.230; + let Dict.760 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.244, Dict.242, Dict.234, Dict.235, Dict.236}; + ret Dict.760; else - let Dict.751 : U64 = CallByName List.6 Dict.228; - let Dict.245 : U64 = CallByName Dict.75 Dict.230 Dict.751; + let Dict.752 : U64 = CallByName List.6 Dict.228; + let Dict.245 : U64 = CallByName Dict.75 Dict.230 Dict.752; let Dict.246 : U32 = CallByName Dict.55 Dict.231; - jump Dict.744 Dict.228 Dict.229 Dict.245 Dict.246 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236; + jump Dict.745 Dict.228 Dict.229 Dict.245 Dict.246 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236; in - inc #Derived_gen.54; - jump Dict.744 #Derived_gen.50 #Derived_gen.51 #Derived_gen.52 #Derived_gen.53 #Derived_gen.54 #Derived_gen.55 #Derived_gen.56 #Derived_gen.57 #Derived_gen.58; + inc #Derived_gen.43; + jump Dict.745 #Derived_gen.39 #Derived_gen.40 #Derived_gen.41 #Derived_gen.42 #Derived_gen.43 #Derived_gen.44 #Derived_gen.45 #Derived_gen.46 #Derived_gen.47; procedure Dict.48 (): - let Dict.868 : U32 = 0i64; let Dict.869 : U32 = 0i64; - let Dict.867 : {U32, U32} = Struct {Dict.868, Dict.869}; - ret Dict.867; + let Dict.870 : U32 = 0i64; + let Dict.868 : {U32, U32} = Struct {Dict.869, Dict.870}; + ret Dict.868; procedure Dict.49 (): - let Dict.749 : U32 = 1i64; - let Dict.750 : U8 = 8i64; - let Dict.748 : U32 = CallByName Num.72 Dict.749 Dict.750; - ret Dict.748; + let Dict.750 : U32 = 1i64; + let Dict.751 : U8 = 8i64; + let Dict.749 : U32 = CallByName Num.72 Dict.750 Dict.751; + ret Dict.749; procedure Dict.50 (): - let Dict.799 : U32 = CallByName Dict.49; - let Dict.800 : U32 = 1i64; - let Dict.798 : U32 = CallByName Num.75 Dict.799 Dict.800; - ret Dict.798; + let Dict.800 : U32 = CallByName Dict.49; + let Dict.801 : U32 = 1i64; + let Dict.799 : U32 = CallByName Num.75 Dict.800 Dict.801; + ret Dict.799; procedure Dict.51 (): - let Dict.899 : Float32 = 0.8f64; - ret Dict.899; + let Dict.900 : Float32 = 0.8f64; + ret Dict.900; procedure Dict.52 (): - let Dict.897 : U8 = 64i64; - let Dict.898 : U8 = 3i64; - let Dict.896 : U8 = CallByName Num.75 Dict.897 Dict.898; - ret Dict.896; + let Dict.898 : U8 = 64i64; + let Dict.899 : U8 = 3i64; + let Dict.897 : U8 = CallByName Num.75 Dict.898 Dict.899; + ret Dict.897; procedure Dict.53 (): - let Dict.842 : U64 = 1i64; - let Dict.843 : U8 = 32i64; - let Dict.841 : U64 = CallByName Num.72 Dict.842 Dict.843; - ret Dict.841; + let Dict.843 : U64 = 1i64; + let Dict.844 : U8 = 32i64; + let Dict.842 : U64 = CallByName Num.72 Dict.843 Dict.844; + ret Dict.842; procedure Dict.54 (): - let Dict.840 : U64 = CallByName Dict.53; - ret Dict.840; + let Dict.841 : U64 = CallByName Dict.53; + ret Dict.841; procedure Dict.55 (Dict.314): - let Dict.747 : U32 = CallByName Dict.49; - let Dict.746 : U32 = CallByName Num.51 Dict.314 Dict.747; - ret Dict.746; - -procedure Dict.66 (Dict.727): - let Dict.384 : List {Str, I64} = StructAtIndex 1 Dict.727; - let Dict.385 : U64 = StructAtIndex 2 Dict.727; - let Dict.386 : Float32 = StructAtIndex 3 Dict.727; - let Dict.387 : U8 = StructAtIndex 4 Dict.727; - let #Derived_gen.79 : List {U32, U32} = StructAtIndex 0 Dict.727; - dec #Derived_gen.79; - let Dict.885 : U64 = CallByName Dict.54; - let Dict.844 : Int1 = CallByName Bool.7 Dict.385 Dict.885; - if Dict.844 then - let Dict.884 : U8 = 1i64; - let Dict.388 : U8 = CallByName Num.75 Dict.387 Dict.884; - let Dict.863 : {List {U32, U32}, U64} = CallByName Dict.67 Dict.388 Dict.386; - let Dict.389 : List {U32, U32} = StructAtIndex 0 Dict.863; - let Dict.390 : U64 = StructAtIndex 1 Dict.863; - let Dict.391 : List {U32, U32} = CallByName Dict.71 Dict.389 Dict.384 Dict.388; - let Dict.845 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.391, Dict.384, Dict.390, Dict.386, Dict.388}; - ret Dict.845; + let Dict.748 : U32 = CallByName Dict.49; + let Dict.747 : U32 = CallByName Num.51 Dict.314 Dict.748; + ret Dict.747; + +procedure Dict.66 (Dict.728): + let Dict.385 : List {Str, I64} = StructAtIndex 1 Dict.728; + let Dict.386 : U64 = StructAtIndex 2 Dict.728; + let Dict.387 : Float32 = StructAtIndex 3 Dict.728; + let Dict.388 : U8 = StructAtIndex 4 Dict.728; + let #Derived_gen.71 : List {U32, U32} = StructAtIndex 0 Dict.728; + dec #Derived_gen.71; + let Dict.886 : U64 = CallByName Dict.54; + let Dict.845 : Int1 = CallByName Bool.7 Dict.386 Dict.886; + if Dict.845 then + let Dict.885 : U8 = 1i64; + let Dict.389 : U8 = CallByName Num.75 Dict.388 Dict.885; + let Dict.864 : {List {U32, U32}, U64} = CallByName Dict.67 Dict.389 Dict.387; + let Dict.390 : List {U32, U32} = StructAtIndex 0 Dict.864; + let Dict.391 : U64 = StructAtIndex 1 Dict.864; + let Dict.392 : List {U32, U32} = CallByName Dict.71 Dict.390 Dict.385 Dict.389; + let Dict.846 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = Struct {Dict.392, Dict.385, Dict.391, Dict.387, Dict.389}; + ret Dict.846; else - dec Dict.384; - let Dict.835 : Str = "Dict hit limit of "; - let Dict.839 : U64 = CallByName Dict.54; - let Dict.837 : Str = CallByName Num.96 Dict.839; - let Dict.838 : Str = " elements. Unable to grow more."; - let Dict.836 : Str = CallByName Str.3 Dict.837 Dict.838; - dec Dict.838; - let Dict.834 : Str = CallByName Str.3 Dict.835 Dict.836; - dec Dict.836; - Crash Dict.834 - -procedure Dict.67 (Dict.392, Dict.393): - let Dict.394 : U64 = CallByName Dict.70 Dict.392; - let Dict.877 : U64 = CallByName Dict.54; - let Dict.872 : Int1 = CallByName Bool.11 Dict.394 Dict.877; - if Dict.872 then - let Dict.875 : {U32, U32} = CallByName Dict.48; - let Dict.876 : U64 = CallByName Dict.54; - let Dict.874 : List {U32, U32} = CallByName List.11 Dict.875 Dict.876; + dec Dict.385; + let Dict.836 : Str = "Dict hit limit of "; + let Dict.840 : U64 = CallByName Dict.54; + let Dict.838 : Str = CallByName Num.96 Dict.840; + let Dict.839 : Str = " elements. Unable to grow more."; + let Dict.837 : Str = CallByName Str.3 Dict.838 Dict.839; + dec Dict.839; + let Dict.835 : Str = CallByName Str.3 Dict.836 Dict.837; + dec Dict.837; + Crash Dict.835 + +procedure Dict.67 (Dict.393, Dict.394): + let Dict.395 : U64 = CallByName Dict.70 Dict.393; + let Dict.878 : U64 = CallByName Dict.54; + let Dict.873 : Int1 = CallByName Bool.11 Dict.395 Dict.878; + if Dict.873 then + let Dict.876 : {U32, U32} = CallByName Dict.48; + let Dict.877 : U64 = CallByName Dict.54; + let Dict.875 : List {U32, U32} = CallByName List.11 Dict.876 Dict.877; let Dict.54 : U64 = CallByName Dict.54; - let Dict.873 : {List {U32, U32}, U64} = Struct {Dict.874, Dict.54}; - ret Dict.873; + let Dict.874 : {List {U32, U32}, U64} = Struct {Dict.875, Dict.54}; + ret Dict.874; else - let Dict.871 : Float32 = CallByName Num.139 Dict.394; - let Dict.870 : Float32 = CallByName Num.21 Dict.871 Dict.393; - let Dict.395 : U64 = CallByName Num.50 Dict.870; - let Dict.866 : {U32, U32} = CallByName Dict.48; - let Dict.865 : List {U32, U32} = CallByName List.11 Dict.866 Dict.394; - let Dict.864 : {List {U32, U32}, U64} = Struct {Dict.865, Dict.395}; - ret Dict.864; - -procedure Dict.70 (Dict.402): - let Dict.881 : U64 = 1i64; - let Dict.883 : U8 = 64i64; - let Dict.882 : U8 = CallByName Num.75 Dict.883 Dict.402; - let Dict.879 : U64 = CallByName Num.72 Dict.881 Dict.882; - let Dict.880 : U64 = CallByName Dict.54; - let Dict.878 : U64 = CallByName Num.148 Dict.879 Dict.880; - ret Dict.878; - -procedure Dict.71 (Dict.403, Dict.404, Dict.405): - let Dict.846 : List {U32, U32} = CallByName List.83 Dict.404 Dict.403 Dict.405; - ret Dict.846; - -procedure Dict.72 (Dict.412, Dict.413, Dict.414): - let Dict.415 : U64 = CallByName Dict.76 Dict.413; - let Dict.416 : U32 = CallByName Dict.77 Dict.415; - let Dict.417 : U64 = CallByName Dict.78 Dict.415 Dict.414; - let Dict.854 : {U64, U32} = CallByName Dict.73 Dict.412 Dict.417 Dict.416; - ret Dict.854; - -procedure Dict.73 (#Derived_gen.19, #Derived_gen.20, #Derived_gen.21): - joinpoint Dict.855 Dict.418 Dict.419 Dict.420: - let Dict.421 : {U32, U32} = CallByName Dict.22 Dict.418 Dict.419; - let Dict.862 : U32 = StructAtIndex 1 Dict.421; - let Dict.857 : Int1 = CallByName Num.22 Dict.420 Dict.862; - if Dict.857 then - let Dict.861 : U64 = CallByName List.6 Dict.418; - let Dict.859 : U64 = CallByName Dict.75 Dict.419 Dict.861; - let Dict.860 : U32 = CallByName Dict.55 Dict.420; - jump Dict.855 Dict.418 Dict.859 Dict.860; + let Dict.872 : Float32 = CallByName Num.139 Dict.395; + let Dict.871 : Float32 = CallByName Num.21 Dict.872 Dict.394; + let Dict.396 : U64 = CallByName Num.50 Dict.871; + let Dict.867 : {U32, U32} = CallByName Dict.48; + let Dict.866 : List {U32, U32} = CallByName List.11 Dict.867 Dict.395; + let Dict.865 : {List {U32, U32}, U64} = Struct {Dict.866, Dict.396}; + ret Dict.865; + +procedure Dict.70 (Dict.403): + let Dict.882 : U64 = 1i64; + let Dict.884 : U8 = 64i64; + let Dict.883 : U8 = CallByName Num.75 Dict.884 Dict.403; + let Dict.880 : U64 = CallByName Num.72 Dict.882 Dict.883; + let Dict.881 : U64 = CallByName Dict.54; + let Dict.879 : U64 = CallByName Num.148 Dict.880 Dict.881; + ret Dict.879; + +procedure Dict.71 (Dict.404, Dict.405, Dict.406): + let Dict.847 : List {U32, U32} = CallByName List.83 Dict.405 Dict.404 Dict.406; + ret Dict.847; + +procedure Dict.72 (Dict.413, Dict.414, Dict.415): + let Dict.416 : U64 = CallByName Dict.76 Dict.414; + let Dict.417 : U32 = CallByName Dict.77 Dict.416; + let Dict.418 : U64 = CallByName Dict.78 Dict.416 Dict.415; + let Dict.855 : {U64, U32} = CallByName Dict.73 Dict.413 Dict.418 Dict.417; + ret Dict.855; + +procedure Dict.73 (#Derived_gen.10, #Derived_gen.11, #Derived_gen.12): + joinpoint Dict.856 Dict.419 Dict.420 Dict.421: + let Dict.422 : {U32, U32} = CallByName Dict.22 Dict.419 Dict.420; + let Dict.863 : U32 = StructAtIndex 1 Dict.422; + let Dict.858 : Int1 = CallByName Num.22 Dict.421 Dict.863; + if Dict.858 then + let Dict.862 : U64 = CallByName List.6 Dict.419; + let Dict.860 : U64 = CallByName Dict.75 Dict.420 Dict.862; + let Dict.861 : U32 = CallByName Dict.55 Dict.421; + jump Dict.856 Dict.419 Dict.860 Dict.861; else - dec Dict.418; - let Dict.856 : {U64, U32} = Struct {Dict.419, Dict.420}; - ret Dict.856; + dec Dict.419; + let Dict.857 : {U64, U32} = Struct {Dict.420, Dict.421}; + ret Dict.857; in - inc #Derived_gen.19; - jump Dict.855 #Derived_gen.19 #Derived_gen.20 #Derived_gen.21; - -procedure Dict.74 (#Derived_gen.59, #Derived_gen.60, #Derived_gen.61): - joinpoint Dict.761 Dict.422 Dict.423 Dict.424: - let Dict.425 : {U32, U32} = CallByName Dict.22 Dict.422 Dict.424; - let Dict.771 : U32 = StructAtIndex 1 Dict.425; - let Dict.772 : U32 = 0i64; - let Dict.763 : Int1 = CallByName Bool.7 Dict.771 Dict.772; - if Dict.763 then - let Dict.426 : List {U32, U32} = CallByName List.3 Dict.422 Dict.424 Dict.423; - let Dict.768 : U32 = StructAtIndex 0 Dict.425; - let Dict.769 : U32 = StructAtIndex 1 Dict.425; - let Dict.770 : U32 = CallByName Dict.55 Dict.769; - let Dict.765 : {U32, U32} = Struct {Dict.768, Dict.770}; - let Dict.767 : U64 = CallByName List.6 Dict.426; - let Dict.766 : U64 = CallByName Dict.75 Dict.424 Dict.767; - jump Dict.761 Dict.426 Dict.765 Dict.766; + inc #Derived_gen.10; + jump Dict.856 #Derived_gen.10 #Derived_gen.11 #Derived_gen.12; + +procedure Dict.74 (#Derived_gen.48, #Derived_gen.49, #Derived_gen.50): + joinpoint Dict.762 Dict.423 Dict.424 Dict.425: + let Dict.426 : {U32, U32} = CallByName Dict.22 Dict.423 Dict.425; + let Dict.772 : U32 = StructAtIndex 1 Dict.426; + let Dict.773 : U32 = 0i64; + let Dict.764 : Int1 = CallByName Bool.7 Dict.772 Dict.773; + if Dict.764 then + let Dict.427 : List {U32, U32} = CallByName List.3 Dict.423 Dict.425 Dict.424; + let Dict.769 : U32 = StructAtIndex 0 Dict.426; + let Dict.770 : U32 = StructAtIndex 1 Dict.426; + let Dict.771 : U32 = CallByName Dict.55 Dict.770; + let Dict.766 : {U32, U32} = Struct {Dict.769, Dict.771}; + let Dict.768 : U64 = CallByName List.6 Dict.427; + let Dict.767 : U64 = CallByName Dict.75 Dict.425 Dict.768; + jump Dict.762 Dict.427 Dict.766 Dict.767; else - let Dict.762 : List {U32, U32} = CallByName List.3 Dict.422 Dict.424 Dict.423; - ret Dict.762; + let Dict.763 : List {U32, U32} = CallByName List.3 Dict.423 Dict.425 Dict.424; + ret Dict.763; in - jump Dict.761 #Derived_gen.59 #Derived_gen.60 #Derived_gen.61; - -procedure Dict.75 (Dict.427, Dict.428): - let Dict.757 : U64 = 1i64; - let Dict.756 : U64 = CallByName Num.51 Dict.427 Dict.757; - let Dict.753 : Int1 = CallByName Bool.7 Dict.756 Dict.428; - if Dict.753 then - let Dict.755 : U64 = 1i64; - let Dict.754 : U64 = CallByName Num.51 Dict.427 Dict.755; - ret Dict.754; + jump Dict.762 #Derived_gen.48 #Derived_gen.49 #Derived_gen.50; + +procedure Dict.75 (Dict.428, Dict.429): + let Dict.758 : U64 = 1i64; + let Dict.757 : U64 = CallByName Num.51 Dict.428 Dict.758; + let Dict.754 : Int1 = CallByName Bool.7 Dict.757 Dict.429; + if Dict.754 then + let Dict.756 : U64 = 1i64; + let Dict.755 : U64 = CallByName Num.51 Dict.428 Dict.756; + ret Dict.755; else - let Dict.752 : U64 = 0i64; - ret Dict.752; - -procedure Dict.76 (Dict.429): - let Dict.805 : [C , C U64] = TagId(0) ; - let Dict.804 : {U64, U64} = CallByName Dict.80 Dict.805; - let Dict.802 : {U64, U64} = CallByName Hash.19 Dict.804 Dict.429; - let Dict.801 : U64 = CallByName Dict.83 Dict.802; - ret Dict.801; - -procedure Dict.77 (Dict.431): - let Dict.796 : U32 = CallByName Num.131 Dict.431; - let Dict.797 : U32 = CallByName Dict.50; - let Dict.794 : U32 = CallByName Num.69 Dict.796 Dict.797; - let Dict.795 : U32 = CallByName Dict.49; - let Dict.793 : U32 = CallByName Num.71 Dict.794 Dict.795; + let Dict.753 : U64 = 0i64; + ret Dict.753; + +procedure Dict.76 (Dict.430): + let Dict.806 : [C , C U64] = TagId(0) ; + let Dict.805 : {U64, U64} = CallByName Dict.80 Dict.806; + let Dict.803 : {U64, U64} = CallByName Hash.19 Dict.805 Dict.430; + let Dict.802 : U64 = CallByName Dict.83 Dict.803; + ret Dict.802; + +procedure Dict.77 (Dict.432): + let Dict.797 : U32 = CallByName Num.131 Dict.432; + let Dict.798 : U32 = CallByName Dict.50; + let Dict.795 : U32 = CallByName Num.69 Dict.797 Dict.798; + let Dict.796 : U32 = CallByName Dict.49; + let Dict.794 : U32 = CallByName Num.71 Dict.795 Dict.796; + ret Dict.794; + +procedure Dict.78 (Dict.433, Dict.434): + let Dict.793 : U64 = CallByName Num.74 Dict.433 Dict.434; ret Dict.793; -procedure Dict.78 (Dict.432, Dict.433): - let Dict.792 : U64 = CallByName Num.74 Dict.432 Dict.433; - ret Dict.792; - procedure Dict.8 (Dict.217, Dict.218, Dict.219): - joinpoint Dict.832 Dict.830: - let Dict.220 : List {U32, U32} = StructAtIndex 0 Dict.830; - let Dict.221 : List {Str, I64} = StructAtIndex 1 Dict.830; - let Dict.222 : U64 = StructAtIndex 2 Dict.830; - let Dict.223 : Float32 = StructAtIndex 3 Dict.830; - let Dict.224 : U8 = StructAtIndex 4 Dict.830; + joinpoint Dict.833 Dict.831: + let Dict.220 : List {U32, U32} = StructAtIndex 0 Dict.831; + let Dict.221 : List {Str, I64} = StructAtIndex 1 Dict.831; + let Dict.222 : U64 = StructAtIndex 2 Dict.831; + let Dict.223 : Float32 = StructAtIndex 3 Dict.831; + let Dict.224 : U8 = StructAtIndex 4 Dict.831; inc Dict.218; let Dict.225 : U64 = CallByName Dict.76 Dict.218; let Dict.226 : U32 = CallByName Dict.77 Dict.225; let Dict.227 : U64 = CallByName Dict.78 Dict.225 Dict.224; - let Dict.743 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.45 Dict.220 Dict.221 Dict.227 Dict.226 Dict.218 Dict.219 Dict.222 Dict.223 Dict.224; + let Dict.744 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.45 Dict.220 Dict.221 Dict.227 Dict.226 Dict.218 Dict.219 Dict.222 Dict.223 Dict.224; dec Dict.218; - ret Dict.743; + ret Dict.744; in inc 2 Dict.217; - let Dict.887 : U64 = CallByName Dict.4 Dict.217; - let Dict.888 : U64 = CallByName Dict.20 Dict.217; - let Dict.886 : Int1 = CallByName Num.22 Dict.887 Dict.888; - if Dict.886 then - jump Dict.832 Dict.217; + let Dict.888 : U64 = CallByName Dict.4 Dict.217; + let Dict.889 : U64 = CallByName Dict.20 Dict.217; + let Dict.887 : Int1 = CallByName Num.22 Dict.888 Dict.889; + if Dict.887 then + jump Dict.833 Dict.217; else - let Dict.831 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.66 Dict.217; - jump Dict.832 Dict.831; - -procedure Dict.80 (Dict.435): - joinpoint Dict.822 Dict.436: - let Dict.807 : U64 = CallByName Dict.82 Dict.436; - let Dict.806 : {U64, U64} = Struct {Dict.807, Dict.436}; - ret Dict.806; + let Dict.832 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.66 Dict.217; + jump Dict.833 Dict.832; + +procedure Dict.80 (Dict.436): + joinpoint Dict.823 Dict.437: + let Dict.808 : U64 = CallByName Dict.82 Dict.437; + let Dict.807 : {U64, U64} = Struct {Dict.808, Dict.437}; + ret Dict.807; in - let Dict.827 : U8 = 0i64; - let Dict.828 : U8 = GetTagId Dict.435; - let Dict.829 : Int1 = lowlevel Eq Dict.827 Dict.828; - if Dict.829 then - let Dict.824 : {} = Struct {}; - let Dict.823 : U64 = CallByName Dict.23 Dict.824; - jump Dict.822 Dict.823; + let Dict.828 : U8 = 0i64; + let Dict.829 : U8 = GetTagId Dict.436; + let Dict.830 : Int1 = lowlevel Eq Dict.828 Dict.829; + if Dict.830 then + let Dict.825 : {} = Struct {}; + let Dict.824 : U64 = CallByName Dict.23 Dict.825; + jump Dict.823 Dict.824; else - let Dict.437 : U64 = UnionAtIndex (Id 1) (Index 0) Dict.435; - jump Dict.822 Dict.437; - -procedure Dict.81 (Dict.716, Dict.717): - let Dict.440 : U64 = StructAtIndex 0 Dict.717; - let Dict.441 : U64 = StructAtIndex 1 Dict.717; - let Dict.443 : U64 = StructAtIndex 2 Dict.717; - let Dict.442 : U64 = StructAtIndex 3 Dict.717; - let Dict.438 : U64 = StructAtIndex 0 Dict.716; - let Dict.439 : U64 = StructAtIndex 1 Dict.716; - let Dict.921 : U64 = CallByName Dict.93; - let Dict.919 : U64 = CallByName Num.70 Dict.440 Dict.921; - let Dict.920 : U64 = CallByName Num.70 Dict.441 Dict.442; - let Dict.444 : {U64, U64} = CallByName Dict.97 Dict.919 Dict.920; - let Dict.916 : U64 = StructAtIndex 0 Dict.444; - let Dict.917 : U64 = CallByName Dict.92; - let Dict.915 : U64 = CallByName Num.70 Dict.916 Dict.917; - let Dict.445 : U64 = CallByName Num.70 Dict.915 Dict.443; - let Dict.912 : U64 = StructAtIndex 1 Dict.444; - let Dict.913 : U64 = CallByName Dict.93; - let Dict.446 : U64 = CallByName Num.70 Dict.912 Dict.913; - let Dict.447 : U64 = CallByName Dict.96 Dict.445 Dict.446; - let Dict.904 : U64 = CallByName Dict.96 Dict.439 Dict.447; - let Dict.903 : {U64, U64} = Struct {Dict.438, Dict.904}; - ret Dict.903; - -procedure Dict.82 (Dict.448): - let Dict.820 : U64 = CallByName Dict.92; - let Dict.810 : U64 = CallByName Num.70 Dict.448 Dict.820; - let Dict.811 : U64 = CallByName Dict.93; - let Dict.809 : U64 = CallByName Dict.96 Dict.810 Dict.811; - let Dict.808 : U64 = CallByName Num.70 Dict.809 Dict.448; - ret Dict.808; - -procedure Dict.83 (Dict.735): - let Dict.449 : U64 = StructAtIndex 1 Dict.735; - ret Dict.449; - -procedure Dict.89 (Dict.710, Dict.488): - let Dict.486 : U64 = StructAtIndex 0 Dict.710; - let Dict.487 : U64 = StructAtIndex 1 Dict.710; - let Dict.489 : U64 = CallByName List.6 Dict.488; - joinpoint Dict.926 Dict.490: - let Dict.901 : {U64, U64} = Struct {Dict.486, Dict.487}; - let Dict.922 : U64 = StructAtIndex 0 Dict.490; - let Dict.923 : U64 = StructAtIndex 1 Dict.490; - let Dict.924 : U64 = StructAtIndex 2 Dict.490; - let Dict.902 : {U64, U64, U64, U64} = Struct {Dict.922, Dict.923, Dict.489, Dict.924}; - let Dict.900 : {U64, U64} = CallByName Dict.81 Dict.901 Dict.902; - ret Dict.900; + let Dict.438 : U64 = UnionAtIndex (Id 1) (Index 0) Dict.436; + jump Dict.823 Dict.438; + +procedure Dict.81 (Dict.717, Dict.718): + let Dict.441 : U64 = StructAtIndex 0 Dict.718; + let Dict.442 : U64 = StructAtIndex 1 Dict.718; + let Dict.444 : U64 = StructAtIndex 2 Dict.718; + let Dict.443 : U64 = StructAtIndex 3 Dict.718; + let Dict.439 : U64 = StructAtIndex 0 Dict.717; + let Dict.440 : U64 = StructAtIndex 1 Dict.717; + let Dict.922 : U64 = CallByName Dict.93; + let Dict.920 : U64 = CallByName Num.70 Dict.441 Dict.922; + let Dict.921 : U64 = CallByName Num.70 Dict.442 Dict.443; + let Dict.445 : {U64, U64} = CallByName Dict.97 Dict.920 Dict.921; + let Dict.917 : U64 = StructAtIndex 0 Dict.445; + let Dict.918 : U64 = CallByName Dict.92; + let Dict.916 : U64 = CallByName Num.70 Dict.917 Dict.918; + let Dict.446 : U64 = CallByName Num.70 Dict.916 Dict.444; + let Dict.913 : U64 = StructAtIndex 1 Dict.445; + let Dict.914 : U64 = CallByName Dict.93; + let Dict.447 : U64 = CallByName Num.70 Dict.913 Dict.914; + let Dict.448 : U64 = CallByName Dict.96 Dict.446 Dict.447; + let Dict.905 : U64 = CallByName Dict.96 Dict.440 Dict.448; + let Dict.904 : {U64, U64} = Struct {Dict.439, Dict.905}; + ret Dict.904; + +procedure Dict.82 (Dict.449): + let Dict.821 : U64 = CallByName Dict.92; + let Dict.811 : U64 = CallByName Num.70 Dict.449 Dict.821; + let Dict.812 : U64 = CallByName Dict.93; + let Dict.810 : U64 = CallByName Dict.96 Dict.811 Dict.812; + let Dict.809 : U64 = CallByName Num.70 Dict.810 Dict.449; + ret Dict.809; + +procedure Dict.83 (Dict.736): + let Dict.450 : U64 = StructAtIndex 1 Dict.736; + ret Dict.450; + +procedure Dict.89 (Dict.711, Dict.489): + let Dict.487 : U64 = StructAtIndex 0 Dict.711; + let Dict.488 : U64 = StructAtIndex 1 Dict.711; + let Dict.490 : U64 = CallByName List.6 Dict.489; + joinpoint Dict.927 Dict.491: + let Dict.902 : {U64, U64} = Struct {Dict.487, Dict.488}; + let Dict.923 : U64 = StructAtIndex 0 Dict.491; + let Dict.924 : U64 = StructAtIndex 1 Dict.491; + let Dict.925 : U64 = StructAtIndex 2 Dict.491; + let Dict.903 : {U64, U64, U64, U64} = Struct {Dict.923, Dict.924, Dict.490, Dict.925}; + let Dict.901 : {U64, U64} = CallByName Dict.81 Dict.902 Dict.903; + ret Dict.901; in - let Dict.1100 : U64 = 16i64; - let Dict.1040 : Int1 = CallByName Num.23 Dict.489 Dict.1100; - if Dict.1040 then - joinpoint Dict.1042 Dict.925: - jump Dict.926 Dict.925; + let Dict.1101 : U64 = 16i64; + let Dict.1041 : Int1 = CallByName Num.23 Dict.490 Dict.1101; + if Dict.1041 then + joinpoint Dict.1043 Dict.926: + jump Dict.927 Dict.926; in - let Dict.1099 : U64 = 4i64; - let Dict.1064 : Int1 = CallByName Num.25 Dict.489 Dict.1099; - if Dict.1064 then - let Dict.1098 : U8 = 3i64; - let Dict.1096 : U64 = CallByName Num.74 Dict.489 Dict.1098; - let Dict.1097 : U8 = 2i64; - let Dict.491 : U64 = CallByName Num.72 Dict.1096 Dict.1097; - let Dict.1095 : U64 = 0i64; - let Dict.1093 : U64 = CallByName Dict.99 Dict.488 Dict.1095; - let Dict.1094 : U8 = 32i64; - let Dict.1091 : U64 = CallByName Num.72 Dict.1093 Dict.1094; - let Dict.1092 : U64 = CallByName Dict.99 Dict.488 Dict.491; - let Dict.492 : U64 = CallByName Num.71 Dict.1091 Dict.1092; - let Dict.1090 : U64 = 4i64; - let Dict.1089 : U64 = CallByName Num.75 Dict.489 Dict.1090; - let Dict.1087 : U64 = CallByName Dict.99 Dict.488 Dict.1089; - let Dict.1088 : U8 = 32i64; - let Dict.1065 : U64 = CallByName Num.72 Dict.1087 Dict.1088; - let Dict.1086 : U64 = 4i64; - let Dict.1085 : U64 = CallByName Num.75 Dict.489 Dict.1086; - let Dict.1067 : U64 = CallByName Num.75 Dict.1085 Dict.491; - let Dict.1066 : U64 = CallByName Dict.99 Dict.488 Dict.1067; - let Dict.493 : U64 = CallByName Num.71 Dict.1065 Dict.1066; - let Dict.1041 : {U64, U64, U64} = Struct {Dict.492, Dict.493, Dict.486}; - jump Dict.1042 Dict.1041; + let Dict.1100 : U64 = 4i64; + let Dict.1065 : Int1 = CallByName Num.25 Dict.490 Dict.1100; + if Dict.1065 then + let Dict.1099 : U8 = 3i64; + let Dict.1097 : U64 = CallByName Num.74 Dict.490 Dict.1099; + let Dict.1098 : U8 = 2i64; + let Dict.492 : U64 = CallByName Num.72 Dict.1097 Dict.1098; + let Dict.1096 : U64 = 0i64; + let Dict.1094 : U64 = CallByName Dict.99 Dict.489 Dict.1096; + let Dict.1095 : U8 = 32i64; + let Dict.1092 : U64 = CallByName Num.72 Dict.1094 Dict.1095; + let Dict.1093 : U64 = CallByName Dict.99 Dict.489 Dict.492; + let Dict.493 : U64 = CallByName Num.71 Dict.1092 Dict.1093; + let Dict.1091 : U64 = 4i64; + let Dict.1090 : U64 = CallByName Num.75 Dict.490 Dict.1091; + let Dict.1088 : U64 = CallByName Dict.99 Dict.489 Dict.1090; + let Dict.1089 : U8 = 32i64; + let Dict.1066 : U64 = CallByName Num.72 Dict.1088 Dict.1089; + let Dict.1087 : U64 = 4i64; + let Dict.1086 : U64 = CallByName Num.75 Dict.490 Dict.1087; + let Dict.1068 : U64 = CallByName Num.75 Dict.1086 Dict.492; + let Dict.1067 : U64 = CallByName Dict.99 Dict.489 Dict.1068; + let Dict.494 : U64 = CallByName Num.71 Dict.1066 Dict.1067; + let Dict.1042 : {U64, U64, U64} = Struct {Dict.493, Dict.494, Dict.487}; + jump Dict.1043 Dict.1042; else - let Dict.1063 : U64 = 0i64; - let Dict.1045 : Int1 = CallByName Num.24 Dict.489 Dict.1063; - if Dict.1045 then + let Dict.1064 : U64 = 0i64; + let Dict.1046 : Int1 = CallByName Num.24 Dict.490 Dict.1064; + if Dict.1046 then + let Dict.1049 : U64 = 0i64; + let Dict.1047 : U64 = CallByName Dict.100 Dict.489 Dict.1049 Dict.490; let Dict.1048 : U64 = 0i64; - let Dict.1046 : U64 = CallByName Dict.100 Dict.488 Dict.1048 Dict.489; - let Dict.1047 : U64 = 0i64; - let Dict.1041 : {U64, U64, U64} = Struct {Dict.1046, Dict.1047, Dict.486}; - jump Dict.1042 Dict.1041; + let Dict.1042 : {U64, U64, U64} = Struct {Dict.1047, Dict.1048, Dict.487}; + jump Dict.1043 Dict.1042; else - let Dict.1043 : U64 = 0i64; let Dict.1044 : U64 = 0i64; - let Dict.1041 : {U64, U64, U64} = Struct {Dict.1043, Dict.1044, Dict.486}; - jump Dict.1042 Dict.1041; + let Dict.1045 : U64 = 0i64; + let Dict.1042 : {U64, U64, U64} = Struct {Dict.1044, Dict.1045, Dict.487}; + jump Dict.1043 Dict.1042; else - let Dict.1039 : U64 = 48i64; - let Dict.1037 : Int1 = CallByName Num.23 Dict.489 Dict.1039; - if Dict.1037 then - let Dict.1038 : U64 = 0i64; - let Dict.925 : {U64, U64, U64} = CallByName Dict.91 Dict.486 Dict.488 Dict.1038 Dict.489; - jump Dict.926 Dict.925; + let Dict.1040 : U64 = 48i64; + let Dict.1038 : Int1 = CallByName Num.23 Dict.490 Dict.1040; + if Dict.1038 then + let Dict.1039 : U64 = 0i64; + let Dict.926 : {U64, U64, U64} = CallByName Dict.91 Dict.487 Dict.489 Dict.1039 Dict.490; + jump Dict.927 Dict.926; else - let Dict.927 : U64 = 0i64; - let Dict.925 : {U64, U64, U64} = CallByName Dict.90 Dict.486 Dict.486 Dict.486 Dict.488 Dict.927 Dict.489; - jump Dict.926 Dict.925; - -procedure Dict.90 (#Derived_gen.9, #Derived_gen.10, #Derived_gen.11, #Derived_gen.12, #Derived_gen.13, #Derived_gen.14): - joinpoint Dict.928 Dict.494 Dict.495 Dict.496 Dict.497 Dict.498 Dict.499: - let Dict.1035 : U64 = CallByName Dict.98 Dict.497 Dict.498; - let Dict.1036 : U64 = CallByName Dict.93; - let Dict.1030 : U64 = CallByName Num.70 Dict.1035 Dict.1036; - let Dict.1034 : U64 = 8i64; - let Dict.1033 : U64 = CallByName Num.51 Dict.498 Dict.1034; - let Dict.1032 : U64 = CallByName Dict.98 Dict.497 Dict.1033; - let Dict.1031 : U64 = CallByName Num.70 Dict.1032 Dict.494; - let Dict.500 : U64 = CallByName Dict.96 Dict.1030 Dict.1031; - let Dict.1029 : U64 = 16i64; - let Dict.1028 : U64 = CallByName Num.51 Dict.498 Dict.1029; - let Dict.1025 : U64 = CallByName Dict.98 Dict.497 Dict.1028; - let Dict.1026 : U64 = CallByName Dict.94; - let Dict.1020 : U64 = CallByName Num.70 Dict.1025 Dict.1026; - let Dict.1024 : U64 = 24i64; - let Dict.1023 : U64 = CallByName Num.51 Dict.498 Dict.1024; - let Dict.1022 : U64 = CallByName Dict.98 Dict.497 Dict.1023; - let Dict.1021 : U64 = CallByName Num.70 Dict.1022 Dict.495; - let Dict.501 : U64 = CallByName Dict.96 Dict.1020 Dict.1021; - let Dict.1019 : U64 = 32i64; - let Dict.1018 : U64 = CallByName Num.51 Dict.498 Dict.1019; - let Dict.1015 : U64 = CallByName Dict.98 Dict.497 Dict.1018; - let Dict.1016 : U64 = CallByName Dict.95; - let Dict.1010 : U64 = CallByName Num.70 Dict.1015 Dict.1016; - let Dict.1014 : U64 = 40i64; - let Dict.1013 : U64 = CallByName Num.51 Dict.498 Dict.1014; - let Dict.1012 : U64 = CallByName Dict.98 Dict.497 Dict.1013; - let Dict.1011 : U64 = CallByName Num.70 Dict.1012 Dict.496; - let Dict.502 : U64 = CallByName Dict.96 Dict.1010 Dict.1011; + let Dict.928 : U64 = 0i64; + let Dict.926 : {U64, U64, U64} = CallByName Dict.90 Dict.487 Dict.487 Dict.487 Dict.489 Dict.928 Dict.490; + jump Dict.927 Dict.926; + +procedure Dict.90 (#Derived_gen.4, #Derived_gen.5, #Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9): + joinpoint Dict.929 Dict.495 Dict.496 Dict.497 Dict.498 Dict.499 Dict.500: + let Dict.1036 : U64 = CallByName Dict.98 Dict.498 Dict.499; + let Dict.1037 : U64 = CallByName Dict.93; + let Dict.1031 : U64 = CallByName Num.70 Dict.1036 Dict.1037; + let Dict.1035 : U64 = 8i64; + let Dict.1034 : U64 = CallByName Num.51 Dict.499 Dict.1035; + let Dict.1033 : U64 = CallByName Dict.98 Dict.498 Dict.1034; + let Dict.1032 : U64 = CallByName Num.70 Dict.1033 Dict.495; + let Dict.501 : U64 = CallByName Dict.96 Dict.1031 Dict.1032; + let Dict.1030 : U64 = 16i64; + let Dict.1029 : U64 = CallByName Num.51 Dict.499 Dict.1030; + let Dict.1026 : U64 = CallByName Dict.98 Dict.498 Dict.1029; + let Dict.1027 : U64 = CallByName Dict.94; + let Dict.1021 : U64 = CallByName Num.70 Dict.1026 Dict.1027; + let Dict.1025 : U64 = 24i64; + let Dict.1024 : U64 = CallByName Num.51 Dict.499 Dict.1025; + let Dict.1023 : U64 = CallByName Dict.98 Dict.498 Dict.1024; + let Dict.1022 : U64 = CallByName Num.70 Dict.1023 Dict.496; + let Dict.502 : U64 = CallByName Dict.96 Dict.1021 Dict.1022; + let Dict.1020 : U64 = 32i64; + let Dict.1019 : U64 = CallByName Num.51 Dict.499 Dict.1020; + let Dict.1016 : U64 = CallByName Dict.98 Dict.498 Dict.1019; + let Dict.1017 : U64 = CallByName Dict.95; + let Dict.1011 : U64 = CallByName Num.70 Dict.1016 Dict.1017; + let Dict.1015 : U64 = 40i64; + let Dict.1014 : U64 = CallByName Num.51 Dict.499 Dict.1015; + let Dict.1013 : U64 = CallByName Dict.98 Dict.498 Dict.1014; + let Dict.1012 : U64 = CallByName Num.70 Dict.1013 Dict.497; + let Dict.503 : U64 = CallByName Dict.96 Dict.1011 Dict.1012; + let Dict.1010 : U64 = 48i64; + let Dict.504 : U64 = CallByName Num.75 Dict.500 Dict.1010; let Dict.1009 : U64 = 48i64; - let Dict.503 : U64 = CallByName Num.75 Dict.499 Dict.1009; + let Dict.505 : U64 = CallByName Num.51 Dict.499 Dict.1009; let Dict.1008 : U64 = 48i64; - let Dict.504 : U64 = CallByName Num.51 Dict.498 Dict.1008; - let Dict.1007 : U64 = 48i64; - let Dict.1005 : Int1 = CallByName Num.24 Dict.503 Dict.1007; - if Dict.1005 then - jump Dict.928 Dict.500 Dict.501 Dict.502 Dict.497 Dict.504 Dict.503; + let Dict.1006 : Int1 = CallByName Num.24 Dict.504 Dict.1008; + if Dict.1006 then + jump Dict.929 Dict.501 Dict.502 Dict.503 Dict.498 Dict.505 Dict.504; else - let Dict.1004 : U64 = 16i64; - let Dict.979 : Int1 = CallByName Num.24 Dict.503 Dict.1004; - if Dict.979 then - let Dict.1003 : U64 = CallByName Num.70 Dict.501 Dict.500; - let Dict.505 : U64 = CallByName Num.70 Dict.502 Dict.1003; - let Dict.980 : {U64, U64, U64} = CallByName Dict.91 Dict.505 Dict.497 Dict.504 Dict.503; - dec Dict.497; - ret Dict.980; + let Dict.1005 : U64 = 16i64; + let Dict.980 : Int1 = CallByName Num.24 Dict.504 Dict.1005; + if Dict.980 then + let Dict.1004 : U64 = CallByName Num.70 Dict.502 Dict.501; + let Dict.506 : U64 = CallByName Num.70 Dict.503 Dict.1004; + let Dict.981 : {U64, U64, U64} = CallByName Dict.91 Dict.506 Dict.498 Dict.505 Dict.504; + dec Dict.498; + ret Dict.981; else - let Dict.978 : U64 = CallByName Num.70 Dict.501 Dict.500; - let Dict.506 : U64 = CallByName Num.70 Dict.502 Dict.978; - let Dict.977 : U64 = 16i64; - let Dict.976 : U64 = CallByName Num.75 Dict.503 Dict.977; - let Dict.975 : U64 = CallByName Num.51 Dict.976 Dict.504; - let Dict.930 : U64 = CallByName Dict.98 Dict.497 Dict.975; - let Dict.974 : U64 = 8i64; - let Dict.973 : U64 = CallByName Num.75 Dict.503 Dict.974; - let Dict.932 : U64 = CallByName Num.51 Dict.973 Dict.504; - let Dict.931 : U64 = CallByName Dict.98 Dict.497 Dict.932; - dec Dict.497; - let Dict.929 : {U64, U64, U64} = Struct {Dict.930, Dict.931, Dict.506}; - ret Dict.929; + let Dict.979 : U64 = CallByName Num.70 Dict.502 Dict.501; + let Dict.507 : U64 = CallByName Num.70 Dict.503 Dict.979; + let Dict.978 : U64 = 16i64; + let Dict.977 : U64 = CallByName Num.75 Dict.504 Dict.978; + let Dict.976 : U64 = CallByName Num.51 Dict.977 Dict.505; + let Dict.931 : U64 = CallByName Dict.98 Dict.498 Dict.976; + let Dict.975 : U64 = 8i64; + let Dict.974 : U64 = CallByName Num.75 Dict.504 Dict.975; + let Dict.933 : U64 = CallByName Num.51 Dict.974 Dict.505; + let Dict.932 : U64 = CallByName Dict.98 Dict.498 Dict.933; + dec Dict.498; + let Dict.930 : {U64, U64, U64} = Struct {Dict.931, Dict.932, Dict.507}; + ret Dict.930; in - inc #Derived_gen.12; - jump Dict.928 #Derived_gen.9 #Derived_gen.10 #Derived_gen.11 #Derived_gen.12 #Derived_gen.13 #Derived_gen.14; - -procedure Dict.91 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4): - joinpoint Dict.981 Dict.507 Dict.508 Dict.509 Dict.510: - let Dict.1001 : U64 = CallByName Dict.98 Dict.508 Dict.509; - let Dict.1002 : U64 = CallByName Dict.93; - let Dict.996 : U64 = CallByName Num.70 Dict.1001 Dict.1002; - let Dict.1000 : U64 = 8i64; - let Dict.999 : U64 = CallByName Num.51 Dict.509 Dict.1000; - let Dict.998 : U64 = CallByName Dict.98 Dict.508 Dict.999; - let Dict.997 : U64 = CallByName Num.70 Dict.998 Dict.507; - let Dict.511 : U64 = CallByName Dict.96 Dict.996 Dict.997; + inc #Derived_gen.7; + jump Dict.929 #Derived_gen.4 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9; + +procedure Dict.91 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3): + joinpoint Dict.982 Dict.508 Dict.509 Dict.510 Dict.511: + let Dict.1002 : U64 = CallByName Dict.98 Dict.509 Dict.510; + let Dict.1003 : U64 = CallByName Dict.93; + let Dict.997 : U64 = CallByName Num.70 Dict.1002 Dict.1003; + let Dict.1001 : U64 = 8i64; + let Dict.1000 : U64 = CallByName Num.51 Dict.510 Dict.1001; + let Dict.999 : U64 = CallByName Dict.98 Dict.509 Dict.1000; + let Dict.998 : U64 = CallByName Num.70 Dict.999 Dict.508; + let Dict.512 : U64 = CallByName Dict.96 Dict.997 Dict.998; + let Dict.996 : U64 = 16i64; + let Dict.513 : U64 = CallByName Num.75 Dict.511 Dict.996; let Dict.995 : U64 = 16i64; - let Dict.512 : U64 = CallByName Num.75 Dict.510 Dict.995; + let Dict.514 : U64 = CallByName Num.51 Dict.510 Dict.995; let Dict.994 : U64 = 16i64; - let Dict.513 : U64 = CallByName Num.51 Dict.509 Dict.994; - let Dict.993 : U64 = 16i64; - let Dict.983 : Int1 = CallByName Num.23 Dict.512 Dict.993; - if Dict.983 then - let Dict.992 : U64 = 16i64; - let Dict.991 : U64 = CallByName Num.75 Dict.512 Dict.992; - let Dict.990 : U64 = CallByName Num.51 Dict.991 Dict.513; - let Dict.985 : U64 = CallByName Dict.98 Dict.508 Dict.990; - let Dict.989 : U64 = 8i64; - let Dict.988 : U64 = CallByName Num.75 Dict.512 Dict.989; - let Dict.987 : U64 = CallByName Num.51 Dict.988 Dict.513; - let Dict.986 : U64 = CallByName Dict.98 Dict.508 Dict.987; - dec Dict.508; - let Dict.984 : {U64, U64, U64} = Struct {Dict.985, Dict.986, Dict.511}; - ret Dict.984; + let Dict.984 : Int1 = CallByName Num.23 Dict.513 Dict.994; + if Dict.984 then + let Dict.993 : U64 = 16i64; + let Dict.992 : U64 = CallByName Num.75 Dict.513 Dict.993; + let Dict.991 : U64 = CallByName Num.51 Dict.992 Dict.514; + let Dict.986 : U64 = CallByName Dict.98 Dict.509 Dict.991; + let Dict.990 : U64 = 8i64; + let Dict.989 : U64 = CallByName Num.75 Dict.513 Dict.990; + let Dict.988 : U64 = CallByName Num.51 Dict.989 Dict.514; + let Dict.987 : U64 = CallByName Dict.98 Dict.509 Dict.988; + dec Dict.509; + let Dict.985 : {U64, U64, U64} = Struct {Dict.986, Dict.987, Dict.512}; + ret Dict.985; else - jump Dict.981 Dict.511 Dict.508 Dict.513 Dict.512; + jump Dict.982 Dict.512 Dict.509 Dict.514 Dict.513; in - inc #Derived_gen.2; - jump Dict.981 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4; + inc #Derived_gen.1; + jump Dict.982 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3; procedure Dict.92 (): - let Dict.918 : U64 = 11562461410679940143i64; - ret Dict.918; + let Dict.919 : U64 = 11562461410679940143i64; + ret Dict.919; procedure Dict.93 (): - let Dict.914 : U64 = 16646288086500911323i64; - ret Dict.914; + let Dict.915 : U64 = 16646288086500911323i64; + ret Dict.915; procedure Dict.94 (): - let Dict.1027 : U64 = 10285213230658275043i64; - ret Dict.1027; + let Dict.1028 : U64 = 10285213230658275043i64; + ret Dict.1028; procedure Dict.95 (): - let Dict.1017 : U64 = 6384245875588680899i64; - ret Dict.1017; - -procedure Dict.96 (Dict.514, Dict.515): - let Dict.906 : {U64, U64} = CallByName Dict.97 Dict.514 Dict.515; - let Dict.516 : U64 = StructAtIndex 0 Dict.906; - let Dict.517 : U64 = StructAtIndex 1 Dict.906; - let Dict.905 : U64 = CallByName Num.70 Dict.516 Dict.517; - ret Dict.905; - -procedure Dict.97 (Dict.518, Dict.519): - let Dict.910 : U128 = CallByName Num.135 Dict.518; + let Dict.1018 : U64 = 6384245875588680899i64; + ret Dict.1018; + +procedure Dict.96 (Dict.515, Dict.516): + let Dict.907 : {U64, U64} = CallByName Dict.97 Dict.515 Dict.516; + let Dict.517 : U64 = StructAtIndex 0 Dict.907; + let Dict.518 : U64 = StructAtIndex 1 Dict.907; + let Dict.906 : U64 = CallByName Num.70 Dict.517 Dict.518; + ret Dict.906; + +procedure Dict.97 (Dict.519, Dict.520): let Dict.911 : U128 = CallByName Num.135 Dict.519; - let Dict.520 : U128 = CallByName Num.78 Dict.910 Dict.911; - let Dict.521 : U64 = CallByName Num.133 Dict.520; - let Dict.909 : U8 = 64i64; - let Dict.908 : U128 = CallByName Num.74 Dict.520 Dict.909; - let Dict.522 : U64 = CallByName Num.133 Dict.908; - let Dict.907 : {U64, U64} = Struct {Dict.521, Dict.522}; - ret Dict.907; - -procedure Dict.98 (Dict.523, Dict.524): - let Dict.972 : U8 = CallByName Dict.22 Dict.523 Dict.524; - let Dict.525 : U64 = CallByName Num.133 Dict.972; - let Dict.971 : U64 = 1i64; - let Dict.970 : U64 = CallByName Num.51 Dict.524 Dict.971; - let Dict.969 : U8 = CallByName Dict.22 Dict.523 Dict.970; - let Dict.526 : U64 = CallByName Num.133 Dict.969; - let Dict.968 : U64 = 2i64; - let Dict.967 : U64 = CallByName Num.51 Dict.524 Dict.968; - let Dict.966 : U8 = CallByName Dict.22 Dict.523 Dict.967; - let Dict.527 : U64 = CallByName Num.133 Dict.966; - let Dict.965 : U64 = 3i64; - let Dict.964 : U64 = CallByName Num.51 Dict.524 Dict.965; - let Dict.963 : U8 = CallByName Dict.22 Dict.523 Dict.964; - let Dict.528 : U64 = CallByName Num.133 Dict.963; - let Dict.962 : U64 = 4i64; - let Dict.961 : U64 = CallByName Num.51 Dict.524 Dict.962; - let Dict.960 : U8 = CallByName Dict.22 Dict.523 Dict.961; - let Dict.529 : U64 = CallByName Num.133 Dict.960; - let Dict.959 : U64 = 5i64; - let Dict.958 : U64 = CallByName Num.51 Dict.524 Dict.959; - let Dict.957 : U8 = CallByName Dict.22 Dict.523 Dict.958; - let Dict.530 : U64 = CallByName Num.133 Dict.957; - let Dict.956 : U64 = 6i64; - let Dict.955 : U64 = CallByName Num.51 Dict.524 Dict.956; - let Dict.954 : U8 = CallByName Dict.22 Dict.523 Dict.955; - let Dict.531 : U64 = CallByName Num.133 Dict.954; - let Dict.953 : U64 = 7i64; - let Dict.951 : U64 = CallByName Num.51 Dict.524 Dict.953; - let Dict.950 : U8 = CallByName Dict.22 Dict.523 Dict.951; - let Dict.532 : U64 = CallByName Num.133 Dict.950; - let Dict.949 : U8 = 8i64; - let Dict.948 : U64 = CallByName Num.72 Dict.526 Dict.949; - let Dict.533 : U64 = CallByName Num.71 Dict.525 Dict.948; - let Dict.947 : U8 = 16i64; - let Dict.944 : U64 = CallByName Num.72 Dict.527 Dict.947; - let Dict.946 : U8 = 24i64; - let Dict.945 : U64 = CallByName Num.72 Dict.528 Dict.946; - let Dict.534 : U64 = CallByName Num.71 Dict.944 Dict.945; - let Dict.943 : U8 = 32i64; - let Dict.940 : U64 = CallByName Num.72 Dict.529 Dict.943; - let Dict.942 : U8 = 40i64; - let Dict.941 : U64 = CallByName Num.72 Dict.530 Dict.942; - let Dict.535 : U64 = CallByName Num.71 Dict.940 Dict.941; - let Dict.939 : U8 = 48i64; - let Dict.936 : U64 = CallByName Num.72 Dict.531 Dict.939; - let Dict.938 : U8 = 56i64; - let Dict.937 : U64 = CallByName Num.72 Dict.532 Dict.938; - let Dict.536 : U64 = CallByName Num.71 Dict.936 Dict.937; - let Dict.934 : U64 = CallByName Num.71 Dict.533 Dict.534; - let Dict.935 : U64 = CallByName Num.71 Dict.535 Dict.536; - let Dict.933 : U64 = CallByName Num.71 Dict.934 Dict.935; - ret Dict.933; - -procedure Dict.99 (Dict.537, Dict.538): - let Dict.1084 : U8 = CallByName Dict.22 Dict.537 Dict.538; - let Dict.539 : U64 = CallByName Num.133 Dict.1084; - let Dict.1083 : U64 = 1i64; - let Dict.1082 : U64 = CallByName Num.51 Dict.538 Dict.1083; - let Dict.1081 : U8 = CallByName Dict.22 Dict.537 Dict.1082; - let Dict.540 : U64 = CallByName Num.133 Dict.1081; - let Dict.1080 : U64 = 2i64; - let Dict.1079 : U64 = CallByName Num.51 Dict.538 Dict.1080; - let Dict.1078 : U8 = CallByName Dict.22 Dict.537 Dict.1079; - let Dict.541 : U64 = CallByName Num.133 Dict.1078; - let Dict.1077 : U64 = 3i64; - let Dict.1076 : U64 = CallByName Num.51 Dict.538 Dict.1077; - let Dict.1075 : U8 = CallByName Dict.22 Dict.537 Dict.1076; - let Dict.542 : U64 = CallByName Num.133 Dict.1075; - let Dict.1074 : U8 = 8i64; - let Dict.1073 : U64 = CallByName Num.72 Dict.540 Dict.1074; - let Dict.543 : U64 = CallByName Num.71 Dict.539 Dict.1073; - let Dict.1072 : U8 = 16i64; - let Dict.1069 : U64 = CallByName Num.72 Dict.541 Dict.1072; - let Dict.1071 : U8 = 24i64; - let Dict.1070 : U64 = CallByName Num.72 Dict.542 Dict.1071; - let Dict.544 : U64 = CallByName Num.71 Dict.1069 Dict.1070; - let Dict.1068 : U64 = CallByName Num.71 Dict.543 Dict.544; - ret Dict.1068; + let Dict.912 : U128 = CallByName Num.135 Dict.520; + let Dict.521 : U128 = CallByName Num.78 Dict.911 Dict.912; + let Dict.522 : U64 = CallByName Num.133 Dict.521; + let Dict.910 : U8 = 64i64; + let Dict.909 : U128 = CallByName Num.74 Dict.521 Dict.910; + let Dict.523 : U64 = CallByName Num.133 Dict.909; + let Dict.908 : {U64, U64} = Struct {Dict.522, Dict.523}; + ret Dict.908; + +procedure Dict.98 (Dict.524, Dict.525): + let Dict.973 : U8 = CallByName Dict.22 Dict.524 Dict.525; + let Dict.526 : U64 = CallByName Num.133 Dict.973; + let Dict.972 : U64 = 1i64; + let Dict.971 : U64 = CallByName Num.51 Dict.525 Dict.972; + let Dict.970 : U8 = CallByName Dict.22 Dict.524 Dict.971; + let Dict.527 : U64 = CallByName Num.133 Dict.970; + let Dict.969 : U64 = 2i64; + let Dict.968 : U64 = CallByName Num.51 Dict.525 Dict.969; + let Dict.967 : U8 = CallByName Dict.22 Dict.524 Dict.968; + let Dict.528 : U64 = CallByName Num.133 Dict.967; + let Dict.966 : U64 = 3i64; + let Dict.965 : U64 = CallByName Num.51 Dict.525 Dict.966; + let Dict.964 : U8 = CallByName Dict.22 Dict.524 Dict.965; + let Dict.529 : U64 = CallByName Num.133 Dict.964; + let Dict.963 : U64 = 4i64; + let Dict.962 : U64 = CallByName Num.51 Dict.525 Dict.963; + let Dict.961 : U8 = CallByName Dict.22 Dict.524 Dict.962; + let Dict.530 : U64 = CallByName Num.133 Dict.961; + let Dict.960 : U64 = 5i64; + let Dict.959 : U64 = CallByName Num.51 Dict.525 Dict.960; + let Dict.958 : U8 = CallByName Dict.22 Dict.524 Dict.959; + let Dict.531 : U64 = CallByName Num.133 Dict.958; + let Dict.957 : U64 = 6i64; + let Dict.956 : U64 = CallByName Num.51 Dict.525 Dict.957; + let Dict.955 : U8 = CallByName Dict.22 Dict.524 Dict.956; + let Dict.532 : U64 = CallByName Num.133 Dict.955; + let Dict.954 : U64 = 7i64; + let Dict.952 : U64 = CallByName Num.51 Dict.525 Dict.954; + let Dict.951 : U8 = CallByName Dict.22 Dict.524 Dict.952; + let Dict.533 : U64 = CallByName Num.133 Dict.951; + let Dict.950 : U8 = 8i64; + let Dict.949 : U64 = CallByName Num.72 Dict.527 Dict.950; + let Dict.534 : U64 = CallByName Num.71 Dict.526 Dict.949; + let Dict.948 : U8 = 16i64; + let Dict.945 : U64 = CallByName Num.72 Dict.528 Dict.948; + let Dict.947 : U8 = 24i64; + let Dict.946 : U64 = CallByName Num.72 Dict.529 Dict.947; + let Dict.535 : U64 = CallByName Num.71 Dict.945 Dict.946; + let Dict.944 : U8 = 32i64; + let Dict.941 : U64 = CallByName Num.72 Dict.530 Dict.944; + let Dict.943 : U8 = 40i64; + let Dict.942 : U64 = CallByName Num.72 Dict.531 Dict.943; + let Dict.536 : U64 = CallByName Num.71 Dict.941 Dict.942; + let Dict.940 : U8 = 48i64; + let Dict.937 : U64 = CallByName Num.72 Dict.532 Dict.940; + let Dict.939 : U8 = 56i64; + let Dict.938 : U64 = CallByName Num.72 Dict.533 Dict.939; + let Dict.537 : U64 = CallByName Num.71 Dict.937 Dict.938; + let Dict.935 : U64 = CallByName Num.71 Dict.534 Dict.535; + let Dict.936 : U64 = CallByName Num.71 Dict.536 Dict.537; + let Dict.934 : U64 = CallByName Num.71 Dict.935 Dict.936; + ret Dict.934; + +procedure Dict.99 (Dict.538, Dict.539): + let Dict.1085 : U8 = CallByName Dict.22 Dict.538 Dict.539; + let Dict.540 : U64 = CallByName Num.133 Dict.1085; + let Dict.1084 : U64 = 1i64; + let Dict.1083 : U64 = CallByName Num.51 Dict.539 Dict.1084; + let Dict.1082 : U8 = CallByName Dict.22 Dict.538 Dict.1083; + let Dict.541 : U64 = CallByName Num.133 Dict.1082; + let Dict.1081 : U64 = 2i64; + let Dict.1080 : U64 = CallByName Num.51 Dict.539 Dict.1081; + let Dict.1079 : U8 = CallByName Dict.22 Dict.538 Dict.1080; + let Dict.542 : U64 = CallByName Num.133 Dict.1079; + let Dict.1078 : U64 = 3i64; + let Dict.1077 : U64 = CallByName Num.51 Dict.539 Dict.1078; + let Dict.1076 : U8 = CallByName Dict.22 Dict.538 Dict.1077; + let Dict.543 : U64 = CallByName Num.133 Dict.1076; + let Dict.1075 : U8 = 8i64; + let Dict.1074 : U64 = CallByName Num.72 Dict.541 Dict.1075; + let Dict.544 : U64 = CallByName Num.71 Dict.540 Dict.1074; + let Dict.1073 : U8 = 16i64; + let Dict.1070 : U64 = CallByName Num.72 Dict.542 Dict.1073; + let Dict.1072 : U8 = 24i64; + let Dict.1071 : U64 = CallByName Num.72 Dict.543 Dict.1072; + let Dict.545 : U64 = CallByName Num.71 Dict.1070 Dict.1071; + let Dict.1069 : U64 = CallByName Num.71 Dict.544 Dict.545; + ret Dict.1069; procedure Hash.19 (Hash.42, Hash.43): let Hash.75 : List U8 = CallByName Str.12 Hash.43; @@ -748,119 +748,79 @@ procedure Hash.19 (Hash.42, Hash.43): dec Hash.75; ret Hash.74; -procedure Inspect.187 (Inspect.188, #Attr.12): - let Inspect.186 : {} = StructAtIndex 3 #Attr.12; - let Inspect.185 : {} = StructAtIndex 2 #Attr.12; - let Inspect.184 : {} = StructAtIndex 1 #Attr.12; - let Inspect.183 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = StructAtIndex 0 #Attr.12; - let Inspect.358 : Str = "{"; - let Inspect.331 : Str = CallByName Inspect.63 Inspect.188 Inspect.358; - dec Inspect.358; - let Inspect.332 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = Struct {Inspect.183, Inspect.184, Inspect.185, Inspect.186}; - let Inspect.327 : {Str, Int1} = CallByName Inspect.189 Inspect.331 Inspect.332; - dec Inspect.331; - let Inspect.328 : {} = Struct {}; - let Inspect.323 : Str = CallByName Inspect.201 Inspect.327; - let Inspect.324 : Str = "}"; - let Inspect.322 : Str = CallByName Inspect.63 Inspect.323 Inspect.324; - dec Inspect.324; - ret Inspect.322; - -procedure Inspect.189 (Inspect.190, #Attr.12): - let Inspect.186 : {} = StructAtIndex 3 #Attr.12; - let Inspect.185 : {} = StructAtIndex 2 #Attr.12; +procedure Inspect.185 (Inspect.186, #Attr.12): + let Inspect.184 : {} = StructAtIndex 3 #Attr.12; + let Inspect.183 : {} = StructAtIndex 2 #Attr.12; + let Inspect.182 : {} = StructAtIndex 1 #Attr.12; + let Inspect.181 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = StructAtIndex 0 #Attr.12; + let Inspect.341 : Str = "{"; + let Inspect.187 : Str = CallByName Inspect.63 Inspect.186 Inspect.341; + dec Inspect.341; + let Inspect.340 : Int1 = CallByName Bool.1; + let Inspect.318 : {Str, Int1} = Struct {Inspect.187, Inspect.340}; + let Inspect.319 : {{}, {}} = Struct {Inspect.183, Inspect.184}; + let Inspect.317 : {Str, Int1} = CallByName Dict.10 Inspect.181 Inspect.318 Inspect.319; + let Inspect.188 : Str = StructAtIndex 0 Inspect.317; + let Inspect.314 : Str = "}"; + let Inspect.313 : Str = CallByName Inspect.63 Inspect.188 Inspect.314; + dec Inspect.314; + ret Inspect.313; + +procedure Inspect.189 (Inspect.320, Inspect.192, Inspect.193, #Attr.12): let Inspect.184 : {} = StructAtIndex 1 #Attr.12; - let Inspect.183 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = StructAtIndex 0 #Attr.12; - let Inspect.357 : Int1 = CallByName Bool.1; - inc Inspect.190; - let Inspect.335 : {Str, Int1} = Struct {Inspect.190, Inspect.357}; - let Inspect.336 : {{}, {}} = Struct {Inspect.185, Inspect.186}; - let Inspect.334 : {Str, Int1} = CallByName Dict.10 Inspect.183 Inspect.335 Inspect.336; - ret Inspect.334; - -procedure Inspect.191 (Inspect.337, Inspect.194, Inspect.195, #Attr.12): - let Inspect.186 : {} = StructAtIndex 1 #Attr.12; - let Inspect.185 : {} = StructAtIndex 0 #Attr.12; - let Inspect.192 : Str = StructAtIndex 0 Inspect.337; - let Inspect.193 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.355 Inspect.196: - let Inspect.352 : Str = CallByName Inspect.47 Inspect.194; - let Inspect.350 : Str = CallByName Inspect.31 Inspect.352 Inspect.196; - let Inspect.351 : Str = ": "; - let Inspect.344 : Str = CallByName Inspect.63 Inspect.350 Inspect.351; - dec Inspect.351; - let Inspect.345 : {I64, {}} = Struct {Inspect.195, Inspect.186}; - let Inspect.340 : Str = CallByName Inspect.197 Inspect.344 Inspect.345; - let Inspect.341 : {} = Struct {}; - let Inspect.339 : {Str, Int1} = CallByName Inspect.199 Inspect.340; - dec Inspect.340; - ret Inspect.339; + let Inspect.183 : {} = StructAtIndex 0 #Attr.12; + let Inspect.190 : Str = StructAtIndex 0 Inspect.320; + let Inspect.191 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.338 Inspect.194: + let Inspect.335 : Str = CallByName Inspect.47 Inspect.192; + let Inspect.333 : Str = CallByName Inspect.31 Inspect.335 Inspect.194; + dec Inspect.335; + let Inspect.334 : Str = ": "; + let Inspect.327 : Str = CallByName Inspect.63 Inspect.333 Inspect.334; + dec Inspect.334; + let Inspect.328 : {I64, {}} = Struct {Inspect.193, Inspect.184}; + let Inspect.323 : Str = CallByName Inspect.195 Inspect.327 Inspect.328; + let Inspect.324 : {} = Struct {}; + let Inspect.322 : {Str, Int1} = CallByName Inspect.197 Inspect.323; + dec Inspect.323; + ret Inspect.322; in - if Inspect.193 then - let Inspect.356 : Str = ", "; - let Inspect.354 : Str = CallByName Inspect.63 Inspect.192 Inspect.356; - dec Inspect.356; - jump Inspect.355 Inspect.354; + if Inspect.191 then + let Inspect.339 : Str = ", "; + let Inspect.337 : Str = CallByName Inspect.63 Inspect.190 Inspect.339; + dec Inspect.339; + jump Inspect.338 Inspect.337; else - jump Inspect.355 Inspect.192; - -procedure Inspect.197 (Inspect.198, #Attr.12): - let Inspect.186 : {} = StructAtIndex 1 #Attr.12; - let Inspect.195 : I64 = StructAtIndex 0 #Attr.12; - let Inspect.348 : I64 = CallByName Inspect.57 Inspect.195; - let Inspect.347 : Str = CallByName Inspect.31 Inspect.348 Inspect.198; - ret Inspect.347; - -procedure Inspect.199 (Inspect.200): - let Inspect.343 : Int1 = CallByName Bool.2; - inc Inspect.200; - let Inspect.342 : {Str, Int1} = Struct {Inspect.200, Inspect.343}; - ret Inspect.342; + jump Inspect.338 Inspect.190; -procedure Inspect.201 (Inspect.329): - let Inspect.330 : Str = StructAtIndex 0 Inspect.329; +procedure Inspect.195 (Inspect.196, #Attr.12): + let Inspect.184 : {} = StructAtIndex 1 #Attr.12; + let Inspect.193 : I64 = StructAtIndex 0 #Attr.12; + let Inspect.331 : I64 = CallByName Inspect.57 Inspect.193; + let Inspect.330 : Str = CallByName Inspect.31 Inspect.331 Inspect.196; ret Inspect.330; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.387 : Str = "\""; - let Inspect.372 : Str = CallByName Inspect.63 Inspect.251 Inspect.387; - dec Inspect.387; - let Inspect.370 : Str = CallByName Inspect.252 Inspect.372 Inspect.249; - let Inspect.371 : Str = "\""; - let Inspect.369 : Str = CallByName Inspect.63 Inspect.370 Inspect.371; - dec Inspect.371; - ret Inspect.369; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.385 : Str = "\u{feff}"; - let Inspect.386 : Str = "\\u(feff)"; - let Inspect.382 : Str = CallByName Str.45 Inspect.249 Inspect.385 Inspect.386; - dec Inspect.386; - dec Inspect.385; - let Inspect.383 : Str = "\u{200b}"; - let Inspect.384 : Str = "\\u(200b)"; - let Inspect.379 : Str = CallByName Str.45 Inspect.382 Inspect.383 Inspect.384; - dec Inspect.384; - dec Inspect.383; - let Inspect.380 : Str = "\u{200c}"; - let Inspect.381 : Str = "\\u(200c)"; - let Inspect.376 : Str = CallByName Str.45 Inspect.379 Inspect.380 Inspect.381; - dec Inspect.380; - dec Inspect.381; - let Inspect.377 : Str = "\u{200d}"; - let Inspect.378 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.376 Inspect.377 Inspect.378; - dec Inspect.377; - dec Inspect.378; - let Inspect.375 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.375; - -procedure Inspect.281 (Inspect.282, Inspect.280): - let Inspect.364 : Str = CallByName Num.96 Inspect.280; - let Inspect.363 : Str = CallByName Inspect.63 Inspect.282 Inspect.364; - dec Inspect.364; - ret Inspect.363; +procedure Inspect.197 (Inspect.198): + let Inspect.326 : Int1 = CallByName Bool.2; + inc Inspect.198; + let Inspect.325 : {Str, Int1} = Struct {Inspect.198, Inspect.326}; + ret Inspect.325; + +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.355 : Str = "\""; + let Inspect.354 : Str = CallByName Inspect.63 Inspect.246 Inspect.355; + dec Inspect.355; + let Inspect.352 : Str = CallByName Inspect.63 Inspect.354 Inspect.244; + let Inspect.353 : Str = "\""; + let Inspect.351 : Str = CallByName Inspect.63 Inspect.352 Inspect.353; + dec Inspect.353; + ret Inspect.351; + +procedure Inspect.273 (Inspect.274, Inspect.272): + let Inspect.347 : Str = CallByName Num.96 Inspect.272; + let Inspect.346 : Str = CallByName Inspect.63 Inspect.274 Inspect.347; + dec Inspect.347; + ret Inspect.346; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -874,55 +834,75 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.317 : Str = CallByName Inspect.187 Inspect.149 Inspect.306; - ret Inspect.317; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.309 : Str = CallByName Inspect.185 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.349 : Str = CallByName Inspect.281 Inspect.149 Inspect.306; - ret Inspect.349; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.332 : Str = CallByName Inspect.273 Inspect.149 Inspect.298; + ret Inspect.332; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.353 : Str = CallByName Inspect.250 Inspect.149 Inspect.306; - ret Inspect.353; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.336 : Str = CallByName Inspect.245 Inspect.149 Inspect.298; + ret Inspect.336; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.42 (Inspect.183, Inspect.184, Inspect.185, Inspect.186): - let Inspect.319 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = Struct {Inspect.183, Inspect.184, Inspect.185, Inspect.186}; - let Inspect.318 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = CallByName Inspect.30 Inspect.319; - ret Inspect.318; +procedure Inspect.42 (Inspect.181, Inspect.182, Inspect.183, Inspect.184): + let Inspect.311 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = Struct {Inspect.181, Inspect.182, Inspect.183, Inspect.184}; + let Inspect.310 : {{List {U32, U32}, List {Str, I64}, U64, Float32, U8}, {}, {}, {}} = CallByName Inspect.30 Inspect.311; + ret Inspect.310; -procedure Inspect.47 (Inspect.249): - let Inspect.365 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.365; +procedure Inspect.47 (Inspect.243): + let Inspect.365 : Str = "\u{feff}"; + let Inspect.366 : Str = "\\u(feff)"; + let Inspect.362 : Str = CallByName Str.45 Inspect.243 Inspect.365 Inspect.366; + dec Inspect.365; + dec Inspect.366; + let Inspect.363 : Str = "\u{200b}"; + let Inspect.364 : Str = "\\u(200b)"; + let Inspect.359 : Str = CallByName Str.45 Inspect.362 Inspect.363 Inspect.364; + dec Inspect.364; + dec Inspect.363; + let Inspect.360 : Str = "\u{200c}"; + let Inspect.361 : Str = "\\u(200c)"; + let Inspect.356 : Str = CallByName Str.45 Inspect.359 Inspect.360 Inspect.361; + dec Inspect.360; + dec Inspect.361; + let Inspect.357 : Str = "\u{200d}"; + let Inspect.358 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.356 Inspect.357 Inspect.358; + dec Inspect.357; + dec Inspect.358; + let Inspect.348 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.348; procedure Inspect.5 (Inspect.150): - let Inspect.315 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.43 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Dict.127 Inspect.311 Inspect.315; - ret Inspect.310; - -procedure Inspect.57 (Inspect.280): - let Inspect.359 : I64 = CallByName Inspect.30 Inspect.280; - ret Inspect.359; + let Inspect.307 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.43 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Dict.127 Inspect.303 Inspect.307; + ret Inspect.302; + +procedure Inspect.57 (Inspect.272): + let Inspect.342 : I64 = CallByName Inspect.30 Inspect.272; + ret Inspect.342; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.326 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.326; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.316 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.316; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; -procedure List.100 (#Derived_gen.45, #Derived_gen.46, #Derived_gen.47, #Derived_gen.48, #Derived_gen.49): +procedure List.100 (#Derived_gen.34, #Derived_gen.35, #Derived_gen.36, #Derived_gen.37, #Derived_gen.38): joinpoint List.732 List.174 List.175 List.176 List.177 List.178: let List.734 : Int1 = CallByName Num.22 List.177 List.178; if List.734 then @@ -936,10 +916,10 @@ procedure List.100 (#Derived_gen.45, #Derived_gen.46, #Derived_gen.47, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.45; - jump List.732 #Derived_gen.45 #Derived_gen.46 #Derived_gen.47 #Derived_gen.48 #Derived_gen.49; + inc #Derived_gen.34; + jump List.732 #Derived_gen.34 #Derived_gen.35 #Derived_gen.36 #Derived_gen.37 #Derived_gen.38; -procedure List.100 (#Derived_gen.72, #Derived_gen.73, #Derived_gen.74, #Derived_gen.75, #Derived_gen.76): +procedure List.100 (#Derived_gen.60, #Derived_gen.61, #Derived_gen.62, #Derived_gen.63, #Derived_gen.64): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then @@ -953,16 +933,16 @@ procedure List.100 (#Derived_gen.72, #Derived_gen.73, #Derived_gen.74, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.72; - jump List.668 #Derived_gen.72 #Derived_gen.73 #Derived_gen.74 #Derived_gen.75 #Derived_gen.76; + inc #Derived_gen.60; + jump List.668 #Derived_gen.60 #Derived_gen.61 #Derived_gen.62 #Derived_gen.63 #Derived_gen.64; -procedure List.101 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27, #Derived_gen.28): +procedure List.101 (#Derived_gen.15, #Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19): joinpoint List.707 List.183 List.184 List.185 List.186 List.187: let List.709 : Int1 = CallByName Num.22 List.186 List.187; if List.709 then let List.713 : {Str, I64} = CallByName List.66 List.183 List.186; inc List.713; - let List.188 : List {U32, U32} = CallByName Dict.406 List.184 List.713 List.186 List.185; + let List.188 : List {U32, U32} = CallByName Dict.407 List.184 List.713 List.186 List.185; let List.712 : U64 = 1i64; let List.711 : U64 = CallByName Num.51 List.186 List.712; jump List.707 List.183 List.188 List.185 List.711 List.187; @@ -970,8 +950,8 @@ procedure List.101 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_ dec List.183; ret List.184; in - inc #Derived_gen.24; - jump List.707 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27 #Derived_gen.28; + inc #Derived_gen.15; + jump List.707 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19; procedure List.11 (List.149, List.150): let List.727 : List {U32, U32} = CallByName List.68 List.150; @@ -998,8 +978,8 @@ procedure List.3 (List.127, List.128, List.129): procedure List.3 (List.127, List.128, List.129): let List.693 : {List {Str, I64}, {Str, I64}} = CallByName List.64 List.127 List.128 List.129; let List.692 : List {Str, I64} = StructAtIndex 0 List.693; - let #Derived_gen.82 : {Str, I64} = StructAtIndex 1 List.693; - dec #Derived_gen.82; + let #Derived_gen.74 : {Str, I64} = StructAtIndex 1 List.693; + dec #Derived_gen.74; ret List.692; procedure List.4 (List.135, List.136): @@ -1074,7 +1054,7 @@ procedure List.83 (List.180, List.181, List.182): let List.704 : List {U32, U32} = CallByName List.101 List.180 List.181 List.182 List.705 List.706; ret List.704; -procedure List.98 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35): +procedure List.98 (#Derived_gen.22, #Derived_gen.23, #Derived_gen.24): joinpoint List.716 List.151 List.152 List.153: let List.724 : U64 = 0i64; let List.718 : Int1 = CallByName Num.24 List.152 List.724; @@ -1086,7 +1066,7 @@ procedure List.98 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35): else ret List.153; in - jump List.716 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35; + jump List.716 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24; procedure Num.131 (#Attr.2): let Num.291 : U32 = lowlevel NumIntCast #Attr.2; @@ -1299,7 +1279,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.344; ret Str.91; -procedure Str.56 (#Derived_gen.62, #Derived_gen.63, #Derived_gen.64, #Derived_gen.65): +procedure Str.56 (#Derived_gen.51, #Derived_gen.52, #Derived_gen.53, #Derived_gen.54): joinpoint Str.253 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.254 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -1323,9 +1303,9 @@ procedure Str.56 (#Derived_gen.62, #Derived_gen.63, #Derived_gen.64, #Derived_ge dec Str.97; ret Str.258; in - inc #Derived_gen.64; - inc #Derived_gen.65; - jump Str.253 #Derived_gen.62 #Derived_gen.63 #Derived_gen.64 #Derived_gen.65; + inc #Derived_gen.54; + inc #Derived_gen.53; + jump Str.253 #Derived_gen.51 #Derived_gen.52 #Derived_gen.53 #Derived_gen.54; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -1335,7 +1315,7 @@ procedure Str.57 (Str.121, Str.122): let Str.279 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.280 Str.125; ret Str.279; -procedure Str.58 (#Derived_gen.68, #Derived_gen.69, #Derived_gen.70, #Derived_gen.71): +procedure Str.58 (#Derived_gen.28, #Derived_gen.29, #Derived_gen.30, #Derived_gen.31): joinpoint Str.281 Str.126 Str.127 Str.128 Str.129: let Str.283 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.283 then @@ -1355,9 +1335,9 @@ procedure Str.58 (#Derived_gen.68, #Derived_gen.69, #Derived_gen.70, #Derived_ge let Str.282 : [C , C U64] = TagId(0) ; ret Str.282; in - inc #Derived_gen.69; - inc #Derived_gen.68; - jump Str.281 #Derived_gen.68 #Derived_gen.69 #Derived_gen.70 #Derived_gen.71; + inc #Derived_gen.29; + inc #Derived_gen.28; + jump Str.281 #Derived_gen.28 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31; procedure Str.61 (Str.152, Str.153): let Str.311 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/inspect_derived_list.txt b/crates/compiler/test_mono/generated/inspect_derived_list.txt index 66920c1412f..6ca8c75892c 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_list.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_list.txt @@ -25,64 +25,49 @@ procedure Inspect.156 (Inspect.157, #Attr.12): let Inspect.155 : {} = StructAtIndex 2 #Attr.12; let Inspect.154 : {} = StructAtIndex 1 #Attr.12; let Inspect.153 : List I64 = StructAtIndex 0 #Attr.12; - let Inspect.350 : Str = "["; - let Inspect.331 : Str = CallByName Inspect.63 Inspect.157 Inspect.350; - dec Inspect.350; - let Inspect.332 : {List I64, {}, {}} = Struct {Inspect.153, Inspect.154, Inspect.155}; - let Inspect.327 : {Str, Int1} = CallByName Inspect.158 Inspect.331 Inspect.332; - dec Inspect.331; - let Inspect.328 : {} = Struct {}; - let Inspect.323 : Str = CallByName Inspect.167 Inspect.327; - let Inspect.324 : Str = "]"; - let Inspect.322 : Str = CallByName Inspect.63 Inspect.323 Inspect.324; - dec Inspect.324; - ret Inspect.322; - -procedure Inspect.158 (Inspect.159, #Attr.12): - let Inspect.155 : {} = StructAtIndex 2 #Attr.12; - let Inspect.154 : {} = StructAtIndex 1 #Attr.12; - let Inspect.153 : List I64 = StructAtIndex 0 #Attr.12; - let Inspect.349 : Int1 = CallByName Bool.1; - inc Inspect.159; - let Inspect.335 : {Str, Int1} = Struct {Inspect.159, Inspect.349}; - let Inspect.334 : {Str, Int1} = CallByName List.18 Inspect.153 Inspect.335 Inspect.155; + let Inspect.333 : Str = "["; + let Inspect.158 : Str = CallByName Inspect.63 Inspect.157 Inspect.333; + dec Inspect.333; + let Inspect.332 : Int1 = CallByName Bool.1; + let Inspect.318 : {Str, Int1} = Struct {Inspect.158, Inspect.332}; + let Inspect.317 : {Str, Int1} = CallByName List.18 Inspect.153 Inspect.318 Inspect.155; dec Inspect.153; - ret Inspect.334; - -procedure Inspect.160 (Inspect.337, Inspect.163, Inspect.155): - let Inspect.161 : Str = StructAtIndex 0 Inspect.337; - let Inspect.162 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.347 Inspect.164: - let Inspect.344 : I64 = CallByName #Derived.3 Inspect.163; - let Inspect.340 : Str = CallByName Inspect.31 Inspect.344 Inspect.164; - let Inspect.341 : {} = Struct {}; - let Inspect.339 : {Str, Int1} = CallByName Inspect.165 Inspect.340; - dec Inspect.340; - ret Inspect.339; + let Inspect.159 : Str = StructAtIndex 0 Inspect.317; + let Inspect.314 : Str = "]"; + let Inspect.313 : Str = CallByName Inspect.63 Inspect.159 Inspect.314; + dec Inspect.314; + ret Inspect.313; + +procedure Inspect.160 (Inspect.320, Inspect.163, Inspect.155): + let Inspect.161 : Str = StructAtIndex 0 Inspect.320; + let Inspect.162 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.330 Inspect.164: + let Inspect.327 : I64 = CallByName #Derived.3 Inspect.163; + let Inspect.323 : Str = CallByName Inspect.31 Inspect.327 Inspect.164; + let Inspect.324 : {} = Struct {}; + let Inspect.322 : {Str, Int1} = CallByName Inspect.165 Inspect.323; + dec Inspect.323; + ret Inspect.322; in if Inspect.162 then - let Inspect.348 : Str = ", "; - let Inspect.346 : Str = CallByName Inspect.63 Inspect.161 Inspect.348; - dec Inspect.348; - jump Inspect.347 Inspect.346; + let Inspect.331 : Str = ", "; + let Inspect.329 : Str = CallByName Inspect.63 Inspect.161 Inspect.331; + dec Inspect.331; + jump Inspect.330 Inspect.329; else - jump Inspect.347 Inspect.161; + jump Inspect.330 Inspect.161; procedure Inspect.165 (Inspect.166): - let Inspect.343 : Int1 = CallByName Bool.2; + let Inspect.326 : Int1 = CallByName Bool.2; inc Inspect.166; - let Inspect.342 : {Str, Int1} = Struct {Inspect.166, Inspect.343}; - ret Inspect.342; + let Inspect.325 : {Str, Int1} = Struct {Inspect.166, Inspect.326}; + ret Inspect.325; -procedure Inspect.167 (Inspect.329): - let Inspect.330 : Str = StructAtIndex 0 Inspect.329; - ret Inspect.330; - -procedure Inspect.281 (Inspect.282, Inspect.280): - let Inspect.356 : Str = CallByName Num.96 Inspect.280; - let Inspect.355 : Str = CallByName Inspect.63 Inspect.282 Inspect.356; - dec Inspect.356; - ret Inspect.355; +procedure Inspect.273 (Inspect.274, Inspect.272): + let Inspect.339 : Str = CallByName Num.96 Inspect.272; + let Inspect.338 : Str = CallByName Inspect.63 Inspect.274 Inspect.339; + dec Inspect.339; + ret Inspect.338; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -93,47 +78,47 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.317 : Str = CallByName Inspect.156 Inspect.149 Inspect.306; - ret Inspect.317; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.309 : Str = CallByName Inspect.156 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.345 : Str = CallByName Inspect.281 Inspect.149 Inspect.306; - ret Inspect.345; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.328 : Str = CallByName Inspect.273 Inspect.149 Inspect.298; + ret Inspect.328; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; procedure Inspect.40 (Inspect.153, Inspect.154, Inspect.155): inc Inspect.153; - let Inspect.319 : {List I64, {}, {}} = Struct {Inspect.153, Inspect.154, Inspect.155}; - let Inspect.318 : {List I64, {}, {}} = CallByName Inspect.30 Inspect.319; - ret Inspect.318; - -procedure Inspect.5 (Inspect.150): - let Inspect.315 : List I64 = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.4 Inspect.311 Inspect.315; - dec Inspect.315; + let Inspect.311 : {List I64, {}, {}} = Struct {Inspect.153, Inspect.154, Inspect.155}; + let Inspect.310 : {List I64, {}, {}} = CallByName Inspect.30 Inspect.311; ret Inspect.310; -procedure Inspect.57 (Inspect.280): - let Inspect.351 : I64 = CallByName Inspect.30 Inspect.280; - ret Inspect.351; +procedure Inspect.5 (Inspect.150): + let Inspect.307 : List I64 = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.4 Inspect.303 Inspect.307; + dec Inspect.307; + ret Inspect.302; + +procedure Inspect.57 (Inspect.272): + let Inspect.334 : I64 = CallByName Inspect.30 Inspect.272; + ret Inspect.334; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.326 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.326; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.316 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.316; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure List.100 (#Derived_gen.8, #Derived_gen.9, #Derived_gen.10, #Derived_gen.11, #Derived_gen.12): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: diff --git a/crates/compiler/test_mono/generated/inspect_derived_nested_record_string.txt b/crates/compiler/test_mono/generated/inspect_derived_nested_record_string.txt index 523be75b0d4..a01894af3c4 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_nested_record_string.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_nested_record_string.txt @@ -46,150 +46,108 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.27 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.27; -procedure Inspect.229 (Inspect.230, Inspect.228): - let Inspect.355 : Str = "{"; - let Inspect.331 : Str = CallByName Inspect.63 Inspect.230 Inspect.355; - dec Inspect.355; - let Inspect.327 : {Str, Int1} = CallByName Inspect.231 Inspect.331 Inspect.228; - dec Inspect.331; - let Inspect.328 : {} = Struct {}; - let Inspect.323 : Str = CallByName Inspect.243 Inspect.327; - let Inspect.324 : Str = "}"; - let Inspect.322 : Str = CallByName Inspect.63 Inspect.323 Inspect.324; - dec Inspect.324; - ret Inspect.322; - -procedure Inspect.229 (Inspect.230, Inspect.228): - let Inspect.395 : Str = "{"; - let Inspect.371 : Str = CallByName Inspect.63 Inspect.230 Inspect.395; - dec Inspect.395; - let Inspect.367 : {Str, Int1} = CallByName Inspect.231 Inspect.371 Inspect.228; - dec Inspect.371; - let Inspect.368 : {} = Struct {}; - let Inspect.363 : Str = CallByName Inspect.243 Inspect.367; - let Inspect.364 : Str = "}"; - let Inspect.362 : Str = CallByName Inspect.63 Inspect.363 Inspect.364; - dec Inspect.364; - ret Inspect.362; - -procedure Inspect.231 (Inspect.232, Inspect.228): - let Inspect.354 : Int1 = CallByName Bool.1; - inc Inspect.232; - let Inspect.335 : {Str, Int1} = Struct {Inspect.232, Inspect.354}; - let Inspect.336 : {} = Struct {}; - let Inspect.334 : {Str, Int1} = CallByName List.18 Inspect.228 Inspect.335 Inspect.336; - ret Inspect.334; - -procedure Inspect.231 (Inspect.232, Inspect.228): - let Inspect.394 : Int1 = CallByName Bool.1; - inc Inspect.232; - let Inspect.375 : {Str, Int1} = Struct {Inspect.232, Inspect.394}; - let Inspect.376 : {} = Struct {}; - let Inspect.374 : {Str, Int1} = CallByName List.18 Inspect.228 Inspect.375 Inspect.376; - ret Inspect.374; - -procedure Inspect.233 (Inspect.337, Inspect.338): - let Inspect.236 : Str = StructAtIndex 0 Inspect.338; - let Inspect.237 : Str = StructAtIndex 1 Inspect.338; - let Inspect.234 : Str = StructAtIndex 0 Inspect.337; - let Inspect.235 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.352 Inspect.238: - let Inspect.349 : Str = CallByName Inspect.63 Inspect.238 Inspect.236; - dec Inspect.236; - let Inspect.350 : Str = ": "; - let Inspect.344 : Str = CallByName Inspect.63 Inspect.349 Inspect.350; - dec Inspect.350; - let Inspect.340 : Str = CallByName Inspect.239 Inspect.344 Inspect.237; - let Inspect.341 : {} = Struct {}; - let Inspect.339 : {Str, Int1} = CallByName Inspect.241 Inspect.340; - dec Inspect.340; - ret Inspect.339; +procedure Inspect.225 (Inspect.226, Inspect.224): + let Inspect.338 : Str = "{"; + let Inspect.227 : Str = CallByName Inspect.63 Inspect.226 Inspect.338; + dec Inspect.338; + let Inspect.337 : Int1 = CallByName Bool.1; + let Inspect.318 : {Str, Int1} = Struct {Inspect.227, Inspect.337}; + let Inspect.319 : {} = Struct {}; + let Inspect.317 : {Str, Int1} = CallByName List.18 Inspect.224 Inspect.318 Inspect.319; + let Inspect.228 : Str = StructAtIndex 0 Inspect.317; + let Inspect.314 : Str = "}"; + let Inspect.313 : Str = CallByName Inspect.63 Inspect.228 Inspect.314; + dec Inspect.314; + ret Inspect.313; + +procedure Inspect.225 (Inspect.226, Inspect.224): + let Inspect.369 : Str = "{"; + let Inspect.227 : Str = CallByName Inspect.63 Inspect.226 Inspect.369; + dec Inspect.369; + let Inspect.368 : Int1 = CallByName Bool.1; + let Inspect.349 : {Str, Int1} = Struct {Inspect.227, Inspect.368}; + let Inspect.350 : {} = Struct {}; + let Inspect.348 : {Str, Int1} = CallByName List.18 Inspect.224 Inspect.349 Inspect.350; + let Inspect.228 : Str = StructAtIndex 0 Inspect.348; + let Inspect.345 : Str = "}"; + let Inspect.344 : Str = CallByName Inspect.63 Inspect.228 Inspect.345; + dec Inspect.345; + ret Inspect.344; + +procedure Inspect.229 (Inspect.320, Inspect.321): + let Inspect.232 : Str = StructAtIndex 0 Inspect.321; + let Inspect.233 : Str = StructAtIndex 1 Inspect.321; + let Inspect.230 : Str = StructAtIndex 0 Inspect.320; + let Inspect.231 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.335 Inspect.234: + let Inspect.332 : Str = CallByName Inspect.63 Inspect.234 Inspect.232; + dec Inspect.232; + let Inspect.333 : Str = ": "; + let Inspect.327 : Str = CallByName Inspect.63 Inspect.332 Inspect.333; + dec Inspect.333; + let Inspect.323 : Str = CallByName Inspect.235 Inspect.327 Inspect.233; + let Inspect.324 : {} = Struct {}; + let Inspect.322 : {Str, Int1} = CallByName Inspect.237 Inspect.323; + dec Inspect.323; + ret Inspect.322; in - if Inspect.235 then - let Inspect.353 : Str = ", "; - let Inspect.351 : Str = CallByName Inspect.63 Inspect.234 Inspect.353; - dec Inspect.353; - jump Inspect.352 Inspect.351; + if Inspect.231 then + let Inspect.336 : Str = ", "; + let Inspect.334 : Str = CallByName Inspect.63 Inspect.230 Inspect.336; + dec Inspect.336; + jump Inspect.335 Inspect.334; else - jump Inspect.352 Inspect.234; - -procedure Inspect.233 (Inspect.337, Inspect.338): - let Inspect.236 : Str = StructAtIndex 0 Inspect.338; - let Inspect.237 : Str = StructAtIndex 1 Inspect.338; - let Inspect.234 : Str = StructAtIndex 0 Inspect.337; - let Inspect.235 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.392 Inspect.238: - let Inspect.389 : Str = CallByName Inspect.63 Inspect.238 Inspect.236; - dec Inspect.236; - let Inspect.390 : Str = ": "; - let Inspect.384 : Str = CallByName Inspect.63 Inspect.389 Inspect.390; - dec Inspect.390; - let Inspect.380 : Str = CallByName Inspect.239 Inspect.384 Inspect.237; - let Inspect.381 : {} = Struct {}; - let Inspect.379 : {Str, Int1} = CallByName Inspect.241 Inspect.380; - dec Inspect.380; - ret Inspect.379; + jump Inspect.335 Inspect.230; + +procedure Inspect.229 (Inspect.320, Inspect.321): + let Inspect.232 : Str = StructAtIndex 0 Inspect.321; + let Inspect.233 : Str = StructAtIndex 1 Inspect.321; + let Inspect.230 : Str = StructAtIndex 0 Inspect.320; + let Inspect.231 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.366 Inspect.234: + let Inspect.363 : Str = CallByName Inspect.63 Inspect.234 Inspect.232; + dec Inspect.232; + let Inspect.364 : Str = ": "; + let Inspect.358 : Str = CallByName Inspect.63 Inspect.363 Inspect.364; + dec Inspect.364; + let Inspect.354 : Str = CallByName Inspect.235 Inspect.358 Inspect.233; + dec Inspect.233; + let Inspect.355 : {} = Struct {}; + let Inspect.353 : {Str, Int1} = CallByName Inspect.237 Inspect.354; + dec Inspect.354; + ret Inspect.353; in - if Inspect.235 then - let Inspect.393 : Str = ", "; - let Inspect.391 : Str = CallByName Inspect.63 Inspect.234 Inspect.393; - dec Inspect.393; - jump Inspect.392 Inspect.391; + if Inspect.231 then + let Inspect.367 : Str = ", "; + let Inspect.365 : Str = CallByName Inspect.63 Inspect.230 Inspect.367; + dec Inspect.367; + jump Inspect.366 Inspect.365; else - jump Inspect.392 Inspect.234; - -procedure Inspect.239 (Inspect.240, Inspect.237): - let Inspect.347 : Str = CallByName Inspect.31 Inspect.237 Inspect.240; - ret Inspect.347; - -procedure Inspect.239 (Inspect.240, Inspect.237): - let Inspect.387 : Str = CallByName Inspect.31 Inspect.237 Inspect.240; - ret Inspect.387; - -procedure Inspect.241 (Inspect.242): - let Inspect.383 : Int1 = CallByName Bool.2; - inc Inspect.242; - let Inspect.382 : {Str, Int1} = Struct {Inspect.242, Inspect.383}; - ret Inspect.382; - -procedure Inspect.243 (Inspect.329): - let Inspect.370 : Str = StructAtIndex 0 Inspect.329; - ret Inspect.370; - -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.418 : Str = "\""; - let Inspect.403 : Str = CallByName Inspect.63 Inspect.251 Inspect.418; - dec Inspect.418; - let Inspect.401 : Str = CallByName Inspect.252 Inspect.403 Inspect.249; - let Inspect.402 : Str = "\""; - let Inspect.400 : Str = CallByName Inspect.63 Inspect.401 Inspect.402; - dec Inspect.402; - ret Inspect.400; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.416 : Str = "\u{feff}"; - let Inspect.417 : Str = "\\u(feff)"; - let Inspect.413 : Str = CallByName Str.45 Inspect.249 Inspect.416 Inspect.417; - dec Inspect.416; - dec Inspect.417; - let Inspect.414 : Str = "\u{200b}"; - let Inspect.415 : Str = "\\u(200b)"; - let Inspect.410 : Str = CallByName Str.45 Inspect.413 Inspect.414 Inspect.415; - dec Inspect.414; - dec Inspect.415; - let Inspect.411 : Str = "\u{200c}"; - let Inspect.412 : Str = "\\u(200c)"; - let Inspect.407 : Str = CallByName Str.45 Inspect.410 Inspect.411 Inspect.412; - dec Inspect.412; - dec Inspect.411; - let Inspect.408 : Str = "\u{200d}"; - let Inspect.409 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.407 Inspect.408 Inspect.409; - dec Inspect.409; - dec Inspect.408; - let Inspect.406 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.406; + jump Inspect.366 Inspect.230; + +procedure Inspect.235 (Inspect.236, Inspect.233): + let Inspect.330 : Str = CallByName Inspect.31 Inspect.233 Inspect.236; + ret Inspect.330; + +procedure Inspect.235 (Inspect.236, Inspect.233): + let Inspect.361 : Str = CallByName Inspect.31 Inspect.233 Inspect.236; + ret Inspect.361; + +procedure Inspect.237 (Inspect.238): + let Inspect.357 : Int1 = CallByName Bool.2; + inc Inspect.238; + let Inspect.356 : {Str, Int1} = Struct {Inspect.238, Inspect.357}; + ret Inspect.356; + +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.377 : Str = "\""; + let Inspect.376 : Str = CallByName Inspect.63 Inspect.246 Inspect.377; + dec Inspect.377; + let Inspect.374 : Str = CallByName Inspect.63 Inspect.376 Inspect.244; + let Inspect.375 : Str = "\""; + let Inspect.373 : Str = CallByName Inspect.63 Inspect.374 Inspect.375; + dec Inspect.375; + ret Inspect.373; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -206,64 +164,84 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.317 : Str = CallByName Inspect.229 Inspect.149 Inspect.306; - ret Inspect.317; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.309 : Str = CallByName Inspect.225 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.348 : Str = CallByName #Derived.6 Inspect.149 Inspect.306; - ret Inspect.348; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.331 : Str = CallByName #Derived.6 Inspect.149 Inspect.298; + ret Inspect.331; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.357 : Str = CallByName Inspect.229 Inspect.149 Inspect.306; - ret Inspect.357; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.340 : Str = CallByName Inspect.225 Inspect.149 Inspect.298; + ret Inspect.340; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.388 : Str = CallByName Inspect.250 Inspect.149 Inspect.306; - ret Inspect.388; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.362 : Str = CallByName Inspect.245 Inspect.149 Inspect.298; + ret Inspect.362; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.45 (Inspect.228): - let Inspect.318 : List {Str, Str} = CallByName Inspect.30 Inspect.228; - ret Inspect.318; - -procedure Inspect.45 (Inspect.228): - let Inspect.358 : List {Str, Str} = CallByName Inspect.30 Inspect.228; - ret Inspect.358; +procedure Inspect.45 (Inspect.224): + let Inspect.310 : List {Str, Str} = CallByName Inspect.30 Inspect.224; + ret Inspect.310; -procedure Inspect.47 (Inspect.249): - let Inspect.396 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.396; +procedure Inspect.45 (Inspect.224): + let Inspect.341 : List {Str, Str} = CallByName Inspect.30 Inspect.224; + ret Inspect.341; + +procedure Inspect.47 (Inspect.243): + let Inspect.387 : Str = "\u{feff}"; + let Inspect.388 : Str = "\\u(feff)"; + let Inspect.384 : Str = CallByName Str.45 Inspect.243 Inspect.387 Inspect.388; + dec Inspect.388; + dec Inspect.387; + let Inspect.385 : Str = "\u{200b}"; + let Inspect.386 : Str = "\\u(200b)"; + let Inspect.381 : Str = CallByName Str.45 Inspect.384 Inspect.385 Inspect.386; + dec Inspect.386; + dec Inspect.385; + let Inspect.382 : Str = "\u{200c}"; + let Inspect.383 : Str = "\\u(200c)"; + let Inspect.378 : Str = CallByName Str.45 Inspect.381 Inspect.382 Inspect.383; + dec Inspect.382; + dec Inspect.383; + let Inspect.379 : Str = "\u{200d}"; + let Inspect.380 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.378 Inspect.379 Inspect.380; + dec Inspect.380; + dec Inspect.379; + let Inspect.370 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.370; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.2 Inspect.311 Inspect.315; - ret Inspect.310; - -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.366 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.366; + let Inspect.307 : Str = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.2 Inspect.303 Inspect.307; + ret Inspect.302; + +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.347 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.347; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; -procedure List.100 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27, #Derived_gen.28): +procedure List.100 (#Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23, #Derived_gen.24): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then let List.674 : {Str, Str} = CallByName List.66 List.174 List.177; inc List.674; - let List.179 : {Str, Int1} = CallByName Inspect.233 List.175 List.674; + let List.179 : {Str, Int1} = CallByName Inspect.229 List.175 List.674; let List.673 : U64 = 1i64; let List.672 : U64 = CallByName Num.51 List.177 List.673; jump List.668 List.174 List.179 List.176 List.672 List.178; @@ -271,16 +249,16 @@ procedure List.100 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.24; - jump List.668 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27 #Derived_gen.28; + inc #Derived_gen.20; + jump List.668 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24; -procedure List.100 (#Derived_gen.54, #Derived_gen.55, #Derived_gen.56, #Derived_gen.57, #Derived_gen.58): +procedure List.100 (#Derived_gen.42, #Derived_gen.43, #Derived_gen.44, #Derived_gen.45, #Derived_gen.46): joinpoint List.680 List.174 List.175 List.176 List.177 List.178: let List.682 : Int1 = CallByName Num.22 List.177 List.178; if List.682 then let List.686 : {Str, Str} = CallByName List.66 List.174 List.177; inc List.686; - let List.179 : {Str, Int1} = CallByName Inspect.233 List.175 List.686; + let List.179 : {Str, Int1} = CallByName Inspect.229 List.175 List.686; let List.685 : U64 = 1i64; let List.684 : U64 = CallByName Num.51 List.177 List.685; jump List.680 List.174 List.179 List.176 List.684 List.178; @@ -288,8 +266,8 @@ procedure List.100 (#Derived_gen.54, #Derived_gen.55, #Derived_gen.56, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.54; - jump List.680 #Derived_gen.54 #Derived_gen.55 #Derived_gen.56 #Derived_gen.57 #Derived_gen.58; + inc #Derived_gen.42; + jump List.680 #Derived_gen.42 #Derived_gen.43 #Derived_gen.44 #Derived_gen.45 #Derived_gen.46; procedure List.18 (List.171, List.172, List.173): let List.666 : U64 = 0i64; @@ -415,7 +393,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.342; ret Str.91; -procedure Str.56 (#Derived_gen.29, #Derived_gen.30, #Derived_gen.31, #Derived_gen.32): +procedure Str.56 (#Derived_gen.27, #Derived_gen.28, #Derived_gen.29, #Derived_gen.30): joinpoint Str.251 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.252 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -439,9 +417,9 @@ procedure Str.56 (#Derived_gen.29, #Derived_gen.30, #Derived_gen.31, #Derived_ge dec Str.97; ret Str.256; in - inc #Derived_gen.31; - inc #Derived_gen.32; - jump Str.251 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31 #Derived_gen.32; + inc #Derived_gen.29; + inc #Derived_gen.30; + jump Str.251 #Derived_gen.27 #Derived_gen.28 #Derived_gen.29 #Derived_gen.30; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -451,7 +429,7 @@ procedure Str.57 (Str.121, Str.122): let Str.277 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.278 Str.125; ret Str.277; -procedure Str.58 (#Derived_gen.49, #Derived_gen.50, #Derived_gen.51, #Derived_gen.52): +procedure Str.58 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35, #Derived_gen.36): joinpoint Str.279 Str.126 Str.127 Str.128 Str.129: let Str.281 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.281 then @@ -471,9 +449,9 @@ procedure Str.58 (#Derived_gen.49, #Derived_gen.50, #Derived_gen.51, #Derived_ge let Str.280 : [C , C U64] = TagId(0) ; ret Str.280; in - inc #Derived_gen.49; - inc #Derived_gen.50; - jump Str.279 #Derived_gen.49 #Derived_gen.50 #Derived_gen.51 #Derived_gen.52; + inc #Derived_gen.34; + inc #Derived_gen.33; + jump Str.279 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35 #Derived_gen.36; procedure Str.61 (Str.152, Str.153): let Str.309 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/inspect_derived_record.txt b/crates/compiler/test_mono/generated/inspect_derived_record.txt index f12f7663164..565021f7907 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_record.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_record.txt @@ -25,79 +25,68 @@ procedure Bool.2 (): let Bool.23 : Int1 = true; ret Bool.23; -procedure Inspect.229 (Inspect.230, Inspect.228): - let Inspect.356 : Str = "{"; - let Inspect.331 : Str = CallByName Inspect.63 Inspect.230 Inspect.356; - dec Inspect.356; - let Inspect.327 : {Str, Int1} = CallByName Inspect.231 Inspect.331 Inspect.228; - dec Inspect.331; - let Inspect.328 : {} = Struct {}; - let Inspect.323 : Str = CallByName Inspect.243 Inspect.327; - let Inspect.324 : Str = "}"; - let Inspect.322 : Str = CallByName Inspect.63 Inspect.323 Inspect.324; - dec Inspect.324; - ret Inspect.322; - -procedure Inspect.231 (Inspect.232, Inspect.228): - let Inspect.355 : Int1 = CallByName Bool.1; - inc Inspect.232; - let Inspect.335 : {Str, Int1} = Struct {Inspect.232, Inspect.355}; - let Inspect.336 : {} = Struct {}; - let Inspect.334 : {Str, Int1} = CallByName List.18 Inspect.228 Inspect.335 Inspect.336; - ret Inspect.334; - -procedure Inspect.233 (Inspect.337, Inspect.338): - let Inspect.237 : [C I64, C Decimal] = StructAtIndex 0 Inspect.338; - let Inspect.236 : Str = StructAtIndex 1 Inspect.338; - let Inspect.234 : Str = StructAtIndex 0 Inspect.337; - let Inspect.235 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.353 Inspect.238: - let Inspect.350 : Str = CallByName Inspect.63 Inspect.238 Inspect.236; - dec Inspect.236; - let Inspect.351 : Str = ": "; - let Inspect.344 : Str = CallByName Inspect.63 Inspect.350 Inspect.351; - dec Inspect.351; - let Inspect.340 : Str = CallByName Inspect.239 Inspect.344 Inspect.237; - let Inspect.341 : {} = Struct {}; - let Inspect.339 : {Str, Int1} = CallByName Inspect.241 Inspect.340; - dec Inspect.340; - ret Inspect.339; +procedure Inspect.225 (Inspect.226, Inspect.224): + let Inspect.339 : Str = "{"; + let Inspect.227 : Str = CallByName Inspect.63 Inspect.226 Inspect.339; + dec Inspect.339; + let Inspect.338 : Int1 = CallByName Bool.1; + let Inspect.318 : {Str, Int1} = Struct {Inspect.227, Inspect.338}; + let Inspect.319 : {} = Struct {}; + let Inspect.317 : {Str, Int1} = CallByName List.18 Inspect.224 Inspect.318 Inspect.319; + let Inspect.228 : Str = StructAtIndex 0 Inspect.317; + let Inspect.314 : Str = "}"; + let Inspect.313 : Str = CallByName Inspect.63 Inspect.228 Inspect.314; + dec Inspect.314; + ret Inspect.313; + +procedure Inspect.229 (Inspect.320, Inspect.321): + let Inspect.233 : [C I64, C Decimal] = StructAtIndex 0 Inspect.321; + let Inspect.232 : Str = StructAtIndex 1 Inspect.321; + let Inspect.230 : Str = StructAtIndex 0 Inspect.320; + let Inspect.231 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.336 Inspect.234: + let Inspect.333 : Str = CallByName Inspect.63 Inspect.234 Inspect.232; + dec Inspect.232; + let Inspect.334 : Str = ": "; + let Inspect.327 : Str = CallByName Inspect.63 Inspect.333 Inspect.334; + dec Inspect.334; + let Inspect.323 : Str = CallByName Inspect.235 Inspect.327 Inspect.233; + let Inspect.324 : {} = Struct {}; + let Inspect.322 : {Str, Int1} = CallByName Inspect.237 Inspect.323; + dec Inspect.323; + ret Inspect.322; in - if Inspect.235 then - let Inspect.354 : Str = ", "; - let Inspect.352 : Str = CallByName Inspect.63 Inspect.234 Inspect.354; - dec Inspect.354; - jump Inspect.353 Inspect.352; + if Inspect.231 then + let Inspect.337 : Str = ", "; + let Inspect.335 : Str = CallByName Inspect.63 Inspect.230 Inspect.337; + dec Inspect.337; + jump Inspect.336 Inspect.335; else - jump Inspect.353 Inspect.234; + jump Inspect.336 Inspect.230; -procedure Inspect.239 (Inspect.240, Inspect.237): - let Inspect.347 : Str = CallByName Inspect.31 Inspect.237 Inspect.240; - ret Inspect.347; - -procedure Inspect.241 (Inspect.242): - let Inspect.343 : Int1 = CallByName Bool.2; - inc Inspect.242; - let Inspect.342 : {Str, Int1} = Struct {Inspect.242, Inspect.343}; - ret Inspect.342; - -procedure Inspect.243 (Inspect.329): - let Inspect.330 : Str = StructAtIndex 0 Inspect.329; +procedure Inspect.235 (Inspect.236, Inspect.233): + let Inspect.330 : Str = CallByName Inspect.31 Inspect.233 Inspect.236; ret Inspect.330; -procedure Inspect.281 (Inspect.282, #Attr.12): - let Inspect.369 : I64 = UnionAtIndex (Id 0) (Index 0) #Attr.12; - let Inspect.368 : Str = CallByName Num.96 Inspect.369; - let Inspect.367 : Str = CallByName Inspect.63 Inspect.282 Inspect.368; - dec Inspect.368; - ret Inspect.367; - -procedure Inspect.296 (Inspect.297, #Attr.12): - let Inspect.363 : Decimal = UnionAtIndex (Id 1) (Index 0) #Attr.12; - let Inspect.362 : Str = CallByName Num.96 Inspect.363; - let Inspect.361 : Str = CallByName Inspect.63 Inspect.297 Inspect.362; - dec Inspect.362; - ret Inspect.361; +procedure Inspect.237 (Inspect.238): + let Inspect.326 : Int1 = CallByName Bool.2; + inc Inspect.238; + let Inspect.325 : {Str, Int1} = Struct {Inspect.238, Inspect.326}; + ret Inspect.325; + +procedure Inspect.273 (Inspect.274, #Attr.12): + let Inspect.352 : I64 = UnionAtIndex (Id 0) (Index 0) #Attr.12; + let Inspect.351 : Str = CallByName Num.96 Inspect.352; + let Inspect.350 : Str = CallByName Inspect.63 Inspect.274 Inspect.351; + dec Inspect.351; + ret Inspect.350; + +procedure Inspect.288 (Inspect.289, #Attr.12): + let Inspect.346 : Decimal = UnionAtIndex (Id 1) (Index 0) #Attr.12; + let Inspect.345 : Str = CallByName Num.96 Inspect.346; + let Inspect.344 : Str = CallByName Inspect.63 Inspect.289 Inspect.345; + dec Inspect.345; + ret Inspect.344; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -108,66 +97,66 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.317 : Str = CallByName Inspect.229 Inspect.149 Inspect.306; - ret Inspect.317; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.309 : Str = CallByName Inspect.225 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.349 : U8 = GetTagId Inspect.306; - switch Inspect.349: +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.332 : U8 = GetTagId Inspect.298; + switch Inspect.332: case 0: - let Inspect.348 : Str = CallByName Inspect.281 Inspect.149 Inspect.306; - ret Inspect.348; + let Inspect.331 : Str = CallByName Inspect.273 Inspect.149 Inspect.298; + ret Inspect.331; default: - let Inspect.348 : Str = CallByName Inspect.296 Inspect.149 Inspect.306; - ret Inspect.348; + let Inspect.331 : Str = CallByName Inspect.288 Inspect.149 Inspect.298; + ret Inspect.331; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.45 (Inspect.228): - let Inspect.318 : List {[C I64, C Decimal], Str} = CallByName Inspect.30 Inspect.228; - ret Inspect.318; - -procedure Inspect.5 (Inspect.150): - let Inspect.315 : {Decimal, I64} = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.2 Inspect.311 Inspect.315; +procedure Inspect.45 (Inspect.224): + let Inspect.310 : List {[C I64, C Decimal], Str} = CallByName Inspect.30 Inspect.224; ret Inspect.310; -procedure Inspect.57 (Inspect.280): - let Inspect.365 : [C I64, C Decimal] = TagId(0) Inspect.280; - let Inspect.364 : [C I64, C Decimal] = CallByName Inspect.30 Inspect.365; - ret Inspect.364; +procedure Inspect.5 (Inspect.150): + let Inspect.307 : {Decimal, I64} = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.2 Inspect.303 Inspect.307; + ret Inspect.302; + +procedure Inspect.57 (Inspect.272): + let Inspect.348 : [C I64, C Decimal] = TagId(0) Inspect.272; + let Inspect.347 : [C I64, C Decimal] = CallByName Inspect.30 Inspect.348; + ret Inspect.347; -procedure Inspect.62 (Inspect.295): - let Inspect.358 : [C I64, C Decimal] = TagId(1) Inspect.295; - let Inspect.357 : [C I64, C Decimal] = CallByName Inspect.30 Inspect.358; - ret Inspect.357; +procedure Inspect.62 (Inspect.287): + let Inspect.341 : [C I64, C Decimal] = TagId(1) Inspect.287; + let Inspect.340 : [C I64, C Decimal] = CallByName Inspect.30 Inspect.341; + ret Inspect.340; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.326 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.326; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.316 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.316; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; -procedure List.100 (#Derived_gen.22, #Derived_gen.23, #Derived_gen.24, #Derived_gen.25, #Derived_gen.26): +procedure List.100 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then let List.674 : {[C I64, C Decimal], Str} = CallByName List.66 List.174 List.177; inc List.674; - let List.179 : {Str, Int1} = CallByName Inspect.233 List.175 List.674; + let List.179 : {Str, Int1} = CallByName Inspect.229 List.175 List.674; let List.673 : U64 = 1i64; let List.672 : U64 = CallByName Num.51 List.177 List.673; jump List.668 List.174 List.179 List.176 List.672 List.178; @@ -175,8 +164,8 @@ procedure List.100 (#Derived_gen.22, #Derived_gen.23, #Derived_gen.24, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.22; - jump List.668 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26; + inc #Derived_gen.16; + jump List.668 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20; procedure List.18 (List.171, List.172, List.173): let List.666 : U64 = 0i64; diff --git a/crates/compiler/test_mono/generated/inspect_derived_record_one_field_string.txt b/crates/compiler/test_mono/generated/inspect_derived_record_one_field_string.txt index dcf8521fc94..5ef69a0c673 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_record_one_field_string.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_record_one_field_string.txt @@ -32,100 +32,65 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.25 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.25; -procedure Inspect.229 (Inspect.230, Inspect.228): - let Inspect.355 : Str = "{"; - let Inspect.331 : Str = CallByName Inspect.63 Inspect.230 Inspect.355; - dec Inspect.355; - let Inspect.327 : {Str, Int1} = CallByName Inspect.231 Inspect.331 Inspect.228; - dec Inspect.331; - let Inspect.328 : {} = Struct {}; - let Inspect.323 : Str = CallByName Inspect.243 Inspect.327; - let Inspect.324 : Str = "}"; - let Inspect.322 : Str = CallByName Inspect.63 Inspect.323 Inspect.324; - dec Inspect.324; - ret Inspect.322; - -procedure Inspect.231 (Inspect.232, Inspect.228): - let Inspect.354 : Int1 = CallByName Bool.1; - inc Inspect.232; - let Inspect.335 : {Str, Int1} = Struct {Inspect.232, Inspect.354}; - let Inspect.336 : {} = Struct {}; - let Inspect.334 : {Str, Int1} = CallByName List.18 Inspect.228 Inspect.335 Inspect.336; - ret Inspect.334; - -procedure Inspect.233 (Inspect.337, Inspect.338): - let Inspect.236 : Str = StructAtIndex 0 Inspect.338; - let Inspect.237 : Str = StructAtIndex 1 Inspect.338; - let Inspect.234 : Str = StructAtIndex 0 Inspect.337; - let Inspect.235 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.352 Inspect.238: - let Inspect.349 : Str = CallByName Inspect.63 Inspect.238 Inspect.236; - dec Inspect.236; - let Inspect.350 : Str = ": "; - let Inspect.344 : Str = CallByName Inspect.63 Inspect.349 Inspect.350; - dec Inspect.350; - let Inspect.340 : Str = CallByName Inspect.239 Inspect.344 Inspect.237; - let Inspect.341 : {} = Struct {}; - let Inspect.339 : {Str, Int1} = CallByName Inspect.241 Inspect.340; - dec Inspect.340; - ret Inspect.339; +procedure Inspect.225 (Inspect.226, Inspect.224): + let Inspect.338 : Str = "{"; + let Inspect.227 : Str = CallByName Inspect.63 Inspect.226 Inspect.338; + dec Inspect.338; + let Inspect.337 : Int1 = CallByName Bool.1; + let Inspect.318 : {Str, Int1} = Struct {Inspect.227, Inspect.337}; + let Inspect.319 : {} = Struct {}; + let Inspect.317 : {Str, Int1} = CallByName List.18 Inspect.224 Inspect.318 Inspect.319; + let Inspect.228 : Str = StructAtIndex 0 Inspect.317; + let Inspect.314 : Str = "}"; + let Inspect.313 : Str = CallByName Inspect.63 Inspect.228 Inspect.314; + dec Inspect.314; + ret Inspect.313; + +procedure Inspect.229 (Inspect.320, Inspect.321): + let Inspect.232 : Str = StructAtIndex 0 Inspect.321; + let Inspect.233 : Str = StructAtIndex 1 Inspect.321; + let Inspect.230 : Str = StructAtIndex 0 Inspect.320; + let Inspect.231 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.335 Inspect.234: + let Inspect.332 : Str = CallByName Inspect.63 Inspect.234 Inspect.232; + dec Inspect.232; + let Inspect.333 : Str = ": "; + let Inspect.327 : Str = CallByName Inspect.63 Inspect.332 Inspect.333; + dec Inspect.333; + let Inspect.323 : Str = CallByName Inspect.235 Inspect.327 Inspect.233; + dec Inspect.233; + let Inspect.324 : {} = Struct {}; + let Inspect.322 : {Str, Int1} = CallByName Inspect.237 Inspect.323; + dec Inspect.323; + ret Inspect.322; in - if Inspect.235 then - let Inspect.353 : Str = ", "; - let Inspect.351 : Str = CallByName Inspect.63 Inspect.234 Inspect.353; - dec Inspect.353; - jump Inspect.352 Inspect.351; + if Inspect.231 then + let Inspect.336 : Str = ", "; + let Inspect.334 : Str = CallByName Inspect.63 Inspect.230 Inspect.336; + dec Inspect.336; + jump Inspect.335 Inspect.334; else - jump Inspect.352 Inspect.234; - -procedure Inspect.239 (Inspect.240, Inspect.237): - let Inspect.347 : Str = CallByName Inspect.31 Inspect.237 Inspect.240; - ret Inspect.347; - -procedure Inspect.241 (Inspect.242): - let Inspect.343 : Int1 = CallByName Bool.2; - inc Inspect.242; - let Inspect.342 : {Str, Int1} = Struct {Inspect.242, Inspect.343}; - ret Inspect.342; + jump Inspect.335 Inspect.230; -procedure Inspect.243 (Inspect.329): - let Inspect.330 : Str = StructAtIndex 0 Inspect.329; +procedure Inspect.235 (Inspect.236, Inspect.233): + let Inspect.330 : Str = CallByName Inspect.31 Inspect.233 Inspect.236; ret Inspect.330; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.378 : Str = "\""; - let Inspect.363 : Str = CallByName Inspect.63 Inspect.251 Inspect.378; - dec Inspect.378; - let Inspect.361 : Str = CallByName Inspect.252 Inspect.363 Inspect.249; - let Inspect.362 : Str = "\""; - let Inspect.360 : Str = CallByName Inspect.63 Inspect.361 Inspect.362; - dec Inspect.362; - ret Inspect.360; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.376 : Str = "\u{feff}"; - let Inspect.377 : Str = "\\u(feff)"; - let Inspect.373 : Str = CallByName Str.45 Inspect.249 Inspect.376 Inspect.377; - dec Inspect.377; - dec Inspect.376; - let Inspect.374 : Str = "\u{200b}"; - let Inspect.375 : Str = "\\u(200b)"; - let Inspect.370 : Str = CallByName Str.45 Inspect.373 Inspect.374 Inspect.375; - dec Inspect.374; - dec Inspect.375; - let Inspect.371 : Str = "\u{200c}"; - let Inspect.372 : Str = "\\u(200c)"; - let Inspect.367 : Str = CallByName Str.45 Inspect.370 Inspect.371 Inspect.372; - dec Inspect.372; - dec Inspect.371; - let Inspect.368 : Str = "\u{200d}"; - let Inspect.369 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.367 Inspect.368 Inspect.369; - dec Inspect.369; - dec Inspect.368; - let Inspect.366 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.366; +procedure Inspect.237 (Inspect.238): + let Inspect.326 : Int1 = CallByName Bool.2; + inc Inspect.238; + let Inspect.325 : {Str, Int1} = Struct {Inspect.238, Inspect.326}; + ret Inspect.325; + +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.346 : Str = "\""; + let Inspect.345 : Str = CallByName Inspect.63 Inspect.246 Inspect.346; + dec Inspect.346; + let Inspect.343 : Str = CallByName Inspect.63 Inspect.345 Inspect.244; + let Inspect.344 : Str = "\""; + let Inspect.342 : Str = CallByName Inspect.63 Inspect.343 Inspect.344; + dec Inspect.344; + ret Inspect.342; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -136,52 +101,72 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.317 : Str = CallByName Inspect.229 Inspect.149 Inspect.306; - ret Inspect.317; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.309 : Str = CallByName Inspect.225 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.348 : Str = CallByName Inspect.250 Inspect.149 Inspect.306; - ret Inspect.348; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.331 : Str = CallByName Inspect.245 Inspect.149 Inspect.298; + ret Inspect.331; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.45 (Inspect.228): - let Inspect.318 : List {Str, Str} = CallByName Inspect.30 Inspect.228; - ret Inspect.318; +procedure Inspect.45 (Inspect.224): + let Inspect.310 : List {Str, Str} = CallByName Inspect.30 Inspect.224; + ret Inspect.310; -procedure Inspect.47 (Inspect.249): - let Inspect.356 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.356; +procedure Inspect.47 (Inspect.243): + let Inspect.356 : Str = "\u{feff}"; + let Inspect.357 : Str = "\\u(feff)"; + let Inspect.353 : Str = CallByName Str.45 Inspect.243 Inspect.356 Inspect.357; + dec Inspect.356; + dec Inspect.357; + let Inspect.354 : Str = "\u{200b}"; + let Inspect.355 : Str = "\\u(200b)"; + let Inspect.350 : Str = CallByName Str.45 Inspect.353 Inspect.354 Inspect.355; + dec Inspect.355; + dec Inspect.354; + let Inspect.351 : Str = "\u{200c}"; + let Inspect.352 : Str = "\\u(200c)"; + let Inspect.347 : Str = CallByName Str.45 Inspect.350 Inspect.351 Inspect.352; + dec Inspect.352; + dec Inspect.351; + let Inspect.348 : Str = "\u{200d}"; + let Inspect.349 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.347 Inspect.348 Inspect.349; + dec Inspect.348; + dec Inspect.349; + let Inspect.339 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.339; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.2 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : Str = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.2 Inspect.303 Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.326 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.326; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.316 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.316; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; -procedure List.100 (#Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17, #Derived_gen.18): +procedure List.100 (#Derived_gen.12, #Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then let List.674 : {Str, Str} = CallByName List.66 List.174 List.177; inc List.674; - let List.179 : {Str, Int1} = CallByName Inspect.233 List.175 List.674; + let List.179 : {Str, Int1} = CallByName Inspect.229 List.175 List.674; let List.673 : U64 = 1i64; let List.672 : U64 = CallByName Num.51 List.177 List.673; jump List.668 List.174 List.179 List.176 List.672 List.178; @@ -189,8 +174,8 @@ procedure List.100 (#Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.14; - jump List.668 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18; + inc #Derived_gen.12; + jump List.668 #Derived_gen.12 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16; procedure List.18 (List.171, List.172, List.173): let List.666 : U64 = 0i64; @@ -302,7 +287,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.341; ret Str.91; -procedure Str.56 (#Derived_gen.28, #Derived_gen.29, #Derived_gen.30, #Derived_gen.31): +procedure Str.56 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -326,9 +311,9 @@ procedure Str.56 (#Derived_gen.28, #Derived_gen.29, #Derived_gen.30, #Derived_ge dec Str.97; ret Str.255; in - inc #Derived_gen.30; - inc #Derived_gen.31; - jump Str.250 #Derived_gen.28 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31; + inc #Derived_gen.27; + inc #Derived_gen.26; + jump Str.250 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -338,7 +323,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_gen.35): +procedure Str.58 (#Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -358,9 +343,9 @@ procedure Str.58 (#Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_ge let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.33; - inc #Derived_gen.32; - jump Str.278 #Derived_gen.32 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35; + inc #Derived_gen.20; + inc #Derived_gen.21; + jump Str.278 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/inspect_derived_record_two_field_strings.txt b/crates/compiler/test_mono/generated/inspect_derived_record_two_field_strings.txt index 623075d0395..35d10ac89a3 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_record_two_field_strings.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_record_two_field_strings.txt @@ -39,100 +39,65 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.25 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.25; -procedure Inspect.229 (Inspect.230, Inspect.228): - let Inspect.355 : Str = "{"; - let Inspect.331 : Str = CallByName Inspect.63 Inspect.230 Inspect.355; - dec Inspect.355; - let Inspect.327 : {Str, Int1} = CallByName Inspect.231 Inspect.331 Inspect.228; - dec Inspect.331; - let Inspect.328 : {} = Struct {}; - let Inspect.323 : Str = CallByName Inspect.243 Inspect.327; - let Inspect.324 : Str = "}"; - let Inspect.322 : Str = CallByName Inspect.63 Inspect.323 Inspect.324; - dec Inspect.324; - ret Inspect.322; - -procedure Inspect.231 (Inspect.232, Inspect.228): - let Inspect.354 : Int1 = CallByName Bool.1; - inc Inspect.232; - let Inspect.335 : {Str, Int1} = Struct {Inspect.232, Inspect.354}; - let Inspect.336 : {} = Struct {}; - let Inspect.334 : {Str, Int1} = CallByName List.18 Inspect.228 Inspect.335 Inspect.336; - ret Inspect.334; - -procedure Inspect.233 (Inspect.337, Inspect.338): - let Inspect.236 : Str = StructAtIndex 0 Inspect.338; - let Inspect.237 : Str = StructAtIndex 1 Inspect.338; - let Inspect.234 : Str = StructAtIndex 0 Inspect.337; - let Inspect.235 : Int1 = StructAtIndex 1 Inspect.337; - joinpoint Inspect.352 Inspect.238: - let Inspect.349 : Str = CallByName Inspect.63 Inspect.238 Inspect.236; - dec Inspect.236; - let Inspect.350 : Str = ": "; - let Inspect.344 : Str = CallByName Inspect.63 Inspect.349 Inspect.350; - dec Inspect.350; - let Inspect.340 : Str = CallByName Inspect.239 Inspect.344 Inspect.237; - let Inspect.341 : {} = Struct {}; - let Inspect.339 : {Str, Int1} = CallByName Inspect.241 Inspect.340; - dec Inspect.340; - ret Inspect.339; +procedure Inspect.225 (Inspect.226, Inspect.224): + let Inspect.338 : Str = "{"; + let Inspect.227 : Str = CallByName Inspect.63 Inspect.226 Inspect.338; + dec Inspect.338; + let Inspect.337 : Int1 = CallByName Bool.1; + let Inspect.318 : {Str, Int1} = Struct {Inspect.227, Inspect.337}; + let Inspect.319 : {} = Struct {}; + let Inspect.317 : {Str, Int1} = CallByName List.18 Inspect.224 Inspect.318 Inspect.319; + let Inspect.228 : Str = StructAtIndex 0 Inspect.317; + let Inspect.314 : Str = "}"; + let Inspect.313 : Str = CallByName Inspect.63 Inspect.228 Inspect.314; + dec Inspect.314; + ret Inspect.313; + +procedure Inspect.229 (Inspect.320, Inspect.321): + let Inspect.232 : Str = StructAtIndex 0 Inspect.321; + let Inspect.233 : Str = StructAtIndex 1 Inspect.321; + let Inspect.230 : Str = StructAtIndex 0 Inspect.320; + let Inspect.231 : Int1 = StructAtIndex 1 Inspect.320; + joinpoint Inspect.335 Inspect.234: + let Inspect.332 : Str = CallByName Inspect.63 Inspect.234 Inspect.232; + dec Inspect.232; + let Inspect.333 : Str = ": "; + let Inspect.327 : Str = CallByName Inspect.63 Inspect.332 Inspect.333; + dec Inspect.333; + let Inspect.323 : Str = CallByName Inspect.235 Inspect.327 Inspect.233; + dec Inspect.233; + let Inspect.324 : {} = Struct {}; + let Inspect.322 : {Str, Int1} = CallByName Inspect.237 Inspect.323; + dec Inspect.323; + ret Inspect.322; in - if Inspect.235 then - let Inspect.353 : Str = ", "; - let Inspect.351 : Str = CallByName Inspect.63 Inspect.234 Inspect.353; - dec Inspect.353; - jump Inspect.352 Inspect.351; + if Inspect.231 then + let Inspect.336 : Str = ", "; + let Inspect.334 : Str = CallByName Inspect.63 Inspect.230 Inspect.336; + dec Inspect.336; + jump Inspect.335 Inspect.334; else - jump Inspect.352 Inspect.234; + jump Inspect.335 Inspect.230; -procedure Inspect.239 (Inspect.240, Inspect.237): - let Inspect.347 : Str = CallByName Inspect.31 Inspect.237 Inspect.240; - ret Inspect.347; - -procedure Inspect.241 (Inspect.242): - let Inspect.343 : Int1 = CallByName Bool.2; - inc Inspect.242; - let Inspect.342 : {Str, Int1} = Struct {Inspect.242, Inspect.343}; - ret Inspect.342; - -procedure Inspect.243 (Inspect.329): - let Inspect.330 : Str = StructAtIndex 0 Inspect.329; +procedure Inspect.235 (Inspect.236, Inspect.233): + let Inspect.330 : Str = CallByName Inspect.31 Inspect.233 Inspect.236; ret Inspect.330; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.378 : Str = "\""; - let Inspect.363 : Str = CallByName Inspect.63 Inspect.251 Inspect.378; - dec Inspect.378; - let Inspect.361 : Str = CallByName Inspect.252 Inspect.363 Inspect.249; - let Inspect.362 : Str = "\""; - let Inspect.360 : Str = CallByName Inspect.63 Inspect.361 Inspect.362; - dec Inspect.362; - ret Inspect.360; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.376 : Str = "\u{feff}"; - let Inspect.377 : Str = "\\u(feff)"; - let Inspect.373 : Str = CallByName Str.45 Inspect.249 Inspect.376 Inspect.377; - dec Inspect.377; - dec Inspect.376; - let Inspect.374 : Str = "\u{200b}"; - let Inspect.375 : Str = "\\u(200b)"; - let Inspect.370 : Str = CallByName Str.45 Inspect.373 Inspect.374 Inspect.375; - dec Inspect.374; - dec Inspect.375; - let Inspect.371 : Str = "\u{200c}"; - let Inspect.372 : Str = "\\u(200c)"; - let Inspect.367 : Str = CallByName Str.45 Inspect.370 Inspect.371 Inspect.372; - dec Inspect.372; - dec Inspect.371; - let Inspect.368 : Str = "\u{200d}"; - let Inspect.369 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.367 Inspect.368 Inspect.369; - dec Inspect.369; - dec Inspect.368; - let Inspect.366 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.366; +procedure Inspect.237 (Inspect.238): + let Inspect.326 : Int1 = CallByName Bool.2; + inc Inspect.238; + let Inspect.325 : {Str, Int1} = Struct {Inspect.238, Inspect.326}; + ret Inspect.325; + +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.346 : Str = "\""; + let Inspect.345 : Str = CallByName Inspect.63 Inspect.246 Inspect.346; + dec Inspect.346; + let Inspect.343 : Str = CallByName Inspect.63 Inspect.345 Inspect.244; + let Inspect.344 : Str = "\""; + let Inspect.342 : Str = CallByName Inspect.63 Inspect.343 Inspect.344; + dec Inspect.344; + ret Inspect.342; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -143,52 +108,72 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.317 : Str = CallByName Inspect.229 Inspect.149 Inspect.306; - ret Inspect.317; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.309 : Str = CallByName Inspect.225 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.348 : Str = CallByName Inspect.250 Inspect.149 Inspect.306; - ret Inspect.348; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.331 : Str = CallByName Inspect.245 Inspect.149 Inspect.298; + ret Inspect.331; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.45 (Inspect.228): - let Inspect.318 : List {Str, Str} = CallByName Inspect.30 Inspect.228; - ret Inspect.318; +procedure Inspect.45 (Inspect.224): + let Inspect.310 : List {Str, Str} = CallByName Inspect.30 Inspect.224; + ret Inspect.310; -procedure Inspect.47 (Inspect.249): - let Inspect.379 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.379; +procedure Inspect.47 (Inspect.243): + let Inspect.369 : Str = "\u{feff}"; + let Inspect.370 : Str = "\\u(feff)"; + let Inspect.366 : Str = CallByName Str.45 Inspect.243 Inspect.369 Inspect.370; + dec Inspect.370; + dec Inspect.369; + let Inspect.367 : Str = "\u{200b}"; + let Inspect.368 : Str = "\\u(200b)"; + let Inspect.363 : Str = CallByName Str.45 Inspect.366 Inspect.367 Inspect.368; + dec Inspect.367; + dec Inspect.368; + let Inspect.364 : Str = "\u{200c}"; + let Inspect.365 : Str = "\\u(200c)"; + let Inspect.360 : Str = CallByName Str.45 Inspect.363 Inspect.364 Inspect.365; + dec Inspect.365; + dec Inspect.364; + let Inspect.361 : Str = "\u{200d}"; + let Inspect.362 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.360 Inspect.361 Inspect.362; + dec Inspect.362; + dec Inspect.361; + let Inspect.358 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.358; procedure Inspect.5 (Inspect.150): - let Inspect.315 : {Str, Str} = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.2 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : {Str, Str} = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.2 Inspect.303 Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.326 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.326; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.316 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.316; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; -procedure List.100 (#Derived_gen.18, #Derived_gen.19, #Derived_gen.20, #Derived_gen.21, #Derived_gen.22): +procedure List.100 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then let List.674 : {Str, Str} = CallByName List.66 List.174 List.177; inc List.674; - let List.179 : {Str, Int1} = CallByName Inspect.233 List.175 List.674; + let List.179 : {Str, Int1} = CallByName Inspect.229 List.175 List.674; let List.673 : U64 = 1i64; let List.672 : U64 = CallByName Num.51 List.177 List.673; jump List.668 List.174 List.179 List.176 List.672 List.178; @@ -196,8 +181,8 @@ procedure List.100 (#Derived_gen.18, #Derived_gen.19, #Derived_gen.20, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.18; - jump List.668 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22; + inc #Derived_gen.16; + jump List.668 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20; procedure List.18 (List.171, List.172, List.173): let List.666 : U64 = 0i64; @@ -289,27 +274,27 @@ procedure Str.38 (Str.112, Str.113): procedure Str.45 (Str.91, Str.92, Str.93): inc Str.91; - let Str.341 : [C {}, C {Str, Str}] = CallByName Str.38 Str.91 Str.92; - let Str.349 : U8 = 1i64; - let Str.350 : U8 = GetTagId Str.341; - let Str.351 : Int1 = lowlevel Eq Str.349 Str.350; - if Str.351 then - let Str.348 : {Str, Str} = UnionAtIndex (Id 1) (Index 0) Str.341; - let Str.95 : Str = StructAtIndex 0 Str.348; - let Str.94 : Str = StructAtIndex 1 Str.348; - let Str.346 : U64 = CallByName Str.36 Str.91; + let Str.385 : [C {}, C {Str, Str}] = CallByName Str.38 Str.91 Str.92; + let Str.393 : U8 = 1i64; + let Str.394 : U8 = GetTagId Str.385; + let Str.395 : Int1 = lowlevel Eq Str.393 Str.394; + if Str.395 then + let Str.392 : {Str, Str} = UnionAtIndex (Id 1) (Index 0) Str.385; + let Str.95 : Str = StructAtIndex 0 Str.392; + let Str.94 : Str = StructAtIndex 1 Str.392; + let Str.390 : U64 = CallByName Str.36 Str.91; dec Str.91; - let Str.345 : Str = CallByName Str.20 Str.346; - let Str.344 : Str = CallByName Str.3 Str.345 Str.94; + let Str.389 : Str = CallByName Str.20 Str.390; + let Str.388 : Str = CallByName Str.3 Str.389 Str.94; dec Str.94; - let Str.343 : Str = CallByName Str.3 Str.344 Str.93; - let Str.342 : Str = CallByName Str.56 Str.343 Str.95 Str.92 Str.93; - ret Str.342; + let Str.387 : Str = CallByName Str.3 Str.388 Str.93; + let Str.386 : Str = CallByName Str.56 Str.387 Str.95 Str.92 Str.93; + ret Str.386; else - dec Str.341; + dec Str.385; ret Str.91; -procedure Str.56 (#Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_gen.35): +procedure Str.56 (#Derived_gen.28, #Derived_gen.29, #Derived_gen.30, #Derived_gen.31): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -333,9 +318,9 @@ procedure Str.56 (#Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_ge dec Str.97; ret Str.255; in - inc #Derived_gen.34; - inc #Derived_gen.35; - jump Str.250 #Derived_gen.32 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35; + inc #Derived_gen.30; + inc #Derived_gen.31; + jump Str.250 #Derived_gen.28 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -345,7 +330,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.36, #Derived_gen.37, #Derived_gen.38, #Derived_gen.39): +procedure Str.58 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -365,9 +350,9 @@ procedure Str.58 (#Derived_gen.36, #Derived_gen.37, #Derived_gen.38, #Derived_ge let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.37; - inc #Derived_gen.36; - jump Str.278 #Derived_gen.36 #Derived_gen.37 #Derived_gen.38 #Derived_gen.39; + inc #Derived_gen.24; + inc #Derived_gen.25; + jump Str.278 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/inspect_derived_string.txt b/crates/compiler/test_mono/generated/inspect_derived_string.txt index 8e34caa54c7..d51bf516840 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_string.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_string.txt @@ -10,70 +10,66 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.23 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.23; -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.340 : Str = "\""; - let Inspect.325 : Str = CallByName Inspect.63 Inspect.251 Inspect.340; - dec Inspect.340; - let Inspect.321 : Str = CallByName Inspect.252 Inspect.325 Inspect.249; - let Inspect.322 : Str = "\""; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.321 Inspect.322; - dec Inspect.322; - ret Inspect.320; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.338 : Str = "\u{feff}"; - let Inspect.339 : Str = "\\u(feff)"; - let Inspect.335 : Str = CallByName Str.45 Inspect.249 Inspect.338 Inspect.339; - dec Inspect.338; - dec Inspect.339; - let Inspect.336 : Str = "\u{200b}"; - let Inspect.337 : Str = "\\u(200b)"; - let Inspect.332 : Str = CallByName Str.45 Inspect.335 Inspect.336 Inspect.337; - dec Inspect.337; - dec Inspect.336; - let Inspect.333 : Str = "\u{200c}"; - let Inspect.334 : Str = "\\u(200c)"; - let Inspect.329 : Str = CallByName Str.45 Inspect.332 Inspect.333 Inspect.334; - dec Inspect.334; - dec Inspect.333; - let Inspect.330 : Str = "\u{200d}"; - let Inspect.331 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.329 Inspect.330 Inspect.331; - dec Inspect.330; - dec Inspect.331; - let Inspect.328 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.328; +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.317 : Str = "\""; + let Inspect.316 : Str = CallByName Inspect.63 Inspect.246 Inspect.317; + dec Inspect.317; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.316 Inspect.244; + let Inspect.313 : Str = "\""; + let Inspect.311 : Str = CallByName Inspect.63 Inspect.312 Inspect.313; + dec Inspect.313; + ret Inspect.311; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.47 (Inspect.249): - let Inspect.316 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.316; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; + +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; + +procedure Inspect.47 (Inspect.243): + let Inspect.327 : Str = "\u{feff}"; + let Inspect.328 : Str = "\\u(feff)"; + let Inspect.324 : Str = CallByName Str.45 Inspect.243 Inspect.327 Inspect.328; + dec Inspect.327; + dec Inspect.328; + let Inspect.325 : Str = "\u{200b}"; + let Inspect.326 : Str = "\\u(200b)"; + let Inspect.321 : Str = CallByName Str.45 Inspect.324 Inspect.325 Inspect.326; + dec Inspect.326; + dec Inspect.325; + let Inspect.322 : Str = "\u{200c}"; + let Inspect.323 : Str = "\\u(200c)"; + let Inspect.318 : Str = CallByName Str.45 Inspect.321 Inspect.322 Inspect.323; + dec Inspect.322; + dec Inspect.323; + let Inspect.319 : Str = "\u{200d}"; + let Inspect.320 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.318 Inspect.319 Inspect.320; + dec Inspect.319; + dec Inspect.320; + let Inspect.308 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.308; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName Inspect.47 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.250 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : Str = CallByName Inspect.47 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.245 Inspect.303 Inspect.307; + dec Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.324 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.324; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.20 (#Attr.2, #Attr.3): let Num.288 : U64 = lowlevel NumSub #Attr.2 #Attr.3; @@ -171,7 +167,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.341; ret Str.91; -procedure Str.56 (#Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9): +procedure Str.56 (#Derived_gen.5, #Derived_gen.6, #Derived_gen.7, #Derived_gen.8): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -195,9 +191,9 @@ procedure Str.56 (#Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9 dec Str.97; ret Str.255; in + inc #Derived_gen.7; inc #Derived_gen.8; - inc #Derived_gen.9; - jump Str.250 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9; + jump Str.250 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -207,7 +203,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5): +procedure Str.58 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -227,9 +223,9 @@ procedure Str.58 (#Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5 let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.3; + inc #Derived_gen.1; inc #Derived_gen.2; - jump Str.278 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5; + jump Str.278 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/inspect_derived_tag_one_field_string.txt b/crates/compiler/test_mono/generated/inspect_derived_tag_one_field_string.txt index 8162cc853d7..6fec6d18f5c 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_tag_one_field_string.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_tag_one_field_string.txt @@ -27,77 +27,48 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.23 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.23; -procedure Inspect.204 (Inspect.205, #Attr.12): - let Inspect.349 : Str = UnionAtIndex (Id 0) (Index 0) #Attr.12; - let Inspect.348 : Str = CallByName Inspect.63 Inspect.205 Inspect.349; - dec Inspect.349; - ret Inspect.348; +procedure Inspect.201 (Inspect.202, #Attr.12): + let Inspect.335 : Str = UnionAtIndex (Id 0) (Index 0) #Attr.12; + let Inspect.334 : Str = CallByName Inspect.63 Inspect.202 Inspect.335; + dec Inspect.335; + ret Inspect.334; + +procedure Inspect.203 (Inspect.204, #Attr.12): + let Inspect.329 : List Str = UnionAtIndex (Id 1) (Index 1) #Attr.12; + let Inspect.328 : Str = UnionAtIndex (Id 1) (Index 0) #Attr.12; + let Inspect.327 : Str = "("; + let Inspect.326 : Str = CallByName Inspect.63 Inspect.204 Inspect.327; + dec Inspect.327; + let Inspect.205 : Str = CallByName Inspect.63 Inspect.326 Inspect.328; + dec Inspect.328; + let Inspect.318 : {} = Struct {}; + let Inspect.206 : Str = CallByName List.18 Inspect.329 Inspect.205 Inspect.318; + dec Inspect.329; + let Inspect.315 : Str = ")"; + let Inspect.314 : Str = CallByName Inspect.63 Inspect.206 Inspect.315; + dec Inspect.315; + ret Inspect.314; -procedure Inspect.206 (Inspect.207, #Attr.12): - let Inspect.343 : List Str = UnionAtIndex (Id 1) (Index 1) #Attr.12; - let Inspect.342 : Str = UnionAtIndex (Id 1) (Index 0) #Attr.12; - let Inspect.341 : Str = "("; - let Inspect.340 : Str = CallByName Inspect.63 Inspect.207 Inspect.341; - dec Inspect.341; - let Inspect.328 : Str = CallByName Inspect.63 Inspect.340 Inspect.342; - dec Inspect.342; - let Inspect.324 : Str = CallByName Inspect.208 Inspect.328 Inspect.343; - dec Inspect.343; - let Inspect.325 : Str = ")"; - let Inspect.323 : Str = CallByName Inspect.63 Inspect.324 Inspect.325; +procedure Inspect.207 (Inspect.208, Inspect.209): + let Inspect.325 : Str = " "; + let Inspect.320 : Str = CallByName Inspect.63 Inspect.208 Inspect.325; dec Inspect.325; + let Inspect.319 : Str = CallByName Inspect.210 Inspect.320 Inspect.209; + ret Inspect.319; + +procedure Inspect.210 (Inspect.211, Inspect.209): + let Inspect.323 : Str = CallByName Inspect.31 Inspect.209 Inspect.211; ret Inspect.323; -procedure Inspect.208 (Inspect.209, Inspect.203): - let Inspect.332 : {} = Struct {}; - let Inspect.331 : Str = CallByName List.18 Inspect.203 Inspect.209 Inspect.332; - ret Inspect.331; - -procedure Inspect.210 (Inspect.211, Inspect.212): - let Inspect.339 : Str = " "; - let Inspect.334 : Str = CallByName Inspect.63 Inspect.211 Inspect.339; - dec Inspect.339; - let Inspect.333 : Str = CallByName Inspect.213 Inspect.334 Inspect.212; - ret Inspect.333; - -procedure Inspect.213 (Inspect.214, Inspect.212): - let Inspect.337 : Str = CallByName Inspect.31 Inspect.212 Inspect.214; - ret Inspect.337; - -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.372 : Str = "\""; - let Inspect.357 : Str = CallByName Inspect.63 Inspect.251 Inspect.372; - dec Inspect.372; - let Inspect.355 : Str = CallByName Inspect.252 Inspect.357 Inspect.249; - let Inspect.356 : Str = "\""; - let Inspect.354 : Str = CallByName Inspect.63 Inspect.355 Inspect.356; - dec Inspect.356; - ret Inspect.354; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.370 : Str = "\u{feff}"; - let Inspect.371 : Str = "\\u(feff)"; - let Inspect.367 : Str = CallByName Str.45 Inspect.249 Inspect.370 Inspect.371; - dec Inspect.370; - dec Inspect.371; - let Inspect.368 : Str = "\u{200b}"; - let Inspect.369 : Str = "\\u(200b)"; - let Inspect.364 : Str = CallByName Str.45 Inspect.367 Inspect.368 Inspect.369; - dec Inspect.369; - dec Inspect.368; - let Inspect.365 : Str = "\u{200c}"; - let Inspect.366 : Str = "\\u(200c)"; - let Inspect.361 : Str = CallByName Str.45 Inspect.364 Inspect.365 Inspect.366; - dec Inspect.365; - dec Inspect.366; - let Inspect.362 : Str = "\u{200d}"; - let Inspect.363 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.361 Inspect.362 Inspect.363; - dec Inspect.362; - dec Inspect.363; - let Inspect.360 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.360; +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.343 : Str = "\""; + let Inspect.342 : Str = CallByName Inspect.63 Inspect.246 Inspect.343; + dec Inspect.343; + let Inspect.340 : Str = CallByName Inspect.63 Inspect.342 Inspect.244; + let Inspect.341 : Str = "\""; + let Inspect.339 : Str = CallByName Inspect.63 Inspect.340 Inspect.341; + dec Inspect.341; + ret Inspect.339; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -108,62 +79,82 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.318 : U8 = GetTagId Inspect.306; - switch Inspect.318: +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.310 : U8 = GetTagId Inspect.298; + switch Inspect.310: case 0: - let Inspect.317 : Str = CallByName Inspect.204 Inspect.149 Inspect.306; - ret Inspect.317; + let Inspect.309 : Str = CallByName Inspect.201 Inspect.149 Inspect.298; + ret Inspect.309; default: - let Inspect.317 : Str = CallByName Inspect.206 Inspect.149 Inspect.306; - ret Inspect.317; + let Inspect.309 : Str = CallByName Inspect.203 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.338 : Str = CallByName Inspect.250 Inspect.149 Inspect.306; - ret Inspect.338; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.324 : Str = CallByName Inspect.245 Inspect.149 Inspect.298; + ret Inspect.324; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.43 (Inspect.202, Inspect.203): - let Inspect.344 : Int1 = CallByName List.1 Inspect.203; - if Inspect.344 then - inc Inspect.202; - let Inspect.346 : [C Str, C Str List Str] = TagId(0) Inspect.202; - let Inspect.345 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.346; - ret Inspect.345; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; + +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; + +procedure Inspect.43 (Inspect.199, Inspect.200): + let Inspect.330 : Int1 = CallByName List.1 Inspect.200; + if Inspect.330 then + inc Inspect.199; + let Inspect.332 : [C Str, C Str List Str] = TagId(0) Inspect.199; + let Inspect.331 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.332; + ret Inspect.331; else - inc Inspect.203; - inc Inspect.202; - let Inspect.320 : [C Str, C Str List Str] = TagId(1) Inspect.202 Inspect.203; - let Inspect.319 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.320; - ret Inspect.319; - -procedure Inspect.47 (Inspect.249): - let Inspect.350 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.350; + inc Inspect.200; + inc Inspect.199; + let Inspect.312 : [C Str, C Str List Str] = TagId(1) Inspect.199 Inspect.200; + let Inspect.311 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.312; + ret Inspect.311; + +procedure Inspect.47 (Inspect.243): + let Inspect.353 : Str = "\u{feff}"; + let Inspect.354 : Str = "\\u(feff)"; + let Inspect.350 : Str = CallByName Str.45 Inspect.243 Inspect.353 Inspect.354; + dec Inspect.353; + dec Inspect.354; + let Inspect.351 : Str = "\u{200b}"; + let Inspect.352 : Str = "\\u(200b)"; + let Inspect.347 : Str = CallByName Str.45 Inspect.350 Inspect.351 Inspect.352; + dec Inspect.352; + dec Inspect.351; + let Inspect.348 : Str = "\u{200c}"; + let Inspect.349 : Str = "\\u(200c)"; + let Inspect.344 : Str = CallByName Str.45 Inspect.347 Inspect.348 Inspect.349; + dec Inspect.348; + dec Inspect.349; + let Inspect.345 : Str = "\u{200d}"; + let Inspect.346 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.344 Inspect.345 Inspect.346; + dec Inspect.346; + dec Inspect.345; + let Inspect.336 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.336; procedure Inspect.5 (Inspect.150): - let Inspect.315 : Str = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.3 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : Str = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.3 Inspect.303 Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.327 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.327; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.317 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.317; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure List.1 (List.118): let List.678 : U64 = CallByName List.6 List.118; @@ -171,13 +162,14 @@ procedure List.1 (List.118): let List.677 : Int1 = CallByName Bool.11 List.678 List.679; ret List.677; -procedure List.100 (#Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20, #Derived_gen.21): +procedure List.100 (#Derived_gen.19, #Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then let List.674 : Str = CallByName List.66 List.174 List.177; inc List.674; - let List.179 : Str = CallByName Inspect.210 List.175 List.674; + let List.179 : Str = CallByName Inspect.207 List.175 List.674; + dec List.674; let List.673 : U64 = 1i64; let List.672 : U64 = CallByName Num.51 List.177 List.673; jump List.668 List.174 List.179 List.176 List.672 List.178; @@ -185,8 +177,8 @@ procedure List.100 (#Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.17; - jump List.668 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20 #Derived_gen.21; + inc #Derived_gen.19; + jump List.668 #Derived_gen.19 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23; procedure List.18 (List.171, List.172, List.173): let List.666 : U64 = 0i64; @@ -298,7 +290,7 @@ procedure Str.45 (Str.91, Str.92, Str.93): dec Str.341; ret Str.91; -procedure Str.56 (#Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_gen.35): +procedure Str.56 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -322,9 +314,9 @@ procedure Str.56 (#Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_ge dec Str.97; ret Str.255; in - inc #Derived_gen.34; - inc #Derived_gen.35; - jump Str.250 #Derived_gen.32 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35; + inc #Derived_gen.27; + inc #Derived_gen.26; + jump Str.250 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -334,7 +326,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27): +procedure Str.58 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -354,9 +346,9 @@ procedure Str.58 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_ge let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.24; - inc #Derived_gen.25; - jump Str.278 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27; + inc #Derived_gen.14; + inc #Derived_gen.13; + jump Str.278 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/inspect_derived_tag_two_payloads_string.txt b/crates/compiler/test_mono/generated/inspect_derived_tag_two_payloads_string.txt index 22db01dd506..0f01f412d77 100644 --- a/crates/compiler/test_mono/generated/inspect_derived_tag_two_payloads_string.txt +++ b/crates/compiler/test_mono/generated/inspect_derived_tag_two_payloads_string.txt @@ -30,77 +30,48 @@ procedure Bool.3 (#Attr.2, #Attr.3): let Bool.23 : Int1 = lowlevel And #Attr.2 #Attr.3; ret Bool.23; -procedure Inspect.204 (Inspect.205, #Attr.12): - let Inspect.349 : Str = UnionAtIndex (Id 0) (Index 0) #Attr.12; - let Inspect.348 : Str = CallByName Inspect.63 Inspect.205 Inspect.349; - dec Inspect.349; - ret Inspect.348; - -procedure Inspect.206 (Inspect.207, #Attr.12): - let Inspect.343 : List Str = UnionAtIndex (Id 1) (Index 1) #Attr.12; - let Inspect.342 : Str = UnionAtIndex (Id 1) (Index 0) #Attr.12; - let Inspect.341 : Str = "("; - let Inspect.340 : Str = CallByName Inspect.63 Inspect.207 Inspect.341; - dec Inspect.341; - let Inspect.328 : Str = CallByName Inspect.63 Inspect.340 Inspect.342; - dec Inspect.342; - let Inspect.324 : Str = CallByName Inspect.208 Inspect.328 Inspect.343; - dec Inspect.343; - let Inspect.325 : Str = ")"; - let Inspect.323 : Str = CallByName Inspect.63 Inspect.324 Inspect.325; +procedure Inspect.201 (Inspect.202, #Attr.12): + let Inspect.335 : Str = UnionAtIndex (Id 0) (Index 0) #Attr.12; + let Inspect.334 : Str = CallByName Inspect.63 Inspect.202 Inspect.335; + dec Inspect.335; + ret Inspect.334; + +procedure Inspect.203 (Inspect.204, #Attr.12): + let Inspect.329 : List Str = UnionAtIndex (Id 1) (Index 1) #Attr.12; + let Inspect.328 : Str = UnionAtIndex (Id 1) (Index 0) #Attr.12; + let Inspect.327 : Str = "("; + let Inspect.326 : Str = CallByName Inspect.63 Inspect.204 Inspect.327; + dec Inspect.327; + let Inspect.205 : Str = CallByName Inspect.63 Inspect.326 Inspect.328; + dec Inspect.328; + let Inspect.318 : {} = Struct {}; + let Inspect.206 : Str = CallByName List.18 Inspect.329 Inspect.205 Inspect.318; + dec Inspect.329; + let Inspect.315 : Str = ")"; + let Inspect.314 : Str = CallByName Inspect.63 Inspect.206 Inspect.315; + dec Inspect.315; + ret Inspect.314; + +procedure Inspect.207 (Inspect.208, Inspect.209): + let Inspect.325 : Str = " "; + let Inspect.320 : Str = CallByName Inspect.63 Inspect.208 Inspect.325; dec Inspect.325; + let Inspect.319 : Str = CallByName Inspect.210 Inspect.320 Inspect.209; + ret Inspect.319; + +procedure Inspect.210 (Inspect.211, Inspect.209): + let Inspect.323 : Str = CallByName Inspect.31 Inspect.209 Inspect.211; ret Inspect.323; -procedure Inspect.208 (Inspect.209, Inspect.203): - let Inspect.332 : {} = Struct {}; - let Inspect.331 : Str = CallByName List.18 Inspect.203 Inspect.209 Inspect.332; - ret Inspect.331; - -procedure Inspect.210 (Inspect.211, Inspect.212): - let Inspect.339 : Str = " "; - let Inspect.334 : Str = CallByName Inspect.63 Inspect.211 Inspect.339; - dec Inspect.339; - let Inspect.333 : Str = CallByName Inspect.213 Inspect.334 Inspect.212; - ret Inspect.333; - -procedure Inspect.213 (Inspect.214, Inspect.212): - let Inspect.337 : Str = CallByName Inspect.31 Inspect.212 Inspect.214; - ret Inspect.337; - -procedure Inspect.250 (Inspect.251, Inspect.249): - let Inspect.372 : Str = "\""; - let Inspect.357 : Str = CallByName Inspect.63 Inspect.251 Inspect.372; - dec Inspect.372; - let Inspect.355 : Str = CallByName Inspect.252 Inspect.357 Inspect.249; - let Inspect.356 : Str = "\""; - let Inspect.354 : Str = CallByName Inspect.63 Inspect.355 Inspect.356; - dec Inspect.356; - ret Inspect.354; - -procedure Inspect.252 (Inspect.253, Inspect.249): - let Inspect.370 : Str = "\u{feff}"; - let Inspect.371 : Str = "\\u(feff)"; - let Inspect.367 : Str = CallByName Str.45 Inspect.249 Inspect.370 Inspect.371; - dec Inspect.370; - dec Inspect.371; - let Inspect.368 : Str = "\u{200b}"; - let Inspect.369 : Str = "\\u(200b)"; - let Inspect.364 : Str = CallByName Str.45 Inspect.367 Inspect.368 Inspect.369; - dec Inspect.369; - dec Inspect.368; - let Inspect.365 : Str = "\u{200c}"; - let Inspect.366 : Str = "\\u(200c)"; - let Inspect.361 : Str = CallByName Str.45 Inspect.364 Inspect.365 Inspect.366; - dec Inspect.365; - dec Inspect.366; - let Inspect.362 : Str = "\u{200d}"; - let Inspect.363 : Str = "\\u(200d)"; - let Inspect.254 : Str = CallByName Str.45 Inspect.361 Inspect.362 Inspect.363; - dec Inspect.362; - dec Inspect.363; - let Inspect.360 : Str = CallByName Inspect.63 Inspect.253 Inspect.254; - dec Inspect.254; - ret Inspect.360; +procedure Inspect.245 (Inspect.246, Inspect.244): + let Inspect.343 : Str = "\""; + let Inspect.342 : Str = CallByName Inspect.63 Inspect.246 Inspect.343; + dec Inspect.343; + let Inspect.340 : Str = CallByName Inspect.63 Inspect.342 Inspect.244; + let Inspect.341 : Str = "\""; + let Inspect.339 : Str = CallByName Inspect.63 Inspect.340 Inspect.341; + dec Inspect.341; + ret Inspect.339; procedure Inspect.30 (Inspect.147): ret Inspect.147; @@ -111,62 +82,82 @@ procedure Inspect.30 (Inspect.147): procedure Inspect.30 (Inspect.147): ret Inspect.147; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.318 : U8 = GetTagId Inspect.306; - switch Inspect.318: +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.310 : U8 = GetTagId Inspect.298; + switch Inspect.310: case 0: - let Inspect.317 : Str = CallByName Inspect.204 Inspect.149 Inspect.306; - ret Inspect.317; + let Inspect.309 : Str = CallByName Inspect.201 Inspect.149 Inspect.298; + ret Inspect.309; default: - let Inspect.317 : Str = CallByName Inspect.206 Inspect.149 Inspect.306; - ret Inspect.317; + let Inspect.309 : Str = CallByName Inspect.203 Inspect.149 Inspect.298; + ret Inspect.309; -procedure Inspect.31 (Inspect.306, Inspect.149): - let Inspect.338 : Str = CallByName Inspect.250 Inspect.149 Inspect.306; - ret Inspect.338; +procedure Inspect.31 (Inspect.298, Inspect.149): + let Inspect.324 : Str = CallByName Inspect.245 Inspect.149 Inspect.298; + ret Inspect.324; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.43 (Inspect.202, Inspect.203): - let Inspect.344 : Int1 = CallByName List.1 Inspect.203; - if Inspect.344 then - inc Inspect.202; - let Inspect.346 : [C Str, C Str List Str] = TagId(0) Inspect.202; - let Inspect.345 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.346; - ret Inspect.345; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; + +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; + +procedure Inspect.43 (Inspect.199, Inspect.200): + let Inspect.330 : Int1 = CallByName List.1 Inspect.200; + if Inspect.330 then + inc Inspect.199; + let Inspect.332 : [C Str, C Str List Str] = TagId(0) Inspect.199; + let Inspect.331 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.332; + ret Inspect.331; else - inc Inspect.203; - inc Inspect.202; - let Inspect.320 : [C Str, C Str List Str] = TagId(1) Inspect.202 Inspect.203; - let Inspect.319 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.320; - ret Inspect.319; - -procedure Inspect.47 (Inspect.249): - let Inspect.373 : Str = CallByName Inspect.30 Inspect.249; - ret Inspect.373; + inc Inspect.200; + inc Inspect.199; + let Inspect.312 : [C Str, C Str List Str] = TagId(1) Inspect.199 Inspect.200; + let Inspect.311 : [C Str, C Str List Str] = CallByName Inspect.30 Inspect.312; + ret Inspect.311; + +procedure Inspect.47 (Inspect.243): + let Inspect.366 : Str = "\u{feff}"; + let Inspect.367 : Str = "\\u(feff)"; + let Inspect.363 : Str = CallByName Str.45 Inspect.243 Inspect.366 Inspect.367; + dec Inspect.367; + dec Inspect.366; + let Inspect.364 : Str = "\u{200b}"; + let Inspect.365 : Str = "\\u(200b)"; + let Inspect.360 : Str = CallByName Str.45 Inspect.363 Inspect.364 Inspect.365; + dec Inspect.365; + dec Inspect.364; + let Inspect.361 : Str = "\u{200c}"; + let Inspect.362 : Str = "\\u(200c)"; + let Inspect.357 : Str = CallByName Str.45 Inspect.360 Inspect.361 Inspect.362; + dec Inspect.362; + dec Inspect.361; + let Inspect.358 : Str = "\u{200d}"; + let Inspect.359 : Str = "\\u(200d)"; + let Inspect.244 : Str = CallByName Str.45 Inspect.357 Inspect.358 Inspect.359; + dec Inspect.359; + dec Inspect.358; + let Inspect.355 : Str = CallByName Inspect.30 Inspect.244; + ret Inspect.355; procedure Inspect.5 (Inspect.150): - let Inspect.315 : {Str, Str} = CallByName #Derived.0 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName #Derived.4 Inspect.311 Inspect.315; - ret Inspect.310; + let Inspect.307 : {Str, Str} = CallByName #Derived.0 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName #Derived.4 Inspect.303 Inspect.307; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.327 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.327; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.317 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.317; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure List.1 (List.118): let List.678 : U64 = CallByName List.6 List.118; @@ -174,13 +165,14 @@ procedure List.1 (List.118): let List.677 : Int1 = CallByName Bool.11 List.678 List.679; ret List.677; -procedure List.100 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17): +procedure List.100 (#Derived_gen.18, #Derived_gen.19, #Derived_gen.20, #Derived_gen.21, #Derived_gen.22): joinpoint List.668 List.174 List.175 List.176 List.177 List.178: let List.670 : Int1 = CallByName Num.22 List.177 List.178; if List.670 then let List.674 : Str = CallByName List.66 List.174 List.177; inc List.674; - let List.179 : Str = CallByName Inspect.210 List.175 List.674; + let List.179 : Str = CallByName Inspect.207 List.175 List.674; + dec List.674; let List.673 : U64 = 1i64; let List.672 : U64 = CallByName Num.51 List.177 List.673; jump List.668 List.174 List.179 List.176 List.672 List.178; @@ -188,8 +180,8 @@ procedure List.100 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_ dec List.174; ret List.175; in - inc #Derived_gen.13; - jump List.668 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17; + inc #Derived_gen.18; + jump List.668 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22; procedure List.18 (List.171, List.172, List.173): let List.666 : U64 = 0i64; @@ -281,27 +273,27 @@ procedure Str.38 (Str.112, Str.113): procedure Str.45 (Str.91, Str.92, Str.93): inc Str.91; - let Str.341 : [C {}, C {Str, Str}] = CallByName Str.38 Str.91 Str.92; - let Str.349 : U8 = 1i64; - let Str.350 : U8 = GetTagId Str.341; - let Str.351 : Int1 = lowlevel Eq Str.349 Str.350; - if Str.351 then - let Str.348 : {Str, Str} = UnionAtIndex (Id 1) (Index 0) Str.341; - let Str.95 : Str = StructAtIndex 0 Str.348; - let Str.94 : Str = StructAtIndex 1 Str.348; - let Str.346 : U64 = CallByName Str.36 Str.91; + let Str.385 : [C {}, C {Str, Str}] = CallByName Str.38 Str.91 Str.92; + let Str.393 : U8 = 1i64; + let Str.394 : U8 = GetTagId Str.385; + let Str.395 : Int1 = lowlevel Eq Str.393 Str.394; + if Str.395 then + let Str.392 : {Str, Str} = UnionAtIndex (Id 1) (Index 0) Str.385; + let Str.95 : Str = StructAtIndex 0 Str.392; + let Str.94 : Str = StructAtIndex 1 Str.392; + let Str.390 : U64 = CallByName Str.36 Str.91; dec Str.91; - let Str.345 : Str = CallByName Str.20 Str.346; - let Str.344 : Str = CallByName Str.3 Str.345 Str.94; + let Str.389 : Str = CallByName Str.20 Str.390; + let Str.388 : Str = CallByName Str.3 Str.389 Str.94; dec Str.94; - let Str.343 : Str = CallByName Str.3 Str.344 Str.93; - let Str.342 : Str = CallByName Str.56 Str.343 Str.95 Str.92 Str.93; - ret Str.342; + let Str.387 : Str = CallByName Str.3 Str.388 Str.93; + let Str.386 : Str = CallByName Str.56 Str.387 Str.95 Str.92 Str.93; + ret Str.386; else - dec Str.341; + dec Str.385; ret Str.91; -procedure Str.56 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35, #Derived_gen.36): +procedure Str.56 (#Derived_gen.25, #Derived_gen.26, #Derived_gen.27, #Derived_gen.28): joinpoint Str.250 Str.96 Str.97 Str.98 Str.99: inc Str.97; let Str.251 : [C {}, C {Str, Str}] = CallByName Str.38 Str.97 Str.98; @@ -325,9 +317,9 @@ procedure Str.56 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35, #Derived_ge dec Str.97; ret Str.255; in - inc #Derived_gen.36; - inc #Derived_gen.35; - jump Str.250 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35 #Derived_gen.36; + inc #Derived_gen.28; + inc #Derived_gen.27; + jump Str.250 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27 #Derived_gen.28; procedure Str.57 (Str.121, Str.122): let Str.123 : U64 = CallByName Str.36 Str.121; @@ -337,7 +329,7 @@ procedure Str.57 (Str.121, Str.122): let Str.276 : [C , C U64] = CallByName Str.58 Str.121 Str.122 Str.277 Str.125; ret Str.276; -procedure Str.58 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27): +procedure Str.58 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16): joinpoint Str.278 Str.126 Str.127 Str.128 Str.129: let Str.280 : Int1 = CallByName Num.23 Str.128 Str.129; if Str.280 then @@ -357,9 +349,9 @@ procedure Str.58 (#Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_ge let Str.279 : [C , C U64] = TagId(0) ; ret Str.279; in - inc #Derived_gen.24; - inc #Derived_gen.25; - jump Str.278 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27; + inc #Derived_gen.14; + inc #Derived_gen.13; + jump Str.278 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16; procedure Str.61 (Str.152, Str.153): let Str.308 : Int1 = CallByName Num.22 Str.152 Str.153; diff --git a/crates/compiler/test_mono/generated/linked_list_filter.txt b/crates/compiler/test_mono/generated/linked_list_filter.txt index 659ccd01420..8d48bbf5b7d 100644 --- a/crates/compiler/test_mono/generated/linked_list_filter.txt +++ b/crates/compiler/test_mono/generated/linked_list_filter.txt @@ -1,56 +1,42 @@ -procedure Num.31 (Num.220): - let Num.284 : I64 = 2i64; - let Num.283 : Int1 = CallByName Num.86 Num.220 Num.284; - ret Num.283; - -procedure Num.86 (#Attr.2, #Attr.3): - let Num.285 : Int1 = lowlevel NumIsMultipleOf #Attr.2 #Attr.3; - ret Num.285; - -procedure Test.2 (#Derived_gen.0, #Derived_gen.1): - let #Derived_gen.3 : [, C I64 *self] = NullPointer; - let #Derived_gen.2 : Ptr([, C I64 *self]) = Alloca #Derived_gen.3; - joinpoint #Derived_gen.4 Test.4 Test.5 #Derived_gen.5 #Derived_gen.6: - let Test.22 : U8 = 1i64; - let Test.23 : U8 = GetTagId Test.4; - let Test.24 : Int1 = lowlevel Eq Test.22 Test.23; - if Test.24 then - let Test.17 : [, C I64 *self] = TagId(1) ; - let #Derived_gen.8 : {} = lowlevel PtrStore #Derived_gen.5 Test.17; - let #Derived_gen.7 : [, C I64 *self] = lowlevel PtrLoad #Derived_gen.6; - ret #Derived_gen.7; +procedure Test.2 (Test.4, Test.5): + let Test.23 : U8 = 1i64; + let Test.24 : U8 = GetTagId Test.4; + let Test.25 : Int1 = lowlevel Eq Test.23 Test.24; + if Test.25 then + let Test.17 : [, C I64 *self] = TagId(1) ; + ret Test.17; + else + let Test.7 : I64 = UnionAtIndex (Id 0) (Index 0) Test.4; + let Test.8 : [, C I64 *self] = UnionAtIndex (Id 0) (Index 1) Test.4; + joinpoint #Derived_gen.2: + dec Test.8; + let Test.22 : Str = "a Lambda Set is empty. Most likely there is a type error in your program."; + Crash Test.22 + in + let #Derived_gen.3 : Int1 = lowlevel RefCountIsUnique Test.4; + if #Derived_gen.3 then + free Test.4; + jump #Derived_gen.2; else - let Test.7 : I64 = UnionAtIndex (Id 0) (Index 0) Test.4; - let Test.8 : [, C I64 *self] = UnionAtIndex (Id 0) (Index 1) Test.4; - joinpoint #Derived_gen.12 #Derived_gen.14: - let Test.19 : Int1 = CallByName Num.31 Test.7; - if Test.19 then - let #Derived_gen.9 : [, C I64 *self] = NullPointer; - let Test.20 : [, C I64 *self] = Reuse #Derived_gen.14 UpdateModeId { id: 1 } TagId(0) Test.7 #Derived_gen.9; - let #Derived_gen.10 : Ptr([, C I64 *self]) = GetElementPointer (Indices [0, 1]) Test.20; - let #Derived_gen.11 : {} = lowlevel PtrStore #Derived_gen.5 Test.20; - jump #Derived_gen.4 Test.8 Test.5 #Derived_gen.10 #Derived_gen.6; - else - decref #Derived_gen.14; - jump #Derived_gen.4 Test.8 Test.5 #Derived_gen.5 #Derived_gen.6; - in - let #Derived_gen.13 : Int1 = lowlevel RefCountIsUnique Test.4; - if #Derived_gen.13 then - jump #Derived_gen.12 Test.4; - else - inc Test.8; - decref Test.4; - let #Derived_gen.15 : [, C I64 *self] = NullPointer; - jump #Derived_gen.12 #Derived_gen.15; - in - jump #Derived_gen.4 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.2; + inc Test.8; + decref Test.4; + jump #Derived_gen.2; procedure Test.0 (): - let Test.25 : I64 = 1i64; - let Test.27 : I64 = 2i64; - let Test.28 : [, C I64 *self] = TagId(1) ; - let Test.26 : [, C I64 *self] = TagId(0) Test.27 Test.28; - let Test.14 : [, C I64 *self] = TagId(0) Test.25 Test.26; - let Test.15 : {} = Struct {}; - let Test.13 : [, C I64 *self] = CallByName Test.2 Test.14 Test.15; - ret Test.13; + let Test.27 : I64 = 1i64; + let Test.29 : I64 = 2i64; + let Test.30 : [, C I64 *self] = TagId(1) ; + let Test.28 : [, C I64 *self] = TagId(0) Test.29 Test.30; + let Test.14 : [, C I64 *self] = TagId(0) Test.27 Test.28; + joinpoint #Derived_gen.4: + let Test.26 : Str = "ValueNotExposed { module_name: ModuleName(IdentStr { string: \"Num\" }), ident: Ident(IdentStr { string: \"isEven\" }), region: @416-426, exposed_values: ['max_f32', 'min_f32', 'abs', 'neg', 'add', 'sub', 'mul', 'is_lt', 'is_lte', 'is_gt', 'is_gte', 'to_frac', 'sin', 'cos', 'tan', 'is_zero', 'is_even', 'is_odd', 'is_positive', 'is_negative', 'rem', 'rem_checked', 'div', 'div_checked', 'div_trunc', 'div_trunc_checked', 'sqrt', 'sqrt_checked', 'log', 'log_checked', 'round', 'compare', 'pow', 'ceiling', 'pow_int', 'floor', 'add_wrap', 'add_checked', 'add_saturated', 'atan', 'acos', 'asin', 'bitwise_and', 'bitwise_xor', 'bitwise_or', 'shift_left_by', 'shift_right_by', 'shift_right_zf_by', 'sub_wrap', 'sub_checked', 'sub_saturated', 'mul_wrap', 'mul_checked', 'mul_saturated', 'e', 'pi', 'tau', 'is_multiple_of', 'count_one_bits', 'abs_diff', 'is_nan', 'is_infinite', 'is_finite', 'count_leading_zero_bits', 'count_trailing_zero_bits', 'to_str', 'min_i8', 'max_i8', 'min_u8', 'max_u8', 'min_i16', 'max_i16', 'min_u16', 'max_u16', 'min_i32', 'max_i32', 'min_u32', 'max_u32', 'min_i64', 'max_i64', 'min_u64', 'max_u64', 'min_i128', 'max_i128', 'min_u128', 'max_u128', 'to_i8', 'to_i8_checked', 'to_i16', 'to_i16_checked', 'to_i32', 'to_i32_checked', 'to_i64', 'to_i64_checked', 'to_i128', 'to_i128_checked', 'to_u8', 'to_u8_checked', 'to_u16', 'to_u16_checked', 'to_u32', 'to_u32_checked', 'to_u64', 'to_u64_checked', 'to_u128', 'to_u128_checked', 'div_ceil', 'div_ceil_checked', 'to_f32', 'to_f32_checked', 'to_f64', 'to_f64_checked', 'max_f64', 'min_f64', 'add_checked_lowlevel', 'sub_checked_lowlevel', 'mul_checked_lowlevel', 'min', 'max', 'bitwise_not', 'int_cast', 'is_approx_eq', 'bytes_to_u16_owlevel', 'bytes_to_u32_lowlevel', 'bytes_to_u64_lowlevel', 'bytes_to_u128_lowlevel', 'div_trunc_unchecked', 'rem_unchecked', 'without_decimal_point', 'with_decimal_point', 'f32_to_parts', 'f64_to_parts', 'f32_from_parts', 'f64_from_parts', 'nan_f32', 'nan_f64', 'infinity_f32', 'infinity_f64', 'from_bool'] }"; + Crash Test.26 + in + let #Derived_gen.5 : Int1 = lowlevel RefCountIsUnique Test.14; + if #Derived_gen.5 then + dec Test.28; + free Test.14; + jump #Derived_gen.4; + else + decref Test.14; + jump #Derived_gen.4; diff --git a/crates/compiler/test_mono/generated/pizza_dbg.txt b/crates/compiler/test_mono/generated/pizza_dbg.txt index 1cea16b3a3d..3c8c1193143 100644 --- a/crates/compiler/test_mono/generated/pizza_dbg.txt +++ b/crates/compiler/test_mono/generated/pizza_dbg.txt @@ -1,38 +1,38 @@ -procedure Inspect.281 (Inspect.282, Inspect.280): - let Inspect.321 : Str = CallByName Num.96 Inspect.280; - let Inspect.320 : Str = CallByName Inspect.63 Inspect.282 Inspect.321; - dec Inspect.321; - ret Inspect.320; +procedure Inspect.273 (Inspect.274, Inspect.272): + let Inspect.313 : Str = CallByName Num.96 Inspect.272; + let Inspect.312 : Str = CallByName Inspect.63 Inspect.274 Inspect.313; + dec Inspect.313; + ret Inspect.312; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.325 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.324 : Str = CallByName Inspect.64 Inspect.325; - ret Inspect.324; - -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; - -procedure Inspect.5 (Inspect.150): - let Inspect.315 : I64 = CallByName Inspect.57 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.281 Inspect.311 Inspect.315; - ret Inspect.310; - -procedure Inspect.57 (Inspect.280): - let Inspect.316 : I64 = CallByName Inspect.30 Inspect.280; + let Inspect.317 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.316 : Str = CallByName Inspect.64 Inspect.317; ret Inspect.316; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.323 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.323; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.5 (Inspect.150): + let Inspect.307 : I64 = CallByName Inspect.57 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.273 Inspect.303 Inspect.307; + ret Inspect.302; + +procedure Inspect.57 (Inspect.272): + let Inspect.308 : I64 = CallByName Inspect.30 Inspect.272; + ret Inspect.308; + +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.315 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.315; + +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Num.19 (#Attr.2, #Attr.3): let Num.283 : I64 = lowlevel NumAdd #Attr.2 #Attr.3; diff --git a/crates/compiler/test_mono/src/tests.rs b/crates/compiler/test_mono/src/tests.rs index e13833aab82..c59eddaff0d 100644 --- a/crates/compiler/test_mono/src/tests.rs +++ b/crates/compiler/test_mono/src/tests.rs @@ -33,47 +33,47 @@ const TARGET: roc_target::Target = roc_target::Target::LinuxX64; pub const ERR_DECODER_FMT: &str = r#" ErrDecoder := {} implements [ DecoderFormatting { - u8: decodeU8, - u16: decodeU16, - u32: decodeU32, - u64: decodeU64, - u128: decodeU128, - i8: decodeI8, - i16: decodeI16, - i32: decodeI32, - i64: decodeI64, - i128: decodeI128, - f32: decodeF32, - f64: decodeF64, - dec: decodeDec, - bool: decodeBool, - string: decodeString, - list: decodeList, - record: decodeRecord, - tuple: decodeTuple, + u8: decode_u8, + u16: decode_u16, + u32: decode_u32, + u64: decode_u64, + u128: decode_u128, + i8: decode_i8, + i16: decode_i16, + i32: decode_i32, + i64: decode_i64, + i128: decode_i128, + f32: decode_f32, + f64: decode_f64, + dec: decode_dec, + bool: decode_bool, + string: decode_string, + list: decode_list, + record: decode_record, + tuple: decode_tuple, }, ] -decodeU8 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeU16 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeU32 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeU64 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeU128 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeI8 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeI16 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeI32 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeI64 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeI128 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeF32 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeF64 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeDec = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeBool = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeString = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeList : Decoder elem ErrDecoder -> Decoder (List elem) ErrDecoder -decodeList = \_ -> Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeRecord : state, (state, Str -> [Keep (Decoder state ErrDecoder), Skip]), (state, ErrDecoder -> Result val DecodeError) -> Decoder val ErrDecoder -decodeRecord = \_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } -decodeTuple : state, (state, U64 -> [Next (Decoder state ErrDecoder), TooLong]), (state -> Result val DecodeError) -> Decoder val ErrDecoder -decodeTuple = \_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_u8 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_u16 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_u32 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_u64 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_u128 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_i8 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_i16 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_i32 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_i64 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_i128 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_f32 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_f64 = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_dec = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_bool = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_string = Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_list : Decoder elem ErrDecoder -> Decoder (List elem) ErrDecoder +decode_list = \_ -> Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_record : state, (state, Str -> [Keep (Decoder state ErrDecoder), Skip]), (state, ErrDecoder -> Result val DecodeError) -> Decoder val ErrDecoder +decode_record = \_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } +decode_tuple : state, (state, U64 -> [Next (Decoder state ErrDecoder), TooLong]), (state -> Result val DecodeError) -> Decoder val ErrDecoder +decode_tuple = \_, _, _ -> Decode.custom \rest, @ErrDecoder {} -> { result: Err TooShort, rest } "#; /// Without this, some tests pass in `cargo test --release` but fail without @@ -367,7 +367,7 @@ fn ir_round() { #[mono_test] fn ir_when_idiv() { r" - when Num.divTruncChecked 1000 10 is + when Num.div_trunc_checked 1000 10 is Ok val -> val Err _ -> -1 " @@ -458,9 +458,9 @@ fn dict() { #[mono_test] fn list_append_closure() { r" - myFunction = \l -> List.append l 42 + my_function = \l -> List.append l 42 - myFunction [1, 2] + my_function [1, 2] " } @@ -687,18 +687,18 @@ fn opaque_as_pattern_in_closure_arg() { fn quicksort_help() { // do we still need with_larger_debug_stack? r" - quicksortHelp : List (Num a), I64, I64 -> List (Num a) - quicksortHelp = \list, low, high -> + quicksort_help : List (Num a), I64, I64 -> List (Num a) + quicksort_help = \list, low, high -> if low < high then - (Pair partitionIndex partitioned) = Pair 0 [] + (Pair partition_index partitioned) = Pair 0 [] partitioned - |> quicksortHelp low (partitionIndex - 1) - |> quicksortHelp (partitionIndex + 1) high + |> quicksort_help low (partition_index - 1) + |> quicksort_help (partition_index + 1) high else list - quicksortHelp [] 0 0 + quicksort_help [] 0 0 " } @@ -710,10 +710,10 @@ fn quicksort_swap() { swap = \list -> when Pair (List.get list 0) (List.get list 0) is - Pair (Ok atI) (Ok atJ) -> + Pair (Ok at_i) (Ok at_j) -> list - |> List.set 0 atJ - |> List.set 0 atI + |> List.set 0 at_j + |> List.set 0 at_i _ -> [] @@ -731,15 +731,15 @@ fn quicksort_swap() { // r#" // app "test" provides [main] to "./platform" -// partitionHelp : I64, I64, List (Num a), I64, (Num a) -> [Pair I64 (List (Num a))] -// partitionHelp = \i, j, list, high, pivot -> +// partition_help : I64, I64, List (Num a), I64, (Num a) -> [Pair I64 (List (Num a))] +// partition_help = \i, j, list, high, pivot -> // if j < high then // when List.get list j is // Ok value -> // if value <= pivot then -// partitionHelp (i + 1) (j + 1) (swap (i + 1) j list) high pivot +// partition_help (i + 1) (j + 1) (swap (i + 1) j list) high pivot // else -// partitionHelp i (j + 1) list high pivot +// partition_help i (j + 1) list high pivot // Err _ -> // Pair i list @@ -747,7 +747,7 @@ fn quicksort_swap() { // Pair i list // main = -// partitionHelp 0 0 [] 0 0 +// partition_help 0 0 [] 0 0 // "# // ) // } @@ -759,57 +759,57 @@ fn quicksort_swap() { // r#" // app "test" provides [main] to "./platform" -// quicksortHelp : List (Num a), I64, I64 -> List (Num a) -// quicksortHelp = \list, low, high -> +// quicksort_help : List (Num a), I64, I64 -> List (Num a) +// quicksort_help = \list, low, high -> // if low < high then -// (Pair partitionIndex partitioned) = partition low high list +// (Pair partition_index partitioned) = partition low high list // partitioned -// |> quicksortHelp low (partitionIndex - 1) -// |> quicksortHelp (partitionIndex + 1) high +// |> quicksort_help low (partition_index - 1) +// |> quicksort_help (partition_index + 1) high // else // list // swap : I64, I64, List a -> List a // swap = \i, j, list -> // when Pair (List.get list i) (List.get list j) is -// Pair (Ok atI) (Ok atJ) -> +// Pair (Ok at_i) (Ok at_j) -> // list -// |> List.set i atJ -// |> List.set j atI +// |> List.set i at_j +// |> List.set j at_i // _ -> // [] // partition : I64, I64, List (Num a) -> [Pair I64 (List (Num a))] -// partition = \low, high, initialList -> -// when List.get initialList high is +// partition = \low, high, initial_list -> +// when List.get initial_list high is // Ok pivot -> -// when partitionHelp (low - 1) low initialList high pivot is -// Pair newI newList -> -// Pair (newI + 1) (swap (newI + 1) high newList) +// when partition_help (low - 1) low initial_list high pivot is +// Pair new_i newList -> +// Pair (new_i + 1) (swap (new_i + 1) high newList) // Err _ -> -// Pair (low - 1) initialList +// Pair (low - 1) initial_list -// partitionHelp : I64, I64, List (Num a), I64, (Num a) -> [Pair I64 (List (Num a))] -// partitionHelp = \i, j, list, high, pivot -> +// partition_help : I64, I64, List (Num a), I64, (Num a) -> [Pair I64 (List (Num a))] +// partition_help = \i, j, list, high, pivot -> // if j < high then // when List.get list j is // Ok value -> // if value <= pivot then -// partitionHelp (i + 1) (j + 1) (swap (i + 1) j list) high pivot +// partition_help (i + 1) (j + 1) (swap (i + 1) j list) high pivot // else -// partitionHelp i (j + 1) list high pivot +// partition_help i (j + 1) list high pivot // Err _ -> // Pair i list // else // Pair i list -// quicksort = \originalList -> -// n = List.len originalList -// quicksortHelp originalList 0 (n - 1) +// quicksort = \original_list -> +// n = List.len original_list +// quicksort_help original_list 0 (n - 1) // main = // quicksort [1,2,3] @@ -837,13 +837,13 @@ fn is_nil() { r" ConsList a : [Cons a (ConsList a), Nil] - isNil : ConsList a -> Bool - isNil = \list -> + is_nil : ConsList a -> Bool + is_nil = \list -> when list is Nil -> Bool.true Cons _ _ -> Bool.false - isNil (Cons 0x2 Nil) + is_nil (Cons 0x2 Nil) " } @@ -854,14 +854,14 @@ fn has_none() { Maybe a : [Just a, Nothing] ConsList a : [Cons a (ConsList a), Nil] - hasNone : ConsList (Maybe a) -> Bool - hasNone = \list -> + has_none : ConsList (Maybe a) -> Bool + has_none = \list -> when list is Nil -> Bool.false Cons Nothing _ -> Bool.true - Cons (Just _) xs -> hasNone xs + Cons (Just _) xs -> has_none xs - hasNone (Cons (Just 3) Nil) + has_none (Cons (Just 3) Nil) " } @@ -871,10 +871,10 @@ fn mk_pair_of() { r#" app "test" provides [main] to "./platform" - mkPairOf = \x -> Pair x x + mk_pair_of = \x -> Pair x x main = - mkPairOf [1,2,3] + mk_pair_of [1,2,3] "# ) } @@ -1052,12 +1052,12 @@ fn rigids() { swap : U64, U64, List a -> List a swap = \i, j, list -> when Pair (List.get list i) (List.get list j) is - Pair (Ok atI) (Ok atJ) -> - foo = atJ + Pair (Ok at_i) (Ok at_j) -> + foo = at_j list |> List.set i foo - |> List.set j atI + |> List.set j at_i _ -> [] @@ -1236,17 +1236,17 @@ fn empty_list_of_function_type() { app "test" provides [main] to "./platform" main = - myList : List (Str -> Str) - myList = [] + my_list : List (Str -> Str) + my_list = [] - myClosure : Str -> Str - myClosure = \_ -> "bar" + my_closure : Str -> Str + my_closure = \_ -> "bar" choose = if Bool.false then - myList + my_list else - [myClosure] + [my_closure] when List.get choose 0 is Ok f -> f "foo" @@ -1417,8 +1417,8 @@ fn issue_2725_alias_polymorphic_lambda() { indoc!( r" wrap = \value -> Tag value - wrapIt = wrap - wrapIt 42 + wrap_it = wrap + wrap_it 42 " ) } @@ -1427,7 +1427,7 @@ fn issue_2725_alias_polymorphic_lambda() { fn issue_2583_specialize_errors_behind_unified_branches() { indoc!( r#" - if Bool.true then List.first [] else Str.toI64 "" + if Bool.true then List.first [] else Str.to_i64 "" "# ) } @@ -1487,11 +1487,11 @@ fn opaque_assign_to_symbol() { Variable := U8 - fromUtf8 : U8 -> Result Variable [InvalidVariableUtf8] - fromUtf8 = \char -> + from_utf8 : U8 -> Result Variable [InvalidVariableUtf8] + from_utf8 = \char -> Ok (@Variable char) - out = fromUtf8 98 + out = from_utf8 98 "# ) } @@ -1500,12 +1500,12 @@ fn opaque_assign_to_symbol() { fn encode() { indoc!( r#" - app "test" provides [myU8Bytes] to "./platform" + app "test" provides [my_u8_bytes] to "./platform" MEncoder fmt := List U8, fmt -> List U8 where fmt implements Format MEncoding implements - toEncoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format + to_encoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format Format implements u8 : U8 -> MEncoder fmt where fmt implements Format @@ -1515,13 +1515,13 @@ fn encode() { u8 = \n -> @MEncoder (\lst, @Linear {} -> List.append lst n) - MyU8 := U8 implements [MEncoding {toEncoder}] + MyU8 := U8 implements [MEncoding {to_encoder}] - toEncoder = \@MyU8 n -> u8 n + to_encoder = \@MyU8 n -> u8 n - myU8Bytes = - when toEncoder (@MyU8 15) is - @MEncoder doEncode -> doEncode [] (@Linear {}) + my_u8_bytes = + when to_encoder (@MyU8 15) is + @MEncoder do_encode -> do_encode [] (@Linear {}) "# ) } @@ -1587,7 +1587,7 @@ fn list_sort_asc() { r#" app "test" provides [out] to "./platform" - out = List.sortAsc [4, 3, 2, 1] + out = List.sort_asc [4, 3, 2, 1] "# ) } @@ -1598,19 +1598,19 @@ fn encode_custom_type() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} HelloWorld := {{}} - toEncoder = \@HelloWorld {{}} -> + to_encoder = \@HelloWorld {{}} -> Encode.custom \bytes, fmt -> bytes - |> Encode.appendWith (Encode.string "Hello, World!\n") fmt + |> Encode.append_with (Encode.string "Hello, World!\n") fmt main = - result = Str.fromUtf8 (Encode.toBytes (@HelloWorld {{}}) tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes (@HelloWorld {{}}) tag_len_fmt) when result is Ok s -> s _ -> "" @@ -1623,13 +1623,13 @@ fn encode_derived_string() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} main = - result = Str.fromUtf8 (Encode.toBytes "abc" tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes "abc" tag_len_fmt) when result is Ok s -> s _ -> "" @@ -1643,13 +1643,13 @@ fn encode_derived_record() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} main = - result = Str.fromUtf8 (Encode.toBytes {{a: "a"}} tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes {{a: "a"}} tag_len_fmt) when result is Ok s -> s _ -> "" @@ -1666,21 +1666,21 @@ fn choose_correct_recursion_var_under_record() { Record (List {parser: Parser}), ] - printCombinatorParser : Parser -> Str - printCombinatorParser = \parser -> + print_combinator_parser : Parser -> Str + print_combinator_parser = \parser -> when parser is Specialize p -> - printed = printCombinatorParser p + printed = print_combinator_parser p if Bool.false then printed else "foo" Record fields -> fields |> List.map \f -> - printed = printCombinatorParser f.parser + printed = print_combinator_parser f.parser if Bool.false then printed else "foo" |> List.first |> Result.withDefault ("foo") - printCombinatorParser (Record []) + print_combinator_parser (Record []) "# ) } @@ -1703,9 +1703,9 @@ fn tail_call_elimination() { fn tail_call_with_same_layout_different_lambda_sets() { indoc!( r#" - chain = \in, buildLazy -> + chain = \in, build_lazy -> \{} -> - thunk = buildLazy in + thunk = build_lazy in thunk {} chain 1u8 \_ -> chain 1u8 \_ -> (\{} -> "") @@ -1717,9 +1717,9 @@ fn tail_call_with_same_layout_different_lambda_sets() { fn tail_call_with_different_layout() { indoc!( r#" - chain = \in, buildLazy -> + chain = \in, build_lazy -> \{} -> - thunk = buildLazy in + thunk = build_lazy in thunk {} chain 1u8 \_ -> chain 1u16 \_ -> (\{} -> "") @@ -1734,7 +1734,7 @@ fn lambda_capture_niche_u8_vs_u64() { capture : _ -> ({} -> Str) capture = \val -> \{} -> - Num.toStr val + Num.to_str val x : [True, False] x = True @@ -1987,13 +1987,13 @@ fn encode_derived_record_one_field_string() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} main = - result = Str.fromUtf8 (Encode.toBytes {{a: "foo"}} tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes {{a: "foo"}} tag_len_fmt) when result is Ok s -> s _ -> "" @@ -2006,13 +2006,13 @@ fn encode_derived_record_two_field_strings() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} main = - result = Str.fromUtf8 (Encode.toBytes {{a: "foo", b: "bar"}} tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes {{a: "foo", b: "bar"}} tag_len_fmt) when result is Ok s -> s _ -> "" @@ -2025,13 +2025,13 @@ fn encode_derived_nested_record_string() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} main = - result = Str.fromUtf8 (Encode.toBytes {{a: {{b: "bar"}}}} tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes {{a: {{b: "bar"}}}} tag_len_fmt) when result is Ok s -> s _ -> "" @@ -2044,7 +2044,7 @@ fn encode_derived_tag_one_field_string() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} @@ -2052,7 +2052,7 @@ fn encode_derived_tag_one_field_string() { main = x : [A Str] x = A "foo" - result = Str.fromUtf8 (Encode.toBytes x tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes x tag_len_fmt) when result is Ok s -> s _ -> "" @@ -2070,12 +2070,12 @@ fn polymorphic_expression_unification() { Text Str, Indent (List RenderTree), ] - parseFunction : Str -> RenderTree - parseFunction = \name -> + parse_function : Str -> RenderTree + parse_function = \name -> last = Indent [Text ".trace(\"$(name)\")" ] Indent [last] - values = parseFunction "interface_header" + values = parse_function "interface_header" main = values == Text "" "# @@ -2087,7 +2087,7 @@ fn encode_derived_tag_two_payloads_string() { &formatdoc!( r#" app "test" - imports [Encode.{{ toEncoder }}] + imports [Encode.{{ to_encoder }}] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} @@ -2095,7 +2095,7 @@ fn encode_derived_tag_two_payloads_string() { main = x : [A Str Str] x = A "foo" "foo" - result = Str.fromUtf8 (Encode.toBytes x tagLenFmt) + result = Str.from_utf8 (Encode.to_bytes x tag_len_fmt) when result is Ok s -> s _ -> "" @@ -2176,7 +2176,7 @@ fn unreachable_branch_is_eliminated_but_produces_lambda_specializations() { r#" app "test" provides [main] to "./platform" - provideThunk = \x -> + provide_thunk = \x -> when x is Ok _ -> t1 = \{} -> "t1" @@ -2201,7 +2201,7 @@ fn unreachable_branch_is_eliminated_but_produces_lambda_specializations() { x : Result Str [] x = Ok "abc" - thunk = provideThunk x + thunk = provide_thunk x thunk {} "# @@ -2234,15 +2234,15 @@ fn recursive_function_and_union_with_inference_hole() { Element (List (Html state)), ] - translateStatic : Html _ -> Html _ - translateStatic = \node -> + translate_static : Html _ -> Html _ + translate_static = \node -> when node is Element children -> - newChildren = List.map children translateStatic + new_children = List.map children translate_static - Element newChildren + Element new_children - main = when translateStatic (Element []) is + main = when translate_static (Element []) is _ -> "" "# ) @@ -2254,14 +2254,14 @@ fn crash() { r#" app "test" provides [main] to "./platform" - getInfallible = \result -> when result is + get_infallible = \result -> when result is Ok x -> x _ -> crash "turns out this was fallible" main = x : [Ok U64, Err Str] x = Ok 78 - getInfallible x + get_infallible x "# ) } @@ -2415,16 +2415,16 @@ fn anonymous_closure_in_polymorphic_expression_issue_4717() { r#" app "test" provides [main] to "platform" - chompWhile : (List U8) -> (List U8) - chompWhile = \input -> - index = List.walkUntil input 0 \i, _ -> Break i + chomp_while : (List U8) -> (List U8) + chomp_while = \input -> + index = List.walk_until input 0 \i, _ -> Break i if index == 0 then input else - List.dropFirst input index + List.drop_first input index - main = chompWhile [1u8, 2u8, 3u8] + main = chomp_while [1u8, 2u8, 3u8] "# ) } @@ -2459,10 +2459,10 @@ fn issue_4557() { r#" app "test" provides [main] to "./platform" - isEqQ = \q1, q2 -> when T q1 q2 is - T (U f1) (U f2) -> Bool.or (isEqQ (U f2) (U f1)) (f1 {} == f2 {}) + is_eq_q = \q1, q2 -> when T q1 q2 is + T (U f1) (U f2) -> Bool.or (is_eq_q (U f2) (U f1)) (f1 {} == f2 {}) - main = isEqQ (U \{} -> "a") (U \{} -> "a") + main = is_eq_q (U \{} -> "a") (U \{} -> "a") "# ) } @@ -2479,14 +2479,14 @@ fn nullable_wrapped_with_nullable_not_last_index() { CharLiteral, ] - toIdParser : Parser -> Str - toIdParser = \parser -> + to_id_parser : Parser -> Str + to_id_parser = \parser -> when parser is OneOrMore _ -> "a" Keyword _ -> "b" CharLiteral -> "c" - main = toIdParser CharLiteral == "c" + main = to_id_parser CharLiteral == "c" "# ) } @@ -2544,11 +2544,11 @@ fn function_specialization_information_in_lambda_set_thunk() { r#" app "test" provides [main] to "./platform" - andThen = \{} -> + and_then = \{} -> x = 10 - \newFn -> Num.add (newFn {}) x + \new_fn -> Num.add (new_fn {}) x - between = andThen {} + between = and_then {} main = between \{} -> between \{} -> 10 "# @@ -2563,13 +2563,13 @@ fn function_specialization_information_in_lambda_set_thunk_independent_defs() { r#" app "test" provides [main] to "./platform" - andThen = \{} -> + and_then = \{} -> x = 10u8 - \newFn -> Num.add (newFn {}) x + \new_fn -> Num.add (new_fn {}) x - between1 = andThen {} + between1 = and_then {} - between2 = andThen {} + between2 = and_then {} main = between1 \{} -> between2 \{} -> 10u8 "# @@ -2584,12 +2584,12 @@ fn issue_4772_weakened_monomorphic_destructure() { {ERR_DECODER_FMT} - getNumber = - {{ result, rest }} = Decode.fromBytesPartial (Str.toUtf8 "-1234") (@ErrDecoder {{}}) + get_number = + {{ result, rest }} = Decode.from_bytes_partial (Str.to_utf8 "-1234") (@ErrDecoder {{}}) when result is Ok val -> - when Str.toI64 val is + when Str.to_i64 val is Ok number -> Ok {{val : number, input : rest}} Err InvalidNumStr -> @@ -2599,7 +2599,7 @@ fn issue_4772_weakened_monomorphic_destructure() { Err (ParsingFailure "not a number") expect - result = getNumber + result = get_number result == Ok {{val : -1234i64, input : []}} "# ) @@ -2616,12 +2616,12 @@ fn weakening_avoids_overspecialization() { main : (List U8) -> (List U8) main = \input -> - index = List.walkUntil input 0 \i, _ -> Break i + index = List.walk_until input 0 \i, _ -> Break i if index == 0 then input else - List.dropFirst input index + List.drop_first input index "# ) } @@ -2639,17 +2639,17 @@ fn recursively_build_effect() { "$(hi), $(name)!" main = - when nestHelp 4 is + when nest_help 4 is _ -> greeting - nestHelp : I64 -> XEffect {} - nestHelp = \m -> + nest_help : I64 -> XEffect {} + nest_help = \m -> when m is 0 -> always {} _ -> - always {} |> after \_ -> nestHelp (m - 1) + always {} |> after \_ -> nest_help (m - 1) XEffect a := {} -> a @@ -2675,9 +2675,9 @@ fn recursive_lambda_set_has_nested_non_recursive_lambda_sets_issue_5026() { Effect : {} -> Str - after = \buildNext -> - afterInner = \{} -> (buildNext "foobar") {} - afterInner + after = \build_next -> + after_inner = \{} -> (build_next "foobar") {} + after_inner await : (Str -> Effect) -> Effect await = \cont -> after (\result -> cont result) @@ -2691,28 +2691,28 @@ fn recursive_lambda_set_has_nested_non_recursive_lambda_sets_issue_5026() { fn unspecialized_lambda_set_unification_keeps_all_concrete_types_without_unification() { // This is a regression test for the ambient lambda set specialization algorithm. // - // In the program below, monomorphization of `toEncoderQ` with the `Q` in `main` induces the + // In the program below, monomorphization of `to_encoder_q` with the `Q` in `main` induces the // resolution of `t.a` and `t.b`, and the unification of their pending unspecialization lambda // sets, when `t.a` and `t.b` have been resolved to concrete types, but before the // specialization procedure steps in to resolve the lambda sets concretely. That's because - // monomorphization unifies the general type of `toEncoderQ` with the concrete type, forcing + // monomorphization unifies the general type of `to_encoder_q` with the concrete type, forcing // concretization of `t`, but the specialization procedure runs only after the unification is // complete. // - // In this case, it's imperative that the unspecialized lambda sets of `toEncoder t.a` and - // `toEncoder t.b` wind up in the same lambda set, that is in + // In this case, it's imperative that the unspecialized lambda sets of `to_encoder t.a` and + // `to_encoder t.b` wind up in the same lambda set, that is in // - // tag : @MEncoder (Bytes, Linear -[[] + @MU8:toEncoder:1 + @MStr:toEncoder+1] -> Bytes) + // tag : @MEncoder (Bytes, Linear -[[] + @MU8:to_encoder:1 + @MStr:to_encoder+1] -> Bytes) // -[lTag]-> - // @MEncoder (Bytes, Linear -[[Linear:lTag:3 { @MEncoder (Bytes, Linear -[[] + @MU8:toEncoder:1 + @MStr:toEncoder:1] -> Bytes) }]] -> Bytes) + // @MEncoder (Bytes, Linear -[[Linear:lTag:3 { @MEncoder (Bytes, Linear -[[] + @MU8:to_encoder:1 + @MStr:to_encoder:1] -> Bytes) }]] -> Bytes) // // rather than forcing the lambda set inside to `tag` to become disjoint, as e.g. // - // tag : @MEncoder (Bytes, Linear -[[] + @MU8:toEncoder:1 + @MStr:toEncoder+1] -> Bytes) + // tag : @MEncoder (Bytes, Linear -[[] + @MU8:to_encoder:1 + @MStr:to_encoder+1] -> Bytes) // -[lTag]-> // @MEncoder (Bytes, Linear -[[ - // Linear:lTag:3 { @MEncoder (Bytes, Linear -[[] + @MU8:toEncoder:1] -> Bytes) }, - // Linear:lTag:3 { @MEncoder (Bytes, Linear -[[] + @MStr:toEncoder:1] -> Bytes) }, + // Linear:lTag:3 { @MEncoder (Bytes, Linear -[[] + @MU8:to_encoder:1] -> Bytes) }, + // Linear:lTag:3 { @MEncoder (Bytes, Linear -[[] + @MStr:to_encoder:1] -> Bytes) }, // ]] -> Bytes) indoc!( r#" @@ -2721,7 +2721,7 @@ fn unspecialized_lambda_set_unification_keeps_all_concrete_types_without_unifica MEncoder fmt := List U8, fmt -> List U8 where fmt implements Format MEncoding implements - toEncoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format + to_encoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format Format implements u8 : {} -> MEncoder fmt where fmt implements Format @@ -2730,8 +2730,8 @@ fn unspecialized_lambda_set_unification_keeps_all_concrete_types_without_unifica Linear := {} implements [Format {u8: lU8, str: lStr, tag: lTag}] - MU8 := U8 implements [MEncoding {toEncoder: toEncoderU8}] - MStr := Str implements [MEncoding {toEncoder: toEncoderStr}] + MU8 := U8 implements [MEncoding {to_encoder: to_encoder_u8}] + MStr := Str implements [MEncoding {to_encoder: to_encoder_str}] Q a b := { a: a, b: b } @@ -2742,20 +2742,20 @@ fn unspecialized_lambda_set_unification_keeps_all_concrete_types_without_unifica doFormat lst (@Linear {}) ) - toEncoderU8 = \@MU8 _ -> u8 {} + to_encoder_u8 = \@MU8 _ -> u8 {} - toEncoderStr = \@MStr _ -> str {} + to_encoder_str = \@MStr _ -> str {} - toEncoderQ = + to_encoder_q = \@Q t -> \fmt -> @MEncoder doit = if Bool.true - then tag (toEncoder t.a) - else tag (toEncoder t.b) + then tag (to_encoder t.a) + else tag (to_encoder t.b) doit [] fmt main = - fmt = toEncoderQ (@Q {a : @MStr "", b: @MU8 7}) + fmt = to_encoder_q (@Q {a : @MStr "", b: @MU8 7}) fmt (@Linear {}) "# ) @@ -2773,30 +2773,30 @@ fn unspecialized_lambda_set_unification_keeps_all_concrete_types_without_unifica // `EncoderFormatting`). // // In this test, the payload types `[A]*` and `[B]*` of the encoded type `Q` are unifiable in - // their unspecialized lambda set representations under `toEncoderQ`; however, they must not + // their unspecialized lambda set representations under `to_encoder_q`; however, they must not // be, because they in fact represent to different specializations of needed encoders. In - // particular, the lambda set `[[] + [A]:toEncoder:1 + [B]:toEncoder:1]` must be preserved, - // rather than collapsing to `[[] + [A, B]:toEncoder:1]`. + // particular, the lambda set `[[] + [A]:to_encoder:1 + [B]:to_encoder:1]` must be preserved, + // rather than collapsing to `[[] + [A, B]:to_encoder:1]`. &formatdoc!( r#" app "test" imports [] provides [main] to "./platform" {TAG_LEN_ENCODER_FMT} - Q a b := {{ a: a, b: b }} implements [Encoding {{toEncoder: toEncoderQ}}] + Q a b := {{ a: a, b: b }} implements [Encoding {{to_encoder: to_encoder_q}}] - toEncoderQ = + to_encoder_q = \@Q t -> Encode.custom \bytes, fmt -> f = if Bool.true - then Encode.tag "A" [Encode.toEncoder t.a] - else Encode.tag "B" [Encode.toEncoder t.b] + then Encode.tag "A" [Encode.to_encoder t.a] + else Encode.tag "B" [Encode.to_encoder t.b] - Encode.appendWith bytes f fmt + Encode.append_with bytes f fmt accessor = @Q {{a : A, b: B}} main = - Encode.toBytes accessor tagLenFmt + Encode.to_bytes accessor tag_len_fmt "# ) } @@ -2812,10 +2812,10 @@ fn unspecialized_lambda_set_unification_does_not_duplicate_identical_concrete_ty // `EncoderFormatting`). // // In this test, the payload types `Str` and `Str` of the encoded type `Q` are unifiable in - // their unspecialized lambda set representations under `toEncoderQ`, and moreoever they are + // their unspecialized lambda set representations under `to_encoder_q`, and moreoever they are // equivalent specializations, since they both come from the same root variable `x`. In as - // such, the lambda set `[[] + Str:toEncoder:1]` should be produced during compaction, rather - // than staying as the expanded `[[] + Str:toEncoder:1 + Str:toEncoder:1]` after the types of + // such, the lambda set `[[] + Str:to_encoder:1]` should be produced during compaction, rather + // than staying as the expanded `[[] + Str:to_encoder:1 + Str:to_encoder:1]` after the types of // `t.a` and `t.b` are filled in. &formatdoc!( r#" @@ -2823,22 +2823,22 @@ fn unspecialized_lambda_set_unification_does_not_duplicate_identical_concrete_ty {TAG_LEN_ENCODER_FMT} - Q a b := {{ a: a, b: b }} implements [Encoding {{toEncoder: toEncoderQ}}] + Q a b := {{ a: a, b: b }} implements [Encoding {{to_encoder: to_encoder_q}}] - toEncoderQ = + to_encoder_q = \@Q t -> Encode.custom \bytes, fmt -> f = if Bool.true - then Encode.tag "A" [Encode.toEncoder t.a] - else Encode.tag "B" [Encode.toEncoder t.b] + then Encode.tag "A" [Encode.to_encoder t.a] + else Encode.tag "B" [Encode.to_encoder t.b] - Encode.appendWith bytes f fmt + Encode.append_with bytes f fmt accessor = x = "" @Q {{a : x, b: x}} main = - Encode.toBytes accessor tagLenFmt + Encode.to_bytes accessor tag_len_fmt "# ) } @@ -2894,14 +2894,14 @@ fn recursive_closure_with_transiently_used_capture() { r#" app "test" provides [f] to "./platform" - thenDo = \x, callback -> + then_do = \x, callback -> callback x f = \{} -> code = 10u16 bf = \{} -> - thenDo code \_ -> bf {} + then_do code \_ -> bf {} bf {} "# @@ -2932,14 +2932,14 @@ fn recursive_lambda_set_resolved_only_upon_specialization() { r#" app "test" provides [main] to "./platform" - factCPS = \n, cont -> + fact_cps = \n, cont -> if n == 0u8 then cont 1u8 else - factCPS (n - 1) \value -> cont (n * value) + fact_cps (n - 1) \value -> cont (n * value) main = - factCPS 5 \x -> x + fact_cps 5 \x -> x "# ) } @@ -2956,12 +2956,12 @@ fn compose_recursive_lambda_set_productive_nullable_wrapped() { else \x -> f (g x) identity = \x -> x - exclame = \s -> "$(s)!" + exclaim = \s -> "$(s)!" whisper = \s -> "($(s))" main = res: Str -> Str - res = List.walk [ exclame, whisper ] identity (compose Bool.true) + res = List.walk [ exclaim, whisper ] identity (compose Bool.true) res "hello" "# ) @@ -3018,19 +3018,19 @@ fn issue_4770() { app "test" provides [main] to "./platform" main = - isCorrectOrder { left: IsList [IsInteger 10], right: IsList [IsInteger 20] } + is_correct_order { left: IsList [IsInteger 10], right: IsList [IsInteger 20] } - isCorrectOrder = \pair -> + is_correct_order = \pair -> when pair is { left: IsInteger left, right: IsInteger right } -> left < right { left: IsList l, right: IsList r } -> - if List.map2 l r (\left, right -> { left, right }) |> List.all isCorrectOrder then + if List.map2 l r (\left, right -> { left, right }) |> List.all is_correct_order then List.len l < List.len r else Bool.false - { left: IsList _, right: IsInteger _ } -> isCorrectOrder { left: pair.left, right: IsList [pair.right] } - { left: IsInteger _, right: IsList _ } -> isCorrectOrder { left: IsList [pair.left], right: pair.right } + { left: IsList _, right: IsInteger _ } -> is_correct_order { left: pair.left, right: IsList [pair.right] } + { left: IsInteger _, right: IsList _ } -> is_correct_order { left: IsList [pair.left], right: pair.right } "# ) } @@ -3054,7 +3054,7 @@ fn binary_tree_fbip() { main = tree = Node (Node (Node (Node Tip Tip) Tip) (Node Tip Tip)) (Node Tip Tip) - checkFbip tree + check_fbip tree Tree : [Node Tree Tree, Tip] @@ -3065,14 +3065,14 @@ fn binary_tree_fbip() { Visit : [NodeR Tree Visit, Done] - checkFbip : Tree -> Num a - checkFbip = \t -> checkFbipHelper t Done 0 + check_fbip : Tree -> Num a + check_fbip = \t -> check_fbip_helper t Done 0 - checkFbipHelper : Tree, Visit, Num a-> Num a - checkFbipHelper = \t, v, a -> when t is - Node l r -> checkFbipHelper l (NodeR r v) (a + 1) + check_fbip_helper : Tree, Visit, Num a-> Num a + check_fbip_helper = \t, v, a -> when t is + Node l r -> check_fbip_helper l (NodeR r v) (a + 1) Tip -> when v is - NodeR r v2 -> checkFbipHelper r v2 a + NodeR r v2 -> check_fbip_helper r v2 a Done -> a "# ) @@ -3140,32 +3140,32 @@ fn specialize_after_match() { app "test" provides [main] to "./platform" main = - listA : LinkedList Str - listA = Nil + list_a : LinkedList Str + list_a = Nil - listB : LinkedList Str - listB = Nil + list_b : LinkedList Str + list_b = Nil - longestLinkedList listA listB + longest_linked_list list_a list_b LinkedList a : [Cons a (LinkedList a), Nil] - longestLinkedList : LinkedList a, LinkedList a -> U64 - longestLinkedList = \listA, listB -> when listA is - Nil -> linkedListLength listB - Cons a aa -> when listB is - Nil -> linkedListLength listA + longest_linked_list : LinkedList a, LinkedList a -> U64 + longest_linked_list = \list_a, list_b -> when list_a is + Nil -> linked_list_length list_b + Cons a aa -> when list_b is + Nil -> linked_list_length list_a Cons b bb -> - lengthA = (linkedListLength aa) + 1 - lengthB = linkedListLength listB - if lengthA > lengthB - then lengthA - else lengthB - - linkedListLength : LinkedList a -> U64 - linkedListLength = \list -> when list is + length_a = (linked_list_length aa) + 1 + length_b = linked_list_length list_b + if length_a > length_b + then length_a + else length_b + + linked_list_length : LinkedList a -> U64 + linked_list_length = \list -> when list is Nil -> 0 - Cons _ rest -> 1 + linkedListLength rest + Cons _ rest -> 1 + linked_list_length rest "# ) } @@ -3209,9 +3209,9 @@ fn drop_specialize_after_jump() { main = v = "value" t = { left: { left: v, right: v }, right: v } - tupleItem t + tuple_item t - tupleItem = \t -> + tuple_item = \t -> true = Bool.true l = t.left x = if true then 1 else 0 @@ -3245,9 +3245,9 @@ fn drop_specialize_before_jump() { main = v = "value" t = { left: v, right: v } - tupleItem t + tuple_item t - tupleItem = \t -> + tuple_item = \t -> true = Bool.true l = t.left x = if true then 1 else 0 @@ -3317,13 +3317,13 @@ fn linked_list_reverse() { LinkedList a : [Nil, Cons a (LinkedList a)] reverse : LinkedList a -> LinkedList a - reverse = \list -> reverseHelp Nil list + reverse = \list -> reverse_help Nil list - reverseHelp : LinkedList a, LinkedList a -> LinkedList a - reverseHelp = \accum, list -> + reverse_help : LinkedList a, LinkedList a -> LinkedList a + reverse_help = \accum, list -> when list is Nil -> accum - Cons first rest -> reverseHelp (Cons first accum) rest + Cons first rest -> reverse_help (Cons first accum) rest main : LinkedList I64 main = reverse (Cons 42 Nil) @@ -3390,32 +3390,32 @@ fn capture_void_layout_task() { succeed = \ok -> \{} -> Ok ok after : Fx a, (a -> Fx b) -> Fx b - after = \fx, toNext -> - afterInner = \{} -> - fxOut = fx {} - next = toNext fxOut + after = \fx, to_next -> + after_inner = \{} -> + fx_out = fx {} + next = to_next fx_out next {} - afterInner + after_inner await : OtherTask a err, (a -> OtherTask b err) -> OtherTask b err - await = \fx, toNext -> + await = \fx, to_next -> inner = after fx \result -> when result is Ok a -> - bFx = toNext a - bFx + b_fx = to_next a + b_fx Err e -> (\{} -> Err e) inner - forEach : List a, (a -> OtherTask {} err) -> OtherTask {} err - forEach = \list, fromElem -> + for_each : List a, (a -> OtherTask {} err) -> OtherTask {} err + for_each = \list, from_elem -> List.walk list (succeed {}) \task, elem -> - await task \{} -> fromElem elem + await task \{} -> from_elem elem main : OtherTask {} [] main = - forEach [] \_ -> succeed {} + for_each [] \_ -> succeed {} "# ) } @@ -3450,10 +3450,10 @@ fn inspect_custom_type() { imports [] provides [main] to "./platform" - HelloWorld := {} implements [Inspect { toInspector: myToInspector }] + HelloWorld := {} implements [Inspect { to_inspector: my_to_inspector }] - myToInspector : HelloWorld -> Inspector f where f implements InspectFormatter - myToInspector = \@HellowWorld {} -> + my_to_inspector : HelloWorld -> Inspector f where f implements InspectFormatter + my_to_inspector = \@HellowWorld {} -> Inspect.custom \fmt -> Inspect.apply (Inspect.str "Hello, World!\n") fmt @@ -3471,7 +3471,7 @@ fn inspect_derived_string() { imports [] provides [main] to "./platform" - main = Inspect.toStr "abc" + main = Inspect.to_str "abc" "# ) } @@ -3484,7 +3484,7 @@ fn inspect_derived_record() { imports [] provides [main] to "./platform" - main = Inspect.toStr {a: 7, b: 3dec} + main = Inspect.to_str {a: 7, b: 3dec} "# ) } @@ -3496,7 +3496,7 @@ fn inspect_derived_record_one_field_string() { imports [] provides [main] to "./platform" - main = Inspect.toStr {a: "foo"} + main = Inspect.to_str {a: "foo"} "# ) } @@ -3509,7 +3509,7 @@ fn inspect_derived_record_two_field_strings() { imports [] provides [main] to "./platform" - main = Inspect.toStr {a: "foo", b: "bar"} + main = Inspect.to_str {a: "foo", b: "bar"} "# ) } @@ -3522,7 +3522,7 @@ fn inspect_derived_nested_record_string() { imports [] provides [main] to "./platform" - main = Inspect.toStr {a: {b: "bar"}} + main = Inspect.to_str {a: {b: "bar"}} "# ) } @@ -3538,7 +3538,7 @@ fn inspect_derived_tag_one_field_string() { main = x : [A Str] x = A "foo" - Inspect.toStr x + Inspect.to_str x "# ) } @@ -3554,7 +3554,7 @@ fn inspect_derived_tag_two_payloads_string() { main = x : [A Str Str] x = A "foo" "foo" - Inspect.toStr x + Inspect.to_str x "# ) } @@ -3567,7 +3567,7 @@ fn inspect_derived_list() { imports [] provides [main] to "./platform" - main = Inspect.toStr [1, 2, 3] + main = Inspect.to_str [1, 2, 3] "# ) } @@ -3581,8 +3581,8 @@ fn inspect_derived_dict() { provides [main] to "./platform" main = - Dict.fromList [("a", 1), ("b", 2)] - |> Inspect.toStr + Dict.from_list [("a", 1), ("b", 2)] + |> Inspect.to_str "# ) } @@ -3678,13 +3678,13 @@ fn issue_6606_2() { fn dec_refcount_for_usage_after_early_return_in_if() { indoc!( r#" - displayN = \n -> - first = Num.toStr n + display_n = \n -> + first = Num.to_str n second = if n == 1 then return "early 1" else - third = Num.toStr (n + 1) + third = Num.to_str (n + 1) if n == 2 then return "early 2" else @@ -3692,7 +3692,7 @@ fn dec_refcount_for_usage_after_early_return_in_if() { "$(first), $(second)" - displayN 3 + display_n 3 "# ) } @@ -3701,13 +3701,13 @@ fn dec_refcount_for_usage_after_early_return_in_if() { fn return_annotated() { indoc!( r#" - validateInput : Str -> Result U64 _ - validateInput = \str -> - num = try Str.toU64 str + validate_input : Str -> Result U64 _ + validate_input = \str -> + num = try Str.to_u64 str Ok num - validateInput "123" + validate_input "123" "# ) } diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.formatted.roc b/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.formatted.roc index b6d53f2f44a..5cfd7e58c44 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.formatted.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.formatted.roc @@ -3,4 +3,4 @@ platform "cli" exposes [] packages {} imports [Task.{ Task }] - provides [mainForHost] + provides [main_for_host] diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.result-ast index ca4b86646d0..17232e5d13f 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.result-ast @@ -90,8 +90,8 @@ SpacesBefore { after: [], }, item: [ - @141-152 ExposedName( - "mainForHost", + @141-154 ExposedName( + "main_for_host", ), ], }, diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.roc b/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.roc index a4ec7c9b78b..0287d20de44 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/function_effect_types.header.roc @@ -3,4 +3,4 @@ platform "cli" exposes [] packages {} imports [ Task.{ Task } ] - provides [ mainForHost ] + provides [ main_for_host ] diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.formatted.roc b/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.formatted.roc index 2020be61739..18e9f949b73 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.formatted.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.formatted.roc @@ -3,4 +3,4 @@ platform "foo/barbaz" exposes [] packages { foo: "./foo" } imports [] - provides [mainForHost] + provides [main_for_host] diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.result-ast index fdb021d33dd..c8134860f36 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.result-ast @@ -80,8 +80,8 @@ SpacesBefore { after: [], }, item: [ - @132-143 ExposedName( - "mainForHost", + @132-145 ExposedName( + "main_for_host", ), ], }, diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.roc b/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.roc index 789dae30555..ba60974d82f 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/nonempty_platform_header.header.roc @@ -3,4 +3,4 @@ platform "foo/barbaz" exposes [] packages { foo: "./foo" } imports [] - provides [ mainForHost ] + provides [ main_for_host ] diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.result-ast index 521b4e9399d..62f899836fa 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.result-ast @@ -3,7 +3,7 @@ Defs { EitherIndex(2147483648), ], regions: [ - @0-166, + @0-167, ], space_before: [ Slice { start: 0, length: 0 }, @@ -20,7 +20,7 @@ Defs { @0-4 Identifier { ident: "main", }, - @11-166 SpaceBefore( + @11-167 SpaceBefore( BinOps( [ ( @@ -103,27 +103,27 @@ Defs { @98-100 Pizza, ), ( - @101-147 SpaceAfter( + @101-148 SpaceAfter( Closure( [ @102-107 Identifier { ident: "total", }, ], - @111-147 Str( + @111-148 Str( Line( [ Plaintext( "Sum of numbers: ", ), Interpolated( - @130-145 Apply( - @130-139 Var { + @130-146 Apply( + @130-140 Var { module_name: "Num", - ident: "toStr", + ident: "to_str", }, [ - @140-145 Var { + @141-146 Var { module_name: "", ident: "total", }, @@ -139,10 +139,10 @@ Defs { Newline, ], ), - @152-154 Pizza, + @153-155 Pizza, ), ], - @155-166 Var { + @156-167 Var { module_name: "Str", ident: "toUpper", }, diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.roc b/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.roc index e53dc93f391..646c9f1d805 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/pizza_question.moduledefs.roc @@ -3,5 +3,5 @@ main = |> List.dropFirst 1 |> List.mapTry? Str.toU8 |> List.sum - |> \total -> "Sum of numbers: $(Num.toStr total)" + |> \total -> "Sum of numbers: $(Num.to_str total)" |> Str.toUpper diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.formatted.roc b/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.formatted.roc index e52d0bf32c5..abf9f3ab817 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.formatted.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.formatted.roc @@ -3,4 +3,4 @@ platform "test/types" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.result-ast index 789547f199f..e298717ad09 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.result-ast @@ -86,8 +86,8 @@ SpacesBefore { after: [], }, item: [ - @141-152 ExposedName( - "mainForHost", + @141-154 ExposedName( + "main_for_host", ), ], }, diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.roc b/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.roc index 1755f5a0665..0065ddc0aca 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/requires_type.header.roc @@ -3,7 +3,7 @@ platform "test/types" exposes [] packages {} imports [] - provides [ mainForHost ] + provides [ main_for_host ] -mainForHost : App Flags Model -mainForHost = main +main_for_host : App Flags Model +main_for_host = main diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.formatted.roc b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.formatted.roc index 037e118de30..231d12611df 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.formatted.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.formatted.roc @@ -5,6 +5,6 @@ maybeEarlyReturn = \x -> else x + 2 - Num.toStr y + Num.to_str y maybeEarlyReturn 10 \ No newline at end of file diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.result-ast index b526d3c2ea4..7553287f094 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.result-ast @@ -1,11 +1,11 @@ -@0-148 SpaceAfter( +@0-149 SpaceAfter( Defs( Defs { tags: [ EitherIndex(2147483648), ], regions: [ - @0-127, + @0-128, ], space_before: [ Slice { start: 0, length: 0 }, @@ -20,13 +20,13 @@ @0-16 Identifier { ident: "maybeEarlyReturn", }, - @19-127 Closure( + @19-128 Closure( [ @20-21 Identifier { ident: "x", }, ], - @29-127 SpaceBefore( + @29-128 SpaceBefore( Defs( Defs { tags: [ @@ -114,14 +114,14 @@ ), ], }, - @116-127 SpaceBefore( + @116-128 SpaceBefore( Apply( - @116-125 Var { + @116-126 Var { module_name: "Num", - ident: "toStr", + ident: "to_str", }, [ - @126-127 Var { + @127-128 Var { module_name: "", ident: "y", }, @@ -142,14 +142,14 @@ ), ], }, - @129-148 SpaceBefore( + @130-149 SpaceBefore( Apply( - @129-145 Var { + @130-146 Var { module_name: "", ident: "maybeEarlyReturn", }, [ - @146-148 Num( + @147-149 Num( "10", ), ], diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.roc b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.roc index 18a7c88d61b..d8fccfaa272 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_if.expr.roc @@ -5,6 +5,6 @@ maybeEarlyReturn = \x -> else x + 2 - Num.toStr y + Num.to_str y maybeEarlyReturn 10 diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.formatted.roc b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.formatted.roc index 59d0508f038..bf5a53fb43f 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.formatted.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.formatted.roc @@ -7,6 +7,6 @@ maybeEarlyReturn = \x -> _ -> x + 2 - Num.toStr y + Num.to_str y maybeEarlyRetun 3 \ No newline at end of file diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.result-ast index bcb05f24fdf..c77117e590f 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.result-ast @@ -1,11 +1,11 @@ -@0-173 SpaceAfter( +@0-174 SpaceAfter( Defs( Defs { tags: [ EitherIndex(2147483648), ], regions: [ - @0-154, + @0-155, ], space_before: [ Slice { start: 0, length: 0 }, @@ -20,13 +20,13 @@ @0-16 Identifier { ident: "maybeEarlyReturn", }, - @19-154 Closure( + @19-155 Closure( [ @20-21 Identifier { ident: "x", }, ], - @29-154 SpaceBefore( + @29-155 SpaceBefore( Defs( Defs { tags: [ @@ -123,14 +123,14 @@ ), ], }, - @143-154 SpaceBefore( + @143-155 SpaceBefore( Apply( - @143-152 Var { + @143-153 Var { module_name: "Num", - ident: "toStr", + ident: "to_str", }, [ - @153-154 Var { + @154-155 Var { module_name: "", ident: "y", }, @@ -152,14 +152,14 @@ ), ], }, - @156-173 SpaceBefore( + @157-174 SpaceBefore( Apply( - @156-171 Var { + @157-172 Var { module_name: "", ident: "maybeEarlyRetun", }, [ - @172-173 Num( + @173-174 Num( "3", ), ], diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.roc b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.roc index 5f00323c6c1..8a7366edb88 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/return_in_when.expr.roc @@ -8,6 +8,6 @@ maybeEarlyReturn = \x -> _ -> x + 2 - Num.toStr y + Num.to_str y maybeEarlyRetun 3 diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.formatted.roc b/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.formatted.roc index bb662215bef..53c8421bb02 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.formatted.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.formatted.roc @@ -1,3 +1,3 @@ -mainForHost : [StdoutWrite Str ({} -> Op), StderrWrite Str ({} -> Op), Done] as Op -mainForHost = main +main_for_host : [StdoutWrite Str ({} -> Op), StderrWrite Str ({} -> Op), Done] as Op +main_for_host = main 42 \ No newline at end of file diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.result-ast b/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.result-ast index 3718cb6a153..260c26ee653 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.result-ast +++ b/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.result-ast @@ -1,11 +1,11 @@ -@0-104 SpaceAfter( +@0-108 SpaceAfter( Defs( Defs { tags: [ EitherIndex(2147483648), ], regions: [ - @0-101, + @0-105, ], space_before: [ Slice { start: 0, length: 0 }, @@ -17,30 +17,30 @@ type_defs: [], value_defs: [ AnnotatedBody { - ann_pattern: @0-11 Identifier { - ident: "mainForHost", + ann_pattern: @0-13 Identifier { + ident: "main_for_host", }, - ann_type: @14-0 As( - @14-76 TagUnion { + ann_type: @16-0 As( + @16-78 TagUnion { ext: None, tags: [ - @15-41 Apply { - name: @15-26 "StdoutWrite", + @17-43 Apply { + name: @17-28 "StdoutWrite", args: [ - @27-30 Apply( + @29-32 Apply( "", "Str", [], ), - @32-40 Function( + @34-42 Function( [ - @32-34 Record { + @34-36 Record { fields: [], ext: None, }, ], Pure, - @38-40 Apply( + @40-42 Apply( "", "Op", [], @@ -48,23 +48,23 @@ ), ], }, - @43-69 Apply { - name: @43-54 "StderrWrite", + @45-71 Apply { + name: @45-56 "StderrWrite", args: [ - @55-58 Apply( + @57-60 Apply( "", "Str", [], ), - @60-68 Function( + @62-70 Function( [ - @60-62 Record { + @62-64 Record { fields: [], ext: None, }, ], Pure, - @66-68 Apply( + @68-70 Apply( "", "Op", [], @@ -72,32 +72,32 @@ ), ], }, - @71-75 Apply { - name: @71-75 "Done", + @73-77 Apply { + name: @73-77 "Done", args: [], }, ], }, [], TypeHeader { - name: @80-82 "Op", + name: @82-84 "Op", vars: [], }, ), lines_between: [ Newline, ], - body_pattern: @83-94 Identifier { - ident: "mainForHost", + body_pattern: @85-98 Identifier { + ident: "main_for_host", }, - body_expr: @97-101 Var { + body_expr: @101-105 Var { module_name: "", ident: "main", }, }, ], }, - @102-104 SpaceBefore( + @106-108 SpaceBefore( Num( "42", ), diff --git a/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.roc b/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.roc index 382ce9377df..9bc27a7b13e 100644 --- a/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.roc +++ b/crates/compiler/test_syntax/tests/snapshots/pass/tag_union_functions_as.expr.roc @@ -1,3 +1,3 @@ -mainForHost : [StdoutWrite Str ({} -> Op), StderrWrite Str ({} -> Op), Done] as Op -mainForHost = main +main_for_host : [StdoutWrite Str ({} -> Op), StderrWrite Str ({} -> Op), Done] as Op +main_for_host = main 42 diff --git a/crates/compiler/test_syntax/tests/test_fmt.rs b/crates/compiler/test_syntax/tests/test_fmt.rs index bb8b69b701e..85ff30d3cf7 100644 --- a/crates/compiler/test_syntax/tests/test_fmt.rs +++ b/crates/compiler/test_syntax/tests/test_fmt.rs @@ -5270,7 +5270,7 @@ mod test_fmt { exposes [] \ packages {} \ imports [] \ - provides [mainForHost]", + provides [main_for_host]", ); } @@ -6207,7 +6207,7 @@ mod test_fmt { exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] "# )); } diff --git a/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets.txt b/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets.txt index 3198cd1bf3a..80f6a284dfd 100644 --- a/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets.txt +++ b/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets.txt @@ -1,9 +1,9 @@ -app "test" provides [isEqQ] to "./platform" +app "test" provides [is_eq_q] to "./platform" -Q := [ F (Str -> Str), G ] implements [Eq { isEq: isEqQ }] +Q := [ F (Str -> Str), G ] implements [Eq { is_eq: is_eq_q }] -isEqQ = \@Q q1, @Q q2 -> when T q1 q2 is -#^^^^^{-1} Q, Q -[[isEqQ(0)]]-> Bool +is_eq_q = \@Q q1, @Q q2 -> when T q1 q2 is +#^^^^^^^{-1} Q, Q -[[is_eq_q(0)]]-> Bool T (F _) (F _) -> Bool.true T G G -> Bool.true _ -> Bool.false diff --git a/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets_material.txt b/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets_material.txt index b47c5af1549..a7e3c92a526 100644 --- a/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets_material.txt +++ b/crates/compiler/uitest/tests/ability/impl_ability_for_opaque_with_lambda_sets_material.txt @@ -1,10 +1,10 @@ # +opt infer:print_only_under_alias app "test" provides [main] to "./platform" -Q := ({} -> Str) implements [Eq {isEq: isEqQ}] +Q := ({} -> Str) implements [Eq {is_eq: is_eq_q}] -isEqQ = \@Q f1, @Q f2 -> (f1 {} == f2 {}) -#^^^^^{-1} ({} -[[]]-> Str), ({} -[[]]-> Str) -[[isEqQ(2)]]-> [False, True] +is_eq_q = \@Q f1, @Q f2 -> (f1 {} == f2 {}) +#^^^^^^^{-1} ({} -[[]]-> Str), ({} -[[]]-> Str) -[[is_eq_q(2)]]-> [False, True] -main = isEqQ (@Q \{} -> "a") (@Q \{} -> "a") -# ^^^^^ ({} -[[6, 7]]-> Str), ({} -[[6, 7]]-> Str) -[[isEqQ(2)]]-> [False, True] +main = is_eq_q (@Q \{} -> "a") (@Q \{} -> "a") +# ^^^^^^^ ({} -[[6, 7]]-> Str), ({} -[[6, 7]]-> Str) -[[is_eq_q(2)]]-> [False, True] diff --git a/crates/compiler/uitest/tests/ability/smoke/decoder.txt b/crates/compiler/uitest/tests/ability/smoke/decoder.txt index 9de1a02c787..734ae96b3f4 100644 --- a/crates/compiler/uitest/tests/ability/smoke/decoder.txt +++ b/crates/compiler/uitest/tests/ability/smoke/decoder.txt @@ -1,4 +1,4 @@ -app "test" provides [myU8] to "./platform" +app "test" provides [my_u8] to "./platform" MDecodeError : [TooShort, Leftover (List U8)] @@ -10,16 +10,16 @@ MDecoding implements MDecoderFormatting implements u8 : MDecoder U8 fmt where fmt implements MDecoderFormatting -decodeWith : List U8, MDecoder val fmt, fmt -> { result: Result val MDecodeError, rest: List U8 } where fmt implements MDecoderFormatting -decodeWith = \lst, (@MDecoder doDecode), fmt -> doDecode lst fmt +decode_with : List U8, MDecoder val fmt, fmt -> { result: Result val MDecodeError, rest: List U8 } where fmt implements MDecoderFormatting +decode_with = \lst, (@MDecoder doDecode), fmt -> doDecode lst fmt -fromBytes : List U8, fmt -> Result val MDecodeError +from_bytes : List U8, fmt -> Result val MDecodeError where fmt implements MDecoderFormatting, val implements MDecoding -fromBytes = \lst, fmt -> - when decodeWith lst decoder fmt is +from_bytes = \lst, fmt -> + when decode_with lst decoder fmt is { result, rest } -> when result is - Ok val -> if List.isEmpty rest then Ok val else Err (Leftover rest) + Ok val -> if List.is_empty rest then Ok val else Err (Leftover rest) Err e -> Err e @@ -28,17 +28,17 @@ Linear := {} implements [MDecoderFormatting {u8}] u8 = @MDecoder \lst, @Linear {} -> #^^{-1} Linear#u8(11): MDecoder U8 Linear when List.first lst is - Ok n -> { result: Ok n, rest: List.dropFirst lst 1 } + Ok n -> { result: Ok n, rest: List.drop_first lst 1 } Err _ -> { result: Err TooShort, rest: [] } MyU8 := U8 implements [MDecoding {decoder}] decoder = @MDecoder \lst, fmt -> #^^^^^^^{-1} MyU8#decoder(12): MDecoder MyU8 fmt where fmt implements MDecoderFormatting - when decodeWith lst u8 fmt is + when decode_with lst u8 fmt is { result, rest } -> { result: Result.map result (\n -> @MyU8 n), rest } -myU8 : Result MyU8 _ -myU8 = fromBytes [15] (@Linear {}) -#^^^^{-1} Result MyU8 MDecodeError +my_u8 : Result MyU8 _ +my_u8 = from_bytes [15] (@Linear {}) +#^^^^^{-1} Result MyU8 MDecodeError diff --git a/crates/compiler/uitest/tests/ability/smoke/encoder.txt b/crates/compiler/uitest/tests/ability/smoke/encoder.txt index 12f639bf021..d4ced878a8d 100644 --- a/crates/compiler/uitest/tests/ability/smoke/encoder.txt +++ b/crates/compiler/uitest/tests/ability/smoke/encoder.txt @@ -1,18 +1,18 @@ -app "test" provides [myU8Bytes] to "./platform" +app "test" provides [my_u8_bytes] to "./platform" MEncoder fmt := List U8, fmt -> List U8 where fmt implements Format MEncoding implements - toEncoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format + to_encoder : val -> MEncoder fmt where val implements MEncoding, fmt implements Format Format implements u8 : U8 -> MEncoder fmt where fmt implements Format -appendWith : List U8, MEncoder fmt, fmt -> List U8 where fmt implements Format -appendWith = \lst, (@MEncoder doFormat), fmt -> doFormat lst fmt +append_with : List U8, MEncoder fmt, fmt -> List U8 where fmt implements Format +append_with = \lst, (@MEncoder doFormat), fmt -> doFormat lst fmt -toBytes : val, fmt -> List U8 where val implements MEncoding, fmt implements Format -toBytes = \val, fmt -> appendWith [] (toEncoder val) fmt +to_bytes : val, fmt -> List U8 where val implements MEncoding, fmt implements Format +to_bytes = \val, fmt -> append_with [] (to_encoder val) fmt Linear := {} implements [Format {u8}] @@ -20,10 +20,10 @@ Linear := {} implements [Format {u8}] u8 = \n -> @MEncoder (\lst, @Linear {} -> List.append lst n) #^^{-1} Linear#u8(10): U8 -[[u8(10)]]-> MEncoder Linear -MyU8 := U8 implements [MEncoding {toEncoder}] +MyU8 := U8 implements [MEncoding {to_encoder}] -toEncoder = \@MyU8 n -> u8 n -#^^^^^^^^^{-1} MyU8#toEncoder(11): MyU8 -[[toEncoder(11)]]-> MEncoder fmt where fmt implements Format +to_encoder = \@MyU8 n -> u8 n +#^^^^^^^^^^{-1} MyU8#to_encoder(11): MyU8 -[[to_encoder(11)]]-> MEncoder fmt where fmt implements Format -myU8Bytes = toBytes (@MyU8 15) (@Linear {}) -#^^^^^^^^^{-1} List U8 +my_u8_bytes = to_bytes (@MyU8 15) (@Linear {}) +#^^^^^^^^^^^{-1} List U8 diff --git a/crates/compiler/uitest/tests/ability/specialize/bool_decoder.txt b/crates/compiler/uitest/tests/ability/specialize/bool_decoder.txt index 0d66b5f47a6..45540eaa8a6 100644 --- a/crates/compiler/uitest/tests/ability/specialize/bool_decoder.txt +++ b/crates/compiler/uitest/tests/ability/specialize/bool_decoder.txt @@ -2,5 +2,5 @@ app "test" provides [main] to "./platform" main : Decoder Bool _ main = Decode.custom \bytes, fmt -> - Decode.decodeWith bytes Decode.decoder fmt - # ^^^^^^^^^^^^^^ Decoding#Decode.decoder(4): Decoder Bool fmt where fmt implements DecoderFormatting + Decode.decode_with bytes Decode.decoder fmt + # ^^^^^^^^^^^^^^ Decoding#Decode.decoder(4): Decoder Bool fmt where fmt implements DecoderFormatting diff --git a/crates/compiler/uitest/tests/ability/specialize/bool_eq.txt b/crates/compiler/uitest/tests/ability/specialize/bool_eq.txt index 3e41b54275f..d78e92f224f 100644 --- a/crates/compiler/uitest/tests/ability/specialize/bool_eq.txt +++ b/crates/compiler/uitest/tests/ability/specialize/bool_eq.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Bool.isEq Bool.true Bool.false -# ^^^^^^^^^ Eq#Bool.isEq(9): Bool, Bool -[[Bool.structuralEq(11)]]-> Bool +main = Bool.is_eq Bool.true Bool.false +# ^^^^^^^^^^ Eq#Bool.is_eq(9): Bool, Bool -[[Bool.structural_eq(11)]]-> Bool diff --git a/crates/compiler/uitest/tests/ability/specialize/bool_hash.txt b/crates/compiler/uitest/tests/ability/specialize/bool_hash.txt index 00a42f8a7e6..b476d878cf9 100644 --- a/crates/compiler/uitest/tests/ability/specialize/bool_hash.txt +++ b/crates/compiler/uitest/tests/ability/specialize/bool_hash.txt @@ -2,4 +2,4 @@ app "test" provides [main] to "./platform" main = \h -> Hash.hash h Bool.true - # ^^^^^^^^^ Hash#Hash.hash(1): a, Bool -[[Hash.hashBool(9)]]-> a where a implements Hasher + # ^^^^^^^^^ Hash#Hash.hash(1): a, Bool -[[Hash.hash_bool(9)]]-> a where a implements Hasher diff --git a/crates/compiler/uitest/tests/ability/specialize/bool_to_encoder.txt b/crates/compiler/uitest/tests/ability/specialize/bool_to_encoder.txt index 72fd873b894..7d37ebb4ae0 100644 --- a/crates/compiler/uitest/tests/ability/specialize/bool_to_encoder.txt +++ b/crates/compiler/uitest/tests/ability/specialize/bool_to_encoder.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Encode.toEncoder Bool.true -# ^^^^^^^^^^^^^^^^ Encoding#Encode.toEncoder(2): Bool -[[] + fmt:Encode.bool(17):1]-> Encoder fmt where fmt implements EncoderFormatting +main = Encode.to_encoder Bool.true +# ^^^^^^^^^^^^^^^^^ Encoding#Encode.to_encoder(2): Bool -[[] + fmt:Encode.bool(17):1]-> Encoder fmt where fmt implements EncoderFormatting diff --git a/crates/compiler/uitest/tests/ability/specialize/dec_hash.txt b/crates/compiler/uitest/tests/ability/specialize/dec_hash.txt index a69b5c6722e..a40306c3fa0 100644 --- a/crates/compiler/uitest/tests/ability/specialize/dec_hash.txt +++ b/crates/compiler/uitest/tests/ability/specialize/dec_hash.txt @@ -2,4 +2,4 @@ app "test" provides [main] to "./platform" main = \h -> Hash.hash h 1.1dec - # ^^^^^^^^^ Hash#Hash.hash(1): a, Dec -[[Hash.hashDec(17)]]-> a where a implements Hasher + # ^^^^^^^^^ Hash#Hash.hash(1): a, Dec -[[Hash.hash_dec(17)]]-> a where a implements Hasher diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/bool.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/bool.txt index 27668f3513b..ae97415979c 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/bool.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/bool.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Inspect.toInspector Bool.true |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): Bool -[[] + f:Inspect.bool(13):1]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector Bool.true |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): Bool -[[] + f:Inspect.bool(13):1]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/dec.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/dec.txt index 57a77a06591..3bdd6617950 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/dec.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/dec.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Inspect.toInspector 7dec |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): Dec -[[] + f:Inspect.dec(29):1]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector 7dec |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): Dec -[[] + f:Inspect.dec(29):1]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/non_implementing_opaque.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/non_implementing_opaque.txt index e1946cb50c5..c863da05561 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/non_implementing_opaque.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/non_implementing_opaque.txt @@ -2,5 +2,5 @@ app "test" provides [main] to "./platform" Op := {} -main = Inspect.toInspector (@Op {}) |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): Op -[[] + f:Inspect.opaque(15):1]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector (@Op {}) |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): Op -[[] + f:Inspect.opaque(15):1]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic.txt index 0e71d162d60..f793852b73d 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic.txt @@ -8,42 +8,42 @@ main = 1 # -emit:mono -procedure Inspect.255 (Inspect.256): - let Inspect.320 : Str = ""; - let Inspect.319 : Str = CallByName Inspect.63 Inspect.256 Inspect.320; - dec Inspect.320; - ret Inspect.319; +procedure Inspect.247 (Inspect.248): + let Inspect.312 : Str = ""; + let Inspect.311 : Str = CallByName Inspect.63 Inspect.248 Inspect.312; + dec Inspect.312; + ret Inspect.311; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.48 (Inspect.302): - let Inspect.317 : {} = Struct {}; - let Inspect.316 : {} = CallByName Inspect.30 Inspect.317; - ret Inspect.316; +procedure Inspect.48 (Inspect.294): + let Inspect.309 : {} = Struct {}; + let Inspect.308 : {} = CallByName Inspect.30 Inspect.309; + ret Inspect.308; procedure Inspect.5 (Inspect.150): - let Inspect.315 : {} = CallByName Inspect.48 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.255 Inspect.311; - ret Inspect.310; - -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.322 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.322; - -procedure Inspect.64 (Inspect.305): - ret Inspect.305; + let Inspect.307 : {} = CallByName Inspect.48 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.247 Inspect.303; + ret Inspect.302; + +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.314 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.314; + +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Str.3 (#Attr.2, #Attr.3): let Str.246 : Str = lowlevel StrConcat #Attr.2 #Attr.3; diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic_late.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic_late.txt index 87645098bbc..9a9e0ffd7f6 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic_late.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_automatic_late.txt @@ -11,42 +11,42 @@ main = late (@Op {}) # -emit:mono -procedure Inspect.255 (Inspect.256): - let Inspect.320 : Str = ""; - let Inspect.319 : Str = CallByName Inspect.63 Inspect.256 Inspect.320; - dec Inspect.320; - ret Inspect.319; +procedure Inspect.247 (Inspect.248): + let Inspect.312 : Str = ""; + let Inspect.311 : Str = CallByName Inspect.63 Inspect.248 Inspect.312; + dec Inspect.312; + ret Inspect.311; procedure Inspect.30 (Inspect.147): ret Inspect.147; procedure Inspect.33 (Inspect.152): - let Inspect.308 : Str = CallByName Inspect.5 Inspect.152; - let Inspect.307 : Str = CallByName Inspect.64 Inspect.308; - ret Inspect.307; + let Inspect.300 : Str = CallByName Inspect.5 Inspect.152; + let Inspect.299 : Str = CallByName Inspect.64 Inspect.300; + ret Inspect.299; -procedure Inspect.39 (Inspect.304): - let Inspect.314 : Str = ""; - ret Inspect.314; +procedure Inspect.39 (Inspect.296): + let Inspect.306 : Str = ""; + ret Inspect.306; -procedure Inspect.48 (Inspect.302): - let Inspect.317 : {} = Struct {}; - let Inspect.316 : {} = CallByName Inspect.30 Inspect.317; - ret Inspect.316; +procedure Inspect.48 (Inspect.294): + let Inspect.309 : {} = Struct {}; + let Inspect.308 : {} = CallByName Inspect.30 Inspect.309; + ret Inspect.308; procedure Inspect.5 (Inspect.150): - let Inspect.315 : {} = CallByName Inspect.48 Inspect.150; - let Inspect.312 : {} = Struct {}; - let Inspect.311 : Str = CallByName Inspect.39 Inspect.312; - let Inspect.310 : Str = CallByName Inspect.255 Inspect.311; - ret Inspect.310; + let Inspect.307 : {} = CallByName Inspect.48 Inspect.150; + let Inspect.304 : {} = Struct {}; + let Inspect.303 : Str = CallByName Inspect.39 Inspect.304; + let Inspect.302 : Str = CallByName Inspect.247 Inspect.303; + ret Inspect.302; -procedure Inspect.63 (Inspect.303, Inspect.299): - let Inspect.322 : Str = CallByName Str.3 Inspect.303 Inspect.299; - ret Inspect.322; +procedure Inspect.63 (Inspect.295, Inspect.291): + let Inspect.314 : Str = CallByName Str.3 Inspect.295 Inspect.291; + ret Inspect.314; -procedure Inspect.64 (Inspect.305): - ret Inspect.305; +procedure Inspect.64 (Inspect.297): + ret Inspect.297; procedure Str.3 (#Attr.2, #Attr.3): let Str.246 : Str = lowlevel StrConcat #Attr.2 #Attr.3; diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_custom_impl.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_custom_impl.txt index 6a3a9f6c627..ef9c8b7644b 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_custom_impl.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_custom_impl.txt @@ -1,9 +1,9 @@ app "test" provides [main] to "./platform" -Op := U8 implements [Inspect { toInspector: myToInspector }] +Op := U8 implements [Inspect { to_inspector: myToInspector }] myToInspector : Op -> Inspector f where f implements InspectFormatter myToInspector = \@Op num -> Inspect.u8 num -main = Inspect.toInspector (@Op 1u8) |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Op#Inspect.toInspector(2): Op -[[myToInspector(2)]]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector (@Op 1u8) |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Op#Inspect.to_inspector(2): Op -[[myToInspector(2)]]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_derived.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_derived.txt index b22d8b9b68f..1de9886958f 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_derived.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/opaque_derived.txt @@ -2,5 +2,5 @@ app "test" provides [main] to "./platform" Op := U8 implements [Inspect] -main = Inspect.toInspector (@Op 1u8) |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Op#Inspect.toInspector(3): Op -[[#Op_toInspector(3)]]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector (@Op 1u8) |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Op#Inspect.to_inspector(3): Op -[[#Op_to_inspector(3)]]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/ranged_num.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/ranged_num.txt index 84b8c5222e8..f2892b16e48 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/ranged_num.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/ranged_num.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Inspect.toInspector 7 |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): I64 -[[] + f:Inspect.i64(24):1]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector 7 |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): I64 -[[] + f:Inspect.i64(24):1]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/record.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/record.txt index 3dc0e5f8d12..f109b61ba11 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/record.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/record.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Inspect.toInspector { a: "" } |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): { a : Str } -[[#Derived.toInspector_{a}(0)]]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector { a: "" } |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): { a : Str } -[[#Derived.to_inspector_{a}(0)]]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/record_with_nested_custom_impl.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/record_with_nested_custom_impl.txt index 794f97b8b5a..9d2034f9670 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/record_with_nested_custom_impl.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/record_with_nested_custom_impl.txt @@ -1,9 +1,9 @@ app "test" provides [main] to "./platform" -Op := U8 implements [Inspect { toInspector: myToInspector }] +Op := U8 implements [Inspect { to_inspector: myToInspector }] myToInspector : Op -> Inspector f where f implements InspectFormatter myToInspector = \@Op num -> Inspect.u8 num -main = Inspect.toInspector { op: @Op 1u8 } |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): { op : Op } -[[#Derived.toInspector_{op}(0)]]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector { op: @Op 1u8 } |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): { op : Op } -[[#Derived.to_inspector_{op}(0)]]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/inspect/u8.txt b/crates/compiler/uitest/tests/ability/specialize/inspect/u8.txt index f6235fca34c..7b1d1627d7b 100644 --- a/crates/compiler/uitest/tests/ability/specialize/inspect/u8.txt +++ b/crates/compiler/uitest/tests/ability/specialize/inspect/u8.txt @@ -1,4 +1,4 @@ app "test" provides [main] to "./platform" -main = Inspect.toInspector 7u8 |> Inspect.apply (Inspect.init {}) -# ^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.toInspector(32): U8 -[[] + f:Inspect.u8(17):1]-> Inspector f where f implements InspectFormatter +main = Inspect.to_inspector 7u8 |> Inspect.apply (Inspect.init {}) +# ^^^^^^^^^^^^^^^^^^^^ Inspect#Inspect.to_inspector(32): U8 -[[] + f:Inspect.u8(17):1]-> Inspector f where f implements InspectFormatter diff --git a/crates/compiler/uitest/tests/ability/specialize/opaque_decoder_derive.txt b/crates/compiler/uitest/tests/ability/specialize/opaque_decoder_derive.txt index 9ea64135f15..3e1a94ceec4 100644 --- a/crates/compiler/uitest/tests/ability/specialize/opaque_decoder_derive.txt +++ b/crates/compiler/uitest/tests/ability/specialize/opaque_decoder_derive.txt @@ -5,5 +5,5 @@ N := U8 implements [Decoding] main : Decoder N _ main = Decode.custom \bytes, fmt -> - Decode.decodeWith bytes Decode.decoder fmt -# ^^^^^^^^^^^^^^ N#Decode.decoder(3): List U8, fmt -[[7]]-> { rest : List U8, result : [Err [TooShort], Ok U8] } where fmt implements DecoderFormatting + Decode.decode_with bytes Decode.decoder fmt +# ^^^^^^^^^^^^^^ N#Decode.decoder(3): List U8, fmt -[[7]]-> { rest : List U8, result : [Err [TooShort], Ok U8] } where fmt implements DecoderFormatting diff --git a/crates/compiler/uitest/tests/ability/specialize/opaque_encoder_derive.txt b/crates/compiler/uitest/tests/ability/specialize/opaque_encoder_derive.txt index 6e1b247dc6b..36968ce9d8c 100644 --- a/crates/compiler/uitest/tests/ability/specialize/opaque_encoder_derive.txt +++ b/crates/compiler/uitest/tests/ability/specialize/opaque_encoder_derive.txt @@ -2,5 +2,5 @@ app "test" provides [main] to "./platform" N := U8 implements [Encoding] -main = Encode.toEncoder (@N 15) -# ^^^^^^^^^^^^^^^^ N#Encode.toEncoder(3): N -[[#N_toEncoder(3)]]-> Encoder fmt where fmt implements EncoderFormatting +main = Encode.to_encoder (@N 15) +# ^^^^^^^^^^^^^^^^^ N#Encode.to_encoder(3): N -[[#N_to_encoder(3)]]-> Encoder fmt where fmt implements EncoderFormatting diff --git a/crates/compiler/uitest/tests/ability/specialize/opaque_eq_custom.txt b/crates/compiler/uitest/tests/ability/specialize/opaque_eq_custom.txt index 8cb1c64cc78..fff1a6978a9 100644 --- a/crates/compiler/uitest/tests/ability/specialize/opaque_eq_custom.txt +++ b/crates/compiler/uitest/tests/ability/specialize/opaque_eq_custom.txt @@ -1,8 +1,8 @@ app "test" provides [main] to "./platform" -Trivial := {} implements [Eq {isEq}] +Trivial := {} implements [Eq {is_eq}] -isEq = \@Trivial {}, @Trivial {} -> Bool.true +is_eq = \@Trivial {}, @Trivial {} -> Bool.true -main = Bool.isEq (@Trivial {}) (@Trivial {}) -# ^^^^^^^^^ Trivial#Bool.isEq(2): Trivial, Trivial -[[isEq(2)]]-> Bool +main = Bool.is_eq (@Trivial {}) (@Trivial {}) +# ^^^^^^^^^^ Trivial#Bool.is_eq(2): Trivial, Trivial -[[is_eq(2)]]-> Bool diff --git a/crates/compiler/uitest/tests/ability/specialize/opaque_eq_derive.txt b/crates/compiler/uitest/tests/ability/specialize/opaque_eq_derive.txt index 173fd0674d4..cbf28f22054 100644 --- a/crates/compiler/uitest/tests/ability/specialize/opaque_eq_derive.txt +++ b/crates/compiler/uitest/tests/ability/specialize/opaque_eq_derive.txt @@ -2,5 +2,5 @@ app "test" provides [main] to "./platform" N := U8 implements [Eq] -main = Bool.isEq (@N 15) (@N 23) -# ^^^^^^^^^ N#Bool.isEq(3): N, N -[[#N_isEq(3)]]-> Bool +main = Bool.is_eq (@N 15) (@N 23) +# ^^^^^^^^^^ N#Bool.is_eq(3): N, N -[[#N_is_eq(3)]]-> Bool diff --git a/crates/compiler/uitest/tests/ability/specialize/ranged_num_hash.txt b/crates/compiler/uitest/tests/ability/specialize/ranged_num_hash.txt index 0cfad58ac9d..8b9c74eb9bb 100644 --- a/crates/compiler/uitest/tests/ability/specialize/ranged_num_hash.txt +++ b/crates/compiler/uitest/tests/ability/specialize/ranged_num_hash.txt @@ -2,4 +2,4 @@ app "test" provides [main] to "./platform" main = \h -> Hash.hash h 7 - # ^^^^^^^^^ Hash#Hash.hash(1): a, I64 -[[Hash.hashI64(13)]]-> a where a implements Hasher + # ^^^^^^^^^ Hash#Hash.hash(1): a, I64 -[[Hash.hash_i64(13)]]-> a where a implements Hasher diff --git a/crates/compiler/uitest/tests/ability/specialize/record_to_encoder.txt b/crates/compiler/uitest/tests/ability/specialize/record_to_encoder.txt index e3b4e8cdc81..13c13056ee7 100644 --- a/crates/compiler/uitest/tests/ability/specialize/record_to_encoder.txt +++ b/crates/compiler/uitest/tests/ability/specialize/record_to_encoder.txt @@ -1,6 +1,6 @@ app "test" - imports [Encode.{ toEncoder }] + imports [Encode.{ to_encoder }] provides [main] to "./platform" -main = toEncoder { a: "" } - # ^^^^^^^^^ Encoding#toEncoder(2): { a : Str } -[[#Derived.toEncoder_{a}(0)]]-> Encoder fmt where fmt implements EncoderFormatting +main = to_encoder { a: "" } + # ^^^^^^^^^^ Encoding#to_encoder(2): { a : Str } -[[#Derived.to_encoder_{a}(0)]]-> Encoder fmt where fmt implements EncoderFormatting diff --git a/crates/compiler/uitest/tests/ability/specialize/record_to_encoder_with_nested_custom_impl.txt b/crates/compiler/uitest/tests/ability/specialize/record_to_encoder_with_nested_custom_impl.txt index 769296f3cf1..bf69e7a4603 100644 --- a/crates/compiler/uitest/tests/ability/specialize/record_to_encoder_with_nested_custom_impl.txt +++ b/crates/compiler/uitest/tests/ability/specialize/record_to_encoder_with_nested_custom_impl.txt @@ -1,9 +1,9 @@ app "test" - imports [Encode.{ toEncoder, custom }] + imports [Encode.{ to_encoder, custom }] provides [main] to "./platform" -A := {} implements [Encoding {toEncoder}] -toEncoder = \@A _ -> custom \b, _ -> b +A := {} implements [Encoding {to_encoder}] +to_encoder = \@A _ -> custom \b, _ -> b -main = toEncoder { a: @A {} } - # ^^^^^^^^^ Encoding#toEncoder(2): { a : A } -[[#Derived.toEncoder_{a}(0)]]-> Encoder fmt where fmt implements EncoderFormatting +main = to_encoder { a: @A {} } + # ^^^^^^^^^^ Encoding#to_encoder(2): { a : A } -[[#Derived.to_encoder_{a}(0)]]-> Encoder fmt where fmt implements EncoderFormatting diff --git a/crates/compiler/uitest/tests/ability/specialize/set_eq_issue_4761.txt b/crates/compiler/uitest/tests/ability/specialize/set_eq_issue_4761.txt index 3656f86edc0..fdd4e6267d9 100644 --- a/crates/compiler/uitest/tests/ability/specialize/set_eq_issue_4761.txt +++ b/crates/compiler/uitest/tests/ability/specialize/set_eq_issue_4761.txt @@ -7,6 +7,6 @@ main = s2 : Set Str s2 = Set.empty {} - Bool.isEq s1 s1 && Bool.isEq s2 s2 -# ^^^^^^^^^ Set#Bool.isEq(31): Set Str, Set Str -[[Set.isEq(31)]]-> Bool -# ^^^^^^^^^ Set#Bool.isEq(31): Set U8, Set U8 -[[Set.isEq(31)]]-> Bool + Bool.is_eq s1 s1 && Bool.is_eq s2 s2 +# ^^^^^^^^^^ Set#Bool.is_eq(31): Set Str, Set Str -[[Set.is_eq(31)]]-> Bool +# ^^^^^^^^^^ Set#Bool.is_eq(31): Set U8, Set U8 -[[Set.is_eq(31)]]-> Bool diff --git a/crates/compiler/uitest/tests/lambda_set/disjoint_nested_lambdas_result_in_disjoint_parents_issue_4712.txt b/crates/compiler/uitest/tests/lambda_set/disjoint_nested_lambdas_result_in_disjoint_parents_issue_4712.txt index 55a9402db28..078e4928ce5 100644 --- a/crates/compiler/uitest/tests/lambda_set/disjoint_nested_lambdas_result_in_disjoint_parents_issue_4712.txt +++ b/crates/compiler/uitest/tests/lambda_set/disjoint_nested_lambdas_result_in_disjoint_parents_issue_4712.txt @@ -42,4 +42,4 @@ parseInput = \{} -> ] is _ -> "" -main = Bool.isEq (parseInput {}) "" \ No newline at end of file +main = Bool.is_eq (parseInput {}) "" \ No newline at end of file diff --git a/crates/compiler/uitest/tests/recursion/choose_correct_recursion_var_under_record.txt b/crates/compiler/uitest/tests/recursion/choose_correct_recursion_var_under_record.txt index e0edb098b86..cd767e9335f 100644 --- a/crates/compiler/uitest/tests/recursion/choose_correct_recursion_var_under_record.txt +++ b/crates/compiler/uitest/tests/recursion/choose_correct_recursion_var_under_record.txt @@ -20,6 +20,6 @@ main = printed = printCombinatorParser f.parser if Bool.false then printed else "foo" |> List.first - |> Result.withDefault ("foo") + |> Result.with_default ("foo") printCombinatorParser (Record []) diff --git a/crates/compiler/uitest/tests/solve/function_alias_in_signature.txt b/crates/compiler/uitest/tests/solve/function_alias_in_signature.txt index e1bd03174cd..0714cf9ad30 100644 --- a/crates/compiler/uitest/tests/solve/function_alias_in_signature.txt +++ b/crates/compiler/uitest/tests/solve/function_alias_in_signature.txt @@ -5,7 +5,7 @@ Parser a : List U8 -> List [Pair a (List U8)] any: Parser U8 any = \inp -> when List.first inp is - Ok u -> [Pair u (List.dropFirst inp 1)] + Ok u -> [Pair u (List.drop_first inp 1)] _ -> [] main = any diff --git a/crates/compiler/uitest/tests/solve/issue_2583_specialize_errors_behind_unified_branches.txt b/crates/compiler/uitest/tests/solve/issue_2583_specialize_errors_behind_unified_branches.txt index f54fdb4a1c5..7100a812199 100644 --- a/crates/compiler/uitest/tests/solve/issue_2583_specialize_errors_behind_unified_branches.txt +++ b/crates/compiler/uitest/tests/solve/issue_2583_specialize_errors_behind_unified_branches.txt @@ -1,7 +1,7 @@ app "test" provides [main] to "./platform" entry = - if Bool.true then List.first [] else Str.toI64 "" + if Bool.true then List.first [] else Str.to_i64 "" main = entry # ^^^^^ Result I64 [InvalidNumStr, ListWasEmpty]w_a diff --git a/crates/compiler/uitest/tests/solve/multiple_abilities_multiple_members_specializations.txt b/crates/compiler/uitest/tests/solve/multiple_abilities_multiple_members_specializations.txt index adddd308cb0..cdeffa166f3 100644 --- a/crates/compiler/uitest/tests/solve/multiple_abilities_multiple_members_specializations.txt +++ b/crates/compiler/uitest/tests/solve/multiple_abilities_multiple_members_specializations.txt @@ -13,7 +13,7 @@ Id := U64 implements [MHash {hash, hash32}, Ord {eq, le}] hash = \@Id n -> n #^^^^{-1} Id#hash(7): Id -[[hash(7)]]-> U64 -hash32 = \@Id n -> Num.toU32 n +hash32 = \@Id n -> Num.to_u32 n #^^^^^^{-1} Id#hash32(8): Id -[[hash32(8)]]-> U32 eq = \@Id m, @Id n -> m == n diff --git a/crates/compiler/uitest/tests/solve/single_ability_multiple_members_specializations.txt b/crates/compiler/uitest/tests/solve/single_ability_multiple_members_specializations.txt index 5738eebcd61..6eda721b4b1 100644 --- a/crates/compiler/uitest/tests/solve/single_ability_multiple_members_specializations.txt +++ b/crates/compiler/uitest/tests/solve/single_ability_multiple_members_specializations.txt @@ -9,5 +9,5 @@ Id := U64 implements [MHash {hash, hash32}] hash = \@Id n -> n #^^^^{-1} Id#hash(4): Id -[[hash(4)]]-> U64 -hash32 = \@Id n -> Num.toU32 n +hash32 = \@Id n -> Num.to_u32 n #^^^^^^{-1} Id#hash32(5): Id -[[hash32(5)]]-> U32 diff --git a/crates/compiler/uitest/tests/solve/stdlib_encode_something.txt b/crates/compiler/uitest/tests/solve/stdlib_encode_something.txt index 14632e2c213..a0d8f30c989 100644 --- a/crates/compiler/uitest/tests/solve/stdlib_encode_something.txt +++ b/crates/compiler/uitest/tests/solve/stdlib_encode_something.txt @@ -39,7 +39,7 @@ encodeF32 = \_n -> encodeNothing encodeF64 = \_n -> encodeNothing encodeDec = \_n -> encodeNothing encodeBool = \_b -> encodeNothing -encodeString = \str -> Encode.custom \bytes, @OnlyStrEncoder {} -> List.concat bytes (Str.toUtf8 str) +encodeString = \str -> Encode.custom \bytes, @OnlyStrEncoder {} -> List.concat bytes (Str.to_utf8 str) encodeList : List elem, (elem -> Encoder OnlyStrEncoder) -> Encoder OnlyStrEncoder encodeList = \_lst, _encodeElem -> encodeNothing encodeRecord : List {key: Str, value: Encoder OnlyStrEncoder} -> Encoder OnlyStrEncoder @@ -50,15 +50,15 @@ encodeTag : Str, List (Encoder OnlyStrEncoder) -> Encoder OnlyStrEncoder encodeTag = \_name, _payload -> encodeNothing -HelloWorld := {} implements [Encoding {toEncoder}] +HelloWorld := {} implements [Encoding {to_encoder}] -toEncoder = \@HelloWorld {} -> +to_encoder = \@HelloWorld {} -> Encode.custom \bytes, fmt -> bytes - |> Encode.appendWith (Encode.string "Hello, World!\n") fmt + |> Encode.append_with (Encode.string "Hello, World!\n") fmt f = - when Str.fromUtf8 (Encode.toBytes (@HelloWorld {}) (@OnlyStrEncoder {})) is + when Str.from_utf8 (Encode.to_bytes (@HelloWorld {}) (@OnlyStrEncoder {})) is Ok s -> s _ -> "" diff --git a/crates/compiler/uitest/tests/solve/to_float.txt b/crates/compiler/uitest/tests/solve/to_float.txt index a8ad9777255..44b0892205e 100644 --- a/crates/compiler/uitest/tests/solve/to_float.txt +++ b/crates/compiler/uitest/tests/solve/to_float.txt @@ -2,9 +2,9 @@ app "test" provides [main] to "./platform" entry = { - toF32: Num.toF32, - toF64: Num.toF64, + to_f32: Num.to_f32, + to_f64: Num.to_f64, } main = entry -# ^^^^^ { toF32 : Num * -[[Num.toF32(139)]]-> F32, toF64 : Num w_a -[[Num.toF64(141)]]-> F64 } +# ^^^^^ { to_f32 : Num * -[[Num.to_f32(139)]]-> F32, to_f64 : Num w_a -[[Num.to_f64(141)]]-> F64 } diff --git a/crates/compiler/uitest/tests/solve/to_int.txt b/crates/compiler/uitest/tests/solve/to_int.txt index 6aeb375ae71..e16b9588349 100644 --- a/crates/compiler/uitest/tests/solve/to_int.txt +++ b/crates/compiler/uitest/tests/solve/to_int.txt @@ -2,17 +2,17 @@ app "test" provides [main] to "./platform" entry = { - toI8: Num.toI8, - toI16: Num.toI16, - toI32: Num.toI32, - toI64: Num.toI64, - toI128: Num.toI128, - toU8: Num.toU8, - toU16: Num.toU16, - toU32: Num.toU32, - toU64: Num.toU64, - toU128: Num.toU128, + to_i8: Num.to_i8, + to_i16: Num.to_i16, + to_i32: Num.to_i32, + to_i64: Num.to_i64, + to_i128: Num.to_i128, + to_u8: Num.to_u8, + to_u16: Num.to_u16, + to_u32: Num.to_u32, + to_u64: Num.to_u64, + to_u128: Num.to_u128, } main = entry -# ^^^^^ { toI128 : Int * -[[Num.toI128(125)]]-> I128, toI16 : Int w_a -[[Num.toI16(119)]]-> I16, toI32 : Int w_b -[[Num.toI32(121)]]-> I32, toI64 : Int w_c -[[Num.toI64(123)]]-> I64, toI8 : Int w_d -[[Num.toI8(117)]]-> I8, toU128 : Int w_e -[[Num.toU128(135)]]-> U128, toU16 : Int w_f -[[Num.toU16(129)]]-> U16, toU32 : Int w_g -[[Num.toU32(131)]]-> U32, toU64 : Int w_h -[[Num.toU64(133)]]-> U64, toU8 : Int w_i -[[Num.toU8(127)]]-> U8 } +# ^^^^^ { to_i128 : Int * -[[Num.to_i128(125)]]-> I128, to_i16 : Int w_a -[[Num.to_i16(119)]]-> I16, to_i32 : Int w_b -[[Num.to_i32(121)]]-> I32, to_i64 : Int w_c -[[Num.to_i64(123)]]-> I64, to_i8 : Int w_d -[[Num.to_i8(117)]]-> I8, to_u128 : Int w_e -[[Num.to_u128(135)]]-> U128, to_u16 : Int w_f -[[Num.to_u16(129)]]-> U16, to_u32 : Int w_g -[[Num.to_u32(131)]]-> U32, to_u64 : Int w_h -[[Num.to_u64(133)]]-> U64, to_u8 : Int w_i -[[Num.to_u8(127)]]-> U8 } diff --git a/crates/compiler/unify/src/unify.rs b/crates/compiler/unify/src/unify.rs index d5829a41701..2b4e1dea286 100644 --- a/crates/compiler/unify/src/unify.rs +++ b/crates/compiler/unify/src/unify.rs @@ -1282,9 +1282,9 @@ fn extract_specialization_lambda_set( // lambda set does not line up with one required by the ability member prototype. // As an example, consider // - // Q := [ F (Str -> Str) ] implements [Eq {isEq}] + // Q := [ F (Str -> Str) ] implements [Eq {is_eq}] // - // isEq = \@Q _, @Q _ -> Bool.false + // is_eq = \@Q _, @Q _ -> Bool.false // // here the lambda set of `F`'s payload is part of the specialization signature, but it is // irrelevant to the specialization. As such, I believe it is safe to drop the diff --git a/crates/glue/README.md b/crates/glue/README.md index 332abd69d3c..c4692bf75fb 100644 --- a/crates/glue/README.md +++ b/crates/glue/README.md @@ -21,13 +21,13 @@ platform "glue-types" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] GlueTypes : { a : SomeType, b : AnotherType, } -mainForHost : GlueTypes -mainForHost = main +main_for_host : GlueTypes +main_for_host = main ``` diff --git a/crates/glue/platform/Shape.roc b/crates/glue/platform/Shape.roc index 56ffad8d40e..02b86fb617a 100644 --- a/crates/glue/platform/Shape.roc +++ b/crates/glue/platform/Shape.roc @@ -62,8 +62,8 @@ RocTagUnion : [ { name : Str, tags : List { name : Str, payload : [Some TypeId, None] }, - discriminantSize : U32, - discriminantOffset : U32, + discriminant_size : U32, + discriminant_offset : U32, }, ## A recursive tag union (general case) ## e.g. `Expr : [Sym Str, Add Expr Expr]` @@ -71,8 +71,8 @@ RocTagUnion : [ { name : Str, tags : List { name : Str, payload : [Some TypeId, None] }, - discriminantSize : U32, - discriminantOffset : U32, + discriminant_size : U32, + discriminant_offset : U32, }, ## A recursive tag union that has an empty variant ## Optimization: Represent the empty variant as null pointer => no memory usage & fast comparison @@ -82,17 +82,17 @@ RocTagUnion : [ NullableWrapped { name : Str, - indexOfNullTag : U16, + index_of_null_tag : U16, tags : List { name : Str, payload : [Some TypeId, None] }, - discriminantSize : U32, - discriminantOffset : U32, + discriminant_size : U32, + discriminant_offset : U32, }, ## Optimization: No need to store a tag ID (the payload is "unwrapped") ## e.g. `RoseTree a : [Tree a (List (RoseTree a))]` NonNullableUnwrapped { name : Str, - tagName : Str, + tag_name : Str, payload : TypeId, # These always have a payload. }, ## Optimization: No need to store a tag ID (the payload is "unwrapped") @@ -100,7 +100,7 @@ RocTagUnion : [ SingleTagStruct { name : Str, - tagName : Str, + tag_name : Str, payload : RocSingleTagPayload, }, ## A recursive tag union with only two variants, where one is empty. @@ -109,10 +109,10 @@ RocTagUnion : [ NullableUnwrapped { name : Str, - nullTag : Str, - nonNullTag : Str, - nonNullPayload : TypeId, - whichTagIsNull : [FirstTagIsNull, SecondTagIsNull], + null_tag : Str, + non_null_tag : Str, + non_null_payload : TypeId, + which_tag_is_null : [FirstTagIsNull, SecondTagIsNull], }, ] @@ -127,10 +127,10 @@ RocSingleTagPayload : [ ] RocFn : { - functionName : Str, - externName : Str, + function_name : Str, + extern_name : Str, args : List TypeId, - lambdaSet : TypeId, + lambda_set : TypeId, ret : TypeId, - isToplevel : Bool, + is_toplevel : Bool, } diff --git a/crates/glue/platform/Target.roc b/crates/glue/platform/Target.roc index 92f18cfa8e4..e223d55c796 100644 --- a/crates/glue/platform/Target.roc +++ b/crates/glue/platform/Target.roc @@ -2,7 +2,7 @@ module [Target, Architecture, OperatingSystem] Target : { architecture : Architecture, - operatingSystem : OperatingSystem, + operating_system : OperatingSystem, } Architecture : [ diff --git a/crates/glue/platform/TypeId.roc b/crates/glue/platform/TypeId.roc index dac002a1dc1..6795f587f69 100644 --- a/crates/glue/platform/TypeId.roc +++ b/crates/glue/platform/TypeId.roc @@ -1,11 +1,11 @@ -module [TypeId, typeIDfromU64, typeIDtoU64] +module [TypeId, type_id_from_u64, type_id_to_u64] TypeId := U64 implements [Eq, Hash, Inspect, Encoding] # renamed here so we can import the functions directly as a workaround for # https://github.com/roc-lang/roc/issues/5477 -typeIDtoU64 : TypeId -> U64 -typeIDtoU64 = \@TypeId x -> x +type_id_to_u64 : TypeId -> U64 +type_id_to_u64 = \@TypeId(x) -> x -typeIDfromU64 : U64 -> TypeId -typeIDfromU64 = @TypeId +type_id_from_u64 : U64 -> TypeId +type_id_from_u64 = @TypeId diff --git a/crates/glue/platform/Types.roc b/crates/glue/platform/Types.roc index ff50eb69384..1f7146d74e5 100644 --- a/crates/glue/platform/Types.roc +++ b/crates/glue/platform/Types.roc @@ -1,7 +1,7 @@ -module [Types, shape, size, alignment, target, walkShapes, entryPoints] +module [Types, shape, size, alignment, target, walk_shapes, entry_points] import Shape exposing [Shape] -import TypeId exposing [TypeId, typeIDfromU64, typeIDtoU64] +import TypeId exposing [TypeId, type_id_from_u64, type_id_to_u64] import Target exposing [Target] # TODO: switch AssocList uses to Dict once roc_std is updated. @@ -15,55 +15,55 @@ Types := { aligns : List U32, # Needed to check for duplicates - typesByName : List Tuple1, + types_by_name : List Tuple1, ## Dependencies - that is, which type depends on which other type. ## This is important for declaration order in C; we need to output a ## type declaration earlier in the file than where it gets referenced by another type. deps : List Tuple2, - ## Names and types of the entry points of the program (e.g. mainForHost) + ## Names and types of the entry points of the program (e.g. main_for_host) entrypoints : List Tuple1, target : Target, } implements [Inspect, Encoding] target : Types -> Target -target = \@Types types -> types.target +target = \@Types(types) -> types.target -entryPoints : Types -> List Tuple1 -entryPoints = \@Types { entrypoints } -> entrypoints +entry_points : Types -> List Tuple1 +entry_points = \@Types({ entrypoints }) -> entrypoints -walkShapes : Types, state, (state, Shape, TypeId -> state) -> state -walkShapes = \@Types { types: shapes }, originalState, update -> - List.walkWithIndex shapes originalState \state, elem, index -> - id = typeIDfromU64 index +walk_shapes : Types, state, (state, Shape, TypeId -> state) -> state +walk_shapes = \@Types({ types: shapes }), original_state, update -> + List.walk_with_index(shapes, original_state, \state, elem, index -> + id = type_id_from_u64(index) - update state elem id + update(state, elem, id)) shape : Types, TypeId -> Shape -shape = \@Types types, id -> - when List.get types.types (typeIDtoU64 id) is - Ok answer -> answer - Err OutOfBounds -> - idStr = Num.toStr (typeIDtoU64 id) +shape = \@Types(types), id -> + when List.get(types.types, type_id_to_u64(id)) is + Ok(answer) -> answer + Err(OutOfBounds) -> + id_str = Num.to_str(type_id_to_u64(id)) - crash "TypeId #$(idStr) was not found in Types. This should never happen, and means there was a bug in `roc glue`. If you have time, please open an issue at " + crash("TypeId #$(id_str) was not found in Types. This should never happen, and means there was a bug in `roc glue`. If you have time, please open an issue at ") alignment : Types, TypeId -> U32 -alignment = \@Types types, id -> - when List.get types.aligns (typeIDtoU64 id) is - Ok answer -> answer - Err OutOfBounds -> - idStr = Num.toStr (typeIDtoU64 id) +alignment = \@Types(types), id -> + when List.get(types.aligns, type_id_to_u64(id)) is + Ok(answer) -> answer + Err(OutOfBounds) -> + id_str = Num.to_str(type_id_to_u64(id)) - crash "TypeId #$(idStr) was not found in Types. This should never happen, and means there was a bug in `roc glue`. If you have time, please open an issue at " + crash("TypeId #$(id_str) was not found in Types. This should never happen, and means there was a bug in `roc glue`. If you have time, please open an issue at ") size : Types, TypeId -> U32 -size = \@Types types, id -> - when List.get types.sizes (typeIDtoU64 id) is - Ok answer -> answer - Err OutOfBounds -> - idStr = Num.toStr (typeIDtoU64 id) +size = \@Types(types), id -> + when List.get(types.sizes, type_id_to_u64(id)) is + Ok(answer) -> answer + Err(OutOfBounds) -> + id_str = Num.to_str(type_id_to_u64(id)) - crash "TypeId #$(idStr) was not found in Types. This should never happen, and means there was a bug in `roc glue`. If you have time, please open an issue at " + crash("TypeId #$(id_str) was not found in Types. This should never happen, and means there was a bug in `roc glue`. If you have time, please open an issue at ") diff --git a/crates/glue/platform/main.roc b/crates/glue/platform/main.roc index 8abd83a981d..fd5d079c896 100644 --- a/crates/glue/platform/main.roc +++ b/crates/glue/platform/main.roc @@ -1,9 +1,9 @@ platform "roc-lang/glue" - requires {} { makeGlue : List Types -> Result (List File) Str } + requires {} { make_glue : List Types -> Result (List File) Str } exposes [Shape, File, Types, TypeId, Target] packages {} imports [Types.{ Types }, File.{ File }] - provides [makeGlueForHost] + provides [make_glue_for_host] -makeGlueForHost : List Types -> Result (List File) Str -makeGlueForHost = \types -> makeGlue types +make_glue_for_host : List Types -> Result (List File) Str +make_glue_for_host = \types -> make_glue(types) diff --git a/crates/glue/src/CGlue.roc b/crates/glue/src/CGlue.roc index cf38922210c..2ed4d99c074 100644 --- a/crates/glue/src/CGlue.roc +++ b/crates/glue/src/CGlue.roc @@ -1,4 +1,4 @@ -app [makeGlue] { pf: platform "../platform/main.roc" } +app [make_glue] { pf: platform "../platform/main.roc" } import pf.Types exposing [Types] # import pf.Shape exposing [Shape, RocFn] @@ -6,24 +6,24 @@ import pf.File exposing [File] # import pf.TypeId exposing [TypeId] ## generate placeholder glue for now that only works for our one C test -makeGlue : List Types -> Result (List File) Str -makeGlue = \_typesByArch -> - Ok ([{ name: "roc_app.h", content: placeholderGlue }]) +make_glue : List Types -> Result (List File) Str +make_glue = \_types_by_arch -> + Ok([{ name: "roc_app.h", content: placeholder_glue }]) -placeholderGlue = +placeholder_glue = """ #ifndef ROC_APP_H #define ROC_APP_H #include - extern void roc__mainForHost_1_exposed_generic(uint8_t *ret); + extern void roc__main_for_host_1_exposed_generic(uint8_t *ret); - uint8_t roc_mainForHost() + uint8_t roc_main_for_host() { uint8_t ret; - roc__mainForHost_1_exposed_generic(&ret); + roc__main_for_host_1_exposed_generic(&ret); return ret; } diff --git a/crates/glue/src/DescribeGlue.roc b/crates/glue/src/DescribeGlue.roc index ea57ddbfee4..886107e8844 100644 --- a/crates/glue/src/DescribeGlue.roc +++ b/crates/glue/src/DescribeGlue.roc @@ -1,13 +1,13 @@ -app [makeGlue] { pf: platform "../platform/main.roc" } +app [make_glue] { pf: platform "../platform/main.roc" } import pf.Types exposing [Types] import pf.File exposing [File] -makeGlue : List Types -> Result (List File) Str -makeGlue = \types -> - Ok [ +make_glue : List Types -> Result (List File) Str +make_glue = \types -> + Ok([ { name: "types.txt", - content: List.map types Inspect.toStr |> Str.joinWith "\n", + content: List.map(types, Inspect.to_str) |> Str.join_with("\n"), }, - ] + ]) diff --git a/crates/glue/src/RustGlue.roc b/crates/glue/src/RustGlue.roc index f8d833203d4..acc4fdd4efd 100644 --- a/crates/glue/src/RustGlue.roc +++ b/crates/glue/src/RustGlue.roc @@ -1,98 +1,99 @@ -app [makeGlue] { pf: platform "../platform/main.roc" } +app [make_glue] { pf: platform "../platform/main.roc" } import pf.Types exposing [Types] import pf.Shape exposing [Shape, RocFn] import pf.File exposing [File] import pf.TypeId exposing [TypeId] -import "../static/Cargo.toml" as rocAppCargoToml : Str -import "../../roc_std/Cargo.toml" as rocStdCargoToml : Str -import "../../roc_std/src/lib.rs" as rocStdLib : Str -import "../../roc_std/src/roc_box.rs" as rocStdBox : Str -import "../../roc_std/src/roc_list.rs" as rocStdList : Str -import "../../roc_std/src/roc_str.rs" as rocStdStr : Str -import "../../roc_std/src/storage.rs" as rocStdStorage : Str - -makeGlue : List Types -> Result (List File) Str -makeGlue = \typesByArch -> - modFileContent = - List.walk typesByArch fileHeader \content, types -> - arch = (Types.target types).architecture - archStr = archName arch - - Str.concat - content +import "../static/Cargo.toml" as roc_app_cargo_toml : Str +import "../../roc_std/Cargo.toml" as roc_std_cargo_toml : Str +import "../../roc_std/src/lib.rs" as roc_std_lib : Str +import "../../roc_std/src/roc_box.rs" as roc_std_box : Str +import "../../roc_std/src/roc_list.rs" as roc_std_list : Str +import "../../roc_std/src/roc_str.rs" as roc_std_str : Str +import "../../roc_std/src/storage.rs" as roc_std_storage : Str + +make_glue : List Types -> Result (List File) Str +make_glue = \types_by_arch -> + mod_file_content = + List.walk(types_by_arch, file_header, \content, types -> + arch = (Types.target(types)).architecture + arch_str = arch_name(arch) + + Str.concat( + content, """ - #[cfg(target_arch = "$(archStr)")] - mod $(archStr); - #[cfg(target_arch = "$(archStr)")] - pub use $(archStr)::*; + #[cfg(target_arch = "$(arch_str)")] + mod $(arch_str); + #[cfg(target_arch = "$(arch_str)")] + pub use $(arch_str)::*; - """ + """, + )) - typesByArch - |> List.map convertTypesToFile - |> List.append { name: "roc_app/src/lib.rs", content: modFileContent } - |> List.concat staticFiles + types_by_arch + |> List.map(convert_types_to_file) + |> List.append({ name: "roc_app/src/lib.rs", content: mod_file_content }) + |> List.concat(static_files) |> Ok ## These are always included, and don't depend on the specifics of the app. -staticFiles : List File -staticFiles = [ - { name: "roc_app/Cargo.toml", content: rocAppCargoToml }, - { name: "roc_std/Cargo.toml", content: rocStdCargoToml }, - { name: "roc_std/src/lib.rs", content: rocStdLib }, - { name: "roc_std/src/roc_box.rs", content: rocStdBox }, - { name: "roc_std/src/roc_list.rs", content: rocStdList }, - { name: "roc_std/src/roc_str.rs", content: rocStdStr }, - { name: "roc_std/src/storage.rs", content: rocStdStorage }, +static_files : List File +static_files = [ + { name: "roc_app/Cargo.toml", content: roc_app_cargo_toml }, + { name: "roc_std/Cargo.toml", content: roc_std_cargo_toml }, + { name: "roc_std/src/lib.rs", content: roc_std_lib }, + { name: "roc_std/src/roc_box.rs", content: roc_std_box }, + { name: "roc_std/src/roc_list.rs", content: roc_std_list }, + { name: "roc_std/src/roc_str.rs", content: roc_std_str }, + { name: "roc_std/src/storage.rs", content: roc_std_storage }, ] -convertTypesToFile : Types -> File -convertTypesToFile = \types -> +convert_types_to_file : Types -> File +convert_types_to_file = \types -> content = - Types.walkShapes types fileHeader \buf, type, id -> + Types.walk_shapes(types, file_header, \buf, type, id -> when type is - Struct { name, fields } -> - generateStruct buf types id name fields Public + Struct({ name, fields }) -> + generate_struct(buf, types, id, name, fields, Public) - TagUnionPayload { name, fields } -> - generateStruct buf types id name (nameTagUnionPayloadFields fields) Public + TagUnionPayload({ name, fields }) -> + generate_struct(buf, types, id, name, name_tag_union_payload_fields(fields), Public) - TagUnion (Enumeration { name, tags, size }) -> - generateEnumeration buf types type name tags size + TagUnion(Enumeration({ name, tags, size })) -> + generate_enumeration(buf, types, type, name, tags, size) - TagUnion (NonRecursive { name, tags, discriminantSize, discriminantOffset }) -> - if !(List.isEmpty tags) then - generateNonRecursiveTagUnion buf types id name tags discriminantSize discriminantOffset + TagUnion(NonRecursive({ name, tags, discriminant_size, discriminant_offset })) -> + if !(List.is_empty(tags)) then + generate_non_recursive_tag_union(buf, types, id, name, tags, discriminant_size, discriminant_offset) else buf - TagUnion (Recursive { name, tags, discriminantSize, discriminantOffset }) -> - if !(List.isEmpty tags) then - generateRecursiveTagUnion buf types id name tags discriminantSize discriminantOffset None + TagUnion(Recursive({ name, tags, discriminant_size, discriminant_offset })) -> + if !(List.is_empty(tags)) then + generate_recursive_tag_union(buf, types, id, name, tags, discriminant_size, discriminant_offset, None) else buf - TagUnion (NullableWrapped { name, indexOfNullTag, tags, discriminantSize, discriminantOffset }) -> + TagUnion(NullableWrapped({ name, index_of_null_tag, tags, discriminant_size, discriminant_offset })) -> # TODO: generate this as `TypeName(*mut u8)` if the payload contains functions / unsized types - generateRecursiveTagUnion buf types id name tags discriminantSize discriminantOffset (Some indexOfNullTag) + generate_recursive_tag_union(buf, types, id, name, tags, discriminant_size, discriminant_offset, Some(index_of_null_tag)) - TagUnion (NullableUnwrapped { name, nullTag, nonNullTag, nonNullPayload, whichTagIsNull }) -> - generateNullableUnwrapped buf types id name nullTag nonNullTag nonNullPayload whichTagIsNull + TagUnion(NullableUnwrapped({ name, null_tag, non_null_tag, non_null_payload, which_tag_is_null })) -> + generate_nullable_unwrapped(buf, types, id, name, null_tag, non_null_tag, non_null_payload, which_tag_is_null) - TagUnion (SingleTagStruct { name, tagName, payload }) -> - generateSingleTagStruct buf types name tagName payload + TagUnion(SingleTagStruct({ name, tag_name, payload })) -> + generate_single_tag_struct(buf, types, name, tag_name, payload) - TagUnion (NonNullableUnwrapped { name, tagName, payload }) -> - generateNonNullableUnwrapped buf types name tagName payload 0 0 None + TagUnion(NonNullableUnwrapped({ name, tag_name, payload })) -> + generate_non_nullable_unwrapped(buf, types, name, tag_name, payload, 0, 0, None) - Function rocFn -> - if rocFn.isToplevel then + Function(roc_fn) -> + if roc_fn.is_toplevel then buf else - generateFunction buf types rocFn + generate_function(buf, types, roc_fn) - RecursivePointer _ -> + RecursivePointer(_) -> # This is recursively pointing to a type that should already have been added, # so no extra work needs to happen. buf @@ -100,107 +101,107 @@ convertTypesToFile = \types -> Unit | Unsized | EmptyTagUnion - | Num _ + | Num(_) | Bool - | RocResult _ _ + | RocResult(_, _) | RocStr - | RocDict _ _ - | RocSet _ - | RocList _ - | RocBox _ -> + | RocDict(_, _) + | RocSet(_) + | RocList(_) + | RocBox(_) -> # These types don't need to be declared in Rust. # TODO: Eventually we want to generate roc_std. So these types will need to be emitted. - buf + buf) - arch = (Types.target types).architecture - archStr = archName arch + arch = (Types.target(types)).architecture + arch_str = arch_name(arch) { - name: "roc_app/src/$(archStr).rs", - content: content |> generateEntryPoints types, + name: "roc_app/src/$(arch_str).rs", + content: content |> generate_entry_points(types), } -generateEntryPoints : Str, Types -> Str -generateEntryPoints = \buf, types -> - List.walk (Types.entryPoints types) buf \accum, T name id -> generateEntryPoint accum types name id +generate_entry_points : Str, Types -> Str +generate_entry_points = \buf, types -> + List.walk(Types.entry_points(types), buf, \accum, T(name, id) -> generate_entry_point(accum, types, name, id)) -generateEntryPoint : Str, Types, Str, TypeId -> Str -generateEntryPoint = \buf, types, name, id -> - publicSignature = - when Types.shape types id is - Function rocFn -> +generate_entry_point : Str, Types, Str, TypeId -> Str +generate_entry_point = \buf, types, name, id -> + public_signature = + when Types.shape(types, id) is + Function(roc_fn) -> arguments = - toArgStr rocFn.args types \argId, _shape, index -> - type = typeName types argId - indexStr = Num.toStr index + to_arg_str(roc_fn.args, types, \arg_id, _shape, index -> + type = type_name(types, arg_id) + index_str = Num.to_str(index) - "arg$(indexStr): $(type)" + "arg$(index_str): $(type)") - ret = typeName types rocFn.ret + ret = type_name(types, roc_fn.ret) "($(arguments)) -> $(ret)" _ -> - ret = typeName types id + ret = type_name(types, id) "() -> $(ret)" - (externSignature, returnTypeName, returnsFn) = - when Types.shape types id is - Function rocFn -> + (extern_signature, return_type_name, returns_fn) = + when Types.shape(types, id) is + Function(roc_fn) -> arguments = - toArgStr rocFn.args types \argId, shape, _index -> - type = typeName types argId + to_arg_str(roc_fn.args, types, \arg_id, shape, _index -> + type = type_name(types, arg_id) - if canDeriveCopy types shape then + if can_derive_copy(types, shape) then "_: $(type)" else - "_: &mut core::mem::ManuallyDrop<$(type)>" + "_: &mut core::mem::ManuallyDrop<$(type)>") - ret = typeName types rocFn.ret - when Types.shape types rocFn.ret is - Function _ -> + ret = type_name(types, roc_fn.ret) + when Types.shape(types, roc_fn.ret) is + Function(_) -> ("(_: *mut u8, $(arguments))", ret, Bool.true) _ -> ("(_: *mut $(ret), $(arguments))", ret, Bool.false) _ -> - ret = typeName types id + ret = type_name(types, id) ("(_: *mut $(ret))", ret, Bool.false) - externArguments = - when Types.shape types id is - Function rocFn -> - toArgStr rocFn.args types \_argId, shape, index -> - indexStr = Num.toStr index + extern_arguments = + when Types.shape(types, id) is + Function(roc_fn) -> + to_arg_str(roc_fn.args, types, \_argId, shape, index -> + index_str = Num.to_str(index) - if canDeriveCopy types shape then - "arg$(indexStr)" + if can_derive_copy(types, shape) then + "arg$(index_str)" else - "&mut core::mem::ManuallyDrop::new(arg$(indexStr))" + "&mut core::mem::ManuallyDrop::new(arg$(index_str))") _ -> "" - if returnsFn then + if returns_fn then """ $(buf) - pub fn $(name)$(publicSignature) { + pub fn $(name)$(public_signature) { extern "C" { - fn roc__$(name)_1_exposed_generic$(externSignature); + fn roc__$(name)_1_exposed_generic$(extern_signature); fn roc__$(name)_1_exposed_size() -> i64; } unsafe { let capacity = roc__$(name)_1_exposed_size() as usize; - let mut ret = $(returnTypeName) { + let mut ret = $(return_type_name) { closure_data: Vec::with_capacity(capacity), }; ret.closure_data.resize(capacity, 0); - roc__$(name)_1_exposed_generic(ret.closure_data.as_mut_ptr(), $(externArguments)); + roc__$(name)_1_exposed_generic(ret.closure_data.as_mut_ptr(), $(extern_arguments)); ret } @@ -210,63 +211,63 @@ generateEntryPoint = \buf, types, name, id -> """ $(buf) - pub fn $(name)$(publicSignature) { + pub fn $(name)$(public_signature) { extern "C" { - fn roc__$(name)_1_exposed_generic$(externSignature); + fn roc__$(name)_1_exposed_generic$(extern_signature); } let mut ret = core::mem::MaybeUninit::uninit(); unsafe { - roc__$(name)_1_exposed_generic(ret.as_mut_ptr(), $(externArguments)); + roc__$(name)_1_exposed_generic(ret.as_mut_ptr(), $(extern_arguments)); ret.assume_init() } } """ -generateFunction : Str, Types, RocFn -> Str -generateFunction = \buf, types, rocFn -> - name = rocFn.functionName - externName = rocFn.externName +generate_function : Str, Types, RocFn -> Str +generate_function = \buf, types, roc_fn -> + name = roc_fn.function_name + extern_name = roc_fn.extern_name - publicArguments = - toArgStr rocFn.args types \argId, _shape, index -> - type = typeName types argId - indexStr = Num.toStr index + public_arguments = + to_arg_str(roc_fn.args, types, \arg_id, _shape, index -> + type = type_name(types, arg_id) + index_str = Num.to_str(index) - "arg$(indexStr): $(type)" + "arg$(index_str): $(type)") - externDefArguments = - withoutUnit = - toArgStr rocFn.args types \argId, _shape, index -> - type = typeName types argId - indexStr = Num.toStr index + extern_def_arguments = + without_unit = + to_arg_str(roc_fn.args, types, \arg_id, _shape, index -> + type = type_name(types, arg_id) + index_str = Num.to_str(index) - "arg$(indexStr): *const $(type)" + "arg$(index_str): *const $(type)") - if Str.isEmpty withoutUnit then + if Str.is_empty(without_unit) then # These always have a first argument that's a pointer, even if it's to nothing. "arg0: *const ()" else - withoutUnit + without_unit - externCallArguments = - withoutUnit = - toArgStr rocFn.args types \_argId, _shape, index -> - indexStr = Num.toStr index + extern_call_arguments = + without_unit = + to_arg_str(roc_fn.args, types, \_argId, _shape, index -> + index_str = Num.to_str(index) - "&arg$(indexStr)" + "&arg$(index_str)") - if Str.isEmpty withoutUnit then + if Str.is_empty(without_unit) then # These always have a first argument that's a pointer, even if it's to nothing. "&()" else - withoutUnit + without_unit - publicComma = if Str.isEmpty publicArguments then "" else ", " + public_comma = if Str.is_empty(public_arguments) then "" else ", " - ret = typeName types rocFn.ret + ret = type_name(types, roc_fn.ret) """ $(buf) @@ -278,31 +279,31 @@ generateFunction = \buf, types, rocFn -> } impl $(name) { - pub fn force_thunk(mut self$(publicComma)$(publicArguments)) -> $(ret) { + pub fn force_thunk(mut self$(public_comma)$(public_arguments)) -> $(ret) { extern "C" { - fn $(externName)($(externDefArguments), closure_data: *mut u8, output: *mut $(ret)); + fn $(extern_name)($(extern_def_arguments), closure_data: *mut u8, output: *mut $(ret)); } let mut output = core::mem::MaybeUninit::uninit(); unsafe { - $(externName)($(externCallArguments), self.closure_data.as_mut_ptr(), output.as_mut_ptr()); + $(extern_name)($(extern_call_arguments), self.closure_data.as_mut_ptr(), output.as_mut_ptr()); output.assume_init() } } } """ - |> generateRocRefcounted types (Function rocFn) name + |> generate_roc_refcounted(types, Function(roc_fn), name) -generateStruct : Str, Types, TypeId, _, _, _ -> Str -generateStruct = \buf, types, id, name, structFields, visibility -> - escapedName = escapeKW name +generate_struct : Str, Types, TypeId, _, _, _ -> Str +generate_struct = \buf, types, id, name, struct_fields, visibility -> + escaped_name = escape_kw(name) repr = length = - when structFields is - HasClosure fields -> List.len fields - HasNoClosure fields -> List.len fields + when struct_fields is + HasClosure(fields) -> List.len(fields) + HasNoClosure(fields) -> List.len(fields) if length <= 1 then "transparent" else @@ -313,97 +314,98 @@ generateStruct = \buf, types, id, name, structFields, visibility -> Public -> "pub " Private -> "" - structType = Types.shape types id + struct_type = Types.shape(types, id) buf - |> generateDeriveStr types structType IncludeDebug - |> Str.concat "#[repr($(repr))]\n$(pub)struct $(escapedName) {\n" - |> generateStructFields types Public structFields - |> Str.concat "}\n\n" - |> generateRocRefcounted types structType escapedName + |> generate_derive_str(types, struct_type, IncludeDebug) + |> Str.concat("#[repr($(repr))]\n$(pub)struct $(escaped_name) {\n") + |> generate_struct_fields(types, Public, struct_fields) + |> Str.concat("}\n\n") + |> generate_roc_refcounted(types, struct_type, escaped_name) -generateStructFields = \buf, types, visibility, structFields -> - when structFields is - HasNoClosure fields -> - List.walk fields buf (generateStructFieldWithoutClosure types visibility) +generate_struct_fields = \buf, types, visibility, struct_fields -> + when struct_fields is + HasNoClosure(fields) -> + List.walk(fields, buf, generate_struct_field_without_closure(types, visibility)) - HasClosure fields -> - List.walk fields buf (generateStructFieldWithoutClosure types visibility) + HasClosure(fields) -> + List.walk(fields, buf, generate_struct_field_without_closure(types, visibility)) -generateStructFieldWithoutClosure = \types, visibility -> - \accum, { name: fieldName, id } -> - typeStr = typeName types id - escapedFieldName = escapeKW fieldName +generate_struct_field_without_closure = \types, visibility -> + \accum, { name: field_name, id } -> + type_str = type_name(types, id) + escaped_field_name = escape_kw(field_name) pub = when visibility is Public -> "pub" Private -> "" - Str.concat accum "$(indent)$(pub) $(escapedFieldName): $(typeStr),\n" + Str.concat(accum, "$(indent)$(pub) $(escaped_field_name): $(type_str),\n") -nameTagUnionPayloadFields = \payloadFields -> +name_tag_union_payload_fields = \payload_fields -> # Tag union payloads have numbered fields, so we prefix them # with an "f" because Rust doesn't allow struct fields to be numbers. - when payloadFields is - HasNoClosure fields -> - renamedFields = List.map fields \{ name, id } -> { name: "f$(name)", id } - HasNoClosure renamedFields + when payload_fields is + HasNoClosure(fields) -> + renamed_fields = List.map(fields, \{ name, id } -> { name: "f$(name)", id }) + HasNoClosure(renamed_fields) - HasClosure fields -> - renamedFields = List.map fields \{ name, id, accessors } -> { name: "f$(name)", id, accessors } - HasClosure renamedFields + HasClosure(fields) -> + renamed_fields = List.map(fields, \{ name, id, accessors } -> { name: "f$(name)", id, accessors }) + HasClosure(renamed_fields) -generateEnumeration = \buf, types, enumType, name, tags, tagBytes -> - escapedName = escapeKW name +generate_enumeration = \buf, types, enum_type, name, tags, tag_bytes -> + escaped_name = escape_kw(name) - reprBits = tagBytes * 8 |> Num.toStr + repr_bits = tag_bytes * 8 |> Num.to_str buf - |> generateDeriveStr types enumType ExcludeDebug - |> Str.concat "#[repr(u$(reprBits))]\npub enum $(escapedName) {\n" - |> \b -> List.walkWithIndex tags b generateEnumTags + |> generate_derive_str(types, enum_type, ExcludeDebug) + |> Str.concat("#[repr(u$(repr_bits))]\npub enum $(escaped_name) {\n") + |> \b -> List.walk_with_index(tags, b, generate_enum_tags) |> # Enums require a custom debug impl to ensure naming is identical on all platforms. - Str.concat + Str.concat( """ } - impl core::fmt::Debug for $(escapedName) { + impl core::fmt::Debug for $(escaped_name) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { match self { - """ - |> \b -> List.walk tags b (generateEnumTagsDebug name) - |> Str.concat "$(indent)$(indent)}\n$(indent)}\n}\n\n" - |> generateRocRefcounted types enumType escapedName + """, + ) + |> \b -> List.walk(tags, b, generate_enum_tags_debug(name)) + |> Str.concat("$(indent)$(indent)}\n$(indent)}\n}\n\n") + |> generate_roc_refcounted(types, enum_type, escaped_name) -generateEnumTags = \accum, name, index -> - indexStr = Num.toStr index +generate_enum_tags = \accum, name, index -> + index_str = Num.to_str(index) - Str.concat accum "$(indent)$(name) = $(indexStr),\n" + Str.concat(accum, "$(indent)$(name) = $(index_str),\n") -generateEnumTagsDebug = \name -> - \accum, tagName -> - Str.concat accum "$(indent)$(indent)$(indent)Self::$(tagName) => f.write_str(\"$(name)::$(tagName)\"),\n" +generate_enum_tags_debug = \name -> + \accum, tag_name -> + Str.concat(accum, "$(indent)$(indent)$(indent)Self::$(tag_name) => f.write_str(\"$(name)::$(tag_name)\"),\n") -deriveCloneTagUnion : Str, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -deriveCloneTagUnion = \buf, tagUnionType, tags -> +derive_clone_tag_union : Str, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +derive_clone_tag_union = \buf, tag_union_type, tags -> clones = - List.walk tags "" \accum, { name: tagName } -> + List.walk(tags, "", \accum, { name: tag_name } -> """ $(accum) - $(tagName) => union_$(tagUnionType) { - $(tagName): self.payload.$(tagName).clone(), + $(tag_name) => union_$(tag_union_type) { + $(tag_name): self.payload.$(tag_name).clone(), }, - """ + """) """ $(buf) - impl Clone for $(tagUnionType) { + impl Clone for $(tag_union_type) { fn clone(&self) -> Self { - use discriminant_$(tagUnionType)::*; + use discriminant_$(tag_union_type)::*; let payload = unsafe { match self.discriminant {$(clones) @@ -418,29 +420,29 @@ deriveCloneTagUnion = \buf, tagUnionType, tags -> } """ -deriveDebugTagUnion : Str, Types, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -deriveDebugTagUnion = \buf, types, tagUnionType, tags -> +derive_debug_tag_union : Str, Types, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +derive_debug_tag_union = \buf, types, tag_union_type, tags -> checks = - List.walk tags "" \accum, { name: tagName, payload } -> + List.walk(tags, "", \accum, { name: tag_name, payload } -> type = when payload is - Some id -> typeName types id + Some(id) -> type_name(types, id) None -> "()" """ $(accum) - $(tagName) => { - let field: &$(type) = &self.payload.$(tagName); - f.debug_tuple("$(tagUnionType)::$(tagName)").field(field).finish() + $(tag_name) => { + let field: &$(type) = &self.payload.$(tag_name); + f.debug_tuple("$(tag_union_type)::$(tag_name)").field(field).finish() }, - """ + """) """ $(buf) - impl core::fmt::Debug for $(tagUnionType) { + impl core::fmt::Debug for $(tag_union_type) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { - use discriminant_$(tagUnionType)::*; + use discriminant_$(tag_union_type)::*; unsafe { match self.discriminant {$(checks) @@ -450,33 +452,33 @@ deriveDebugTagUnion = \buf, types, tagUnionType, tags -> } """ -deriveEqTagUnion : Str, Types, Shape, Str -> Str -deriveEqTagUnion = \buf, types, shape, tagUnionType -> - if canSupportEqHashOrd types shape then +derive_eq_tag_union : Str, Types, Shape, Str -> Str +derive_eq_tag_union = \buf, types, shape, tag_union_type -> + if can_support_eq_hash_ord(types, shape) then """ $(buf) - impl Eq for $(tagUnionType) {} + impl Eq for $(tag_union_type) {} """ else buf -derivePartialEqTagUnion : Str, Types, Shape, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -derivePartialEqTagUnion = \buf, types, shape, tagUnionType, tags -> - if canSupportPartialEqOrd types shape then +derive_partial_eq_tag_union : Str, Types, Shape, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +derive_partial_eq_tag_union = \buf, types, shape, tag_union_type, tags -> + if can_support_partial_eq_ord(types, shape) then checks = - List.walk tags "" \accum, { name: tagName } -> + List.walk(tags, "", \accum, { name: tag_name } -> """ $(accum) - $(tagName) => self.payload.$(tagName) == other.payload.$(tagName), - """ + $(tag_name) => self.payload.$(tag_name) == other.payload.$(tag_name), + """) """ $(buf) - impl PartialEq for $(tagUnionType) { + impl PartialEq for $(tag_union_type) { fn eq(&self, other: &Self) -> bool { - use discriminant_$(tagUnionType)::*; + use discriminant_$(tag_union_type)::*; if self.discriminant != other.discriminant { return false; @@ -492,13 +494,13 @@ derivePartialEqTagUnion = \buf, types, shape, tagUnionType, tags -> else buf -deriveOrdTagUnion : Str, Types, Shape, Str -> Str -deriveOrdTagUnion = \buf, types, shape, tagUnionType -> - if canSupportEqHashOrd types shape then +derive_ord_tag_union : Str, Types, Shape, Str -> Str +derive_ord_tag_union = \buf, types, shape, tag_union_type -> + if can_support_eq_hash_ord(types, shape) then """ $(buf) - impl Ord for $(tagUnionType) { + impl Ord for $(tag_union_type) { fn cmp(&self, other: &Self) -> std::cmp::Ordering { self.partial_cmp(other).unwrap() } @@ -507,22 +509,22 @@ deriveOrdTagUnion = \buf, types, shape, tagUnionType -> else buf -derivePartialOrdTagUnion : Str, Types, Shape, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -derivePartialOrdTagUnion = \buf, types, shape, tagUnionType, tags -> - if canSupportPartialEqOrd types shape then +derive_partial_ord_tag_union : Str, Types, Shape, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +derive_partial_ord_tag_union = \buf, types, shape, tag_union_type, tags -> + if can_support_partial_eq_ord(types, shape) then checks = - List.walk tags "" \accum, { name: tagName } -> + List.walk(tags, "", \accum, { name: tag_name } -> """ $(accum) - $(tagName) => self.payload.$(tagName).partial_cmp(&other.payload.$(tagName)), - """ + $(tag_name) => self.payload.$(tag_name).partial_cmp(&other.payload.$(tag_name)), + """) """ $(buf) - impl PartialOrd for $(tagUnionType) { + impl PartialOrd for $(tag_union_type) { fn partial_cmp(&self, other: &Self) -> Option { - use discriminant_$(tagUnionType)::*; + use discriminant_$(tag_union_type)::*; use std::cmp::Ordering::*; @@ -540,22 +542,22 @@ derivePartialOrdTagUnion = \buf, types, shape, tagUnionType, tags -> else buf -deriveHashTagUnion : Str, Types, Shape, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -deriveHashTagUnion = \buf, types, shape, tagUnionType, tags -> - if canSupportEqHashOrd types shape then +derive_hash_tag_union : Str, Types, Shape, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +derive_hash_tag_union = \buf, types, shape, tag_union_type, tags -> + if can_support_eq_hash_ord(types, shape) then checks = - List.walk tags "" \accum, { name: tagName } -> + List.walk(tags, "", \accum, { name: tag_name } -> """ $(accum) - $(tagName) => self.payload.$(tagName).hash(state), - """ + $(tag_name) => self.payload.$(tag_name).hash(state), + """) """ $(buf) - impl core::hash::Hash for $(tagUnionType) { + impl core::hash::Hash for $(tag_union_type) { fn hash(&self, state: &mut H) { - use discriminant_$(tagUnionType)::*; + use discriminant_$(tag_union_type)::*; unsafe { match self.discriminant {$(checks) @@ -567,36 +569,36 @@ deriveHashTagUnion = \buf, types, shape, tagUnionType, tags -> else buf -generateConstructorFunctions : Str, Types, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -generateConstructorFunctions = \buf, types, tagUnionType, tags -> +generate_constructor_functions : Str, Types, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +generate_constructor_functions = \buf, types, tag_union_type, tags -> buf - |> Str.concat "\n\nimpl $(tagUnionType) {" - |> \b -> List.walk tags b \accum, r -> generateConstructorFunction accum types tagUnionType r.name r.payload - |> Str.concat "\n}\n\n" + |> Str.concat("\n\nimpl $(tag_union_type) {") + |> \b -> List.walk(tags, b, \accum, r -> generate_constructor_function(accum, types, tag_union_type, r.name, r.payload)) + |> Str.concat("\n}\n\n") -generateConstructorFunction : Str, Types, Str, Str, [Some TypeId, None] -> Str -generateConstructorFunction = \buf, types, tagUnionType, name, optPayload -> - when optPayload is +generate_constructor_function : Str, Types, Str, Str, [Some TypeId, None] -> Str +generate_constructor_function = \buf, types, tag_union_type, name, opt_payload -> + when opt_payload is None -> """ $(buf) pub fn $(name)() -> Self { Self { - discriminant: discriminant_$(tagUnionType)::$(name), - payload: union_$(tagUnionType) { + discriminant: discriminant_$(tag_union_type)::$(name), + payload: union_$(tag_union_type) { $(name): (), } } } """ - Some payloadId -> - payloadType = typeName types payloadId - shape = Types.shape types payloadId + Some(payload_id) -> + payload_type = type_name(types, payload_id) + shape = Types.shape(types, payload_id) new = - if canDeriveCopy types shape then + if can_derive_copy(types, shape) then "payload" else "core::mem::ManuallyDrop::new(payload)" @@ -604,288 +606,292 @@ generateConstructorFunction = \buf, types, tagUnionType, name, optPayload -> """ $(buf) - pub fn $(name)(payload: $(payloadType)) -> Self { + pub fn $(name)(payload: $(payload_type)) -> Self { Self { - discriminant: discriminant_$(tagUnionType)::$(name), - payload: union_$(tagUnionType) { + discriminant: discriminant_$(tag_union_type)::$(name), + payload: union_$(tag_union_type) { $(name): $(new), } } } """ -generateDestructorFunctions : Str, Types, Str, List { name : Str, payload : [Some TypeId, None] } -> Str -generateDestructorFunctions = \buf, types, tagUnionType, tags -> +generate_destructor_functions : Str, Types, Str, List { name : Str, payload : [Some TypeId, None] } -> Str +generate_destructor_functions = \buf, types, tag_union_type, tags -> buf - |> Str.concat "\n\nimpl $(tagUnionType) {" - |> \b -> List.walk tags b \accum, r -> generateDestructorFunction accum types tagUnionType r.name r.payload - |> Str.concat "\n}\n\n" + |> Str.concat("\n\nimpl $(tag_union_type) {") + |> \b -> List.walk(tags, b, \accum, r -> generate_destructor_function(accum, types, tag_union_type, r.name, r.payload)) + |> Str.concat("\n}\n\n") -generateDestructorFunction : Str, Types, Str, Str, [Some TypeId, None] -> Str -generateDestructorFunction = \buf, types, tagUnionType, name, optPayload -> - when optPayload is +generate_destructor_function : Str, Types, Str, Str, [Some TypeId, None] -> Str +generate_destructor_function = \buf, types, tag_union_type, name, opt_payload -> + when opt_payload is None -> """ $(buf) pub fn is_$(name)(&self) -> bool { - matches!(self.discriminant, discriminant_$(tagUnionType)::$(name)) + matches!(self.discriminant, discriminant_$(tag_union_type)::$(name)) } """ - Some payloadId -> - payloadType = typeName types payloadId - shape = Types.shape types payloadId + Some(payload_id) -> + payload_type = type_name(types, payload_id) + shape = Types.shape(types, payload_id) take = - if canDeriveCopy types shape then + if can_derive_copy(types, shape) then "unsafe { self.payload.$(name) }" else "unsafe { core::mem::ManuallyDrop::take(&mut self.payload.$(name)) }" - (borrow, borrowType) = - if canDeriveCopy types shape then - ("unsafe { self.payload.$(name) }", payloadType) + (borrow, borrow_type) = + if can_derive_copy(types, shape) then + ("unsafe { self.payload.$(name) }", payload_type) else ( """ use core::borrow::Borrow; unsafe { self.payload.$(name).borrow() } """, - "&$(payloadType)", + "&$(payload_type)", ) - (borrowMut, borrowMutType) = - if canDeriveCopy types shape then - ("unsafe { &mut self.payload.$(name) }", "&mut $(payloadType)") + (borrow_mut, borrow_mut_type) = + if can_derive_copy(types, shape) then + ("unsafe { &mut self.payload.$(name) }", "&mut $(payload_type)") else ( """ use core::borrow::BorrowMut; unsafe { self.payload.$(name).borrow_mut() } """, - "&mut $(payloadType)", + "&mut $(payload_type)", ) """ $(buf) - pub fn unwrap_$(name)(mut self) -> $(payloadType) { - debug_assert_eq!(self.discriminant, discriminant_$(tagUnionType)::$(name)); + pub fn unwrap_$(name)(mut self) -> $(payload_type) { + debug_assert_eq!(self.discriminant, discriminant_$(tag_union_type)::$(name)); $(take) } - pub fn borrow_$(name)(&self) -> $(borrowType) { - debug_assert_eq!(self.discriminant, discriminant_$(tagUnionType)::$(name)); + pub fn borrow_$(name)(&self) -> $(borrow_type) { + debug_assert_eq!(self.discriminant, discriminant_$(tag_union_type)::$(name)); $(borrow) } - pub fn borrow_mut_$(name)(&mut self) -> $(borrowMutType) { - debug_assert_eq!(self.discriminant, discriminant_$(tagUnionType)::$(name)); - $(borrowMut) + pub fn borrow_mut_$(name)(&mut self) -> $(borrow_mut_type) { + debug_assert_eq!(self.discriminant, discriminant_$(tag_union_type)::$(name)); + $(borrow_mut) } pub fn is_$(name)(&self) -> bool { - matches!(self.discriminant, discriminant_$(tagUnionType)::$(name)) + matches!(self.discriminant, discriminant_$(tag_union_type)::$(name)) } """ -generateNonRecursiveTagUnion : Str, Types, TypeId, Str, List { name : Str, payload : [Some TypeId, None] }, U32, U32 -> Str -generateNonRecursiveTagUnion = \buf, types, id, name, tags, discriminantSize, discriminantOffset -> - escapedName = escapeKW name - discriminantName = "discriminant_$(escapedName)" - unionName = "union_$(escapedName)" - discriminantOffsetStr = Num.toStr discriminantOffset - tagNames = List.map tags \{ name: n } -> n - selfMut = "self" +generate_non_recursive_tag_union : Str, Types, TypeId, Str, List { name : Str, payload : [Some TypeId, None] }, U32, U32 -> Str +generate_non_recursive_tag_union = \buf, types, id, name, tags, discriminant_size, discriminant_offset -> + escaped_name = escape_kw(name) + discriminant_name = "discriminant_$(escaped_name)" + union_name = "union_$(escaped_name)" + discriminant_offset_str = Num.to_str(discriminant_offset) + tag_names = List.map(tags, \{ name: n } -> n) + self_mut = "self" max = \a, b -> if a >= b then a else b - alignOfUnion = - List.walk tags 1 \accum, { payload } -> + align_of_union = + List.walk(tags, 1, \accum, { payload } -> when payload is - Some payloadId -> max accum (Types.alignment types payloadId) - None -> accum + Some(payload_id) -> max(accum, Types.alignment(types, payload_id)) + None -> accum) - alignOfUnionStr = Num.toStr alignOfUnion + align_of_union_str = Num.to_str(align_of_union) - sizeOfUnionStr = - List.walk tags 1 \accum, { payload } -> + size_of_union_str = + List.walk(tags, 1, \accum, { payload } -> when payload is - Some payloadId -> max accum (Types.size types payloadId) - None -> accum - |> nextMultipleOf alignOfUnion - |> Num.toStr + Some(payload_id) -> max(accum, Types.size(types, payload_id)) + None -> accum) + |> next_multiple_of(align_of_union) + |> Num.to_str - sizeOfSelf = Num.toStr (Types.size types id) - alignOfSelf = Num.toStr (Types.alignment types id) - shape = Types.shape types id + size_of_self = Num.to_str(Types.size(types, id)) + align_of_self = Num.to_str(Types.alignment(types, id)) + shape = Types.shape(types, id) # TODO: this value can be different than the alignment of `id` align = - List.walk tags 1 \accum, { payload } -> + List.walk(tags, 1, \accum, { payload } -> when payload is - Some payloadId -> max accum (Types.alignment types payloadId) - None -> accum - |> Num.toStr + Some(payload_id) -> max(accum, Types.alignment(types, payload_id)) + None -> accum) + |> Num.to_str - unionType = Types.shape types id + union_type = Types.shape(types, id) buf - |> generateDiscriminant types discriminantName tagNames discriminantSize - |> Str.concat "#[repr(C, align($(align)))]\npub union $(unionName) {\n" - |> \b -> List.walk tags b (generateUnionField types) - |> Str.concat + |> generate_discriminant(types, discriminant_name, tag_names, discriminant_size) + |> Str.concat("#[repr(C, align($(align)))]\npub union $(union_name) {\n") + |> \b -> List.walk(tags, b, generate_union_field(types)) + |> Str.concat( """ } // TODO(@roc-lang): See https://github.com/roc-lang/roc/issues/6012 - // const _SIZE_CHECK_$(unionName): () = assert!(core::mem::size_of::<$(unionName)>() == $(sizeOfUnionStr)); - const _ALIGN_CHECK_$(unionName): () = assert!(core::mem::align_of::<$(unionName)>() == $(alignOfUnionStr)); + // const _SIZE_CHECK_$(union_name): () = assert!(core::mem::size_of::<$(union_name)>() == $(size_of_union_str)); + const _ALIGN_CHECK_$(union_name): () = assert!(core::mem::align_of::<$(union_name)>() == $(align_of_union_str)); - const _SIZE_CHECK_$(escapedName): () = assert!(core::mem::size_of::<$(escapedName)>() == $(sizeOfSelf)); - const _ALIGN_CHECK_$(escapedName): () = assert!(core::mem::align_of::<$(escapedName)>() == $(alignOfSelf)); + const _SIZE_CHECK_$(escaped_name): () = assert!(core::mem::size_of::<$(escaped_name)>() == $(size_of_self)); + const _ALIGN_CHECK_$(escaped_name): () = assert!(core::mem::align_of::<$(escaped_name)>() == $(align_of_self)); - impl $(escapedName) { - $(discriminantDocComment) - pub fn discriminant(&self) -> $(discriminantName) { + impl $(escaped_name) { + $(discriminant_doc_comment) + pub fn discriminant(&self) -> $(discriminant_name) { unsafe { let bytes = core::mem::transmute::<&Self, &[u8; core::mem::size_of::()]>(self); - core::mem::transmute::(*bytes.as_ptr().add($(discriminantOffsetStr))) + core::mem::transmute::(*bytes.as_ptr().add($(discriminant_offset_str))) } } /// Internal helper - fn set_discriminant(&mut self, discriminant: $(discriminantName)) { - let discriminant_ptr: *mut $(discriminantName) = (self as *mut $(escapedName)).cast(); + fn set_discriminant(&mut self, discriminant: $(discriminant_name)) { + let discriminant_ptr: *mut $(discriminant_name) = (self as *mut $(escaped_name)).cast(); unsafe { - *(discriminant_ptr.add($(discriminantOffsetStr))) = discriminant; + *(discriminant_ptr.add($(discriminant_offset_str))) = discriminant; } } } - """ - |> Str.concat + """, + ) + |> Str.concat( """ #[repr(C)] - pub struct $(escapedName) { - payload: union_$(escapedName), - discriminant: discriminant_$(escapedName), + pub struct $(escaped_name) { + payload: union_$(escaped_name), + discriminant: discriminant_$(escaped_name), } - """ - |> deriveCloneTagUnion escapedName tags - |> deriveDebugTagUnion types escapedName tags - |> deriveEqTagUnion types shape escapedName - |> derivePartialEqTagUnion types shape escapedName tags - |> deriveOrdTagUnion types shape escapedName - |> derivePartialOrdTagUnion types shape escapedName tags - |> deriveHashTagUnion types shape escapedName tags - |> generateDestructorFunctions types escapedName tags - |> generateConstructorFunctions types escapedName tags + """, + ) + |> derive_clone_tag_union(escaped_name, tags) + |> derive_debug_tag_union(types, escaped_name, tags) + |> derive_eq_tag_union(types, shape, escaped_name) + |> derive_partial_eq_tag_union(types, shape, escaped_name, tags) + |> derive_ord_tag_union(types, shape, escaped_name) + |> derive_partial_ord_tag_union(types, shape, escaped_name, tags) + |> derive_hash_tag_union(types, shape, escaped_name, tags) + |> generate_destructor_functions(types, escaped_name, tags) + |> generate_constructor_functions(types, escaped_name, tags) |> \b -> - if cannotSupportCopy types unionType then + if cannot_support_copy(types, union_type) then # A custom drop impl is only needed when we can't derive copy. b - |> Str.concat + |> Str.concat( """ - impl Drop for $(escapedName) { + impl Drop for $(escaped_name) { fn drop(&mut self) { // Drop the payloads - """ - |> generateTagUnionDropPayload types selfMut tags discriminantName discriminantSize 2 - |> Str.concat + """, + ) + |> generate_tag_union_drop_payload(types, self_mut, tags, discriminant_name, discriminant_size, 2) + |> Str.concat( """ } } - """ + """, + ) else b - |> generateRocRefcounted types unionType escapedName + |> generate_roc_refcounted(types, union_type, escaped_name) -generateNonNullableUnwrapped = \buf, types, name, tagName, payload, discriminantSize, _discriminantOffset, _nullTagIndex -> - escapedName = escapeKW name - discriminantName = "discriminant_$(escapedName)" +generate_non_nullable_unwrapped = \buf, types, name, tag_name, payload, discriminant_size, _discriminant_offset, _null_tagIndex -> + escaped_name = escape_kw(name) + discriminant_name = "discriminant_$(escaped_name)" - payloadFields = - when Types.shape types payload is - TagUnionPayload { fields } -> + payload_fields = + when Types.shape(types, payload) is + TagUnionPayload({ fields }) -> when fields is - HasNoClosure xs -> List.map xs .id - HasClosure xs -> List.map xs .id + HasNoClosure(xs) -> List.map(xs, .id) + HasClosure(xs) -> List.map(xs, .id) _ -> [] - payloadFieldNames = - commaSeparated "" payloadFields \_, i -> - n = Num.toStr i - "f$(n)" + payload_field_names = + comma_separated("", payload_fields, \_, i -> + n = Num.to_str(i) + "f$(n)") - constructorArguments = - commaSeparated "" payloadFields \id, i -> - n = Num.toStr i - type = typeName types id - "f$(n): $(type)" + constructor_arguments = + comma_separated("", payload_fields, \id, i -> + n = Num.to_str(i) + type = type_name(types, id) + "f$(n): $(type)") - debugFields = - payloadFields - |> List.mapWithIndex \_, i -> - n = Num.toStr i - ".field(&node.f$(n))" - |> Str.joinWith "" + debug_fields = + payload_fields + |> List.map_with_index(\_, i -> + n = Num.to_str(i) + ".field(&node.f$(n))") + |> Str.join_with("") - buf1 = buf |> generateDiscriminant types discriminantName [tagName] discriminantSize + buf1 = buf |> generate_discriminant(types, discriminant_name, [tag_name], discriminant_size) - unionType = TagUnion (NonNullableUnwrapped { name, tagName, payload }) + union_type = TagUnion(NonNullableUnwrapped({ name, tag_name, payload })) """ $(buf1) #[repr(transparent)] #[derive(Clone, PartialEq, PartialOrd, Eq, Ord, Hash)] - pub struct $(escapedName)(roc_std::RocBox<$(name)_$(tagName)>); + pub struct $(escaped_name)(roc_std::RocBox<$(name)_$(tag_name)>); - impl $(escapedName) { - pub fn $(tagName)($(constructorArguments)) -> Self { - let payload = $(name)_$(tagName) { $(payloadFieldNames) }; + impl $(escaped_name) { + pub fn $(tag_name)($(constructor_arguments)) -> Self { + let payload = $(name)_$(tag_name) { $(payload_field_names) }; Self(roc_std::RocBox::new(payload)) } } - impl core::fmt::Debug for $(escapedName) { + impl core::fmt::Debug for $(escaped_name) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { let node = &self.0; - f.debug_tuple("$(escapedName)::$(tagName)")$(debugFields).finish() + f.debug_tuple("$(escaped_name)::$(tag_name)")$(debug_fields).finish() } } """ - |> generateRocRefcounted types unionType escapedName + |> generate_roc_refcounted(types, union_type, escaped_name) -generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSize, _discriminantOffset, nullTagIndex -> - escapedName = escapeKW tagUnionName - discriminantName = "discriminant_$(escapedName)" - tagNames = List.map tags \{ name: n } -> n +generate_recursive_tag_union = \buf, types, id, tag_union_name, tags, discriminant_size, _discriminant_offset, null_tag_index -> + escaped_name = escape_kw(tag_union_name) + discriminant_name = "discriminant_$(escaped_name)" + tag_names = List.map(tags, \{ name: n } -> n) # self = "(&*self.union_pointer())" # selfMut = "(&mut *self.union_pointer())" # other = "(&*other.union_pointer())" - unionName = "union_$(escapedName)" + union_name = "union_$(escaped_name)" discriminants = - tagNames - |> Str.joinWith ", " + tag_names + |> Str.join_with(", ") |> \b -> "[ $(b) ]" - nullTagId = - when nullTagIndex is - Some index -> - n = Num.toStr index + null_tag_id = + when null_tag_index is + Some(index) -> + n = Num.to_str(index) "discriminants[$(n)]" None -> @@ -893,15 +899,15 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz unreachable!("this pointer cannot be NULL") """ - isFunction = \{ name: tagName, payload: optPayload }, index -> - payloadFields = - when optPayload is - Some payload -> - when Types.shape types payload is - TagUnionPayload { fields } -> + is_function = \{ name: tag_name, payload: opt_payload }, index -> + payload_fields = + when opt_payload is + Some(payload) -> + when Types.shape(types, payload) is + TagUnionPayload({ fields }) -> when fields is - HasNoClosure xs -> List.map xs .id - HasClosure xs -> List.map xs .id + HasNoClosure(xs) -> List.map(xs, .id) + HasClosure(xs) -> List.map(xs, .id) _ -> [] @@ -909,49 +915,49 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz None -> [] - fieldGetters = - List.walk payloadFields { i: 0, accum: "" } \{ i, accum }, fieldTypeId -> - fieldTypeName = typeName types fieldTypeId - fieldIndex = Num.toStr i + field_getters = + List.walk(payload_fields, { i: 0, accum: "" }, \{ i, accum }, field_type_id -> + field_type_name = type_name(types, field_type_id) + field_index = Num.to_str(i) { i: i + 1, accum: """ $(accum) - pub fn get_$(tagName)_f$(fieldIndex)(&self) -> &$(fieldTypeName) { - debug_assert!(self.is_$(tagName)()); + pub fn get_$(tag_name)_f$(field_index)(&self) -> &$(field_type_name) { + debug_assert!(self.is_$(tag_name)()); // extern "C" { // fn foobar(tag_id: u16, field_index: usize) -> usize; // } - // let offset = unsafe { foobar($(fieldIndex)) }; + // let offset = unsafe { foobar($(field_index)) }; let offset = 0; unsafe { &*self.unmasked_pointer().add(offset).cast() } } """, - } + }) |> .accum - payloadFieldNames = - commaSeparated "" payloadFields \_, i -> - n = Num.toStr i - "f$(n)" + payload_field_names = + comma_separated("", payload_fields, \_, i -> + n = Num.to_str(i) + "f$(n)") - constructorArguments = - commaSeparated "" payloadFields \payloadId, i -> - n = Num.toStr i - type = typeName types payloadId - "f$(n): $(type)" + constructor_arguments = + comma_separated("", payload_fields, \payload_id, i -> + n = Num.to_str(i) + type = type_name(types, payload_id) + "f$(n): $(type)") - fixManuallyDrop = - when optPayload is - Some payload -> - shape = Types.shape types payload + fix_manually_drop = + when opt_payload is + Some(payload) -> + shape = Types.shape(types, payload) - if canDeriveCopy types shape then + if can_derive_copy(types, shape) then "payload" else "core::mem::ManuallyDrop::new(payload)" @@ -959,60 +965,60 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz None -> "payload" - if Some (Num.intCast index) == nullTagIndex then + if Some(Num.int_cast(index)) == null_tag_index then """ - pub fn is_$(tagName)(&self) -> bool { - matches!(self.discriminant(), discriminant_$(escapedName)::$(tagName)) + pub fn is_$(tag_name)(&self) -> bool { + matches!(self.discriminant(), discriminant_$(escaped_name)::$(tag_name)) } - pub fn $(tagName)($(constructorArguments)) -> Self { + pub fn $(tag_name)($(constructor_arguments)) -> Self { Self(std::ptr::null_mut()) } """ else """ - pub fn is_$(tagName)(&self) -> bool { - matches!(self.discriminant(), discriminant_$(escapedName)::$(tagName)) + pub fn is_$(tag_name)(&self) -> bool { + matches!(self.discriminant(), discriminant_$(escaped_name)::$(tag_name)) } - pub fn $(tagName)($(constructorArguments)) -> Self { - let tag_id = discriminant_$(escapedName)::$(tagName); + pub fn $(tag_name)($(constructor_arguments)) -> Self { + let tag_id = discriminant_$(escaped_name)::$(tag_name); - let payload = $(escapedName)_$(tagName) { $(payloadFieldNames) } ; + let payload = $(escaped_name)_$(tag_name) { $(payload_field_names) } ; - let union_payload = union_$(escapedName) { $(tagName): $(fixManuallyDrop) }; + let union_payload = union_$(escaped_name) { $(tag_name): $(fix_manually_drop) }; let ptr = unsafe { roc_std::RocBox::leak(roc_std::RocBox::new(union_payload)) }; Self((ptr as usize | tag_id as usize) as *mut _) } - $(fieldGetters) + $(field_getters) - pub fn get_$(tagName)(mut self) -> $(escapedName)_$(tagName) { - debug_assert!(self.is_$(tagName)()); + pub fn get_$(tag_name)(mut self) -> $(escaped_name)_$(tag_name) { + debug_assert!(self.is_$(tag_name)()); - unsafe { core::mem::ManuallyDrop::take(&mut self.ptr_read_union().$(tagName)) } + unsafe { core::mem::ManuallyDrop::take(&mut self.ptr_read_union().$(tag_name)) } } """ constructors = tags - |> List.mapWithIndex isFunction - |> Str.joinWith "\n\n" + |> List.map_with_index(is_function) + |> Str.join_with("\n\n") - cloneCase = \{ name: tagName }, index -> - if Some (Num.intCast index) == nullTagIndex then + clone_case = \{ name: tag_name }, index -> + if Some(Num.int_cast(index)) == null_tag_index then """ - $(tagName) => Self::$(tagName)(), + $(tag_name) => Self::$(tag_name)(), """ else """ - $(tagName) => { - let tag_id = discriminant_$(escapedName)::$(tagName); + $(tag_name) => { + let tag_id = discriminant_$(escaped_name)::$(tag_name); let payload_union = unsafe { self.ptr_read_union() }; - let payload = union_$(escapedName) { - $(tagName): unsafe { payload_union.$(tagName).clone() }, + let payload = union_$(escaped_name) { + $(tag_name): unsafe { payload_union.$(tag_name).clone() }, }; let ptr = unsafe { roc_std::RocBox::leak(roc_std::RocBox::new(payload)) }; @@ -1021,69 +1027,69 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz }, """ - cloneCases = + clone_cases = tags - |> List.mapWithIndex cloneCase - |> Str.joinWith "\n" + |> List.map_with_index(clone_case) + |> Str.join_with("\n") - partialEqCase = \{ name: tagName }, index -> - if Some (Num.intCast index) == nullTagIndex then + partial_eq_case = \{ name: tag_name }, index -> + if Some(Num.int_cast(index)) == null_tag_index then """ - $(tagName) => true, + $(tag_name) => true, """ else """ - $(tagName) => { + $(tag_name) => { let payload_union1 = unsafe { self.ptr_read_union() }; let payload_union2 = unsafe { other.ptr_read_union() }; unsafe { - payload_union1.$(tagName) == payload_union2.$(tagName) + payload_union1.$(tag_name) == payload_union2.$(tag_name) } }, """ - partialEqCases = + partial_eq_cases = tags - |> List.mapWithIndex partialEqCase - |> Str.joinWith "\n" + |> List.map_with_index(partial_eq_case) + |> Str.join_with("\n") - partialEqImpl = - if canSupportPartialEqOrd types (Types.shape types id) then + partial_eq_impl = + if can_support_partial_eq_ord(types, Types.shape(types, id)) then """ - impl PartialEq for $(escapedName) { + impl PartialEq for $(escaped_name) { fn eq(&self, other: &Self) -> bool { - use discriminant_$(escapedName)::*; + use discriminant_$(escaped_name)::*; if self.discriminant() != other.discriminant() { return false; } match self.discriminant() { - $(partialEqCases) + $(partial_eq_cases) } } } - impl Eq for $(escapedName) {} + impl Eq for $(escaped_name) {} """ else "" - debugCase = \{ name: tagName, payload: optPayload }, index -> - if Some (Num.intCast index) == nullTagIndex then + debug_case = \{ name: tag_name, payload: opt_payload }, index -> + if Some(Num.int_cast(index)) == null_tag_index then """ - $(tagName) => f.debug_tuple("$(escapedName)::$(tagName)").finish(), + $(tag_name) => f.debug_tuple("$(escaped_name)::$(tag_name)").finish(), """ else - payloadFields = - when optPayload is - Some payload -> - when Types.shape types payload is - TagUnionPayload { fields } -> + payload_fields = + when opt_payload is + Some(payload) -> + when Types.shape(types, payload) is + TagUnionPayload({ fields }) -> when fields is - HasNoClosure xs -> List.map xs .id - HasClosure xs -> List.map xs .id + HasNoClosure(xs) -> List.map(xs, .id) + HasClosure(xs) -> List.map(xs, .id) _ -> [] @@ -1091,58 +1097,58 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz None -> [] - debugFields = - payloadFields - |> List.mapWithIndex \_, i -> - n = Num.toStr i - ".field(&payload_union.$(tagName).f$(n))" - |> Str.joinWith "" + debug_fields = + payload_fields + |> List.map_with_index(\_, i -> + n = Num.to_str(i) + ".field(&payload_union.$(tag_name).f$(n))") + |> Str.join_with("") """ - $(tagName) => { + $(tag_name) => { let payload_union = unsafe { self.ptr_read_union() }; unsafe { - f.debug_tuple("$(escapedName)::$(tagName)")$(debugFields).finish() + f.debug_tuple("$(escaped_name)::$(tag_name)")$(debug_fields).finish() } }, """ - debugCases = + debug_cases = tags - |> List.mapWithIndex debugCase - |> Str.joinWith "\n" + |> List.map_with_index(debug_case) + |> Str.join_with("\n") - hashCase = \{ name: tagName }, index -> - if Some (Num.intCast index) == nullTagIndex then + hash_case = \{ name: tag_name }, index -> + if Some(Num.int_cast(index)) == null_tag_index then """ - $(tagName) => {} + $(tag_name) => {} """ else """ - $(tagName) => { + $(tag_name) => { let payload_union = unsafe { self.ptr_read_union() }; - unsafe { payload_union.$(tagName).hash(state) }; + unsafe { payload_union.$(tag_name).hash(state) }; }, """ - hashCases = + hash_cases = tags - |> List.mapWithIndex hashCase - |> Str.joinWith "\n" + |> List.map_with_index(hash_case) + |> Str.join_with("\n") - unionType = Types.shape types id - hashImpl = - if canSupportPartialEqOrd types unionType then + union_type = Types.shape(types, id) + hash_impl = + if can_support_partial_eq_ord(types, union_type) then """ - impl core::hash::Hash for $(escapedName) { + impl core::hash::Hash for $(escaped_name) { fn hash(&self, state: &mut H) { - use discriminant_$(escapedName)::*; + use discriminant_$(escaped_name)::*; self.discriminant().hash(state); match self.discriminant() { - $(hashCases) + $(hash_cases) } } } @@ -1150,40 +1156,40 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz else "" - partialOrdCase = \{ name: tagName }, index -> - if Some (Num.intCast index) == nullTagIndex then + partial_ord_case = \{ name: tag_name }, index -> + if Some(Num.int_cast(index)) == null_tag_index then """ - $(tagName) => std::cmp::Ordering::Equal, + $(tag_name) => std::cmp::Ordering::Equal, """ else """ - $(tagName) => { + $(tag_name) => { let payload_union1 = unsafe { self.ptr_read_union() }; let payload_union2 = unsafe { other.ptr_read_union() }; unsafe { - payload_union1.$(tagName).cmp(&payload_union2.$(tagName)) + payload_union1.$(tag_name).cmp(&payload_union2.$(tag_name)) } }, """ - partialOrdCases = + partial_ord_cases = tags - |> List.mapWithIndex partialOrdCase - |> Str.joinWith "\n" + |> List.map_with_index(partial_ord_case) + |> Str.join_with("\n") - partialOrdImpl = - if canSupportPartialEqOrd types (Types.shape types id) then + partial_ord_impl = + if can_support_partial_eq_ord(types, Types.shape(types, id)) then """ - impl PartialOrd for $(escapedName) { + impl PartialOrd for $(escaped_name) { fn partial_cmp(&self, other: &Self) -> Option { Some(::cmp(self, other)) } } - impl Ord for $(escapedName) { + impl Ord for $(escaped_name) { fn cmp(&self, other: &Self) -> std::cmp::Ordering { - use discriminant_$(escapedName)::*; + use discriminant_$(escaped_name)::*; use std::cmp::Ordering::*; @@ -1192,7 +1198,7 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz Greater => Greater, Equal => unsafe { match self.discriminant() { - $(partialOrdCases) + $(partial_ord_cases) } }, } @@ -1202,29 +1208,29 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz else "" - sizeOfSelf = Num.toStr (Types.size types id) - alignOfSelf = Num.toStr (Types.alignment types id) + size_of_self = Num.to_str(Types.size(types, id)) + align_of_self = Num.to_str(Types.alignment(types, id)) buf - |> generateDiscriminant types discriminantName tagNames discriminantSize - |> Str.concat + |> generate_discriminant(types, discriminant_name, tag_names, discriminant_size) + |> Str.concat( """ #[repr(transparent)] - pub struct $(escapedName)(*mut $(unionName)); + pub struct $(escaped_name)(*mut $(union_name)); - const _SIZE_CHECK_$(escapedName): () = assert!(core::mem::size_of::<$(escapedName)>() == $(sizeOfSelf)); - const _ALIGN_CHECK_$(escapedName): () = assert!(core::mem::align_of::<$(escapedName)>() == $(alignOfSelf)); + const _SIZE_CHECK_$(escaped_name): () = assert!(core::mem::size_of::<$(escaped_name)>() == $(size_of_self)); + const _ALIGN_CHECK_$(escaped_name): () = assert!(core::mem::align_of::<$(escaped_name)>() == $(align_of_self)); - impl $(escapedName) { - pub fn discriminant(&self) -> discriminant_$(escapedName) { + impl $(escaped_name) { + pub fn discriminant(&self) -> discriminant_$(escaped_name) { let discriminants = { - use $(discriminantName)::*; + use $(discriminant_name)::*; $(discriminants) }; if self.0.is_null() { - $(nullTagId) + $(null_tag_id) } else { match std::mem::size_of::() { 4 => discriminants[self.0 as usize & 0b011], @@ -1234,7 +1240,7 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz } } - fn unmasked_pointer(&self) -> *mut union_$(escapedName) { + fn unmasked_pointer(&self) -> *mut union_$(escaped_name) { debug_assert!(!self.0.is_null()); let mask = match std::mem::size_of::() { @@ -1243,10 +1249,10 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz _ => unreachable!(), }; - ((self.0 as usize) & mask) as *mut union_$(escapedName) + ((self.0 as usize) & mask) as *mut union_$(escaped_name) } - unsafe fn ptr_read_union(&self) -> core::mem::ManuallyDrop { + unsafe fn ptr_read_union(&self) -> core::mem::ManuallyDrop { let ptr = self.unmasked_pointer(); core::mem::ManuallyDrop::new(unsafe { std::ptr::read(ptr) }) @@ -1255,184 +1261,185 @@ generateRecursiveTagUnion = \buf, types, id, tagUnionName, tags, discriminantSiz $(constructors) } - impl Clone for $(escapedName) { + impl Clone for $(escaped_name) { fn clone(&self) -> Self { - use discriminant_$(escapedName)::*; + use discriminant_$(escaped_name)::*; let discriminant = self.discriminant(); match discriminant { - $(cloneCases) + $(clone_cases) } } } - $(partialEqImpl) + $(partial_eq_impl) - $(hashImpl) + $(hash_impl) - $(partialOrdImpl) + $(partial_ord_impl) - impl core::fmt::Debug for $(escapedName) { + impl core::fmt::Debug for $(escaped_name) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { - use discriminant_$(escapedName)::*; + use discriminant_$(escaped_name)::*; match self.discriminant() { - $(debugCases) + $(debug_cases) } } } #[repr(C)] - union $(unionName) { - """ - |> \b -> List.walk tags b (generateUnionField types) - |> Str.concat "}\n\n" - |> generateRocRefcounted types unionType escapedName - -generateTagUnionDropPayload = \buf, types, selfMut, tags, discriminantName, discriminantSize, indents -> - if discriminantSize == 0 then - when List.first tags is - Ok { name } -> + union $(union_name) { + """, + ) + |> \b -> List.walk(tags, b, generate_union_field(types)) + |> Str.concat("}\n\n") + |> generate_roc_refcounted(types, union_type, escaped_name) + +generate_tag_union_drop_payload = \buf, types, self_mut, tags, discriminant_name, discriminant_size, indents -> + if discriminant_size == 0 then + when List.first(tags) is + Ok({ name }) -> # There's only one tag, so there's no discriminant and no need to match; # just drop the pointer. buf - |> writeIndents indents - |> Str.concat "unsafe { core::mem::ManuallyDrop::drop(&mut core::ptr::read(self.pointer).$(name)); }" + |> write_indents(indents) + |> Str.concat("unsafe { core::mem::ManuallyDrop::drop(&mut core::ptr::read(self.pointer).$(name)); }") - Err ListWasEmpty -> - crash "unreachable" + Err(ListWasEmpty) -> + crash("unreachable") else buf - |> writeTagImpls tags discriminantName indents \name, payload -> + |> write_tag_impls(tags, discriminant_name, indents, \name, payload -> when payload is - Some id if cannotSupportCopy types (Types.shape types id) -> - "unsafe { core::mem::ManuallyDrop::drop(&mut $(selfMut).payload.$(name)) }," + Some(id) if cannot_support_copy(types, Types.shape(types, id)) -> + "unsafe { core::mem::ManuallyDrop::drop(&mut $(self_mut).payload.$(name)) }," _ -> # If it had no payload, or if the payload had no pointers, # there's nothing to clean up, so do `=> {}` for the branch. - "{}" + "{}") -writeIndents = \buf, indents -> +write_indents = \buf, indents -> if indents <= 0 then buf else buf - |> Str.concat indent - |> writeIndents (indents - 1) + |> Str.concat(indent) + |> write_indents((indents - 1)) -writeTagImpls : Str, List { name : Str, payload : [Some TypeId, None] }, Str, U64, (Str, [Some TypeId, None] -> Str) -> Str -writeTagImpls = \buf, tags, discriminantName, indents, f -> +write_tag_impls : Str, List { name : Str, payload : [Some TypeId, None] }, Str, U64, (Str, [Some TypeId, None] -> Str) -> Str +write_tag_impls = \buf, tags, discriminant_name, indents, f -> buf - |> writeIndents indents - |> Str.concat "match self.discriminant() {\n" - |> \b -> List.walk tags b \accum, { name, payload } -> - branchStr = f name payload + |> write_indents(indents) + |> Str.concat("match self.discriminant() {\n") + |> \b -> + List.walk(tags, b, \accum, { name, payload } -> + branch_str = f(name, payload) accum - |> writeIndents (indents + 1) - |> Str.concat "$(discriminantName)::$(name) => $(branchStr)\n" - |> writeIndents indents - |> Str.concat "}\n" + |> write_indents((indents + 1)) + |> Str.concat("$(discriminant_name)::$(name) => $(branch_str)\n")) + |> write_indents(indents) + |> Str.concat("}\n") -generateDiscriminant = \buf, types, name, tags, size -> +generate_discriminant = \buf, types, name, tags, size -> if size > 0 then - enumType = - TagUnion - ( - Enumeration { - name, - tags, - size, - } - ) + enum_type = + TagUnion( + Enumeration({ + name, + tags, + size, + }), + ) buf - |> generateEnumeration types enumType name tags size + |> generate_enumeration(types, enum_type, name, tags, size) else buf -generateUnionField = \types -> - \accum, { name: fieldName, payload } -> - escapedFieldName = escapeKW fieldName +generate_union_field = \types -> + \accum, { name: field_name, payload } -> + escaped_field_name = escape_kw(field_name) when payload is - Some id -> - typeStr = typeName types id + Some(id) -> + type_str = type_name(types, id) - type = Types.shape types id - fullTypeStr = - if cannotSupportCopy types type then + type = Types.shape(types, id) + full_type_str = + if cannot_support_copy(types, type) then # types with pointers need ManuallyDrop # because rust unions don't (and can't) # know how to drop them automatically! - "core::mem::ManuallyDrop<$(typeStr)>" + "core::mem::ManuallyDrop<$(type_str)>" else - typeStr + type_str - Str.concat accum "$(indent)$(escapedFieldName): $(fullTypeStr),\n" + Str.concat(accum, "$(indent)$(escaped_field_name): $(full_type_str),\n") None -> # use unit as the payload - Str.concat accum "$(indent)$(escapedFieldName): (),\n" + Str.concat(accum, "$(indent)$(escaped_field_name): (),\n") -commaSeparated : Str, List a, (a, U64 -> Str) -> Str -commaSeparated = \buf, items, step -> +comma_separated : Str, List a, (a, U64 -> Str) -> Str +comma_separated = \buf, items, step -> - length = List.len items |> Num.intCast + length = List.len(items) |> Num.int_cast help : { buf : Str, count : U64 }, a -> { buf : Str, count : U64 } help = \accum, item -> if accum.count + 1 == length then - { buf: Str.concat accum.buf (step item accum.count), count: length } + { buf: Str.concat(accum.buf, step(item, accum.count)), count: length } else - { buf: Str.concat accum.buf (step item accum.count) |> Str.concat ", ", count: accum.count + 1 } + { buf: Str.concat(accum.buf, step(item, accum.count)) |> Str.concat(", "), count: accum.count + 1 } items - |> List.walk { buf, count: 0 } help + |> List.walk({ buf, count: 0 }, help) |> .buf -generateNullableUnwrapped : Str, Types, TypeId, Str, Str, Str, TypeId, [FirstTagIsNull, SecondTagIsNull] -> Str -generateNullableUnwrapped = \buf, types, tagUnionid, name, nullTag, nonNullTag, nonNullPayload, whichTagIsNull -> - payloadFields = - when Types.shape types nonNullPayload is - TagUnionPayload { fields } -> +generate_nullable_unwrapped : Str, Types, TypeId, Str, Str, Str, TypeId, [FirstTagIsNull, SecondTagIsNull] -> Str +generate_nullable_unwrapped = \buf, types, tag_unionid, name, null_tag, non_null_tag, non_null_payload, which_tag_is_null -> + payload_fields = + when Types.shape(types, non_null_payload) is + TagUnionPayload({ fields }) -> when fields is - HasNoClosure xs -> List.map xs .id - HasClosure xs -> List.map xs .id + HasNoClosure(xs) -> List.map(xs, .id) + HasClosure(xs) -> List.map(xs, .id) _ -> [] - payloadFieldNames = - commaSeparated "" payloadFields \_, i -> - n = Num.toStr i - "f$(n)" - - constructorArguments = - commaSeparated "" payloadFields \id, i -> - n = Num.toStr i - type = typeName types id - "f$(n): $(type)" - - debugFields = - payloadFields - |> List.mapWithIndex \_, i -> - n = Num.toStr i - ".field(&node.f$(n))" - |> Str.joinWith "" - - unionType = TagUnion (NullableUnwrapped { name, nullTag, nonNullTag, nonNullPayload, whichTagIsNull }) + payload_field_names = + comma_separated("", payload_fields, \_, i -> + n = Num.to_str(i) + "f$(n)") + + constructor_arguments = + comma_separated("", payload_fields, \id, i -> + n = Num.to_str(i) + type = type_name(types, id) + "f$(n): $(type)") + + debug_fields = + payload_fields + |> List.map_with_index(\_, i -> + n = Num.to_str(i) + ".field(&node.f$(n))") + |> Str.join_with("") + + union_type = TagUnion(NullableUnwrapped({ name, null_tag, non_null_tag, non_null_payload, which_tag_is_null })) discriminant = - when whichTagIsNull is + when which_tag_is_null is FirstTagIsNull -> """ #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] pub enum discriminant_$(name) { - $(nullTag) = 0, - $(nonNullTag) = 1, + $(null_tag) = 0, + $(non_null_tag) = 1, } """ @@ -1440,33 +1447,33 @@ generateNullableUnwrapped = \buf, types, tagUnionid, name, nullTag, nonNullTag, """ #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] pub enum discriminant_$(name) { - $(nonNullTag) = 0, - $(nullTag) = 1, + $(non_null_tag) = 0, + $(null_tag) = 1, } """ - sizeOfSelf = Num.toStr (Types.size types tagUnionid) - alignOfSelf = Num.toStr (Types.alignment types tagUnionid) + size_of_self = Num.to_str(Types.size(types, tag_unionid)) + align_of_self = Num.to_str(Types.alignment(types, tag_unionid)) """ $(buf) #[derive(PartialOrd, Ord)] #[repr(C)] - pub struct $(name)(*mut $(name)_$(nonNullTag)); + pub struct $(name)(*mut $(name)_$(non_null_tag)); $(discriminant) - const _SIZE_CHECK_$(name): () = assert!(core::mem::size_of::<$(name)>() == $(sizeOfSelf)); - const _ALIGN_CHECK_$(name): () = assert!(core::mem::align_of::<$(name)>() == $(alignOfSelf)); + const _SIZE_CHECK_$(name): () = assert!(core::mem::size_of::<$(name)>() == $(size_of_self)); + const _ALIGN_CHECK_$(name): () = assert!(core::mem::align_of::<$(name)>() == $(align_of_self)); impl $(name) { - pub fn $(nullTag)() -> Self { + pub fn $(null_tag)() -> Self { Self(core::ptr::null_mut()) } - pub fn $(nonNullTag)($(constructorArguments)) -> Self { - let payload = $(name)_$(nonNullTag) { $(payloadFieldNames) }; + pub fn $(non_null_tag)($(constructor_arguments)) -> Self { + let payload = $(name)_$(non_null_tag) { $(payload_field_names) }; let ptr = unsafe { roc_std::RocBox::leak(roc_std::RocBox::new(payload)) }; @@ -1474,42 +1481,42 @@ generateNullableUnwrapped = \buf, types, tagUnionid, name, nullTag, nonNullTag, } pub fn discriminant(&self) -> discriminant_$(name) { - if self.is_$(nullTag)() { - discriminant_$(name)::$(nullTag) + if self.is_$(null_tag)() { + discriminant_$(name)::$(null_tag) } else { - discriminant_$(name)::$(nonNullTag) + discriminant_$(name)::$(non_null_tag) } } - pub fn is_$(nullTag)(&self) -> bool { + pub fn is_$(null_tag)(&self) -> bool { self.0.is_null() } - pub fn is_$(nonNullTag)(&self) -> bool { + pub fn is_$(non_null_tag)(&self) -> bool { !self.0.is_null() } } impl core::fmt::Debug for $(name) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { - if self.is_$(nullTag)() { - f.debug_tuple("$(name)::$(nullTag)").finish() + if self.is_$(null_tag)() { + f.debug_tuple("$(name)::$(null_tag)").finish() } else { let node = core::mem::ManuallyDrop::new(unsafe { std::ptr::read(self.0) }); - f.debug_tuple("$(name)::$(nonNullTag)")$(debugFields).finish() + f.debug_tuple("$(name)::$(non_null_tag)")$(debug_fields).finish() } } } impl Clone for $(name) { fn clone(&self) -> Self { - if self.is_$(nullTag)() { - Self::$(nullTag)() + if self.is_$(null_tag)() { + Self::$(null_tag)() } else { use std::ops::Deref; let node_ref = core::mem::ManuallyDrop::new(unsafe { std::ptr::read(self.0) }); - let payload : $(name)_$(nonNullTag) = (node_ref.deref()).clone(); + let payload : $(name)_$(non_null_tag) = (node_ref.deref()).clone(); let ptr = unsafe { roc_std::RocBox::leak(roc_std::RocBox::new(payload)) }; @@ -1524,7 +1531,7 @@ generateNullableUnwrapped = \buf, types, tagUnionid, name, nullTag, nonNullTag, return false; } - if self.is_$(nullTag)() { + if self.is_$(null_tag)() { return true; } @@ -1541,448 +1548,455 @@ generateNullableUnwrapped = \buf, types, tagUnionid, name, nullTag, nonNullTag, fn hash(&self, state: &mut H) { self.discriminant().hash(state); - if self.is_$(nonNullTag)() { + if self.is_$(non_null_tag)() { let payload = core::mem::ManuallyDrop::new(unsafe { std::ptr::read(self.0) }); payload.hash(state); } } } """ - |> generateRocRefcounted types unionType name + |> generate_roc_refcounted(types, union_type, name) -generateSingleTagStruct = \buf, types, name, tagName, payload -> +generate_single_tag_struct = \buf, types, name, tag_name, payload -> # Store single-tag unions as structs rather than enums, # because they have only one alternative. However, still # offer the usual tag union APIs. - escapedName = escapeKW name + escaped_name = escape_kw(name) repr = length = when payload is - HasClosure fields -> List.len fields - HasNoClosure fields -> List.len fields + HasClosure(fields) -> List.len(fields) + HasNoClosure(fields) -> List.len(fields) if length <= 1 then "transparent" else "C" when payload is - HasNoClosure fields -> - asStructFields = - List.mapWithIndex fields \{ id }, index -> - indexStr = Num.toStr index + HasNoClosure(fields) -> + as_struct_fields = + List.map_with_index(fields, \{ id }, index -> + index_str = Num.to_str(index) - { name: "f$(indexStr)", id } + { name: "f$(index_str)", id }) |> HasNoClosure - asStructType = - Struct { + as_struct_type = + Struct({ name, - fields: asStructFields, - } + fields: as_struct_fields, + }) buf - |> generateDeriveStr types asStructType ExcludeDebug - |> Str.concat "#[repr($(repr))]\npub struct $(escapedName) " + |> generate_derive_str(types, as_struct_type, ExcludeDebug) + |> Str.concat("#[repr($(repr))]\npub struct $(escaped_name) ") |> \b -> - if List.isEmpty fields then - generateZeroElementSingleTagStruct b escapedName tagName + if List.is_empty(fields) then + generate_zero_element_single_tag_struct(b, escaped_name, tag_name) else - generateMultiElementSingleTagStruct b types escapedName tagName fields asStructFields - |> generateRocRefcounted types (TagUnion (SingleTagStruct { name, tagName, payload })) escapedName + generate_multi_element_single_tag_struct(b, types, escaped_name, tag_name, fields, as_struct_fields) + |> generate_roc_refcounted(types, TagUnion(SingleTagStruct({ name, tag_name, payload })), escaped_name) - HasClosure _ -> - Str.concat buf "\\TODO: SingleTagStruct with closures" + HasClosure(_) -> + Str.concat(buf, "\\TODO: SingleTagStruct with closures") -generateMultiElementSingleTagStruct = \buf, types, name, tagName, payloadFields, asStructFields -> +generate_multi_element_single_tag_struct = \buf, types, name, tag_name, payload_fields, as_struct_fields -> buf - |> Str.concat "{\n" - |> generateStructFields types Private asStructFields - |> Str.concat "}\n\n" - |> Str.concat + |> Str.concat("{\n") + |> generate_struct_fields(types, Private, as_struct_fields) + |> Str.concat("}\n\n") + |> Str.concat( """ impl $(name) { - """ + """, + ) |> \b -> - fieldTypes = - payloadFields - |> List.map \{ id } -> - typeName types id + field_types = + payload_fields + |> List.map(\{ id } -> + type_name(types, id)) args = - fieldTypes - |> List.mapWithIndex \fieldTypeName, index -> - indexStr = Num.toStr index + field_types + |> List.map_with_index(\field_type_name, index -> + index_str = Num.to_str(index) - "f$(indexStr): $(fieldTypeName)" + "f$(index_str): $(field_type_name)") fields = - payloadFields - |> List.mapWithIndex \_, index -> - indexStr = Num.toStr index + payload_fields + |> List.map_with_index(\_, index -> + index_str = Num.to_str(index) - "f$(indexStr)" + "f$(index_str)") - fieldAccesses = + field_accesses = fields - |> List.map \field -> - "self.$(field)" + |> List.map(\field -> + "self.$(field)") { b, args, fields, - fieldTypes, - fieldAccesses, + field_types, + field_accesses, } - |> \{ b, args, fields, fieldTypes, fieldAccesses } -> - argsStr = Str.joinWith args ", " - fieldsStr = Str.joinWith fields ",\n$(indent)$(indent)$(indent)" + |> \{ b, args, fields, field_types, field_accesses } -> + args_str = Str.join_with(args, ", ") + fields_str = Str.join_with(fields, ",\n$(indent)$(indent)$(indent)") { - b: Str.concat - b + b: Str.concat( + b, """ - $(indent)/// A tag named ``$(tagName)``, with the given payload. - $(indent)pub fn $(tagName)($(argsStr)) -> Self { + $(indent)/// A tag named ``$(tag_name)``, with the given payload. + $(indent)pub fn $(tag_name)($(args_str)) -> Self { $(indent) Self { - $(indent) $(fieldsStr) + $(indent) $(fields_str) $(indent) } $(indent)} """, - fieldTypes, - fieldAccesses, + ), + field_types, + field_accesses, } - |> \{ b, fieldTypes, fieldAccesses } -> - retType = asRustTuple fieldTypes - retExpr = asRustTuple fieldAccesses + |> \{ b, field_types, field_accesses } -> + ret_type = as_rust_tuple(field_types) + ret_expr = as_rust_tuple(field_accesses) { - b: Str.concat - b + b: Str.concat( + b, """ - $(indent)/// Since `$(name)` only has one tag (namely, `$(tagName)`), - $(indent)/// convert it to `$(tagName)`'s payload. - $(indent)pub fn into_$(tagName)(self) -> $(retType) { - $(indent) $(retExpr) + $(indent)/// Since `$(name)` only has one tag (namely, `$(tag_name)`), + $(indent)/// convert it to `$(tag_name)`'s payload. + $(indent)pub fn into_$(tag_name)(self) -> $(ret_type) { + $(indent) $(ret_expr) $(indent)} """, - fieldTypes, - fieldAccesses, + ), + field_types, + field_accesses, } - |> \{ b, fieldTypes, fieldAccesses } -> - retType = - fieldTypes - |> List.map \ft -> "&$(ft)" - |> asRustTuple - retExpr = - fieldAccesses - |> List.map \fa -> "&$(fa)" - |> asRustTuple - - Str.concat - b + |> \{ b, field_types, field_accesses } -> + ret_type = + field_types + |> List.map(\ft -> "&$(ft)") + |> as_rust_tuple + ret_expr = + field_accesses + |> List.map(\fa -> "&$(fa)") + |> as_rust_tuple + + Str.concat( + b, """ - $(indent)/// Since `$(name)` only has one tag (namely, `$(tagName)`), - $(indent)/// convert it to `$(tagName)`'s payload. - $(indent)pub fn as_$(tagName)(&self) -> $(retType) { - $(indent) $(retExpr) + $(indent)/// Since `$(name)` only has one tag (namely, `$(tag_name)`), + $(indent)/// convert it to `$(tag_name)`'s payload. + $(indent)pub fn as_$(tag_name)(&self) -> $(ret_type) { + $(indent) $(ret_expr) $(indent)} - """ - |> Str.concat + """, + ) + |> Str.concat( """ } impl core::fmt::Debug for $(name) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { - f.debug_tuple("$(name)::$(tagName)") + f.debug_tuple("$(name)::$(tag_name)") - """ + """, + ) |> \b -> - payloadFields - |> List.mapWithIndex \_, index -> - indexStr = Num.toStr index + payload_fields + |> List.map_with_index(\_, index -> + index_str = Num.to_str(index) - "$(indent)$(indent)$(indent)$(indent).field(&self.f$(indexStr))\n" - |> List.walk b Str.concat - |> Str.concat + "$(indent)$(indent)$(indent)$(indent).field(&self.f$(index_str))\n") + |> List.walk(b, Str.concat) + |> Str.concat( """ .finish() } } - """ + """, + ) -asRustTuple = \list -> +as_rust_tuple = \list -> # If there is 1 element in the list we just return it # Otherwise, we make a proper tuple string. - joined = Str.joinWith list ", " + joined = Str.join_with(list, ", ") - if List.len list == 1 then + if List.len(list) == 1 then joined else "($(joined))" -generateZeroElementSingleTagStruct = \buf, name, tagName -> +generate_zero_element_single_tag_struct = \buf, name, tag_name -> # A single tag with no payload is a zero-sized unit type, so # represent it as a zero-sized struct (e.g. "struct Foo()"). buf - |> Str.concat "();\n\n" - |> Str.concat + |> Str.concat("();\n\n") + |> Str.concat( """ impl $(name) { - /// A tag named $(tagName), which has no payload. - pub const $(tagName): Self = Self(); + /// A tag named $(tag_name), which has no payload. + pub const $(tag_name): Self = Self(); - /// Other `into_` methods return a payload, but since $(tagName) tag + /// Other `into_` methods return a payload, but since $(tag_name) tag /// has no payload, this does nothing and is only here for completeness. - pub fn into_$(tagName)(self) { + pub fn into_$(tag_name)(self) { () } - /// Other `as_` methods return a payload, but since $(tagName) tag + /// Other `as_` methods return a payload, but since $(tag_name) tag /// has no payload, this does nothing and is only here for completeness. - pub fn as_$(tagName)(&self) { + pub fn as_$(tag_name)(&self) { () } } impl core::fmt::Debug for $(name) { fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { - f.write_str("$(name)::$(tagName)") + f.write_str("$(name)::$(tag_name)") } } - """ + """, + ) -generateDeriveStr = \buf, types, type, includeDebug -> - condWrite = \b, cond, str -> +generate_derive_str = \buf, types, type, include_debug -> + cond_write = \b, cond, str -> if cond then - Str.concat b str + Str.concat(b, str) else b - deriveDebug = - when includeDebug is + derive_debug = + when include_debug is IncludeDebug -> Bool.true ExcludeDebug -> Bool.false buf - |> Str.concat "#[derive(Clone, " - |> condWrite (!(cannotSupportCopy types type)) "Copy, " - |> condWrite (!(cannotSupportDefault types type)) "Default, " - |> condWrite deriveDebug "Debug, " - |> condWrite (canSupportPartialEqOrd types type) "PartialEq, PartialOrd, " - |> condWrite (canSupportEqHashOrd types type) "Eq, Ord, Hash, " - |> Str.concat ")]\n" - -canSupportEqHashOrd : Types, Shape -> Bool -canSupportEqHashOrd = \types, type -> - !(hasFloat types type) && (canSupportPartialEqOrd types type) - -canSupportPartialEqOrd : Types, Shape -> Bool -canSupportPartialEqOrd = \types, type -> + |> Str.concat("#[derive(Clone, ") + |> cond_write(!(cannot_support_copy(types, type)), "Copy, ") + |> cond_write(!(cannot_support_default(types, type)), "Default, ") + |> cond_write(derive_debug, "Debug, ") + |> cond_write(can_support_partial_eq_ord(types, type), "PartialEq, PartialOrd, ") + |> cond_write(can_support_eq_hash_ord(types, type), "Eq, Ord, Hash, ") + |> Str.concat(")]\n") + +can_support_eq_hash_ord : Types, Shape -> Bool +can_support_eq_hash_ord = \types, type -> + !(has_float(types, type)) && (can_support_partial_eq_ord(types, type)) + +can_support_partial_eq_ord : Types, Shape -> Bool +can_support_partial_eq_ord = \types, type -> when type is - Function rocFn -> - runtimeRepresentation = Types.shape types rocFn.lambdaSet - canSupportPartialEqOrd types runtimeRepresentation + Function(roc_fn) -> + runtime_representation = Types.shape(types, roc_fn.lambda_set) + can_support_partial_eq_ord(types, runtime_representation) Unsized -> Bool.false - Unit | EmptyTagUnion | Bool | Num _ | TagUnion (Enumeration _) -> Bool.true + Unit | EmptyTagUnion | Bool | Num(_) | TagUnion(Enumeration(_)) -> Bool.true RocStr -> Bool.true - RocList inner | RocSet inner | RocBox inner -> - innerType = Types.shape types inner - canSupportPartialEqOrd types innerType + RocList(inner) | RocSet(inner) | RocBox(inner) -> + inner_type = Types.shape(types, inner) + can_support_partial_eq_ord(types, inner_type) - RocDict k v -> - kType = Types.shape types k - vType = Types.shape types v + RocDict(k, v) -> + k_type = Types.shape(types, k) + v_type = Types.shape(types, v) - canSupportPartialEqOrd types kType && canSupportPartialEqOrd types vType + can_support_partial_eq_ord(types, k_type) && can_support_partial_eq_ord(types, v_type) - TagUnion (Recursive { tags }) -> - List.all tags \{ payload } -> + TagUnion(Recursive({ tags })) -> + List.all(tags, \{ payload } -> when payload is None -> Bool.true - Some id -> canSupportPartialEqOrd types (Types.shape types id) + Some(id) -> can_support_partial_eq_ord(types, Types.shape(types, id))) - TagUnion (NullableWrapped { tags }) -> - List.all tags \{ payload } -> + TagUnion(NullableWrapped({ tags })) -> + List.all(tags, \{ payload } -> when payload is None -> Bool.true - Some id -> canSupportPartialEqOrd types (Types.shape types id) + Some(id) -> can_support_partial_eq_ord(types, Types.shape(types, id))) - TagUnion (NonNullableUnwrapped { payload }) -> - canSupportPartialEqOrd types (Types.shape types payload) + TagUnion(NonNullableUnwrapped({ payload })) -> + can_support_partial_eq_ord(types, Types.shape(types, payload)) - TagUnion (NullableUnwrapped { nonNullPayload }) -> - canSupportPartialEqOrd types (Types.shape types nonNullPayload) + TagUnion(NullableUnwrapped({ non_null_payload })) -> + can_support_partial_eq_ord(types, Types.shape(types, non_null_payload)) - RecursivePointer _ -> Bool.true - TagUnion (SingleTagStruct { payload: HasNoClosure fields }) -> - List.all fields \{ id } -> canSupportPartialEqOrd types (Types.shape types id) + RecursivePointer(_) -> Bool.true + TagUnion(SingleTagStruct({ payload: HasNoClosure(fields) })) -> + List.all(fields, \{ id } -> can_support_partial_eq_ord(types, Types.shape(types, id))) - TagUnion (SingleTagStruct { payload: HasClosure _ }) -> + TagUnion(SingleTagStruct({ payload: HasClosure(_) })) -> Bool.false - TagUnion (NonRecursive { tags }) -> - List.all tags \{ payload } -> + TagUnion(NonRecursive({ tags })) -> + List.all(tags, \{ payload } -> when payload is - Some id -> canSupportPartialEqOrd types (Types.shape types id) - None -> Bool.true + Some(id) -> can_support_partial_eq_ord(types, Types.shape(types, id)) + None -> Bool.true) - RocResult okId errId -> - okShape = Types.shape types okId - errShape = Types.shape types errId + RocResult(ok_id, err_id) -> + ok_shape = Types.shape(types, ok_id) + err_shape = Types.shape(types, err_id) - canSupportPartialEqOrd types okShape && canSupportPartialEqOrd types errShape + can_support_partial_eq_ord(types, ok_shape) && can_support_partial_eq_ord(types, err_shape) - Struct { fields: HasNoClosure fields } | TagUnionPayload { fields: HasNoClosure fields } -> - List.all fields \{ id } -> canSupportPartialEqOrd types (Types.shape types id) + Struct({ fields: HasNoClosure(fields) }) | TagUnionPayload({ fields: HasNoClosure(fields) }) -> + List.all(fields, \{ id } -> can_support_partial_eq_ord(types, Types.shape(types, id))) - Struct { fields: HasClosure fields } | TagUnionPayload { fields: HasClosure fields } -> - List.all fields \{ id } -> canSupportPartialEqOrd types (Types.shape types id) + Struct({ fields: HasClosure(fields) }) | TagUnionPayload({ fields: HasClosure(fields) }) -> + List.all(fields, \{ id } -> can_support_partial_eq_ord(types, Types.shape(types, id))) -cannotSupportCopy : Types, Shape -> Bool -cannotSupportCopy = \types, type -> - !(canDeriveCopy types type) +cannot_support_copy : Types, Shape -> Bool +cannot_support_copy = \types, type -> + !(can_derive_copy(types, type)) -canDeriveCopy : Types, Shape -> Bool -canDeriveCopy = \types, type -> +can_derive_copy : Types, Shape -> Bool +can_derive_copy = \types, type -> when type is - Function rocFn -> - runtimeRepresentation = Types.shape types rocFn.lambdaSet - canDeriveCopy types runtimeRepresentation + Function(roc_fn) -> + runtime_representation = Types.shape(types, roc_fn.lambda_set) + can_derive_copy(types, runtime_representation) # unsized values are heap-allocated Unsized -> Bool.false - Unit | EmptyTagUnion | Bool | Num _ | TagUnion (Enumeration _) -> Bool.true - RocStr | RocList _ | RocDict _ _ | RocSet _ | RocBox _ | TagUnion (NullableUnwrapped _) | TagUnion (NullableWrapped _) | TagUnion (Recursive _) | TagUnion (NonNullableUnwrapped _) | RecursivePointer _ -> Bool.false - TagUnion (SingleTagStruct { payload: HasNoClosure fields }) -> - List.all fields \{ id } -> canDeriveCopy types (Types.shape types id) + Unit | EmptyTagUnion | Bool | Num(_) | TagUnion(Enumeration(_)) -> Bool.true + RocStr | RocList(_) | RocDict(_, _) | RocSet(_) | RocBox(_) | TagUnion(NullableUnwrapped(_)) | TagUnion(NullableWrapped(_)) | TagUnion(Recursive(_)) | TagUnion(NonNullableUnwrapped(_)) | RecursivePointer(_) -> Bool.false + TagUnion(SingleTagStruct({ payload: HasNoClosure(fields) })) -> + List.all(fields, \{ id } -> can_derive_copy(types, Types.shape(types, id))) - TagUnion (SingleTagStruct { payload: HasClosure fields }) -> - List.all fields \{ id } -> canDeriveCopy types (Types.shape types id) + TagUnion(SingleTagStruct({ payload: HasClosure(fields) })) -> + List.all(fields, \{ id } -> can_derive_copy(types, Types.shape(types, id))) - TagUnion (NonRecursive { tags }) -> - List.all tags \{ payload } -> + TagUnion(NonRecursive({ tags })) -> + List.all(tags, \{ payload } -> when payload is - Some id -> canDeriveCopy types (Types.shape types id) - None -> Bool.true + Some(id) -> can_derive_copy(types, Types.shape(types, id)) + None -> Bool.true) - RocResult okId errId -> - canDeriveCopy types (Types.shape types okId) - && canDeriveCopy types (Types.shape types errId) + RocResult(ok_id, err_id) -> + can_derive_copy(types, Types.shape(types, ok_id)) + && can_derive_copy(types, Types.shape(types, err_id)) - Struct { fields: HasNoClosure fields } | TagUnionPayload { fields: HasNoClosure fields } -> - List.all fields \{ id } -> canDeriveCopy types (Types.shape types id) + Struct({ fields: HasNoClosure(fields) }) | TagUnionPayload({ fields: HasNoClosure(fields) }) -> + List.all(fields, \{ id } -> can_derive_copy(types, Types.shape(types, id))) - Struct { fields: HasClosure fields } | TagUnionPayload { fields: HasClosure fields } -> - List.all fields \{ id } -> canDeriveCopy types (Types.shape types id) + Struct({ fields: HasClosure(fields) }) | TagUnionPayload({ fields: HasClosure(fields) }) -> + List.all(fields, \{ id } -> can_derive_copy(types, Types.shape(types, id))) -cannotSupportDefault = \types, type -> +cannot_support_default = \types, type -> when type is - Unit | Unsized | EmptyTagUnion | TagUnion _ | RocResult _ _ | RecursivePointer _ | Function _ -> Bool.true - RocStr | Bool | Num _ -> Bool.false - RocList id | RocSet id | RocBox id -> - cannotSupportDefault types (Types.shape types id) + Unit | Unsized | EmptyTagUnion | TagUnion(_) | RocResult(_, _) | RecursivePointer(_) | Function(_) -> Bool.true + RocStr | Bool | Num(_) -> Bool.false + RocList(id) | RocSet(id) | RocBox(id) -> + cannot_support_default(types, Types.shape(types, id)) - TagUnionPayload { fields: HasClosure _ } -> Bool.true - RocDict keyId valId -> - cannotSupportCopy types (Types.shape types keyId) - || cannotSupportCopy types (Types.shape types valId) + TagUnionPayload({ fields: HasClosure(_) }) -> Bool.true + RocDict(key_id, val_id) -> + cannot_support_copy(types, Types.shape(types, key_id)) + || cannot_support_copy(types, Types.shape(types, val_id)) - Struct { fields: HasClosure _ } -> Bool.true - Struct { fields: HasNoClosure fields } | TagUnionPayload { fields: HasNoClosure fields } -> - List.any fields \{ id } -> cannotSupportDefault types (Types.shape types id) + Struct({ fields: HasClosure(_) }) -> Bool.true + Struct({ fields: HasNoClosure(fields) }) | TagUnionPayload({ fields: HasNoClosure(fields) }) -> + List.any(fields, \{ id } -> cannot_support_default(types, Types.shape(types, id))) -hasFloat = \types, type -> - hasFloatHelp types type (Set.empty {}) +has_float = \types, type -> + has_float_help(types, type, Set.empty({})) -hasFloatHelp = \types, type, doNotRecurse -> +has_float_help = \types, type, do_not_recurse -> # TODO: is doNotRecurse problematic? Do we need an updated doNotRecurse for calls up the tree? # I think there is a change it really only matters for RecursivePointer, so it may be fine. # Otherwise we need to deal with threading through updates to doNotRecurse when type is - Num kind -> + Num(kind) -> when kind is F32 | F64 -> Bool.true _ -> Bool.false - Unit | Unsized | EmptyTagUnion | RocStr | Bool | TagUnion (Enumeration _) | Function _ -> Bool.false - RocList id | RocSet id | RocBox id -> - hasFloatHelp types (Types.shape types id) doNotRecurse + Unit | Unsized | EmptyTagUnion | RocStr | Bool | TagUnion(Enumeration(_)) | Function(_) -> Bool.false + RocList(id) | RocSet(id) | RocBox(id) -> + has_float_help(types, Types.shape(types, id), do_not_recurse) - RocDict id0 id1 | RocResult id0 id1 -> - hasFloatHelp types (Types.shape types id0) doNotRecurse - || hasFloatHelp types (Types.shape types id1) doNotRecurse + RocDict(id0, id1) | RocResult(id0, id1) -> + has_float_help(types, Types.shape(types, id0), do_not_recurse) + || has_float_help(types, Types.shape(types, id1), do_not_recurse) - Struct { fields: HasNoClosure fields } | TagUnionPayload { fields: HasNoClosure fields } -> - List.any fields \{ id } -> hasFloatHelp types (Types.shape types id) doNotRecurse + Struct({ fields: HasNoClosure(fields) }) | TagUnionPayload({ fields: HasNoClosure(fields) }) -> + List.any(fields, \{ id } -> has_float_help(types, Types.shape(types, id), do_not_recurse)) - Struct { fields: HasClosure fields } | TagUnionPayload { fields: HasClosure fields } -> - List.any fields \{ id } -> hasFloatHelp types (Types.shape types id) doNotRecurse + Struct({ fields: HasClosure(fields) }) | TagUnionPayload({ fields: HasClosure(fields) }) -> + List.any(fields, \{ id } -> has_float_help(types, Types.shape(types, id), do_not_recurse)) - TagUnion (SingleTagStruct { payload: HasNoClosure fields }) -> - List.any fields \{ id } -> hasFloatHelp types (Types.shape types id) doNotRecurse + TagUnion(SingleTagStruct({ payload: HasNoClosure(fields) })) -> + List.any(fields, \{ id } -> has_float_help(types, Types.shape(types, id), do_not_recurse)) - TagUnion (SingleTagStruct { payload: HasClosure fields }) -> - List.any fields \{ id } -> hasFloatHelp types (Types.shape types id) doNotRecurse + TagUnion(SingleTagStruct({ payload: HasClosure(fields) })) -> + List.any(fields, \{ id } -> has_float_help(types, Types.shape(types, id), do_not_recurse)) - TagUnion (Recursive { tags }) -> - List.any tags \{ payload } -> + TagUnion(Recursive({ tags })) -> + List.any(tags, \{ payload } -> when payload is - Some id -> hasFloatHelp types (Types.shape types id) doNotRecurse - None -> Bool.false + Some(id) -> has_float_help(types, Types.shape(types, id), do_not_recurse) + None -> Bool.false) - TagUnion (NonRecursive { tags }) -> - List.any tags \{ payload } -> + TagUnion(NonRecursive({ tags })) -> + List.any(tags, \{ payload } -> when payload is - Some id -> hasFloatHelp types (Types.shape types id) doNotRecurse - None -> Bool.false + Some(id) -> has_float_help(types, Types.shape(types, id), do_not_recurse) + None -> Bool.false) - TagUnion (NullableWrapped { tags }) -> - List.any tags \{ payload } -> + TagUnion(NullableWrapped({ tags })) -> + List.any(tags, \{ payload } -> when payload is - Some id -> hasFloatHelp types (Types.shape types id) doNotRecurse - None -> Bool.false + Some(id) -> has_float_help(types, Types.shape(types, id), do_not_recurse) + None -> Bool.false) - TagUnion (NonNullableUnwrapped { payload }) -> - if Set.contains doNotRecurse payload then + TagUnion(NonNullableUnwrapped({ payload })) -> + if Set.contains(do_not_recurse, payload) then Bool.false else - nextDoNotRecurse = Set.insert doNotRecurse payload + next_do_not_recurse = Set.insert(do_not_recurse, payload) - hasFloatHelp types (Types.shape types payload) nextDoNotRecurse + has_float_help(types, Types.shape(types, payload), next_do_not_recurse) - TagUnion (NullableUnwrapped { nonNullPayload }) -> - if Set.contains doNotRecurse nonNullPayload then + TagUnion(NullableUnwrapped({ non_null_payload })) -> + if Set.contains(do_not_recurse, non_null_payload) then Bool.false else - nextDoNotRecurse = Set.insert doNotRecurse nonNullPayload + next_do_not_recurse = Set.insert(do_not_recurse, non_null_payload) - hasFloatHelp types (Types.shape types nonNullPayload) nextDoNotRecurse + has_float_help(types, Types.shape(types, non_null_payload), next_do_not_recurse) - RecursivePointer payload -> - if Set.contains doNotRecurse payload then + RecursivePointer(payload) -> + if Set.contains(do_not_recurse, payload) then Bool.false else - nextDoNotRecurse = Set.insert doNotRecurse payload + next_do_not_recurse = Set.insert(do_not_recurse, payload) - hasFloatHelp types (Types.shape types payload) nextDoNotRecurse + has_float_help(types, Types.shape(types, payload), next_do_not_recurse) -generateRocRefcounted = \buf, types, type, escapedName -> - if containsRefcounted types type then +generate_roc_refcounted = \buf, types, type, escaped_name -> + if contains_refcounted(types, type) then impl = when type is - TagUnion (NonNullableUnwrapped _) -> + TagUnion(NonNullableUnwrapped(_)) -> """ - impl roc_std::RocRefcounted for $(escapedName) { + impl roc_std::RocRefcounted for $(escaped_name) { fn inc(&mut self) { self.0.inc(); } @@ -1995,9 +2009,9 @@ generateRocRefcounted = \buf, types, type, escapedName -> }\n\n """ - TagUnion (Recursive _) -> + TagUnion(Recursive(_)) -> """ - impl roc_std::RocRefcounted for $(escapedName) { + impl roc_std::RocRefcounted for $(escaped_name) { fn inc(&mut self) { unimplemented!(); } @@ -2008,7 +2022,7 @@ generateRocRefcounted = \buf, types, type, escapedName -> true } }\n\n - impl roc_std::RocRefcounted for union_$(escapedName) { + impl roc_std::RocRefcounted for union_$(escaped_name) { fn inc(&mut self) { unimplemented!(); } @@ -2021,9 +2035,9 @@ generateRocRefcounted = \buf, types, type, escapedName -> }\n\n """ - TagUnion (NullableWrapped _) -> + TagUnion(NullableWrapped(_)) -> """ - impl roc_std::RocRefcounted for $(escapedName) { + impl roc_std::RocRefcounted for $(escaped_name) { fn inc(&mut self) { unimplemented!(); } @@ -2034,7 +2048,7 @@ generateRocRefcounted = \buf, types, type, escapedName -> true } }\n\n - impl roc_std::RocRefcounted for union_$(escapedName) { + impl roc_std::RocRefcounted for union_$(escaped_name) { fn inc(&mut self) { unimplemented!(); } @@ -2047,16 +2061,16 @@ generateRocRefcounted = \buf, types, type, escapedName -> }\n\n """ - Struct { fields: HasNoClosure fields } -> - incFields = generateRocRefcountedNamedFields types fields Inc Struct - decFields = generateRocRefcountedNamedFields types fields Dec Struct + Struct({ fields: HasNoClosure(fields) }) -> + inc_fields = generate_roc_refcounted_named_fields(types, fields, Inc, Struct) + dec_fields = generate_roc_refcounted_named_fields(types, fields, Dec, Struct) """ - impl roc_std::RocRefcounted for $(escapedName) { + impl roc_std::RocRefcounted for $(escaped_name) { fn inc(&mut self) { - $(incFields) + $(inc_fields) } fn dec(&mut self) { - $(decFields) + $(dec_fields) } fn is_refcounted() -> bool { true @@ -2064,16 +2078,16 @@ generateRocRefcounted = \buf, types, type, escapedName -> }\n\n """ - TagUnionPayload { fields: HasNoClosure fields } -> - incFields = generateRocRefcountedNamedFields types fields Inc Tag - decFields = generateRocRefcountedNamedFields types fields Dec Tag + TagUnionPayload({ fields: HasNoClosure(fields) }) -> + inc_fields = generate_roc_refcounted_named_fields(types, fields, Inc, Tag) + dec_fields = generate_roc_refcounted_named_fields(types, fields, Dec, Tag) """ - impl roc_std::RocRefcounted for $(escapedName) { + impl roc_std::RocRefcounted for $(escaped_name) { fn inc(&mut self) { - $(incFields) + $(inc_fields) } fn dec(&mut self) { - $(decFields) + $(dec_fields) } fn is_refcounted() -> bool { true @@ -2083,7 +2097,7 @@ generateRocRefcounted = \buf, types, type, escapedName -> _ -> """ - impl roc_std::RocRefcounted for $(escapedName) { + impl roc_std::RocRefcounted for $(escaped_name) { fn inc(&mut self) { unimplemented!(); } @@ -2095,141 +2109,143 @@ generateRocRefcounted = \buf, types, type, escapedName -> } }\n\n """ - Str.concat - buf - impl + Str.concat( + buf, + impl, + ) else - Str.concat buf "roc_refcounted_noop_impl!($(escapedName));\n\n" + Str.concat(buf, "roc_refcounted_noop_impl!($(escaped_name));\n\n") -generateRocRefcountedNamedFields = \types, fields, mode, wrapper -> - fieldName = \name -> - escapedName = escapeKW name +generate_roc_refcounted_named_fields = \types, fields, mode, wrapper -> + field_name = \name -> + escaped_name = escape_kw(name) when wrapper is - Struct -> escapedName - Tag -> "f$(escapedName)" + Struct -> escaped_name + Tag -> "f$(escaped_name)" - methodName = + method_name = when mode is Inc -> "inc" Dec -> "dec" walker = \accum, { name, id } -> - if containsRefcounted types (Types.shape types id) then - Str.concat - accum - "$(indent) self.$(fieldName name).$(methodName)();\n" + if contains_refcounted(types, Types.shape(types, id)) then + Str.concat( + accum, + "$(indent) self.$(field_name(name)).$(method_name)();\n", + ) else accum - List.walk fields "" walker + List.walk(fields, "", walker) # If a value or any data in it must be refcounted. -containsRefcounted = \types, type -> - containsRefcountedHelp types type (Set.empty {}) +contains_refcounted = \types, type -> + contains_refcounted_help(types, type, Set.empty({})) -containsRefcountedHelp = \types, type, doNotRecurse -> +contains_refcounted_help = \types, type, do_not_recurse -> # TODO: is doNotRecurse problematic? Do we need an updated doNotRecurse for calls up the tree? # I think there is a change it really only matters for RecursivePointer, so it may be fine. # Otherwise we need to deal with threading through updates to doNotRecurse when type is - RocStr | RocList _ | RocSet _ | RocDict _ _ | RocBox _ | RecursivePointer _ -> + RocStr | RocList(_) | RocSet(_) | RocDict(_, _) | RocBox(_) | RecursivePointer(_) -> Bool.true - Unit | Unsized | EmptyTagUnion | Num _ | Bool | TagUnion (Enumeration _) -> + Unit | Unsized | EmptyTagUnion | Num(_) | Bool | TagUnion(Enumeration(_)) -> Bool.false - Function { lambdaSet: id } -> - containsRefcountedHelp types (Types.shape types id) doNotRecurse + Function({ lambda_set: id }) -> + contains_refcounted_help(types, Types.shape(types, id), do_not_recurse) - RocResult id0 id1 -> - containsRefcountedHelp types (Types.shape types id0) doNotRecurse - || containsRefcountedHelp types (Types.shape types id1) doNotRecurse + RocResult(id0, id1) -> + contains_refcounted_help(types, Types.shape(types, id0), do_not_recurse) + || contains_refcounted_help(types, Types.shape(types, id1), do_not_recurse) - Struct { fields: HasNoClosure fields } | TagUnionPayload { fields: HasNoClosure fields } -> - List.any fields \{ id } -> containsRefcountedHelp types (Types.shape types id) doNotRecurse + Struct({ fields: HasNoClosure(fields) }) | TagUnionPayload({ fields: HasNoClosure(fields) }) -> + List.any(fields, \{ id } -> contains_refcounted_help(types, Types.shape(types, id), do_not_recurse)) - Struct { fields: HasClosure fields } | TagUnionPayload { fields: HasClosure fields } -> - List.any fields \{ id } -> containsRefcountedHelp types (Types.shape types id) doNotRecurse + Struct({ fields: HasClosure(fields) }) | TagUnionPayload({ fields: HasClosure(fields) }) -> + List.any(fields, \{ id } -> contains_refcounted_help(types, Types.shape(types, id), do_not_recurse)) - TagUnion (SingleTagStruct { payload: HasNoClosure fields }) -> - List.any fields \{ id } -> containsRefcountedHelp types (Types.shape types id) doNotRecurse + TagUnion(SingleTagStruct({ payload: HasNoClosure(fields) })) -> + List.any(fields, \{ id } -> contains_refcounted_help(types, Types.shape(types, id), do_not_recurse)) - TagUnion (SingleTagStruct { payload: HasClosure fields }) -> - List.any fields \{ id } -> containsRefcountedHelp types (Types.shape types id) doNotRecurse + TagUnion(SingleTagStruct({ payload: HasClosure(fields) })) -> + List.any(fields, \{ id } -> contains_refcounted_help(types, Types.shape(types, id), do_not_recurse)) - TagUnion (Recursive _) -> Bool.true - TagUnion (NullableWrapped _) -> Bool.true - TagUnion (NonNullableUnwrapped _) -> Bool.true - TagUnion (NullableUnwrapped _) -> Bool.true - TagUnion (NonRecursive { tags }) -> - List.any tags \{ payload } -> + TagUnion(Recursive(_)) -> Bool.true + TagUnion(NullableWrapped(_)) -> Bool.true + TagUnion(NonNullableUnwrapped(_)) -> Bool.true + TagUnion(NullableUnwrapped(_)) -> Bool.true + TagUnion(NonRecursive({ tags })) -> + List.any(tags, \{ payload } -> when payload is - Some id -> containsRefcountedHelp types (Types.shape types id) doNotRecurse - None -> Bool.false + Some(id) -> contains_refcounted_help(types, Types.shape(types, id), do_not_recurse) + None -> Bool.false) -typeName = \types, id -> - when Types.shape types id is +type_name = \types, id -> + when Types.shape(types, id) is Unit -> "()" Unsized -> "roc_std::RocList" EmptyTagUnion -> "std::convert::Infallible" RocStr -> "roc_std::RocStr" Bool -> "bool" - Num U8 -> "u8" - Num U16 -> "u16" - Num U32 -> "u32" - Num U64 -> "u64" - Num U128 -> "u128" - Num I8 -> "i8" - Num I16 -> "i16" - Num I32 -> "i32" - Num I64 -> "i64" - Num I128 -> "i128" - Num F32 -> "f32" - Num F64 -> "f64" - Num Dec -> "roc_std:RocDec" - RocDict _key _value -> - # keyName = typeName types key - # valueName = typeName types value - # "roc_std::RocDict<$(keyName), $(valueName)>" - crash "RocDict is not yet supported in rust" - - RocSet _elem -> - # elemName = typeName types elem - # "roc_std::RocSet<$(elemName)>" - crash "RocSet is not yet supported in rust" - - RocList elem -> - elemName = typeName types elem - - "roc_std::RocList<$(elemName)>" - - RocBox elem -> - elemName = typeName types elem - - "roc_std::RocBox<$(elemName)>" - - RocResult ok err -> - okName = typeName types ok - errName = typeName types err - - "roc_std::RocResult<$(okName), $(errName)>" - - RecursivePointer content -> - typeName types content - - Struct { name } -> escapeKW name - TagUnionPayload { name } -> escapeKW name - TagUnion (NonRecursive { name }) -> escapeKW name - TagUnion (Recursive { name }) -> escapeKW name - TagUnion (Enumeration { name }) -> escapeKW name - TagUnion (NullableWrapped { name }) -> escapeKW name - TagUnion (NullableUnwrapped { name }) -> escapeKW name - TagUnion (NonNullableUnwrapped { name }) -> escapeKW name - TagUnion (SingleTagStruct { name }) -> escapeKW name - Function { functionName } -> escapeKW functionName - -archName = \arch -> + Num(U8) -> "u8" + Num(U16) -> "u16" + Num(U32) -> "u32" + Num(U64) -> "u64" + Num(U128) -> "u128" + Num(I8) -> "i8" + Num(I16) -> "i16" + Num(I32) -> "i32" + Num(I64) -> "i64" + Num(I128) -> "i128" + Num(F32) -> "f32" + Num(F64) -> "f64" + Num(Dec) -> "roc_std:RocDec" + RocDict(_key, _value) -> + # key_name = type_name(types, key) + # value_name = type_name(types, value) + # "roc_std::RocDict<$(key_name), $(value_name)>" + crash("RocDict is not yet supported in rust") + + RocSet(_elem) -> + # elem_name = type_name(types, elem) + # "roc_std::RocSet<$(elem_name)>" + crash("RocSet is not yet supported in rust") + + RocList(elem) -> + elem_name = type_name(types, elem) + + "roc_std::RocList<$(elem_name)>" + + RocBox(elem) -> + elem_name = type_name(types, elem) + + "roc_std::RocBox<$(elem_name)>" + + RocResult(ok, err) -> + ok_name = type_name(types, ok) + err_name = type_name(types, err) + + "roc_std::RocResult<$(ok_name), $(err_name)>" + + RecursivePointer(content) -> + type_name(types, content) + + Struct({ name }) -> escape_kw(name) + TagUnionPayload({ name }) -> escape_kw(name) + TagUnion(NonRecursive({ name })) -> escape_kw(name) + TagUnion(Recursive({ name })) -> escape_kw(name) + TagUnion(Enumeration({ name })) -> escape_kw(name) + TagUnion(NullableWrapped({ name })) -> escape_kw(name) + TagUnion(NullableUnwrapped({ name })) -> escape_kw(name) + TagUnion(NonNullableUnwrapped({ name })) -> escape_kw(name) + TagUnion(SingleTagStruct({ name })) -> escape_kw(name) + Function({ function_name }) -> escape_kw(function_name) + +arch_name = \arch -> when arch is Aarch32 -> "arm" @@ -2246,7 +2262,7 @@ archName = \arch -> X86x64 -> "x86_64" -fileHeader = +file_header = """ // ⚠️ GENERATED CODE ⚠️ - this entire file was generated by the `roc glue` CLI command @@ -2274,9 +2290,9 @@ fileHeader = """ indent = " " -discriminantDocComment = "/// Returns which variant this tag union holds. Note that this never includes a payload!" +discriminant_doc_comment = "/// Returns which variant this tag union holds. Note that this never includes a payload!" -reservedKeywords = Set.fromList [ +reserved_keywords = Set.from_list([ "try", "abstract", "become", @@ -2328,42 +2344,42 @@ reservedKeywords = Set.fromList [ "use", "where", "while", -] +]) -escapeKW = \input -> +escape_kw = \input -> # use a raw identifier for this, to prevent a syntax error due to using a reserved keyword. # https://doc.rust-lang.org/rust-by-example/compatibility/raw_identifiers.html # another design would be to add an underscore after it; this is an experiment! - if Set.contains reservedKeywords input then + if Set.contains(reserved_keywords, input) then "r#$(input)" else input -nextMultipleOf = \lhs, rhs -> +next_multiple_of = \lhs, rhs -> when lhs % rhs is 0 -> lhs r -> lhs + (rhs - r) -isUnit : Shape -> Bool -isUnit = \shape -> +is_unit : Shape -> Bool +is_unit = \shape -> when shape is Unit -> Bool.true _ -> Bool.false -toArgStr : List TypeId, Types, (TypeId, Shape, U64 -> Str) -> Str -toArgStr = \args, types, fmt -> - List.walkWithIndex args "" \state, argId, index -> - shape = Types.shape types argId +to_arg_str : List TypeId, Types, (TypeId, Shape, U64 -> Str) -> Str +to_arg_str = \args, types, fmt -> + List.walk_with_index(args, "", \state, arg_id, index -> + shape = Types.shape(types, arg_id) # Drop `()` args; they aren't FFI-safe, and nothing will get passed anyway. - if isUnit shape then + if is_unit(shape) then state else - argStr = fmt argId shape index + arg_str = fmt(arg_id, shape, index) - if Str.isEmpty state then - argStr # Don't prepend a comma if this is the first one + if Str.is_empty(state) then + arg_str # Don't prepend a comma if this is the first one else state - |> Str.concat ", " - |> Str.concat argStr + |> Str.concat(", ") + |> Str.concat(arg_str)) diff --git a/crates/glue/src/ZigGlue.roc b/crates/glue/src/ZigGlue.roc index bf5dc23cb91..ef85ebece37 100644 --- a/crates/glue/src/ZigGlue.roc +++ b/crates/glue/src/ZigGlue.roc @@ -1,28 +1,28 @@ -app [makeGlue] { pf: platform "../platform/main.roc" } +app [make_glue] { pf: platform "../platform/main.roc" } import pf.Types exposing [Types] import pf.File exposing [File] -import "../../compiler/builtins/bitcode/src/list.zig" as rocStdList : Str -import "../../compiler/builtins/bitcode/src/str.zig" as rocStdStr : Str -import "../../compiler/builtins/bitcode/src/utils.zig" as rocStdUtils : Str +import "../../compiler/builtins/bitcode/src/list.zig" as roc_std_list : Str +import "../../compiler/builtins/bitcode/src/str.zig" as roc_std_str : Str +import "../../compiler/builtins/bitcode/src/utils.zig" as roc_std_utils : Str -makeGlue : List Types -> Result (List File) Str -makeGlue = \typesByArch -> - typesByArch - |> List.map convertTypesToFile - |> List.concat staticFiles +make_glue : List Types -> Result (List File) Str +make_glue = \types_by_arch -> + types_by_arch + |> List.map(convert_types_to_file) + |> List.concat(static_files) |> Ok ## These are always included, and don't depend on the specifics of the app. -staticFiles : List File -staticFiles = [ - { name: "list.zig", content: rocStdList }, - { name: "str.zig", content: rocStdStr }, - { name: "utils.zig", content: rocStdUtils }, +static_files : List File +static_files = [ + { name: "list.zig", content: roc_std_list }, + { name: "str.zig", content: roc_std_str }, + { name: "utils.zig", content: roc_std_utils }, ] -convertTypesToFile : Types -> File -convertTypesToFile = \_ -> { name: "main.zig", content } +convert_types_to_file : Types -> File +convert_types_to_file = \_ -> { name: "main.zig", content } content = """ diff --git a/crates/glue/src/glue.rs b/crates/glue/src/glue.rs index 34a1f2d8855..e64e2dc054f 100644 --- a/crates/glue/src/glue.rs +++ b/crates/glue/src/glue.rs @@ -24,7 +24,7 @@ pub struct Types { pub deps: roc_std::RocDict>, pub sizes: roc_std::RocList, pub types: roc_std::RocList, - pub typesByName: roc_std::RocDict, + pub types_by_name: roc_std::RocDict, pub target: Target, } @@ -163,7 +163,7 @@ pub struct R3 { #[repr(C)] pub struct Target { pub architecture: Architecture, - pub operatingSystem: OperatingSystem, + pub operating_system: OperatingSystem, } #[cfg(any( @@ -289,16 +289,16 @@ pub union RocTagUnion { #[repr(C)] pub struct R13 { pub name: roc_std::RocStr, - pub payloadFields: roc_std::RocList, - pub tagName: roc_std::RocStr, + pub payload_fields: roc_std::RocList, + pub tag_name: roc_std::RocStr, } #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] #[derive(Clone, Debug, Eq, Ord, Hash, PartialEq, PartialOrd)] #[repr(C)] pub struct R11 { - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, pub name: roc_std::RocStr, pub tags: roc_std::RocList, } @@ -337,11 +337,11 @@ pub union U4 { #[derive(Clone, Debug, Eq, Ord, Hash, PartialEq, PartialOrd)] #[repr(C)] pub struct R9 { - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub indexOfNullTag: u16, + pub index_of_null_tag: u16, } #[cfg(any( @@ -379,10 +379,10 @@ pub union U3 { #[repr(C)] pub struct R8 { pub name: roc_std::RocStr, - pub nonNullPayload: u32, - pub nonNullTag: roc_std::RocStr, - pub nullTag: roc_std::RocStr, - pub whichTagIsNull: U2, + pub non_null_payload: u32, + pub non_null_tag: roc_std::RocStr, + pub null_tag: roc_std::RocStr, + pub which_tag_is_null: U2, } #[cfg(any( @@ -412,8 +412,8 @@ impl core::fmt::Debug for U2 { #[derive(Clone, Debug, Eq, Ord, Hash, PartialEq, PartialOrd)] #[repr(C)] pub struct R6 { - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, pub name: roc_std::RocStr, pub tags: roc_std::RocList, } @@ -454,7 +454,7 @@ pub union U1 { pub struct R5 { pub name: roc_std::RocStr, pub payload: u32, - pub tagName: roc_std::RocStr, + pub tag_name: roc_std::RocStr, } #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] @@ -558,7 +558,7 @@ pub struct Types { pub deps: roc_std::RocDict>, pub sizes: roc_std::RocList, pub types: roc_std::RocList, - pub typesByName: roc_std::RocDict, + pub types_by_name: roc_std::RocDict, pub target: Target, } @@ -613,8 +613,8 @@ pub union RocTagUnion { #[repr(C)] pub struct R13 { pub name: roc_std::RocStr, - pub payloadFields: roc_std::RocList, - pub tagName: roc_std::RocStr, + pub payload_fields: roc_std::RocList, + pub tag_name: roc_std::RocStr, } #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] @@ -623,8 +623,8 @@ pub struct R13 { pub struct R11 { pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, } #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] @@ -640,9 +640,9 @@ pub union U4 { pub struct R9 { pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub discriminantOffset: u32, - pub discriminantSize: u32, - pub indexOfNullTag: u16, + pub discriminant_offset: u32, + pub discriminant_size: u32, + pub index_of_null_tag: u16, } #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] @@ -657,10 +657,10 @@ pub union U3 { #[repr(C)] pub struct R8 { pub name: roc_std::RocStr, - pub nonNullPayload: u64, - pub nonNullTag: roc_std::RocStr, - pub nullTag: roc_std::RocStr, - pub whichTagIsNull: U2, + pub non_null_payload: u64, + pub non_null_tag: roc_std::RocStr, + pub null_tag: roc_std::RocStr, + pub which_tag_is_null: U2, } #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] @@ -669,8 +669,8 @@ pub struct R8 { pub struct R6 { pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, } #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] @@ -686,7 +686,7 @@ pub union U1 { pub struct R5 { pub name: roc_std::RocStr, pub payload: u64, - pub tagName: roc_std::RocStr, + pub tag_name: roc_std::RocStr, } #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] diff --git a/crates/glue/src/load.rs b/crates/glue/src/load.rs index 8891e31ef25..4401a04b75d 100644 --- a/crates/glue/src/load.rs +++ b/crates/glue/src/load.rs @@ -247,11 +247,11 @@ fn call_roc_make_glue( &roc_std::RocList, ); - let name_of_main = "roc__makeGlueForHost_1_exposed_generic"; + let name_of_main = "roc__make_glue_for_host_1_exposed_generic"; let make_glue: libloading::Symbol = unsafe { lib.get(name_of_main.as_bytes()) - .unwrap_or_else(|_| panic!("Unable to load glue function")) + .unwrap_or_else(|_| panic!("Unable to load glue function: {lib:?}")) }; let mut files = RocCallResult::new(roc_std::RocResult::err(roc_std::RocStr::empty())); unsafe { make_glue(&mut files, &roc_types) }; diff --git a/crates/glue/src/roc_type/mod.rs b/crates/glue/src/roc_type/mod.rs index 96deeb18891..02b45efa36a 100644 --- a/crates/glue/src/roc_type/mod.rs +++ b/crates/glue/src/roc_type/mod.rs @@ -65,7 +65,7 @@ pub struct Types { pub entrypoints: roc_std::RocList, pub sizes: roc_std::RocList, pub types: roc_std::RocList, - pub typesByName: roc_std::RocList, + pub types_by_name: roc_std::RocList, pub target: Target, } @@ -76,7 +76,7 @@ impl RocRefcounted for Types { self.entrypoints.inc(); self.sizes.inc(); self.types.inc(); - self.typesByName.inc(); + self.types_by_name.inc(); self.target.inc(); } @@ -86,7 +86,7 @@ impl RocRefcounted for Types { self.entrypoints.dec(); self.sizes.dec(); self.types.dec(); - self.typesByName.dec(); + self.types_by_name.dec(); self.target.dec(); } @@ -242,7 +242,7 @@ pub struct Tuple2 { #[repr(C)] pub struct Target { pub architecture: Architecture, - pub operatingSystem: OperatingSystem, + pub operating_system: OperatingSystem, } roc_refcounted_noop_impl!(Target); @@ -364,20 +364,20 @@ pub union RocTagUnion { pub struct R14 { pub name: roc_std::RocStr, pub payload: RocSingleTagPayload, - pub tagName: roc_std::RocStr, + pub tag_name: roc_std::RocStr, } impl RocRefcounted for R14 { fn inc(&mut self) { self.name.inc(); self.payload.inc(); - self.tagName.inc(); + self.tag_name.inc(); } fn dec(&mut self) { self.name.dec(); self.payload.dec(); - self.tagName.dec(); + self.tag_name.dec(); } fn is_refcounted() -> bool { @@ -454,11 +454,11 @@ impl RocRefcounted for RocSingleTagPayload { #[derive(Clone, Debug, Eq, Ord, Hash, PartialEq, PartialOrd)] #[repr(C)] pub struct R10 { - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub indexOfNullTag: u16, + pub index_of_null_tag: u16, } #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] @@ -466,10 +466,10 @@ pub struct R10 { #[repr(C)] pub struct R9 { pub name: roc_std::RocStr, - pub nonNullPayload: u32, - pub nonNullTag: roc_std::RocStr, - pub nullTag: roc_std::RocStr, - pub whichTagIsNull: U2, + pub non_null_payload: u32, + pub non_null_tag: roc_std::RocStr, + pub null_tag: roc_std::RocStr, + pub which_tag_is_null: U2, } #[cfg(any( @@ -499,8 +499,8 @@ impl core::fmt::Debug for U2 { #[derive(Clone, Debug, Eq, Ord, Hash, PartialEq, PartialOrd)] #[repr(C)] pub struct R7 { - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, pub name: roc_std::RocStr, pub tags: roc_std::RocList, } @@ -541,7 +541,7 @@ pub union U1 { pub struct R6 { pub name: roc_std::RocStr, pub payload: u32, - pub tagName: roc_std::RocStr, + pub tag_name: roc_std::RocStr, } #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] @@ -730,9 +730,9 @@ impl core::fmt::Debug for RocNum { #[repr(C)] pub struct RocFn { pub args: roc_std::RocList, - pub externName: roc_std::RocStr, - pub functionName: roc_std::RocStr, - pub lambdaSet: u32, + pub extern_name: roc_std::RocStr, + pub function_name: roc_std::RocStr, + pub lambda_set: u32, pub ret: u32, pub is_toplevel: bool, } @@ -967,9 +967,9 @@ impl RocRefcounted for RocTagUnion { pub struct R10 { pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub discriminantOffset: u32, - pub discriminantSize: u32, - pub indexOfNullTag: u16, + pub discriminant_offset: u32, + pub discriminant_size: u32, + pub index_of_null_tag: u16, } impl RocRefcounted for R10 { @@ -993,23 +993,23 @@ impl RocRefcounted for R10 { #[repr(C)] pub struct R9 { pub name: roc_std::RocStr, - pub nonNullPayload: u64, - pub nonNullTag: roc_std::RocStr, - pub nullTag: roc_std::RocStr, - pub whichTagIsNull: U2, + pub non_null_payload: u64, + pub non_null_tag: roc_std::RocStr, + pub null_tag: roc_std::RocStr, + pub which_tag_is_null: U2, } impl RocRefcounted for R9 { fn inc(&mut self) { self.name.inc(); - self.nonNullTag.inc(); - self.nullTag.inc(); + self.non_null_tag.inc(); + self.null_tag.inc(); } fn dec(&mut self) { self.name.dec(); - self.nonNullTag.dec(); - self.nullTag.dec(); + self.non_null_tag.dec(); + self.null_tag.dec(); } fn is_refcounted() -> bool { @@ -1023,8 +1023,8 @@ impl RocRefcounted for R9 { pub struct R7 { pub name: roc_std::RocStr, pub tags: roc_std::RocList, - pub discriminantOffset: u32, - pub discriminantSize: u32, + pub discriminant_offset: u32, + pub discriminant_size: u32, } impl RocRefcounted for R7 { @@ -1056,18 +1056,18 @@ pub union U1 { pub struct R6 { pub name: roc_std::RocStr, pub payload: u64, - pub tagName: roc_std::RocStr, + pub tag_name: roc_std::RocStr, } impl RocRefcounted for R6 { fn inc(&mut self) { self.name.inc(); - self.tagName.inc(); + self.tag_name.inc(); } fn dec(&mut self) { self.name.dec(); - self.tagName.dec(); + self.tag_name.dec(); } fn is_refcounted() -> bool { @@ -1114,24 +1114,24 @@ roc_refcounted_noop_impl!(RocType_RocDict); #[repr(C)] pub struct RocFn { pub args: roc_std::RocList, - pub externName: roc_std::RocStr, - pub functionName: roc_std::RocStr, - pub lambdaSet: u64, + pub extern_name: roc_std::RocStr, + pub function_name: roc_std::RocStr, + pub lambda_set: u64, pub ret: u64, - pub isToplevel: bool, + pub is_toplevel: bool, } impl RocRefcounted for RocFn { fn inc(&mut self) { self.args.inc(); - self.externName.inc(); - self.functionName.inc(); + self.extern_name.inc(); + self.function_name.inc(); } fn dec(&mut self) { self.args.dec(); - self.externName.dec(); - self.functionName.dec(); + self.extern_name.dec(); + self.function_name.dec(); } fn is_refcounted() -> bool { diff --git a/crates/glue/src/types.rs b/crates/glue/src/types.rs index 2ec9b13d521..1ad014ad18d 100644 --- a/crates/glue/src/types.rs +++ b/crates/glue/src/types.rs @@ -669,7 +669,7 @@ impl From<&Types> for roc_type::Types { entrypoints, sizes: types.sizes.as_slice().into(), types: types.types.iter().map(roc_type::RocType::from).collect(), - typesByName: types_by_name, + types_by_name, target: types.target.into(), } } @@ -708,11 +708,11 @@ impl From<&RocType> for roc_type::RocType { is_toplevel, }) => roc_type::RocType::Function(roc_type::RocFn { args: args.iter().map(|arg| arg.0 as _).collect(), - functionName: function_name.as_str().into(), - externName: extern_name.as_str().into(), + function_name: function_name.as_str().into(), + extern_name: extern_name.as_str().into(), ret: ret.0 as _, - lambdaSet: lambda_set.0 as _, - isToplevel: *is_toplevel, + lambda_set: lambda_set.0 as _, + is_toplevel: *is_toplevel, }), RocType::Unit => roc_type::RocType::Unit, RocType::Unsized => roc_type::RocType::Unsized, @@ -764,8 +764,8 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { payload: payload.into(), }) .collect(), - discriminantSize: *discriminant_size, - discriminantOffset: *discriminant_offset, + discriminant_size: *discriminant_size, + discriminant_offset: *discriminant_offset, }), RocTagUnion::Recursive { name, @@ -781,8 +781,8 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { payload: payload.into(), }) .collect(), - discriminantSize: *discriminant_size, - discriminantOffset: *discriminant_offset, + discriminant_size: *discriminant_size, + discriminant_offset: *discriminant_offset, }), RocTagUnion::NonNullableUnwrapped { name, @@ -790,7 +790,7 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { payload, } => roc_type::RocTagUnion::NonNullableUnwrapped(roc_type::R6 { name: name.as_str().into(), - tagName: tag_name.as_str().into(), + tag_name: tag_name.as_str().into(), payload: payload.0 as _, }), RocTagUnion::SingleTagStruct { @@ -799,7 +799,7 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { payload, } => roc_type::RocTagUnion::SingleTagStruct(roc_type::R14 { name: name.as_str().into(), - tagName: tag_name.as_str().into(), + tag_name: tag_name.as_str().into(), payload: payload.into(), }), RocTagUnion::NullableWrapped { @@ -810,7 +810,7 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { discriminant_offset, } => roc_type::RocTagUnion::NullableWrapped(roc_type::R10 { name: name.as_str().into(), - indexOfNullTag: *index_of_null_tag, + index_of_null_tag: *index_of_null_tag, tags: tags .iter() .map(|(name, payload)| roc_type::R8 { @@ -818,8 +818,8 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { payload: payload.into(), }) .collect(), - discriminantSize: *discriminant_size, - discriminantOffset: *discriminant_offset, + discriminant_size: *discriminant_size, + discriminant_offset: *discriminant_offset, }), RocTagUnion::NullableUnwrapped { name, @@ -829,10 +829,10 @@ impl From<&RocTagUnion> for roc_type::RocTagUnion { null_represents_first_tag, } => roc_type::RocTagUnion::NullableUnwrapped(roc_type::R9 { name: name.as_str().into(), - nonNullPayload: non_null_payload.0 as _, - nonNullTag: non_null_tag.as_str().into(), - nullTag: null_tag.as_str().into(), - whichTagIsNull: if *null_represents_first_tag { + non_null_payload: non_null_payload.0 as _, + non_null_tag: non_null_tag.as_str().into(), + null_tag: null_tag.as_str().into(), + which_tag_is_null: if *null_represents_first_tag { roc_type::U2::FirstTagIsNull } else { roc_type::U2::SecondTagIsNull @@ -909,7 +909,7 @@ impl From for roc_type::Target { fn from(target: Target) -> Self { roc_type::Target { architecture: target.architecture().into(), - operatingSystem: target.operating_system().into(), + operating_system: target.operating_system().into(), } } } @@ -1269,7 +1269,7 @@ fn add_function_type<'a>( let name = format!("RocFunction_{closure_var:?}"); let extern_name = match env.lambda_set_ids.get(&closure_var) { - Some(id) => format!("roc__mainForHost_{}_caller", id.0), + Some(id) => format!("roc__main_for_host_{}_caller", id.0), None => { debug_assert!(is_toplevel); String::from("this_extern_should_not_be_used_this_is_a_bug") diff --git a/crates/glue/tests/fixtures/c/hello-world/host.c b/crates/glue/tests/fixtures/c/hello-world/host.c index cc2343ef47f..6d070f9532c 100644 --- a/crates/glue/tests/fixtures/c/hello-world/host.c +++ b/crates/glue/tests/fixtures/c/hello-world/host.c @@ -6,9 +6,9 @@ int main(void) { - uint8_t mainForHost = roc_mainForHost(); + uint8_t main_for_host = roc_main_for_host(); - printf("mainForHost = %i\n", mainForHost); + printf("main_for_host = %i\n", main_for_host); - assert(mainForHost == 42); + assert(main_for_host == 42); } \ No newline at end of file diff --git a/crates/glue/tests/fixtures/c/hello-world/platform.roc b/crates/glue/tests/fixtures/c/hello-world/platform.roc index bfc3a5bad49..db519c12ba3 100644 --- a/crates/glue/tests/fixtures/c/hello-world/platform.roc +++ b/crates/glue/tests/fixtures/c/hello-world/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : U8 -mainForHost = main +main_for_host : U8 +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/advanced-recursive-union/app.roc b/crates/glue/tests/fixtures/rust/advanced-recursive-union/app.roc index 9ba7529b68d..f1e9137f313 100644 --- a/crates/glue/tests/fixtures/rust/advanced-recursive-union/app.roc +++ b/crates/glue/tests/fixtures/rust/advanced-recursive-union/app.roc @@ -1,11 +1,11 @@ app [main] { pf: platform "platform.roc" } main = { - default: Job { - command: Command { - tool: SystemTool { name: "test", num: 42 }, - }, - inputFiles: ["foo"], - }, + default: Job({ + command: Command({ + tool: SystemTool({ name: "test", num: 42 }), + }), + input_files: ["foo"], + }), } diff --git a/crates/glue/tests/fixtures/rust/advanced-recursive-union/platform.roc b/crates/glue/tests/fixtures/rust/advanced-recursive-union/platform.roc index 06b43a6dc9d..f957fee1c82 100644 --- a/crates/glue/tests/fixtures/rust/advanced-recursive-union/platform.roc +++ b/crates/glue/tests/fixtures/rust/advanced-recursive-union/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] Tool : [ SystemTool { name : Str, num : U32 }, @@ -13,7 +13,7 @@ Tool : [ Command : [Command { tool : Tool }] Job : [ - Job { command : Command, inputFiles : List Str }, + Job { command : Command, input_files : List Str }, Foo Str, # TODO make a recursive tag union test that doesn't try to do mutual recursion, # just so I can get a PR up. @@ -22,5 +22,5 @@ Job : [ Rbt : { default : Job } -mainForHost : {} -> Rbt -mainForHost = \{} -> main +main_for_host : {} -> Rbt +main_for_host = \{} -> main diff --git a/crates/glue/tests/fixtures/rust/advanced-recursive-union/src/lib.rs b/crates/glue/tests/fixtures/rust/advanced-recursive-union/src/lib.rs index bb9660783e9..ee089a004a4 100644 --- a/crates/glue/tests/fixtures/rust/advanced-recursive-union/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/advanced-recursive-union/src/lib.rs @@ -10,7 +10,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/arguments/platform.roc b/crates/glue/tests/fixtures/rust/arguments/platform.roc index b4cfc05570b..ca036a7878f 100644 --- a/crates/glue/tests/fixtures/rust/arguments/platform.roc +++ b/crates/glue/tests/fixtures/rust/arguments/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : I64 -> I64 -mainForHost = \x -> main x +main_for_host : I64 -> I64 +main_for_host = \x -> main(x) diff --git a/crates/glue/tests/fixtures/rust/arguments/src/lib.rs b/crates/glue/tests/fixtures/rust/arguments/src/lib.rs index 3f8b31edd29..e3206a26854 100644 --- a/crates/glue/tests/fixtures/rust/arguments/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/arguments/src/lib.rs @@ -3,7 +3,7 @@ use roc_std::RocStr; #[no_mangle] pub extern "C" fn rust_main() { - let answer = roc_app::mainForHost(42i64); + let answer = roc_app::main_for_host(42i64); init(); diff --git a/crates/glue/tests/fixtures/rust/basic-record/platform.roc b/crates/glue/tests/fixtures/rust/basic-record/platform.roc index 12466b50bca..2291914615d 100644 --- a/crates/glue/tests/fixtures/rust/basic-record/platform.roc +++ b/crates/glue/tests/fixtures/rust/basic-record/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] MyRcd : { a : U64, b : U128 } -mainForHost : MyRcd -mainForHost = main +main_for_host : MyRcd +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/basic-record/src/lib.rs b/crates/glue/tests/fixtures/rust/basic-record/src/lib.rs index 9ed84a80485..de04edaafba 100644 --- a/crates/glue/tests/fixtures/rust/basic-record/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/basic-record/src/lib.rs @@ -8,7 +8,7 @@ pub extern "C" fn rust_main() { init(); - let record = roc_app::mainForHost(); + let record = roc_app::main_for_host(); // Verify that the record has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/basic-recursive-union/app.roc b/crates/glue/tests/fixtures/rust/basic-recursive-union/app.roc index bf26d2ec032..7451fbabe02 100644 --- a/crates/glue/tests/fixtures/rust/basic-recursive-union/app.roc +++ b/crates/glue/tests/fixtures/rust/basic-recursive-union/app.roc @@ -1,3 +1,3 @@ app [main] { pf: platform "platform.roc" } -main = Concat (String "Hello, ") (String "World!") +main = Concat(String("Hello, "), String("World!")) diff --git a/crates/glue/tests/fixtures/rust/basic-recursive-union/platform.roc b/crates/glue/tests/fixtures/rust/basic-recursive-union/platform.roc index 2816c4ba72e..861e6b4b96c 100644 --- a/crates/glue/tests/fixtures/rust/basic-recursive-union/platform.roc +++ b/crates/glue/tests/fixtures/rust/basic-recursive-union/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] Expr : [String Str, Concat Expr Expr] -mainForHost : {} -> Expr -mainForHost = \{} -> main +main_for_host : {} -> Expr +main_for_host = \{} -> main diff --git a/crates/glue/tests/fixtures/rust/basic-recursive-union/src/lib.rs b/crates/glue/tests/fixtures/rust/basic-recursive-union/src/lib.rs index 2492ef4213a..44d84939da0 100644 --- a/crates/glue/tests/fixtures/rust/basic-recursive-union/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/basic-recursive-union/src/lib.rs @@ -9,7 +9,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/closures/platform.roc b/crates/glue/tests/fixtures/rust/closures/platform.roc index d00c64de206..9d74d98bbdd 100644 --- a/crates/glue/tests/fixtures/rust/closures/platform.roc +++ b/crates/glue/tests/fixtures/rust/closures/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : I64 -> ({} -> I64) -mainForHost = \x -> main x +main_for_host : I64 -> ({} -> I64) +main_for_host = \x -> main(x) diff --git a/crates/glue/tests/fixtures/rust/closures/src/lib.rs b/crates/glue/tests/fixtures/rust/closures/src/lib.rs index 7dc784be364..08c00197661 100644 --- a/crates/glue/tests/fixtures/rust/closures/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/closures/src/lib.rs @@ -3,7 +3,7 @@ use roc_std::RocStr; #[no_mangle] pub extern "C" fn rust_main() { - let closure = roc_app::mainForHost(42i64); + let closure = roc_app::main_for_host(42i64); init(); diff --git a/crates/glue/tests/fixtures/rust/enumeration/platform.roc b/crates/glue/tests/fixtures/rust/enumeration/platform.roc index ba4b90b610f..1f7b8e58884 100644 --- a/crates/glue/tests/fixtures/rust/enumeration/platform.roc +++ b/crates/glue/tests/fixtures/rust/enumeration/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] MyEnum : [Foo, Bar, Baz] -mainForHost : MyEnum -mainForHost = main +main_for_host : MyEnum +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/enumeration/src/lib.rs b/crates/glue/tests/fixtures/rust/enumeration/src/lib.rs index aee5f45e497..78f4e93663d 100644 --- a/crates/glue/tests/fixtures/rust/enumeration/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/enumeration/src/lib.rs @@ -8,7 +8,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/list-recursive-union/app.roc b/crates/glue/tests/fixtures/rust/list-recursive-union/app.roc index baa81e8172c..b9c4446d82f 100644 --- a/crates/glue/tests/fixtures/rust/list-recursive-union/app.roc +++ b/crates/glue/tests/fixtures/rust/list-recursive-union/app.roc @@ -1,13 +1,13 @@ app [main] { pf: platform "platform.roc" } main = { - default: Job { - command: Command { - tool: SystemTool { name: "test" }, + default: Job({ + command: Command({ + tool: SystemTool({ name: "test" }), args: [], - }, + }), job: [], - inputFiles: ["foo"], - }, + input_files: ["foo"], + }), } diff --git a/crates/glue/tests/fixtures/rust/list-recursive-union/platform.roc b/crates/glue/tests/fixtures/rust/list-recursive-union/platform.roc index b248ccc6f11..3de676309d1 100644 --- a/crates/glue/tests/fixtures/rust/list-recursive-union/platform.roc +++ b/crates/glue/tests/fixtures/rust/list-recursive-union/platform.roc @@ -3,15 +3,15 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] Tool : [SystemTool { name : Str }] Command : [Command { tool : Tool, args : List Str }] -Job : [Job { command : Command, job : List Job, inputFiles : List Str }, Blah Str] +Job : [Job { command : Command, job : List Job, input_files : List Str }, Blah Str] Rbt : { default : Job } -mainForHost : Rbt -mainForHost = main +main_for_host : Rbt +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/list-recursive-union/src/lib.rs b/crates/glue/tests/fixtures/rust/list-recursive-union/src/lib.rs index e18174bfb93..a1b2ed4ac1c 100644 --- a/crates/glue/tests/fixtures/rust/list-recursive-union/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/list-recursive-union/src/lib.rs @@ -11,7 +11,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/multiple-modules/Dep1.roc b/crates/glue/tests/fixtures/rust/multiple-modules/Dep1.roc index 291dfd66ac7..4f9e98832da 100644 --- a/crates/glue/tests/fixtures/rust/multiple-modules/Dep1.roc +++ b/crates/glue/tests/fixtures/rust/multiple-modules/Dep1.roc @@ -1,5 +1,5 @@ -interface Dep1 exposes [DepStr1, string] imports [] +module [DepStr1, string] DepStr1 := [S Str] -string = \s -> @DepStr1 (S s) +string = \s -> @DepStr1(S(s)) diff --git a/crates/glue/tests/fixtures/rust/multiple-modules/Dep2.roc b/crates/glue/tests/fixtures/rust/multiple-modules/Dep2.roc index 99f00e08c16..2b5d5deee05 100644 --- a/crates/glue/tests/fixtures/rust/multiple-modules/Dep2.roc +++ b/crates/glue/tests/fixtures/rust/multiple-modules/Dep2.roc @@ -1,5 +1,5 @@ -interface Dep2 exposes [DepStr2, string] imports [] +module [DepStr2, string] DepStr2 := [R Str] -string = \s -> @DepStr2 (R s) +string = \s -> @DepStr2(R(s)) diff --git a/crates/glue/tests/fixtures/rust/multiple-modules/app.roc b/crates/glue/tests/fixtures/rust/multiple-modules/app.roc index 50b7b6ee703..e83bf8bfc10 100644 --- a/crates/glue/tests/fixtures/rust/multiple-modules/app.roc +++ b/crates/glue/tests/fixtures/rust/multiple-modules/app.roc @@ -3,4 +3,4 @@ app [main] { pf: platform "platform.roc" } import pf.Dep1 import pf.Dep2 -main = { s1: Dep1.string "hello", s2: Dep2.string "world" } +main = { s1: Dep1.string("hello"), s2: Dep2.string("world") } diff --git a/crates/glue/tests/fixtures/rust/multiple-modules/platform.roc b/crates/glue/tests/fixtures/rust/multiple-modules/platform.roc index 016bb3fc138..bb0bc187f51 100644 --- a/crates/glue/tests/fixtures/rust/multiple-modules/platform.roc +++ b/crates/glue/tests/fixtures/rust/multiple-modules/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [Dep1, Dep2] - provides [mainForHost] + provides [main_for_host] Combined : { s1 : Dep1.DepStr1, s2 : Dep2.DepStr2 } -mainForHost : Combined -mainForHost = main +main_for_host : Combined +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/multiple-modules/src/lib.rs b/crates/glue/tests/fixtures/rust/multiple-modules/src/lib.rs index 89273a00d81..195299f98e3 100644 --- a/crates/glue/tests/fixtures/rust/multiple-modules/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/multiple-modules/src/lib.rs @@ -9,7 +9,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/nested-record/platform.roc b/crates/glue/tests/fixtures/rust/nested-record/platform.roc index 90c0b2b769b..ce4e869a819 100644 --- a/crates/glue/tests/fixtures/rust/nested-record/platform.roc +++ b/crates/glue/tests/fixtures/rust/nested-record/platform.roc @@ -3,11 +3,11 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] Outer : { x : Inner, y : Str, z : List U8 } Inner : { a : U16, b : F32 } -mainForHost : Outer -mainForHost = main +main_for_host : Outer +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/nested-record/src/lib.rs b/crates/glue/tests/fixtures/rust/nested-record/src/lib.rs index d92c175ce22..b84eff83d53 100644 --- a/crates/glue/tests/fixtures/rust/nested-record/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/nested-record/src/lib.rs @@ -7,7 +7,7 @@ pub extern "C" fn rust_main() { init(); - let outer = roc_app::mainForHost(); + let outer = roc_app::main_for_host(); // Verify that `inner` has all the expected traits. { diff --git a/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/app.roc b/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/app.roc index 530d8799107..66cdea1f119 100644 --- a/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/app.roc +++ b/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/app.roc @@ -1,3 +1,3 @@ app [main] { pf: platform "platform.roc" } -main = Tree "root" [Tree "leaf1" [], Tree "leaf2" []] +main = Tree("root", [Tree("leaf1", []), Tree("leaf2", [])]) diff --git a/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/platform.roc b/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/platform.roc index 6765fbf5258..cd9f595951f 100644 --- a/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/platform.roc +++ b/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] StrRoseTree : [Tree Str (List StrRoseTree)] -mainForHost : StrRoseTree -mainForHost = main +main_for_host : StrRoseTree +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/src/lib.rs b/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/src/lib.rs index a84fb47ae3f..9a89c165878 100644 --- a/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/nonnullable-unwrapped/src/lib.rs @@ -5,7 +5,7 @@ use roc_app::StrRoseTree; use roc_std::{RocList, RocStr}; extern "C" { - #[link_name = "roc__mainForHost_1_exposed_generic"] + #[link_name = "roc__main_for_host_1_exposed_generic"] fn roc_main(_: *mut StrRoseTree); } diff --git a/crates/glue/tests/fixtures/rust/nullable-unwrapped/app.roc b/crates/glue/tests/fixtures/rust/nullable-unwrapped/app.roc index b76da9e4f50..5a12077575f 100644 --- a/crates/glue/tests/fixtures/rust/nullable-unwrapped/app.roc +++ b/crates/glue/tests/fixtures/rust/nullable-unwrapped/app.roc @@ -1,3 +1,3 @@ app [main] { pf: platform "platform.roc" } -main = Cons "World!" (Cons "Hello " Nil) +main = Cons("World!", Cons("Hello ", Nil)) diff --git a/crates/glue/tests/fixtures/rust/nullable-unwrapped/platform.roc b/crates/glue/tests/fixtures/rust/nullable-unwrapped/platform.roc index 13992876507..2bb373dbe7e 100644 --- a/crates/glue/tests/fixtures/rust/nullable-unwrapped/platform.roc +++ b/crates/glue/tests/fixtures/rust/nullable-unwrapped/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] StrConsList : [Nil, Cons Str StrConsList] -mainForHost : StrConsList -mainForHost = main +main_for_host : StrConsList +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/nullable-unwrapped/src/lib.rs b/crates/glue/tests/fixtures/rust/nullable-unwrapped/src/lib.rs index 93adb3146b9..9b049c31973 100644 --- a/crates/glue/tests/fixtures/rust/nullable-unwrapped/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/nullable-unwrapped/src/lib.rs @@ -11,7 +11,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/nullable-wrapped/app.roc b/crates/glue/tests/fixtures/rust/nullable-wrapped/app.roc index a240679aaec..561fd952b27 100644 --- a/crates/glue/tests/fixtures/rust/nullable-wrapped/app.roc +++ b/crates/glue/tests/fixtures/rust/nullable-wrapped/app.roc @@ -1,3 +1,3 @@ app [main] { pf: platform "platform.roc" } -main = More "foo" (More "bar" Empty) +main = More("foo", More("bar", Empty)) diff --git a/crates/glue/tests/fixtures/rust/nullable-wrapped/platform.roc b/crates/glue/tests/fixtures/rust/nullable-wrapped/platform.roc index dc3d2283c30..a689b0c1c47 100644 --- a/crates/glue/tests/fixtures/rust/nullable-wrapped/platform.roc +++ b/crates/glue/tests/fixtures/rust/nullable-wrapped/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] StrFingerTree : [Empty, Single Str, More Str StrFingerTree] -mainForHost : {} -> StrFingerTree -mainForHost = \{} -> main +main_for_host : {} -> StrFingerTree +main_for_host = \{} -> main diff --git a/crates/glue/tests/fixtures/rust/nullable-wrapped/src/lib.rs b/crates/glue/tests/fixtures/rust/nullable-wrapped/src/lib.rs index f69df0a4e09..13657d67657 100644 --- a/crates/glue/tests/fixtures/rust/nullable-wrapped/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/nullable-wrapped/src/lib.rs @@ -5,7 +5,7 @@ use roc_app::StrFingerTree; use roc_std::RocStr; extern "C" { - #[link_name = "roc__mainForHost_1_exposed_generic"] + #[link_name = "roc__main_for_host_1_exposed_generic"] fn roc_main(_: *mut StrFingerTree); } @@ -16,7 +16,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Eq assert!(StrFingerTree::Empty() == StrFingerTree::Empty()); diff --git a/crates/glue/tests/fixtures/rust/option/app.roc b/crates/glue/tests/fixtures/rust/option/app.roc index 82b21e996dc..34278512943 100644 --- a/crates/glue/tests/fixtures/rust/option/app.roc +++ b/crates/glue/tests/fixtures/rust/option/app.roc @@ -1,8 +1,8 @@ app [main] { pf: platform "platform.roc" } main : Bool -> [Some Str, None] -main = \returnStr -> - if returnStr then - Some "Hello World!" +main = \return_str -> + if return_str then + Some("Hello World!") else None diff --git a/crates/glue/tests/fixtures/rust/option/platform.roc b/crates/glue/tests/fixtures/rust/option/platform.roc index bfa9a5f9f87..b42ca7bf4b5 100644 --- a/crates/glue/tests/fixtures/rust/option/platform.roc +++ b/crates/glue/tests/fixtures/rust/option/platform.roc @@ -1,9 +1,9 @@ platform "test-platform" - requires {} { main : Bool -> [ Some Str, None ] } + requires {} { main : Bool -> [Some Str, None] } exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Bool -> [ Some Str, None ] -mainForHost = \u -> main u +main_for_host : Bool -> [Some Str, None] +main_for_host = \u -> main(u) diff --git a/crates/glue/tests/fixtures/rust/option/src/lib.rs b/crates/glue/tests/fixtures/rust/option/src/lib.rs index 788cd675705..2a7f79cf60f 100644 --- a/crates/glue/tests/fixtures/rust/option/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/option/src/lib.rs @@ -5,10 +5,10 @@ use roc_std::RocStr; pub extern "C" fn rust_main() { init(); - let string = roc_app::mainForHost(true); + let string = roc_app::main_for_host(true); println!("Answer was: {:?}", string.unwrap_Some()); // Debug // - let integer = roc_app::mainForHost(false); + let integer = roc_app::main_for_host(false); println!("Answer was: {:?}", integer.discriminant()); // Debug } diff --git a/crates/glue/tests/fixtures/rust/rocresult/app.roc b/crates/glue/tests/fixtures/rust/rocresult/app.roc index 0bcc926bee5..19f984a7033 100644 --- a/crates/glue/tests/fixtures/rust/rocresult/app.roc +++ b/crates/glue/tests/fixtures/rust/rocresult/app.roc @@ -1,8 +1,8 @@ app [main] { pf: platform "platform.roc" } main : Bool -> Result Str I32 -main = \returnStr -> - if returnStr then - Ok "Hello World!" +main = \return_str -> + if return_str then + Ok("Hello World!") else - Err 42 + Err(42) diff --git a/crates/glue/tests/fixtures/rust/rocresult/platform.roc b/crates/glue/tests/fixtures/rust/rocresult/platform.roc index bdb6635c382..c1d59fddafb 100644 --- a/crates/glue/tests/fixtures/rust/rocresult/platform.roc +++ b/crates/glue/tests/fixtures/rust/rocresult/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Bool -> Result Str I32 -mainForHost = \u -> main u +main_for_host : Bool -> Result Str I32 +main_for_host = \u -> main(u) diff --git a/crates/glue/tests/fixtures/rust/rocresult/src/lib.rs b/crates/glue/tests/fixtures/rust/rocresult/src/lib.rs index c5eb7d0b919..dcd37f38fae 100644 --- a/crates/glue/tests/fixtures/rust/rocresult/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/rocresult/src/lib.rs @@ -5,10 +5,10 @@ use roc_std::RocStr; pub extern "C" fn rust_main() { init(); - let string = roc_app::mainForHost(true); + let string = roc_app::main_for_host(true); println!("Answer was: {:?}", string); // Debug // - let integer = roc_app::mainForHost(false); + let integer = roc_app::main_for_host(false); println!("Answer was: {:?}", integer); // Debug } diff --git a/crates/glue/tests/fixtures/rust/single-tag-union/platform.roc b/crates/glue/tests/fixtures/rust/single-tag-union/platform.roc index c6c13c5e586..bf335e4e238 100644 --- a/crates/glue/tests/fixtures/rust/single-tag-union/platform.roc +++ b/crates/glue/tests/fixtures/rust/single-tag-union/platform.roc @@ -3,9 +3,9 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] SingleTagUnion : [OneTag] -mainForHost : SingleTagUnion -mainForHost = main +main_for_host : SingleTagUnion +main_for_host = main diff --git a/crates/glue/tests/fixtures/rust/single-tag-union/src/lib.rs b/crates/glue/tests/fixtures/rust/single-tag-union/src/lib.rs index 8d41e9a9ce6..edea3ad0134 100644 --- a/crates/glue/tests/fixtures/rust/single-tag-union/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/single-tag-union/src/lib.rs @@ -11,7 +11,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/union-with-padding/app.roc b/crates/glue/tests/fixtures/rust/union-with-padding/app.roc index 5ad22410b13..1a71f224be6 100644 --- a/crates/glue/tests/fixtures/rust/union-with-padding/app.roc +++ b/crates/glue/tests/fixtures/rust/union-with-padding/app.roc @@ -1,3 +1,3 @@ app [main] { pf: platform "platform.roc" } -main = Foo "This is a test" +main = Foo("This is a test") diff --git a/crates/glue/tests/fixtures/rust/union-with-padding/platform.roc b/crates/glue/tests/fixtures/rust/union-with-padding/platform.roc index ba923679cb4..a55b581e6b1 100644 --- a/crates/glue/tests/fixtures/rust/union-with-padding/platform.roc +++ b/crates/glue/tests/fixtures/rust/union-with-padding/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] # This case is important to test because the U128 # gives the whole struct an alignment of 16, but the @@ -13,5 +13,5 @@ platform "test-platform" # that all variants have. NonRecursive : [Foo Str, Bar U128, Blah I32, Baz] -mainForHost : {} -> NonRecursive -mainForHost = \{} -> main +main_for_host : {} -> NonRecursive +main_for_host = \{} -> main diff --git a/crates/glue/tests/fixtures/rust/union-with-padding/src/lib.rs b/crates/glue/tests/fixtures/rust/union-with-padding/src/lib.rs index 9b04972c17a..6db7f76ade5 100644 --- a/crates/glue/tests/fixtures/rust/union-with-padding/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/union-with-padding/src/lib.rs @@ -4,7 +4,7 @@ use roc_app::NonRecursive; use roc_std::RocStr; extern "C" { - #[link_name = "roc__mainForHost_1_exposed_generic"] + #[link_name = "roc__main_for_host_1_exposed_generic"] fn roc_main(_: *mut NonRecursive); } @@ -15,7 +15,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/fixtures/rust/union-without-padding/app.roc b/crates/glue/tests/fixtures/rust/union-without-padding/app.roc index 5ad22410b13..1a71f224be6 100644 --- a/crates/glue/tests/fixtures/rust/union-without-padding/app.roc +++ b/crates/glue/tests/fixtures/rust/union-without-padding/app.roc @@ -1,3 +1,3 @@ app [main] { pf: platform "platform.roc" } -main = Foo "This is a test" +main = Foo("This is a test") diff --git a/crates/glue/tests/fixtures/rust/union-without-padding/platform.roc b/crates/glue/tests/fixtures/rust/union-without-padding/platform.roc index 35ff29794e2..a490cb82a3c 100644 --- a/crates/glue/tests/fixtures/rust/union-without-padding/platform.roc +++ b/crates/glue/tests/fixtures/rust/union-without-padding/platform.roc @@ -3,7 +3,7 @@ platform "test-platform" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] # This case is important to test because there's no padding # after the largest variant, so the compiler adds an extra u8 @@ -11,5 +11,5 @@ platform "test-platform" # to store the discriminant. We have to generate glue code accordingly! NonRecursive : [Foo Str, Bar I64, Blah I32, Baz] -mainForHost : {} -> NonRecursive -mainForHost = \{} -> main +main_for_host : {} -> NonRecursive +main_for_host = \{} -> main diff --git a/crates/glue/tests/fixtures/rust/union-without-padding/src/lib.rs b/crates/glue/tests/fixtures/rust/union-without-padding/src/lib.rs index 2c49645bcba..ef5d3fdef8f 100644 --- a/crates/glue/tests/fixtures/rust/union-without-padding/src/lib.rs +++ b/crates/glue/tests/fixtures/rust/union-without-padding/src/lib.rs @@ -2,7 +2,7 @@ use roc_app; use roc_std::RocStr; extern "C" { - #[link_name = "roc__mainForHost_1_exposed_generic"] + #[link_name = "roc__main_for_host_1_exposed_generic"] fn roc_main(_: *mut roc_app::NonRecursive); } @@ -13,7 +13,7 @@ pub extern "C" fn rust_main() { init(); - let tag_union = roc_app::mainForHost(); + let tag_union = roc_app::main_for_host(); // Verify that it has all the expected traits. diff --git a/crates/glue/tests/test_glue_cli.rs b/crates/glue/tests/test_glue_cli.rs index 63823ad43e6..5a47237e1a7 100644 --- a/crates/glue/tests/test_glue_cli.rs +++ b/crates/glue/tests/test_glue_cli.rs @@ -140,10 +140,10 @@ mod glue_cli_tests { `String "this is a test"` is: Expr::String("this is a test") "#), rust_advanced_recursive_union:"rust/advanced-recursive-union" => indoc!(r#" - rbt was: Rbt { default: Job::Job(R1 { command: Command::Command(R2 { tool: Tool::SystemTool(R4 { name: "test", num: 42 }) }), inputFiles: ["foo"] }) } + rbt was: Rbt { default: Job::Job(R1 { command: Command::Command(R2 { tool: Tool::SystemTool(R4 { name: "test", num: 42 }) }), input_files: ["foo"] }) } "#), rust_list_recursive_union:"rust/list-recursive-union" => indoc!(r#" - rbt was: Rbt { default: Job::Job(R1 { command: Command::Command(R2 { args: [], tool: Tool::SystemTool(R3 { name: "test" }) }), inputFiles: ["foo"], job: [] }) } + rbt was: Rbt { default: Job::Job(R1 { command: Command::Command(R2 { args: [], tool: Tool::SystemTool(R3 { name: "test" }) }), input_files: ["foo"], job: [] }) } "#), rust_multiple_modules:"rust/multiple-modules" => indoc!(r#" combined was: Combined { s1: DepStr1::S("hello"), s2: DepStr2::R("world") } @@ -167,7 +167,7 @@ mod glue_cli_tests { Answer was: discriminant_U1::None "#), c_hello_world:"c/hello-world" => indoc!(r#" - mainForHost = 42 + main_for_host = 42 "#), } @@ -233,6 +233,7 @@ mod glue_cli_tests { if glue_dir.exists() { std::fs::remove_dir_all(&glue_dir) .expect("Unable to remove test_glue dir in order to regenerate it in the test"); + // std::fs::create_dir(&glue_dir) } let glue_spec_filename = match fixtures_subfolder_name.to_str().unwrap() { @@ -242,6 +243,8 @@ mod glue_cli_tests { unknown_subfolder => panic!("I don't know which glue file to use for tests in the `{}` subfolder! Please add one here!", unknown_subfolder), }; + println!("here"); + let rust_glue_spec = tests_dir .parent() .unwrap() diff --git a/crates/linker/src/macho.rs b/crates/linker/src/macho.rs index 4aad845d270..cc884ebaa9c 100644 --- a/crates/linker/src/macho.rs +++ b/crates/linker/src/macho.rs @@ -418,7 +418,7 @@ pub(crate) fn preprocess_macho_le( ); // Find all the lazily-bound roc symbols - // (e.g. "_roc__mainForHost_1_exposed") + // (e.g. "_roc__main_for_host_1_exposed") // For Macho, we may need to deal with some GOT stuff here as well. for (i, symbol) in lazy_bind_symbols .skip(stubs_symbol_index as usize) diff --git a/crates/repl_eval/src/eval.rs b/crates/repl_eval/src/eval.rs index 8343346308d..cc853c7f527 100644 --- a/crates/repl_eval/src/eval.rs +++ b/crates/repl_eval/src/eval.rs @@ -1501,12 +1501,12 @@ fn f64_literal_to_ast(arena: &Bump, num: f64) -> Expr<'_> { use std::fmt::Write; if num.is_nan() { - Expr::Num("Num.nanF64") + Expr::Num("Num.nan_f64") } else if num.is_infinite() { if num.is_sign_positive() { - Expr::Num("Num.infinityF64") + Expr::Num("Num.infinity_f64") } else { - Expr::Num("-Num.infinityF64") + Expr::Num("-Num.infinity_f64") } } else { let mut string = bumpalo::collections::String::with_capacity_in(64, arena); @@ -1519,12 +1519,12 @@ fn f32_literal_to_ast(arena: &Bump, num: f32) -> Expr<'_> { use std::fmt::Write; if num.is_nan() { - Expr::Num("Num.nanF32") + Expr::Num("Num.nan_f32") } else if num.is_infinite() { if num.is_sign_positive() { - Expr::Num("Num.infinityF32") + Expr::Num("Num.infinity_f32") } else { - Expr::Num("-Num.infinityF32") + Expr::Num("-Num.infinity_f32") } } else { let mut string = bumpalo::collections::String::with_capacity_in(64, arena); diff --git a/crates/repl_eval/src/gen.rs b/crates/repl_eval/src/gen.rs index 3d68999eaa1..3fabeb30e10 100644 --- a/crates/repl_eval/src/gen.rs +++ b/crates/repl_eval/src/gen.rs @@ -179,8 +179,8 @@ fn promote_expr_to_module<'a, 'i, I: Iterator>( defs: I, expr: &str, ) -> (usize, &'a str) { - const REPL_MODULE_HEADER: &str = "app \"app\" provides [replOutput] to \"./platform\"\n\n"; - const REPL_MODULE_MAIN_DEF: &str = "replOutput =\n"; + const REPL_MODULE_HEADER: &str = "app \"app\" provides [repl_output] to \"./platform\"\n\n"; + const REPL_MODULE_MAIN_DEF: &str = "repl_output =\n"; const INDENT: &str = " "; let mut buffer = bumpalo::collections::string::String::from_str_in(REPL_MODULE_HEADER, arena); diff --git a/crates/repl_expect/src/lib.rs b/crates/repl_expect/src/lib.rs index f880456b6b2..c4fdb056d26 100644 --- a/crates/repl_expect/src/lib.rs +++ b/crates/repl_expect/src/lib.rs @@ -886,13 +886,13 @@ mod test { ] expect - nonEmpty = + non_empty = a = "abcdefgh" b = @NonEmpty (First "ijkl" 67u8) c = Next [{ item: a, rest: b }] @NonEmpty c - when nonEmpty is + when non_empty is _ -> Bool.false "# ), @@ -901,19 +901,19 @@ mod test { This expectation failed: 8│> expect - 9│> nonEmpty = + 9│> non_empty = 10│> a = "abcdefgh" 11│> b = @NonEmpty (First "ijkl" 67u8) 12│> c = Next [{ item: a, rest: b }] 13│> @NonEmpty c 14│> - 15│> when nonEmpty is + 15│> when non_empty is 16│> _ -> Bool.false When it failed, these variables had these values: - nonEmpty : NonEmpty - nonEmpty = @NonEmpty (Next [{ item: "abcdefgh", rest: @NonEmpty (First "ijkl" 67) }]) + non_empty : NonEmpty + non_empty = @NonEmpty (Next [{ item: "abcdefgh", rest: @NonEmpty (First "ijkl" 67) }]) "# ), ); @@ -926,11 +926,11 @@ mod test { r#" interface Test exposes [] imports [] - makeForcer : {} -> (Str -> U8) - makeForcer = \{} -> \_ -> 2u8 + make_forcer : {} -> (Str -> U8) + make_forcer = \{} -> \_ -> 2u8 expect - forcer = makeForcer {} + forcer = make_forcer {} case = "" @@ -942,7 +942,7 @@ mod test { This expectation failed: 6│> expect - 7│> forcer = makeForcer {} + 7│> forcer = make_forcer {} 8│> 9│> case = "" 10│> @@ -965,8 +965,8 @@ mod test { interface Test exposes [] imports [] expect - totalCount = \{} -> 1u8 - totalCount {} == 96u8 + total_count = \{} -> 1u8 + total_count {} == 96u8 " ), indoc!( @@ -974,8 +974,8 @@ mod test { This expectation failed: 3│> expect - 4│> totalCount = \{} -> 1u8 - 5│> totalCount {} == 96u8 + 4│> total_count = \{} -> 1u8 + 5│> total_count {} == 96u8 " ), ); @@ -1053,22 +1053,22 @@ mod test { interface Test exposes [] imports [] Request : { - fieldA : [Get, Post], - fieldB : Str, + field_a : [Get, Post], + field_b : Str, } expect actual : Request actual = { - fieldA: Get, - fieldB: "/things?id=2", + field_a: Get, + field_b: "/things?id=2", } expected : Request expected = { - fieldA: Get, - fieldB: "/things?id=1", + field_a: Get, + field_b: "/things?id=1", } actual == expected "# @@ -1081,24 +1081,24 @@ mod test { 9│> 10│> actual : Request 11│> actual = { - 12│> fieldA: Get, - 13│> fieldB: "/things?id=2", + 12│> field_a: Get, + 13│> field_b: "/things?id=2", 14│> } 15│> 16│> expected : Request 17│> expected = { - 18│> fieldA: Get, - 19│> fieldB: "/things?id=1", + 18│> field_a: Get, + 19│> field_b: "/things?id=1", 20│> } 21│> actual == expected When it failed, these variables had these values: actual : Request - actual = { fieldA: Get, fieldB: "/things?id=2" } + actual = { field_a: Get, field_b: "/things?id=2" } expected : Request - expected = { fieldA: Get, fieldB: "/things?id=1" } + expected = { field_a: Get, field_b: "/things?id=1" } "# ), @@ -1219,12 +1219,12 @@ mod test { r" interface Test exposes [] imports [] - hexToByte : U8, U8 -> U8 - hexToByte = \upper, lower -> - Num.bitwiseOr (Num.shiftRightBy upper 4) lower + hex_to_byte : U8, U8 -> U8 + hex_to_byte = \upper, lower -> + Num.bitwise_or (Num.shift_right_by upper 4) lower expect - actual = hexToByte 7 4 + actual = hex_to_byte 7 4 expected = 't' actual == expected " @@ -1234,7 +1234,7 @@ mod test { This expectation failed: 7│> expect - 8│> actual = hexToByte 7 4 + 8│> actual = hex_to_byte 7 4 9│> expected = 't' 10│> actual == expected diff --git a/crates/repl_test/src/state.rs b/crates/repl_test/src/state.rs index 96a4af523e0..4705d22618d 100644 --- a/crates/repl_test/src/state.rs +++ b/crates/repl_test/src/state.rs @@ -98,7 +98,7 @@ fn partial_record_definition() { // Partially define a record incompletely { let mut state = ReplState::new(); - let mut input = "failedRecord = {".to_string(); + let mut input = "failed_record = {".to_string(); incomplete(&mut input); input.push_str("field: \"field\","); @@ -111,11 +111,11 @@ fn partial_record_definition() { I am partway through parsing a record, but I got stuck here: - 1│ app "app" provides [replOutput] to "./platform" + 1│ app "app" provides [repl_output] to "./platform" 2│ - 3│ replOutput = - 4│ failedRecord = { - ^ + 3│ repl_output = + 4│ failed_record = { + ^ TODO provide more context."# ); diff --git a/crates/repl_test/src/tests.rs b/crates/repl_test/src/tests.rs index 94536b83caf..c1ff65330b7 100644 --- a/crates/repl_test/src/tests.rs +++ b/crates/repl_test/src/tests.rs @@ -69,14 +69,14 @@ fn num_rem() { #[cfg(not(feature = "wasm"))] #[test] fn num_floor_division() { - expect_success("Num.divTrunc 4 3", "1 : Int *"); + expect_success("Num.div_trunc 4 3", "1 : Int *"); } #[cfg(not(feature = "wasm"))] #[test] fn num_floor_checked_division_success() { expect_success( - "Num.divTruncChecked 4 3", + "Num.div_trunc_checked 4 3", "Ok 1 : Result (Int *) [DivByZero]", ); } @@ -85,7 +85,7 @@ fn num_floor_checked_division_success() { #[test] fn num_floor_checked_division_divby_zero() { expect_success( - "Num.divTruncChecked 4 0", + "Num.div_trunc_checked 4 0", "Err DivByZero : Result (Int *) [DivByZero]", ); } @@ -93,27 +93,27 @@ fn num_floor_checked_division_divby_zero() { #[cfg(not(feature = "wasm"))] #[test] fn num_ceil_division() { - expect_success("Num.divCeil 4 3", "2 : Int *") + expect_success("Num.div_ceil 4 3", "2 : Int *") } #[cfg(not(feature = "wasm"))] #[test] fn num_ceil_checked_division_success() { expect_success( - "Num.divCeilChecked 4 3", + "Num.div_ceil_checked 4 3", "Ok 2 : Result (Int *) [DivByZero]", ) } #[test] fn float_division_by_zero() { - expect_success("1f64 / 0", "Num.infinityF64 : F64"); - expect_success("-1f64 / 0", "-Num.infinityF64 : F64"); - expect_success("0f64 / 0", "Num.nanF64 : F64"); + expect_success("1f64 / 0", "Num.infinity_f64 : F64"); + expect_success("-1f64 / 0", "-Num.infinity_f64 : F64"); + expect_success("0f64 / 0", "Num.nan_f64 : F64"); - expect_success("1f32 / 0", "Num.infinityF32 : F32"); - expect_success("-1f32 / 0", "-Num.infinityF32 : F32"); - expect_success("0f32 / 0", "Num.nanF32 : F32"); + expect_success("1f32 / 0", "Num.infinity_f32 : F32"); + expect_success("-1f32 / 0", "-Num.infinity_f32 : F32"); + expect_success("0f32 / 0", "Num.nan_f32 : F32"); } #[test] @@ -349,50 +349,53 @@ fn nested_float_list() { #[test] fn num_bitwise_and() { - expect_success("Num.bitwiseAnd 20 20", "20 : Int *"); + expect_success("Num.bitwise_and 20 20", "20 : Int *"); - expect_success("Num.bitwiseAnd 25 10", "8 : Int *"); + expect_success("Num.bitwise_and 25 10", "8 : Int *"); - expect_success("Num.bitwiseAnd 200 0", "0 : Int *") + expect_success("Num.bitwise_and 200 0", "0 : Int *") } #[test] fn num_bitwise_xor() { - expect_success("Num.bitwiseXor 20 20", "0 : Int *"); + expect_success("Num.bitwise_xor 20 20", "0 : Int *"); - expect_success("Num.bitwiseXor 15 14", "1 : Int *"); + expect_success("Num.bitwise_xor 15 14", "1 : Int *"); - expect_success("Num.bitwiseXor 7 15", "8 : Int *"); + expect_success("Num.bitwise_xor 7 15", "8 : Int *"); - expect_success("Num.bitwiseXor 200 0", "200 : Int *") + expect_success("Num.bitwise_xor 200 0", "200 : Int *") } #[test] fn num_add_wrap() { - expect_success("Num.addWrap Num.maxI64 1", "-9223372036854775808 : I64"); + expect_success("Num.add_wrap Num.max_i64 1", "-9223372036854775808 : I64"); } #[test] fn num_sub_wrap() { - expect_success("Num.subWrap Num.minI64 1", "9223372036854775807 : I64"); + expect_success("Num.sub_wrap Num.min_i64 1", "9223372036854775807 : I64"); } #[test] fn num_mul_wrap() { - expect_success("Num.mulWrap Num.maxI64 2", "-2 : I64"); + expect_success("Num.mul_wrap Num.max_i64 2", "-2 : I64"); } #[test] fn num_mul_saturated() { - expect_success("Num.mulSaturated Num.maxI64 2", "9223372036854775807 : I64"); + expect_success( + "Num.mul_saturated Num.max_i64 2", + "9223372036854775807 : I64", + ); } #[cfg(not(feature = "wasm"))] #[test] fn num_add_checked() { - expect_success("Num.addChecked 1 1", "Ok 2 : Result (Num *) [Overflow]"); + expect_success("Num.add_checked 1 1", "Ok 2 : Result (Num *) [Overflow]"); expect_success( - "Num.addChecked Num.maxI64 1", + "Num.add_checked Num.max_i64 1", "Err Overflow : Result I64 [Overflow]", ); } @@ -400,9 +403,9 @@ fn num_add_checked() { #[cfg(not(feature = "wasm"))] #[test] fn num_sub_checked() { - expect_success("Num.subChecked 1 1", "Ok 0 : Result (Num *) [Overflow]"); + expect_success("Num.sub_checked 1 1", "Ok 0 : Result (Num *) [Overflow]"); expect_success( - "Num.subChecked Num.minI64 1", + "Num.sub_checked Num.min_i64 1", "Err Overflow : Result I64 [Overflow]", ); } @@ -410,9 +413,9 @@ fn num_sub_checked() { #[cfg(not(feature = "wasm"))] #[test] fn num_mul_checked() { - expect_success("Num.mulChecked 20 2", "Ok 40 : Result (Num *) [Overflow]"); + expect_success("Num.mul_checked 20 2", "Ok 40 : Result (Num *) [Overflow]"); expect_success( - "Num.mulChecked Num.maxI64 2", + "Num.mul_checked Num.max_i64 2", "Err Overflow : Result I64 [Overflow]", ); } @@ -778,21 +781,21 @@ fn type_problem_string_interpolation() { #[test] fn list_drop_at_negative_index() { expect_failure( - "List.dropAt [1, 2, 3] -1", + "List.drop_at [1, 2, 3] -1", indoc!( r#" ── TYPE MISMATCH ─────────────────────────────────────────────────────────────── - This 2nd argument to dropAt has an unexpected type: + This 2nd argument to drop_at has an unexpected type: - 4│ List.dropAt [1, 2, 3] -1 - ^^ + 4│ List.drop_at [1, 2, 3] -1 + ^^ The argument is a number of type: I8, I16, F32, I32, F64, I64, I128, or Dec - But dropAt needs its 2nd argument to be: + But drop_at needs its 2nd argument to be: U64 "# @@ -854,13 +857,13 @@ fn invalid_string_interpolation() { #[test] fn issue_2149_i8_ok() { - expect_success(r#"Str.toI8 "127""#, "Ok 127 : Result I8 [InvalidNumStr]"); + expect_success(r#"Str.to_i8 "127""#, "Ok 127 : Result I8 [InvalidNumStr]"); } #[test] fn issue_2149_i8_err() { expect_success( - r#"Str.toI8 "128""#, + r#"Str.to_i8 "128""#, "Err InvalidNumStr : Result I8 [InvalidNumStr]", ); } @@ -868,7 +871,7 @@ fn issue_2149_i8_err() { #[test] fn issue_2149_i16_ok() { expect_success( - r#"Str.toI16 "32767""#, + r#"Str.to_i16 "32767""#, "Ok 32767 : Result I16 [InvalidNumStr]", ); } @@ -876,7 +879,7 @@ fn issue_2149_i16_ok() { #[test] fn issue_2149_i16_err() { expect_success( - r#"Str.toI16 "32768""#, + r#"Str.to_i16 "32768""#, "Err InvalidNumStr : Result I16 [InvalidNumStr]", ); } @@ -1136,9 +1139,9 @@ fn parse_problem() { I am partway through parsing a definition, but I got stuck here: - 1│ app "app" provides [replOutput] to "./platform" + 1│ app "app" provides [repl_output] to "./platform" 2│ - 3│ replOutput = + 3│ repl_output = 4│ add m n = m + n ^^^ @@ -1330,9 +1333,9 @@ fn box_box_type_alias() { indoc!( r#" HeapStr : Box Str - helloHeap : HeapStr - helloHeap = Box.box "bye stacks" - helloHeap"# + hello_heap : HeapStr + hello_heap = Box.box "bye stacks" + hello_heap"# ), r#"Box.box "bye stacks" : HeapStr"#, ) @@ -1480,7 +1483,7 @@ fn str_to_dec() { expect_success( indoc!( r#" - Str.toDec "1234.1234" + Str.to_dec "1234.1234" "# ), r"Ok 1234.1234 : Result Dec [InvalidNumStr]", @@ -1534,7 +1537,7 @@ fn interpolation_with_nested_strings() { expect_success( indoc!( r#" - "foo $(Str.joinWith ["a", "b", "c"] ", ") bar" + "foo $(Str.join_with ["a", "b", "c"] ", ") bar" "# ), r#""foo a, b, c bar" : Str"#, @@ -1546,7 +1549,7 @@ fn interpolation_with_num_to_str() { expect_success( indoc!( r#" - "foo $(Num.toStr Num.maxI8) bar" + "foo $(Num.to_str Num.max_i8) bar" "# ), r#""foo 127 bar" : Str"#, @@ -1558,7 +1561,7 @@ fn interpolation_with_operator_desugaring() { expect_success( indoc!( r#" - "foo $(Num.toStr (1 + 2)) bar" + "foo $(Num.to_str (1 + 2)) bar" "# ), r#""foo 3 bar" : Str"#, @@ -1573,7 +1576,7 @@ fn interpolation_with_nested_interpolation() { expect_failure( indoc!( r#" - "foo $(Str.joinWith ["a$(Num.toStr 5)", "b"] "c")" + "foo $(Str.join_with ["a$(Num.to_str 5)", "b"] "c")" "# ), indoc!( @@ -1582,8 +1585,8 @@ fn interpolation_with_nested_interpolation() { This string interpolation is invalid: - 4│ "foo $(Str.joinWith ["a$(Num.toStr 5)", "b"] "c")" - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 4│ "foo $(Str.join_with ["a$(Num.to_str 5)", "b"] "c")" + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ String interpolations cannot contain newlines or other interpolations. diff --git a/crates/reporting/src/error/canonicalize.rs b/crates/reporting/src/error/canonicalize.rs index d296f48a550..7b900f22e51 100644 --- a/crates/reporting/src/error/canonicalize.rs +++ b/crates/reporting/src/error/canonicalize.rs @@ -1405,7 +1405,7 @@ pub fn can_problem<'b>( )]), alloc.tip().append( alloc.reflow( - "An expression like `4`, `\"hello\"`, or `functionCall MyThing` is like `return 4` in other programming languages. To me, it seems like you did `return 4` followed by more code in the lines after, that code would never be executed!" + "An expression like `4`, `\"hello\"`, or `function_call(MyThing)` is like `return 4` in other programming languages. To me, it seems like you did `return 4` followed by more code in the lines after, that code would never be executed!" ) ), alloc.tip().append( @@ -1426,7 +1426,7 @@ pub fn can_problem<'b>( alloc.region(lines.convert_region(region), severity), alloc.reflow("Add an exclamation mark at the end, like:"), alloc - .parser_suggestion("{ readFile!: Str => Str }") + .parser_suggestion("{ read_file!: Str => Str }") .indent(4), alloc.reflow("This will help readers identify it as a source of effects."), ]); diff --git a/crates/reporting/src/error/type.rs b/crates/reporting/src/error/type.rs index bd9a17c5760..6c9831f9c7e 100644 --- a/crates/reporting/src/error/type.rs +++ b/crates/reporting/src/error/type.rs @@ -436,7 +436,7 @@ pub fn type_problem<'b>( alloc.region(lines.convert_region(region), severity), alloc.reflow("Add an exclamation mark at the end, like:"), alloc - .parser_suggestion("{ readFile! : File.read! }") + .parser_suggestion("{ read_file! : File.read! }") .indent(4), alloc.reflow("This will help readers identify it as a source of effects."), ]; diff --git a/crates/test_utils/src/TagLenEncoderFmt.roc b/crates/test_utils/src/TagLenEncoderFmt.roc index 75f2fb39dd5..bd156b578d6 100644 --- a/crates/test_utils/src/TagLenEncoderFmt.roc +++ b/crates/test_utils/src/TagLenEncoderFmt.roc @@ -9,252 +9,252 @@ # # module [ # TagLenFmt, -# tagLenFmt, +# tag_len_fmt, # ] TagLenFmt := {} implements [ EncoderFormatting { - u8: encodeU8, - u16: encodeU16, - u32: encodeU32, - u64: encodeU64, - u128: encodeU128, - i8: encodeI8, - i16: encodeI16, - i32: encodeI32, - i64: encodeI64, - i128: encodeI128, - f32: encodeF32, - f64: encodeF64, - dec: encodeDec, - bool: encodeBool, - string: encodeString, - list: encodeList, - record: encodeRecord, - tuple: encodeTuple, - tag: encodeTag, + u8: encode_u8, + u16: encode_u16, + u32: encode_u32, + u64: encode_u64, + u128: encode_u128, + i8: encode_i8, + i16: encode_i16, + i32: encode_i32, + i64: encode_i64, + i128: encode_i128, + f32: encode_f32, + f64: encode_f64, + dec: encode_dec, + bool: encode_bool, + string: encode_string, + list: encode_list, + record: encode_record, + tuple: encode_tuple, + tag: encode_tag, }, DecoderFormatting { - u8: decodeU8, - u16: decodeU16, - u32: decodeU32, - u64: decodeU64, - u128: decodeU128, - i8: decodeI8, - i16: decodeI16, - i32: decodeI32, - i64: decodeI64, - i128: decodeI128, - f32: decodeF32, - f64: decodeF64, - dec: decodeDec, - bool: decodeBool, - string: decodeString, - list: decodeList, - record: decodeRecord, - tuple: decodeTuple, + u8: decode_u8, + u16: decode_u16, + u32: decode_u32, + u64: decode_u64, + u128: decode_u128, + i8: decode_i8, + i16: decode_i16, + i32: decode_i32, + i64: decode_i64, + i128: decode_i128, + f32: decode_f32, + f64: decode_f64, + dec: decode_dec, + bool: decode_bool, + string: decode_string, + list: decode_list, + record: decode_record, + tuple: decode_tuple, }, ] -tagLenFmt = @TagLenFmt {} +tag_len_fmt = @TagLenFmt {} # ENCODE -appendPreLen = \bytes, pre, len -> - List.append bytes (Num.toU8 pre) - |> List.concat (Num.toStr len |> Str.toUtf8) +append_pre_len = \bytes, pre, len -> + List.append bytes (Num.to_u8 pre) + |> List.concat (Num.to_str len |> Str.to_utf8) |> List.append ' ' -encodeNum = \n -> Encode.custom \bytes, @TagLenFmt {} -> appendPreLen bytes 'n' n - -encodeU8 = encodeNum -encodeU16 = encodeNum -encodeU32 = encodeNum -encodeU64 = encodeNum -encodeU128 = encodeNum -encodeI8 = encodeNum -encodeI16 = encodeNum -encodeI32 = encodeNum -encodeI64 = encodeNum -encodeI128 = encodeNum -encodeF32 = encodeNum -encodeF64 = encodeNum -encodeDec = encodeNum -encodeBool = \b -> encodeU8 (if b then 1 else 0) +encode_num = \n -> Encode.custom \bytes, @TagLenFmt {} -> append_pre_len bytes 'n' n + +encode_u8 = encode_num +encode_u16 = encode_num +encode_u32 = encode_num +encode_u64 = encode_num +encode_u128 = encode_num +encode_i8 = encode_num +encode_i16 = encode_num +encode_i32 = encode_num +encode_i64 = encode_num +encode_i128 = encode_num +encode_f32 = encode_num +encode_f64 = encode_num +encode_dec = encode_num +encode_bool = \b -> encode_u8 (if b then 1 else 0) expect - actual = Encode.toBytes 1 tagLenFmt - actual == (Str.toUtf8 "n1 ") + actual = Encode.to_bytes 1 tag_len_fmt + actual == (Str.to_utf8 "n1 ") expect - actual = Encode.toBytes 1.3dec tagLenFmt - actual == (Str.toUtf8 "n1.3 ") + actual = Encode.to_bytes 1.3dec tag_len_fmt + actual == (Str.to_utf8 "n1.3 ") expect - actual = Encode.toBytes Bool.true tagLenFmt - actual == (Str.toUtf8 "n1 ") + actual = Encode.to_bytes Bool.true tag_len_fmt + actual == (Str.to_utf8 "n1 ") -encodeString = \str -> Encode.custom \bytes, @TagLenFmt {} -> - appendPreLen bytes 's' (Str.countUtf8Bytes str) - |> List.concat (Str.toUtf8 str) +encode_string = \str -> Encode.custom \bytes, @TagLenFmt {} -> + append_pre_len bytes 's' (Str.count_utf8_bytes str) + |> List.concat (Str.to_utf8 str) |> List.append ' ' expect - actual = Encode.toBytes "hey" tagLenFmt - actual == (Str.toUtf8 "s3 hey ") + actual = Encode.to_bytes "hey" tag_len_fmt + actual == (Str.to_utf8 "s3 hey ") -encodeList = \lst, encodeElem -> Encode.custom \bytes, @TagLenFmt {} -> - bytesPre = appendPreLen bytes 'l' (List.len lst) - List.walk lst bytesPre \buf, elem -> - Encode.appendWith buf (encodeElem elem) (@TagLenFmt {}) +encode_list = \lst, encode_elem -> Encode.custom \bytes, @TagLenFmt {} -> + bytes_pre = append_pre_len bytes 'l' (List.len lst) + List.walk lst bytes_pre \buf, elem -> + Encode.append_with buf (encode_elem elem) (@TagLenFmt {}) expect - actual = Encode.toBytes [1, 2, 3] tagLenFmt - actual == (Str.toUtf8 "l3 n1 n2 n3 ") + actual = Encode.to_bytes [1, 2, 3] tag_len_fmt + actual == (Str.to_utf8 "l3 n1 n2 n3 ") -encodeRecord = \fields -> Encode.custom \bytes, @TagLenFmt {} -> - bytesPre = - appendPreLen bytes 'r' (List.len fields) - List.walk fields bytesPre \buf, { key, value } -> - Encode.appendWith buf (encodeString key) (@TagLenFmt {}) - |> Encode.appendWith value (@TagLenFmt {}) +encode_record = \fields -> Encode.custom \bytes, @TagLenFmt {} -> + bytes_pre = + append_pre_len bytes 'r' (List.len fields) + List.walk fields bytes_pre \buf, { key, value } -> + Encode.append_with buf (encode_string key) (@TagLenFmt {}) + |> Encode.append_with value (@TagLenFmt {}) expect - actual = Encode.toBytes { foo: "foo", bar: Bool.true } tagLenFmt - actual == Str.toUtf8 "r2 s3 bar n1 s3 foo s3 foo " + actual = Encode.to_bytes { foo: "foo", bar: Bool.true } tag_len_fmt + actual == Str.to_utf8 "r2 s3 bar n1 s3 foo s3 foo " -encodeTuple = \elems -> encodeList elems (\e -> e) -encodeTag = \name, payload -> encodeTuple (List.prepend payload (encodeString name)) +encode_tuple = \elems -> encode_list elems (\e -> e) +encode_tag = \name, payload -> encode_tuple (List.prepend payload (encode_string name)) expect - actual = Encode.toBytes (1, "foo", {}) tagLenFmt - actual == (Str.toUtf8 "l3 n1 s3 foo r0 ") + actual = Encode.to_bytes (1, "foo", {}) tag_len_fmt + actual == (Str.to_utf8 "l3 n1 s3 foo r0 ") # DECODE -splitAtSpace = \bytes -> - when List.splitFirst bytes ' ' is +split_at_space = \bytes -> + when List.split_first bytes ' ' is Ok { before, after } -> { taken: before, rest: after } Err _ -> { taken: [], rest: bytes } -decodeNumPre = \bytes, pre, toNum -> - when List.splitAt bytes 1 is +decode_num_pre = \bytes, pre, to_num -> + when List.split_at bytes 1 is { before: [b], others } if b == pre -> - { taken, rest } = splitAtSpace others - str = taken |> Str.fromUtf8 |> Result.mapErr \_ -> TooShort - result = Result.try str \s -> (toNum s |> Result.mapErr \_ -> TooShort) + { taken, rest } = split_at_space others + str = taken |> Str.from_utf8 |> Result.map_err \_ -> TooShort + result = Result.try str \s -> (to_num s |> Result.map_err \_ -> TooShort) when result is Ok _ -> { result, rest } Err _ -> { result, rest: others } _ -> { result: Err TooShort, rest: bytes } -decodeNum = \toNum -> Decode.custom \bytes, @TagLenFmt {} -> decodeNumPre bytes 'n' toNum - -decodeU8 = decodeNum Str.toU8 -decodeU16 = decodeNum Str.toU16 -decodeU32 = decodeNum Str.toU32 -decodeU64 = decodeNum Str.toU64 -decodeU128 = decodeNum Str.toU128 -decodeI8 = decodeNum Str.toI8 -decodeI16 = decodeNum Str.toI16 -decodeI32 = decodeNum Str.toI32 -decodeI64 = decodeNum Str.toI64 -decodeI128 = decodeNum Str.toI128 -decodeF32 = decodeNum Str.toF32 -decodeF64 = decodeNum Str.toF64 -decodeDec = decodeNum Str.toDec -decodeBool = Decode.custom \bytes, @TagLenFmt {} -> - { result: numResult, rest } = Decode.decodeWith bytes decodeU8 (@TagLenFmt {}) - when numResult is +decode_num = \to_num -> Decode.custom \bytes, @TagLenFmt {} -> decode_num_pre bytes 'n' to_num + +decode_u8 = decode_num Str.to_u8 +decode_u16 = decode_num Str.to_u16 +decode_u32 = decode_num Str.to_u32 +decode_u64 = decode_num Str.to_u64 +decode_u128 = decode_num Str.to_u128 +decode_i8 = decode_num Str.to_i8 +decode_i16 = decode_num Str.to_i16 +decode_i32 = decode_num Str.to_i32 +decode_i64 = decode_num Str.to_i64 +decode_i128 = decode_num Str.to_i128 +decode_f32 = decode_num Str.to_f32 +decode_f64 = decode_num Str.to_f64 +decode_dec = decode_num Str.to_dec +decode_bool = Decode.custom \bytes, @TagLenFmt {} -> + { result: num_result, rest } = Decode.decode_with bytes decode_u8 (@TagLenFmt {}) + when num_result is Ok 1 -> { result: Ok Bool.true, rest } Ok 0 -> { result: Ok Bool.false, rest } _ -> { result: Err TooShort, rest: bytes } expect - actual = Decode.fromBytes (Str.toUtf8 "n1 ") tagLenFmt - actual == Ok (Num.toU8 1) + actual = Decode.from_bytes (Str.to_utf8 "n1 ") tag_len_fmt + actual == Ok (Num.to_u8 1) expect - actual = Decode.fromBytes (Str.toUtf8 "n1 ") tagLenFmt + actual = Decode.from_bytes (Str.to_utf8 "n1 ") tag_len_fmt actual == Ok Bool.true -decodeLenPre = \bytes, pre -> decodeNumPre bytes pre Str.toU64 +decode_len_pre = \bytes, pre -> decode_num_pre bytes pre Str.to_u64 -decodeTry = \{ result, rest }, map -> +decode_try = \{ result, rest }, map -> when result is Ok a -> map a rest Err e -> { result: Err e, rest } -decodeString = Decode.custom \bytes, @TagLenFmt {} -> - decodeLenPre bytes 's' - |> decodeTry \len, lenRest -> - { before, others } = List.splitAt lenRest len - result = Str.fromUtf8 before |> Result.mapErr \_ -> TooShort - when List.splitAt others 1 is +decode_string = Decode.custom \bytes, @TagLenFmt {} -> + decode_len_pre bytes 's' + |> decode_try \len, len_rest -> + { before, others } = List.split_at len_rest len + result = Str.from_utf8 before |> Result.map_err \_ -> TooShort + when List.split_at others 1 is { before: [' '], others: rest } -> { result, rest } _ -> { result: Err TooShort, rest: others } expect - actual = Decode.fromBytes (Str.toUtf8 "s3 foo ") tagLenFmt + actual = Decode.from_bytes (Str.to_utf8 "s3 foo ") tag_len_fmt actual == Ok "foo" -repeatDecode : U8, List U8, state, (state -> Decode.Decoder state TagLenFmt) -> DecodeResult state -repeatDecode = \pre, bytes, state, stepState -> +repeat_decode : U8, List U8, state, (state -> Decode.Decoder state TagLenFmt) -> DecodeResult state +repeat_decode = \pre, bytes, state, step_state -> run = \end, bs -> List.range { start: At 0, end: Before end } |> List.walk { result: Ok state, rest: bs } \res, _i -> - decodeTry res \s, rest -> - Decode.decodeWith rest (stepState s) (@TagLenFmt {}) + decode_try res \s, rest -> + Decode.decode_with rest (step_state s) (@TagLenFmt {}) - decodeLenPre bytes pre |> decodeTry run + decode_len_pre bytes pre |> decode_try run -decodeList = \elemDecoder -> Decode.custom \bytes, @TagLenFmt {} -> +decode_list = \elem_decoder -> Decode.custom \bytes, @TagLenFmt {} -> step = \lst -> Decode.custom \sbytes, @TagLenFmt {} -> - Decode.decodeWith sbytes elemDecoder (@TagLenFmt {}) - |> Decode.mapResult \elem -> List.append lst elem - repeatDecode 'l' bytes [] step + Decode.decode_with sbytes elem_decoder (@TagLenFmt {}) + |> Decode.map_result \elem -> List.append lst elem + repeat_decode 'l' bytes [] step expect - actual = Decode.fromBytes (Str.toUtf8 "l3 n1 n2 n3 ") tagLenFmt + actual = Decode.from_bytes (Str.to_utf8 "l3 n1 n2 n3 ") tag_len_fmt actual == Ok [1, 2, 3] -decodeRecord = \initState, stepField, finalizer -> Decode.custom \bytes, @TagLenFmt {} -> - flattenFieldRes = \next, rest -> +decode_record = \init_state, step_field, finalizer -> Decode.custom \bytes, @TagLenFmt {} -> + flatten_field_res = \next, rest -> when next is - Keep valueDecoder -> { result: Ok valueDecoder, rest } + Keep value_decoder -> { result: Ok value_decoder, rest } Skip -> { result: Err TooShort, rest } step = \state -> Decode.custom \sbytes, @TagLenFmt {} -> - Decode.decodeWith sbytes decodeString (@TagLenFmt {}) - |> decodeTry \key, bs -> - flattenFieldRes (stepField state key) bs - |> decodeTry \valueDecoder, bs -> - Decode.decodeWith bs valueDecoder (@TagLenFmt {}) + Decode.decode_with sbytes decode_string (@TagLenFmt {}) + |> decode_try \key, bs -> + flatten_field_res (step_field state key) bs + |> decode_try \value_decoder, bs -> + Decode.decode_with bs value_decoder (@TagLenFmt {}) - repeatDecode 'r' bytes initState step - |> decodeTry \state, rest -> { result: finalizer state (@TagLenFmt {}), rest } + repeat_decode 'r' bytes init_state step + |> decode_try \state, rest -> { result: finalizer state (@TagLenFmt {}), rest } expect - actual = Decode.fromBytes (Str.toUtf8 "r2 s3 bar n1 s3 foo s3 foo ") tagLenFmt + actual = Decode.from_bytes (Str.to_utf8 "r2 s3 bar n1 s3 foo s3 foo ") tag_len_fmt actual == Ok ({ foo: "foo", bar: Bool.true }) -decodeTuple = \initialState, stepElem, finalizer -> Decode.custom \bytes, @TagLenFmt {} -> - flattenFieldRes = \next, rest -> +decode_tuple = \initial_state, step_elem, finalizer -> Decode.custom \bytes, @TagLenFmt {} -> + flatten_field_res = \next, rest -> when next is Next dec -> { result: Ok dec, rest } TooLong -> { result: Err TooShort, rest } step = \{ state, i } -> Decode.custom \sbytes, @TagLenFmt {} -> - flattenFieldRes (stepElem state i) sbytes - |> decodeTry \dec, rest -> Decode.decodeWith rest dec (@TagLenFmt {}) - |> Decode.mapResult \s -> { state: s, i: i + 1 } + flatten_field_res (step_elem state i) sbytes + |> decode_try \dec, rest -> Decode.decode_with rest dec (@TagLenFmt {}) + |> Decode.map_result \s -> { state: s, i: i + 1 } - repeatDecode 'l' bytes { state: initialState, i: 0 } step - |> decodeTry \s, rest -> { result: finalizer s.state, rest } + repeat_decode 'l' bytes { state: initial_state, i: 0 } step + |> decode_try \s, rest -> { result: finalizer s.state, rest } expect - actual = Decode.fromBytes (Str.toUtf8 "l3 n1 s3 abc l1 n0 ") tagLenFmt + actual = Decode.from_bytes (Str.to_utf8 "l3 n1 s3 abc l1 n0 ") tag_len_fmt actual == Ok (1, "abc", [Bool.false]) expect input = { foo: (1, "abc", [Bool.false, Bool.true]), bar: { baz: 0.32 } } - encoded = Encode.toBytes input tagLenFmt - decoded = Decode.fromBytes encoded tagLenFmt + encoded = Encode.to_bytes input tag_len_fmt + decoded = Decode.from_bytes encoded tag_len_fmt decoded == Ok input diff --git a/crates/valgrind_tests/src/lib.rs b/crates/valgrind_tests/src/lib.rs index 75a481234a8..6f909b0c798 100644 --- a/crates/valgrind_tests/src/lib.rs +++ b/crates/valgrind_tests/src/lib.rs @@ -24,7 +24,7 @@ fn build_host() { } let stub_dll_symbols = roc_linker::ExposedSymbols { - top_level_values: vec![String::from("mainForHost")], + top_level_values: vec![String::from("main_for_host")], exported_closure_types: vec![], } .stub_dll_symbols(); @@ -204,7 +204,7 @@ fn run_with_valgrind(binary_path: &std::path::Path) { #[test] fn list_concat_consumes_first_argument() { - valgrind_test("List.concat (List.withCapacity 1024) [1,2,3] |> List.len |> Num.toStr"); + valgrind_test("List.concat (List.with_capacity 1024) [1,2,3] |> List.len |> Num.to_str"); } #[test] @@ -217,7 +217,7 @@ fn list_concat_consumes_second_argument() { b = List.reserve [] 11 List.concat a b |> List.len - |> Num.toStr + |> Num.to_str ) " )); @@ -225,15 +225,15 @@ fn list_concat_consumes_second_argument() { #[test] fn str_capacity_concat() { - valgrind_test(r#"Str.withCapacity 42 |> Str.concat "foobar""#); + valgrind_test(r#"Str.with_capacity 42 |> Str.concat "foobar""#); } #[test] fn split_not_present() { valgrind_test(indoc!( r#" - Str.splitOn (Str.concat "a string that is stored on the heap" "!") "\n" - |> Str.joinWith "" + Str.split_on (Str.concat "a string that is stored on the heap" "!") "\n" + |> Str.join_with "" "# )); } @@ -265,7 +265,7 @@ fn list_concat_empty_list_zero_sized_type() { b = [] List.concat a b |> List.len - |> Num.toStr + |> Num.to_str ) " )); @@ -277,7 +277,7 @@ fn str_trim_end_capacity() { r#" ( str = "a" |> Str.reserve 30 - out = str |> Str.trimEnd + out = str |> Str.trim_end if out == "" then "A" else "B" ) @@ -291,7 +291,7 @@ fn str_trim_start_capacity() { r#" ( str = " a" |> Str.reserve 30 - out = str |> Str.trimStart + out = str |> Str.trim_start if out == "" then "A" else "B" ) @@ -305,12 +305,12 @@ fn str_concat_later_referencing_empty_list_with_capacity() { r" ( a : List U8 - a = List.withCapacity 1 + a = List.with_capacity 1 List.concat a [58] |> List.len - |> Num.addWrap (List.len a) - |> Num.toStr + |> Num.add_wrap (List.len a) + |> Num.to_str ) " )); @@ -323,25 +323,25 @@ fn joinpoint_with_closure() { ( Animal : [Cat, Dog, Goose] - makeSound : Animal -> Str - makeSound = \animal -> - dogSound = "Woof" + make_sound : Animal -> Str + make_sound = \animal -> + dog_sound = "Woof" when animal is - Cat | Dog if isCat animal -> "Miauw" + Cat | Dog if is_cat animal -> "Miauw" Goose -> "Honk" - _ -> dogSound + _ -> dog_sound - isCat : Animal -> Bool - isCat = \animal -> + is_cat : Animal -> Bool + is_cat = \animal -> when animal is Cat -> Bool.true _ -> Bool.false test = - catSound = makeSound Cat - dogSound = makeSound Dog - gooseSound = makeSound Goose - "Cat: $(catSound), Dog: $(dogSound), Goose: $(gooseSound)" + cat_sound = make_sound Cat + dog_sound = make_sound Dog + goose_sound = make_sound Goose + "Cat: $(cat_sound), Dog: $(dog_sound), Goose: $(goose_sound)" test ) @@ -356,25 +356,25 @@ fn joinpoint_with_reuse() { ( LinkedList a : [Cons a (LinkedList a), Nil] - # mapLinkedList : LinkedList a, (a -> b) -> LinkedList b - mapLinkedList = \linkedList, f -> when linkedList is + # map_linked_list : LinkedList a, (a -> b) -> LinkedList b + map_linked_list = \linked_list, f -> when linked_list is Nil -> Nil Cons x xs -> x2 = if Bool.true then x else x - Cons (f x2) (mapLinkedList xs f) + Cons (f x2) (map_linked_list xs f) - # printLinkedList : LinkedList a, (a -> Str) -> Str - printLinkedList = \linkedList, f -> - when linkedList is + # print_linked_list : LinkedList a, (a -> Str) -> Str + print_linked_list = \linked_list, f -> + when linked_list is Nil -> "Nil" Cons x xs -> - strX = f x - strXs = printLinkedList xs f - "Cons $(strX) ($(strXs))" + str_x = f x + str_xs = print_linked_list xs f + "Cons $(str_x) ($(str_xs))" test = - newList = mapLinkedList (Cons 1 (Cons 2 (Cons 3 Nil))) (\x -> x + 1) - printLinkedList newList Num.toStr + new_list = map_linked_list (Cons 1 (Cons 2 (Cons 3 Nil))) (\x -> x + 1) + print_linked_list new_list Num.to_str test ) @@ -395,83 +395,83 @@ fn tree_rebalance() { insert : Key k, v, RedBlackTree (Key k) v -> RedBlackTree (Key k) v insert = \key, value, dict -> - when insertHelp key value dict is + when insert_help key value dict is Node Red k v l r -> Node Black k v l r x -> x - insertHelp : Key k, v, RedBlackTree (Key k) v -> RedBlackTree (Key k) v - insertHelp = \key, value, dict -> + insert_help : Key k, v, RedBlackTree (Key k) v -> RedBlackTree (Key k) v + insert_help = \key, value, dict -> when dict is Empty -> # New nodes are always red. If it violates the rules, it will be fixed # when balancing. Node Red key value Empty Empty - Node nColor nKey nValue nLeft nRight -> - when Num.compare key nKey is - LT -> balance nColor nKey nValue (insertHelp key value nLeft) nRight - EQ -> Node nColor nKey value nLeft nRight - GT -> balance nColor nKey nValue nLeft (insertHelp key value nRight) + Node n_color n_key n_value n_left n_right -> + when Num.compare key n_key is + LT -> balance n_color n_key n_value (insert_help key value n_left) n_right + EQ -> Node n_color n_key value n_left n_right + GT -> balance n_color n_key n_value n_left (insert_help key value n_right) balance : NodeColor, k, v, RedBlackTree k v, RedBlackTree k v -> RedBlackTree k v balance = \color, key, value, left, right -> when right is - Node Red rK rV rLeft rRight -> + Node Red r_k r_v r_left r_right -> when left is - Node Red lK lV lLeft lRight -> + Node Red l_k l_v l_left l_right -> Node Red key value - (Node Black lK lV lLeft lRight) - (Node Black rK rV rLeft rRight) + (Node Black l_k l_v l_left l_right) + (Node Black r_k r_v r_left r_right) _ -> - Node color rK rV (Node Red key value left rLeft) rRight + Node color r_k r_v (Node Red key value left r_left) r_right _ -> when left is - Node Red lK lV (Node Red llK llV llLeft llRight) lRight -> + Node Red l_k l_v (Node Red ll_k ll_v ll_left ll_right) l_right -> Node Red - lK - lV - (Node Black llK llV llLeft llRight) - (Node Black key value lRight right) + l_k + l_v + (Node Black ll_k ll_v ll_left ll_right) + (Node Black key value l_right right) _ -> Node color key value left right show : RedBlackTree I64 {} -> Str - show = \tree -> showRBTree tree Num.toStr (\{} -> "{}") + show = \tree -> show_rb_tree tree Num.to_str (\{} -> "{}") - showRBTree : RedBlackTree k v, (k -> Str), (v -> Str) -> Str - showRBTree = \tree, showKey, showValue -> + show_rb_tree : RedBlackTree k v, (k -> Str), (v -> Str) -> Str + show_rb_tree = \tree, show_key, show_value -> when tree is Empty -> "Empty" Node color key value left right -> - sColor = showColor color - sKey = showKey key - sValue = showValue value - sL = nodeInParens left showKey showValue - sR = nodeInParens right showKey showValue + s_color = show_color color + s_key = show_key key + s_value = show_value value + s_l = node_in_parens left show_key show_value + s_r = node_in_parens right show_key show_value - "Node $(sColor) $(sKey) $(sValue) $(sL) $(sR)" + "Node $(s_color) $(s_key) $(s_value) $(s_l) $(s_r)" - nodeInParens : RedBlackTree k v, (k -> Str), (v -> Str) -> Str - nodeInParens = \tree, showKey, showValue -> + node_in_parens : RedBlackTree k v, (k -> Str), (v -> Str) -> Str + node_in_parens = \tree, show_key, show_value -> when tree is Empty -> - showRBTree tree showKey showValue + show_rb_tree tree show_key show_value Node _ _ _ _ _ -> - inner = showRBTree tree showKey showValue + inner = show_rb_tree tree show_key show_value "($(inner))" - showColor : NodeColor -> Str - showColor = \color -> + show_color : NodeColor -> Str + show_color = \color -> when color is Red -> "Red" Black -> "Black" @@ -482,7 +482,6 @@ fn tree_rebalance() { Key k : Num k - "# )); } @@ -496,9 +495,9 @@ fn lowlevel_list_calls() { b = List.map2 a [1,1,1,1,1] (\x, y -> x + y) c = List.map3 a b [1,1,1,1,1] (\x, y, z -> x + y + z) d = List.map4 a b c [1,1,1,1,1] (\x, y, z, w -> x + y + z + w) - e = List.sortWith d (\x, y -> Num.compare x y) + e = List.sort_with d (\x, y -> Num.compare x y) - Num.toStr (List.len e) + Num.to_str (List.len e) ) " )); @@ -511,24 +510,24 @@ fn joinpoint_nullpointer() { ( LinkedList a : [Cons a (LinkedList a), Nil] - printLinkedList : LinkedList Str -> Str - printLinkedList = \linkedList-> - when linkedList is + print_linked_list : LinkedList Str -> Str + print_linked_list = \linked_list-> + when linked_list is Nil -> "Nil" Cons x xs -> - strXs = printLinkedList xs - "Cons $(x) ($(strXs))" + str_xs = print_linked_list xs + "Cons $(x) ($(str_xs))" - linkedListHead : LinkedList Str -> LinkedList Str - linkedListHead = \linkedList -> - string = when linkedList is + linked_list_head : LinkedList Str -> LinkedList Str + linked_list_head = \linked_list -> + string = when linked_list is Cons s _ -> s Nil -> "" Cons string Nil test = - cons = printLinkedList (linkedListHead (Cons "foo" Nil)) - nil = printLinkedList (linkedListHead (Nil)) + cons = print_linked_list (linked_list_head (Cons "foo" Nil)) + nil = print_linked_list (linked_list_head (Nil)) "$(cons) - $(nil)" test @@ -556,7 +555,7 @@ fn freeing_boxes() { |> Box.unbox a - |> Num.toStr + |> Num.to_str |> Str.concat b ) "# @@ -568,15 +567,15 @@ fn joinpoint_that_owns() { valgrind_test(indoc!( r#" ( - writeIndents = \buf, indents -> + write_indents = \buf, indents -> if indents <= 0 then buf else buf |> Str.concat " " - |> writeIndents (indents - 1) + |> write_indents (indents - 1) - List.walk [{}, {}] "" \accum, {} -> accum |> writeIndents 4 + List.walk [{}, {}] "" \accum, {} -> accum |> write_indents 4 ) "# )); diff --git a/crates/valgrind_tests/zig-platform/host.zig b/crates/valgrind_tests/zig-platform/host.zig index 26d432aa997..1bec2f024f7 100644 --- a/crates/valgrind_tests/zig-platform/host.zig +++ b/crates/valgrind_tests/zig-platform/host.zig @@ -102,7 +102,7 @@ comptime { const mem = std.mem; const Allocator = mem.Allocator; -extern fn roc__mainForHost_1_exposed_generic(*RocStr) void; +extern fn roc__main_for_host_1_exposed_generic(*RocStr) void; const Unit = extern struct {}; @@ -114,7 +114,7 @@ pub export fn main() u8 { // actually call roc to populate the callresult var callresult = RocStr.empty(); - roc__mainForHost_1_exposed_generic(&callresult); + roc__main_for_host_1_exposed_generic(&callresult); const nanos = timer.read(); const seconds = (@as(f64, @floatFromInt(nanos)) / 1_000_000_000.0); diff --git a/crates/valgrind_tests/zig-platform/main.roc b/crates/valgrind_tests/zig-platform/main.roc index a52fe9a4801..f42048abe8c 100644 --- a/crates/valgrind_tests/zig-platform/main.roc +++ b/crates/valgrind_tests/zig-platform/main.roc @@ -3,7 +3,7 @@ platform "echo-in-zig" exposes [] packages {} imports [] - provides [mainForHost] + provides [main_for_host] -mainForHost : Str -mainForHost = main +main_for_host : Str +main_for_host = main diff --git a/crates/wasm_module/src/lib.rs b/crates/wasm_module/src/lib.rs index f29f413e539..3e662c1c7e5 100644 --- a/crates/wasm_module/src/lib.rs +++ b/crates/wasm_module/src/lib.rs @@ -513,7 +513,7 @@ impl<'a> WasmModule<'a> { }) } - /// Linking steps for host-to-app functions like `roc__mainForHost_1_exposed` + /// Linking steps for host-to-app functions like `roc__main_for_host_1_exposed` /// (See further explanation in the gen_wasm README) /// - Remove the target function from the ImportSection. It's not a JS import but the host declared it as one. /// - Update all of its call sites to the new index in the app diff --git a/examples/glue/glue.roc b/examples/glue/glue.roc new file mode 100644 index 00000000000..912853e350e --- /dev/null +++ b/examples/glue/glue.roc @@ -0,0 +1,7 @@ +app [main] { pf: platform "rust-platform/main.roc" } + +main = + msg = "Roc <3 Rust, also on stderr!\n" + StdoutWrite("Roc <3 Rust!\n", \{} -> + StderrWrite(msg, \{} -> + Done)) diff --git a/examples/glue/rust-platform/main.roc b/examples/glue/rust-platform/main.roc new file mode 100644 index 00000000000..657653f7e2e --- /dev/null +++ b/examples/glue/rust-platform/main.roc @@ -0,0 +1,17 @@ +platform "echo-in-rust" + requires {} { main : _ } + exposes [] + packages {} + imports [] + provides [main_for_host] + +# main_for_host : [StdoutWrite Str (({} -> Op) as Fx0), StderrWrite Str (({} -> Op) as Fx1), Done] as Op +main_for_host : [StdoutWrite Str ({} -> Op), StderrWrite Str ({} -> Op), Done] as Op +main_for_host = main + +# main_for_host : { x: Str, y: {} -> Str } +# main_for_host = +# y = "foo" +# +# when main is +# _ -> { x: "bar", y: \{} -> y } diff --git a/examples/glue/rust-platform/src/glue.rs b/examples/glue/rust-platform/src/glue.rs new file mode 100644 index 00000000000..b0787246928 --- /dev/null +++ b/examples/glue/rust-platform/src/glue.rs @@ -0,0 +1,744 @@ +// ⚠️ GENERATED CODE ⚠️ - this entire file was generated by the `roc glue` CLI command + +#![allow(unused_unsafe)] +#![allow(unused_variables)] +#![allow(dead_code)] +#![allow(unused_mut)] +#![allow(non_snake_case)] +#![allow(non_camel_case_types)] +#![allow(non_upper_case_globals)] +#![allow(clippy::undocumented_unsafe_blocks)] +#![allow(clippy::redundant_static_lifetimes)] +#![allow(clippy::unused_unit)] +#![allow(clippy::missing_safety_doc)] +#![allow(clippy::let_and_return)] +#![allow(clippy::missing_safety_doc)] +#![allow(clippy::redundant_static_lifetimes)] +#![allow(clippy::needless_borrow)] +#![allow(clippy::clone_on_copy)] + +type Op_StderrWrite = roc_std::RocStr; +type Op_StdoutWrite = roc_std::RocStr; +type TODO_roc_function_69 = roc_std::RocStr; +type TODO_roc_function_70 = roc_std::RocStr; + +#[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" +))] +#[derive(Clone, Copy, PartialEq, PartialOrd, Eq, Ord, Hash)] +#[repr(u8)] +pub enum discriminant_Op { + Done = 0, + StderrWrite = 1, + StdoutWrite = 2, +} + +impl core::fmt::Debug for discriminant_Op { + fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { + match self { + Self::Done => f.write_str("discriminant_Op::Done"), + Self::StderrWrite => f.write_str("discriminant_Op::StderrWrite"), + Self::StdoutWrite => f.write_str("discriminant_Op::StdoutWrite"), + } + } +} + +#[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" +))] +#[repr(transparent)] +pub struct Op { + pointer: *mut union_Op, +} + +#[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" +))] +#[repr(C)] +union union_Op { + StderrWrite: core::mem::ManuallyDrop, + StdoutWrite: core::mem::ManuallyDrop, + _sizer: [u8; 8], +} + +#[cfg(any( + target_arch = "arm", + target_arch = "arm", + target_arch = "aarch64", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86", + target_arch = "x86_64", + target_arch = "x86_64" +))] +//TODO HAS CLOSURE 2 +#[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" +))] +#[repr(C)] +pub struct RocFunction_66 { + pub closure_data: roc_std::RocList, +} + +impl RocFunction_66 { + pub fn force_thunk(mut self, arg_0: ()) -> Op { + extern "C" { + fn roc__main_for_host_0_caller(arg_0: &(), closure_data: *mut u8, output: *mut Op); + } + + let mut output = std::mem::MaybeUninit::uninit(); + let ptr = self.closure_data.as_mut_ptr(); + unsafe { roc__main_for_host_0_caller(&arg_0, ptr, output.as_mut_ptr()) }; + unsafe { output.assume_init() } + } +} + +#[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" +))] +#[repr(C)] +pub struct RocFunction_67 { + pub closure_data: roc_std::RocList, +} + +impl RocFunction_67 { + pub fn force_thunk(mut self, arg_0: ()) -> Op { + extern "C" { + fn roc__main_for_host_1_caller(arg_0: &(), closure_data: *mut u8, output: *mut Op); + } + + let mut output = std::mem::MaybeUninit::uninit(); + let ptr = self.closure_data.as_mut_ptr(); + unsafe { roc__main_for_host_1_caller(&arg_0, ptr, output.as_mut_ptr()) }; + unsafe { output.assume_init() } + } +} + +impl Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + #[inline(always)] + fn storage(&self) -> Option<&core::cell::Cell> { + let mask = match std::mem::size_of::() { + 4 => 0b11, + 8 => 0b111, + _ => unreachable!(), + }; + + // NOTE: pointer provenance is probably lost here + let unmasked_address = (self.pointer as usize) & !mask; + let untagged = unmasked_address as *const core::cell::Cell; + + if untagged.is_null() { + None + } else { + unsafe { Some(&*untagged.sub(1)) } + } + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Returns which variant this tag union holds. Note that this never includes a payload! + pub fn discriminant(&self) -> discriminant_Op { + // The discriminant is stored in the unused bytes at the end of the recursive pointer + unsafe { core::mem::transmute::((self.pointer as u8) & 0b11) } + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Internal helper + fn tag_discriminant(pointer: *mut union_Op, discriminant: discriminant_Op) -> *mut union_Op { + // The discriminant is stored in the unused bytes at the end of the union pointer + let untagged = (pointer as usize) & (!0b11 as usize); + let tagged = untagged | (discriminant as usize); + + tagged as *mut union_Op + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Internal helper + fn union_pointer(&self) -> *mut union_Op { + // The discriminant is stored in the unused bytes at the end of the union pointer + ((self.pointer as usize) & (!0b11 as usize)) as *mut union_Op + } + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// A tag named Done, which has no payload. + pub const Done: Self = Self { + pointer: core::ptr::null_mut(), + }; + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StderrWrite` and return its payload at index 0. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StderrWrite`. + pub unsafe fn get_StderrWrite_0(&self) -> roc_std::RocStr { + debug_assert_eq!(self.discriminant(), discriminant_Op::StderrWrite); + + extern "C" { + #[link_name = "roc__getter__2_generic"] + fn getter(_: *mut roc_std::RocStr, _: *const Op); + } + + let mut ret = core::mem::MaybeUninit::uninit(); + getter(ret.as_mut_ptr(), self); + ret.assume_init() + } + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StderrWrite` and return its payload at index 1. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StderrWrite`. + pub unsafe fn get_StderrWrite_1(&self) -> RocFunction_67 { + debug_assert_eq!(self.discriminant(), discriminant_Op::StderrWrite); + + extern "C" { + #[link_name = "roc__getter__3_size"] + fn size() -> usize; + + #[link_name = "roc__getter__3_generic"] + fn getter(_: *mut u8, _: *const Op); + } + + // allocate memory to store this variably-sized value + // allocates with roc_alloc, but that likely still uses the heap + let it = std::iter::repeat(0xAAu8).take(size()); + let mut bytes = roc_std::RocList::from_iter(it); + + getter(bytes.as_mut_ptr(), self); + + RocFunction_67 { + closure_data: bytes, + } + } + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// Construct a tag named `StderrWrite`, with the appropriate payload + pub fn StderrWrite(arg: Op_StderrWrite) -> Self { + let size = core::mem::size_of::(); + let align = core::mem::align_of::() as u32; + + unsafe { + let ptr = roc_std::roc_alloc_refcounted::(); + + *ptr = union_Op { + StderrWrite: core::mem::ManuallyDrop::new(arg), + }; + + Self { + pointer: Self::tag_discriminant(ptr, discriminant_Op::StderrWrite), + } + } + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StderrWrite` and convert it to `StderrWrite`'s payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StderrWrite`. + pub unsafe fn into_StderrWrite(mut self) -> Op_StderrWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StderrWrite); + let payload = { + let ptr = (self.pointer as usize & !0b11) as *mut union_Op; + let mut uninitialized = core::mem::MaybeUninit::uninit(); + let swapped = unsafe { + core::mem::replace( + &mut (*ptr).StderrWrite, + core::mem::ManuallyDrop::new(uninitialized.assume_init()), + ) + }; + + core::mem::forget(self); + + core::mem::ManuallyDrop::into_inner(swapped) + }; + + payload + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StderrWrite` and return its payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StderrWrite`. + pub unsafe fn as_StderrWrite(&self) -> &Op_StderrWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StderrWrite); + let payload = { + let ptr = (self.pointer as usize & !0b11) as *mut union_Op; + + unsafe { &(*ptr).StderrWrite } + }; + + &payload + } + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StdoutWrite` and return its payload at index 0. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StdoutWrite`. + pub unsafe fn get_StdoutWrite_0(&self) -> roc_std::RocStr { + debug_assert_eq!(self.discriminant(), discriminant_Op::StdoutWrite); + + extern "C" { + #[link_name = "roc__getter__2_generic"] + fn getter(_: *mut roc_std::RocStr, _: *const Op); + } + + let mut ret = core::mem::MaybeUninit::uninit(); + getter(ret.as_mut_ptr(), self); + ret.assume_init() + } + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StdoutWrite` and return its payload at index 1. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StdoutWrite`. + pub unsafe fn get_StdoutWrite_1(&self) -> RocFunction_66 { + debug_assert_eq!(self.discriminant(), discriminant_Op::StdoutWrite); + + extern "C" { + #[link_name = "roc__getter__3_size"] + fn size() -> usize; + + #[link_name = "roc__getter__3_generic"] + fn getter(_: *mut u8, _: *const Op); + } + + // allocate memory to store this variably-sized value + // allocates with roc_alloc, but that likely still uses the heap + let it = std::iter::repeat(0xAAu8).take(size()); + let mut bytes = roc_std::RocList::from_iter(it); + + getter(bytes.as_mut_ptr(), self); + + RocFunction_66 { + closure_data: bytes, + } + } + + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + /// Construct a tag named `StdoutWrite`, with the appropriate payload + pub fn StdoutWrite(arg: Op_StdoutWrite) -> Self { + let size = core::mem::size_of::(); + let align = core::mem::align_of::() as u32; + + unsafe { + let ptr = roc_std::roc_alloc_refcounted::(); + + *ptr = union_Op { + StdoutWrite: core::mem::ManuallyDrop::new(arg), + }; + + Self { + pointer: Self::tag_discriminant(ptr, discriminant_Op::StdoutWrite), + } + } + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StdoutWrite` and convert it to `StdoutWrite`'s payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StdoutWrite`. + pub unsafe fn into_StdoutWrite(mut self) -> Op_StdoutWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StdoutWrite); + let payload = { + let ptr = (self.pointer as usize & !0b11) as *mut union_Op; + let mut uninitialized = core::mem::MaybeUninit::uninit(); + let swapped = unsafe { + core::mem::replace( + &mut (*ptr).StdoutWrite, + core::mem::ManuallyDrop::new(uninitialized.assume_init()), + ) + }; + + core::mem::forget(self); + + core::mem::ManuallyDrop::into_inner(swapped) + }; + + payload + } + + #[cfg(any(target_arch = "arm", target_arch = "wasm32", target_arch = "x86"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StdoutWrite` and return its payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StdoutWrite`. + pub unsafe fn as_StdoutWrite(&self) -> &Op_StdoutWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StdoutWrite); + let payload = { + let ptr = (self.pointer as usize & !0b11) as *mut union_Op; + + unsafe { &(*ptr).StdoutWrite } + }; + + &payload + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Returns which variant this tag union holds. Note that this never includes a payload! + pub fn discriminant(&self) -> discriminant_Op { + // The discriminant is stored in the unused bytes at the end of the recursive pointer + unsafe { core::mem::transmute::((self.pointer as u8) & 0b111) } + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Internal helper + fn tag_discriminant(pointer: *mut union_Op, discriminant: discriminant_Op) -> *mut union_Op { + // The discriminant is stored in the unused bytes at the end of the union pointer + let untagged = (pointer as usize) & (!0b111 as usize); + let tagged = untagged | (discriminant as usize); + + tagged as *mut union_Op + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Internal helper + fn union_pointer(&self) -> *mut union_Op { + // The discriminant is stored in the unused bytes at the end of the union pointer + ((self.pointer as usize) & (!0b111 as usize)) as *mut union_Op + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StderrWrite` and convert it to `StderrWrite`'s payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StderrWrite`. + pub unsafe fn into_StderrWrite(mut self) -> Op_StderrWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StderrWrite); + let payload = { + let ptr = (self.pointer as usize & !0b111) as *mut union_Op; + let mut uninitialized = core::mem::MaybeUninit::uninit(); + let swapped = unsafe { + core::mem::replace( + &mut (*ptr).StderrWrite, + core::mem::ManuallyDrop::new(uninitialized.assume_init()), + ) + }; + + core::mem::forget(self); + + core::mem::ManuallyDrop::into_inner(swapped) + }; + + payload + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StderrWrite` and return its payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StderrWrite`. + pub unsafe fn as_StderrWrite(&self) -> &Op_StderrWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StderrWrite); + let payload = { + let ptr = (self.pointer as usize & !0b111) as *mut union_Op; + + unsafe { &(*ptr).StderrWrite } + }; + + &payload + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StdoutWrite` and convert it to `StdoutWrite`'s payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StdoutWrite`. + pub unsafe fn into_StdoutWrite(mut self) -> Op_StdoutWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StdoutWrite); + let payload = { + let ptr = (self.pointer as usize & !0b111) as *mut union_Op; + let mut uninitialized = core::mem::MaybeUninit::uninit(); + let swapped = unsafe { + core::mem::replace( + &mut (*ptr).StdoutWrite, + core::mem::ManuallyDrop::new(uninitialized.assume_init()), + ) + }; + + core::mem::forget(self); + + core::mem::ManuallyDrop::into_inner(swapped) + }; + + payload + } + + #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] + /// Unsafely assume this `Op` has a `.discriminant()` of `StdoutWrite` and return its payload. + /// (Always examine `.discriminant()` first to make sure this is the correct variant!) + /// Panics in debug builds if the `.discriminant()` doesn't return `StdoutWrite`. + pub unsafe fn as_StdoutWrite(&self) -> &Op_StdoutWrite { + debug_assert_eq!(self.discriminant(), discriminant_Op::StdoutWrite); + let payload = { + let ptr = (self.pointer as usize & !0b111) as *mut union_Op; + + unsafe { &(*ptr).StdoutWrite } + }; + + &payload + } +} + +impl Drop for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn drop(&mut self) { + // We only need to do any work if there's actually a heap-allocated payload. + if let Some(storage) = self.storage() { + let mut new_storage = storage.get(); + + // Decrement the refcount + let needs_dealloc = !new_storage.is_readonly() && new_storage.decrease(); + + if needs_dealloc { + // Drop the payload first. + match self.discriminant() { + discriminant_Op::Done => {} + discriminant_Op::StderrWrite => unsafe { + core::mem::ManuallyDrop::drop(&mut (&mut *self.union_pointer()).StderrWrite) + }, + discriminant_Op::StdoutWrite => unsafe { + core::mem::ManuallyDrop::drop(&mut (&mut *self.union_pointer()).StdoutWrite) + }, + } + + // Dealloc the pointer + let alignment = + core::mem::align_of::().max(core::mem::align_of::()); + + unsafe { + crate::roc_dealloc(storage.as_ptr().cast(), alignment as u32); + } + } else { + // Write the storage back. + storage.set(new_storage); + } + } + } +} + +impl Eq for Op {} + +impl PartialEq for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn eq(&self, other: &Self) -> bool { + if self.discriminant() != other.discriminant() { + return false; + } + + unsafe { + match self.discriminant() { + discriminant_Op::Done => true, + discriminant_Op::StderrWrite => { + (&*self.union_pointer()).StderrWrite == (&*other.union_pointer()).StderrWrite + } + discriminant_Op::StdoutWrite => { + (&*self.union_pointer()).StdoutWrite == (&*other.union_pointer()).StdoutWrite + } + } + } + } +} + +impl PartialOrd for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn partial_cmp(&self, other: &Self) -> Option { + match self.discriminant().partial_cmp(&other.discriminant()) { + Some(core::cmp::Ordering::Equal) => {} + not_eq => return not_eq, + } + + unsafe { + match self.discriminant() { + discriminant_Op::Done => Some(core::cmp::Ordering::Equal), + discriminant_Op::StderrWrite => (&*self.union_pointer()) + .StderrWrite + .partial_cmp(&(&*other.union_pointer()).StderrWrite), + discriminant_Op::StdoutWrite => (&*self.union_pointer()) + .StdoutWrite + .partial_cmp(&(&*other.union_pointer()).StdoutWrite), + } + } + } +} + +impl Ord for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn cmp(&self, other: &Self) -> core::cmp::Ordering { + match self.discriminant().cmp(&other.discriminant()) { + core::cmp::Ordering::Equal => {} + not_eq => return not_eq, + } + + unsafe { + match self.discriminant() { + discriminant_Op::Done => core::cmp::Ordering::Equal, + discriminant_Op::StderrWrite => (&*self.union_pointer()) + .StderrWrite + .cmp(&(&*other.union_pointer()).StderrWrite), + discriminant_Op::StdoutWrite => (&*self.union_pointer()) + .StdoutWrite + .cmp(&(&*other.union_pointer()).StdoutWrite), + } + } + } +} + +impl Clone for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn clone(&self) -> Self { + if let Some(storage) = self.storage() { + let mut new_storage = storage.get(); + if !new_storage.is_readonly() { + new_storage.increment_reference_count(); + storage.set(new_storage); + } + } + + Self { + pointer: self.pointer, + } + } +} + +impl core::hash::Hash for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn hash(&self, state: &mut H) { + match self.discriminant() { + discriminant_Op::Done => discriminant_Op::Done.hash(state), + discriminant_Op::StderrWrite => unsafe { + discriminant_Op::StderrWrite.hash(state); + (&*self.union_pointer()).StderrWrite.hash(state); + }, + discriminant_Op::StdoutWrite => unsafe { + discriminant_Op::StdoutWrite.hash(state); + (&*self.union_pointer()).StdoutWrite.hash(state); + }, + } + } +} + +impl core::fmt::Debug for Op { + #[cfg(any( + target_arch = "arm", + target_arch = "aarch64", + target_arch = "wasm32", + target_arch = "x86", + target_arch = "x86_64" + ))] + fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { + f.write_str("Op::")?; + + unsafe { + match self.discriminant() { + discriminant_Op::Done => f.write_str("Done"), + discriminant_Op::StderrWrite => f + .debug_tuple("StderrWrite") + // TODO HAS CLOSURE + .finish(), + discriminant_Op::StdoutWrite => f + .debug_tuple("StdoutWrite") + // TODO HAS CLOSURE + .finish(), + } + } + } +} diff --git a/examples/glue/rust-platform/src/lib.rs b/examples/glue/rust-platform/src/lib.rs new file mode 100644 index 00000000000..64bf071a65f --- /dev/null +++ b/examples/glue/rust-platform/src/lib.rs @@ -0,0 +1,123 @@ +#![allow(non_snake_case)] + +use core::ffi::c_void; +use roc_app::Op; +use roc_std::RocStr; +use std::ffi::CStr; +use std::io::Write; +use std::os::raw::c_char; + +use roc_app::main_for_host as roc_main; + +#[no_mangle] +pub unsafe extern "C" fn roc_alloc(size: usize, _alignment: u32) -> *mut c_void { + return libc::malloc(size); +} + +#[no_mangle] +pub unsafe extern "C" fn roc_realloc( + c_ptr: *mut c_void, + new_size: usize, + _old_size: usize, + _alignment: u32, +) -> *mut c_void { + return libc::realloc(c_ptr, new_size); +} + +#[no_mangle] +pub unsafe extern "C" fn roc_dealloc(c_ptr: *mut c_void, _alignment: u32) { + return libc::free(c_ptr); +} + +#[no_mangle] +pub unsafe extern "C" fn roc_panic(msg: *mut RocStr, tag_id: u32) { + match tag_id { + 0 => { + eprintln!("Roc standard library hit a panic: {}", &*msg); + } + 1 => { + eprintln!("Application hit a panic: {}", &*msg); + } + _ => unreachable!(), + } + std::process::exit(1); +} + +#[no_mangle] +pub unsafe extern "C" fn roc_dbg(loc: *mut RocStr, msg: *mut RocStr, src: *mut RocStr) { + eprintln!("[{}] {} = {}", &*loc, &*src, &*msg); +} + +#[no_mangle] +pub unsafe extern "C" fn roc_memset(dst: *mut c_void, c: i32, n: usize) -> *mut c_void { + libc::memset(dst, c, n) +} + +#[cfg(unix)] +#[no_mangle] +pub unsafe extern "C" fn roc_getppid() -> libc::pid_t { + libc::getppid() +} + +#[cfg(unix)] +#[no_mangle] +pub unsafe extern "C" fn roc_mmap( + addr: *mut libc::c_void, + len: libc::size_t, + prot: libc::c_int, + flags: libc::c_int, + fd: libc::c_int, + offset: libc::off_t, +) -> *mut libc::c_void { + libc::mmap(addr, len, prot, flags, fd, offset) +} + +#[cfg(unix)] +#[no_mangle] +pub unsafe extern "C" fn roc_shm_open( + name: *const libc::c_char, + oflag: libc::c_int, + mode: libc::mode_t, +) -> libc::c_int { + libc::shm_open(name, oflag, mode as libc::c_uint) +} + +#[no_mangle] +pub extern "C" fn rust_main() -> i32 { + use roc_app::discriminant_Op::*; + + println!("Let's do things!"); + + let mut op: Op = roc_main(); + + loop { + match op.discriminant() { + StdoutWrite => { + let stdout_write = op.get_StdoutWrite(); + let output: RocStr = stdout_write.f0; + op = unsafe { stdout_write.f1.force_thunk() }; + + if let Err(e) = std::io::stdout().write_all(output.as_bytes()) { + panic!("Writing to stdout failed! {:?}", e); + } + } + StderrWrite => { + let stderr_write = op.get_StderrWrite(); + let output: RocStr = stderr_write.f0; + op = unsafe { stderr_write.f1.force_thunk() }; + + if let Err(e) = std::io::stderr().write_all(output.as_bytes()) { + panic!("Writing to stdout failed! {:?}", e); + } + } + Done => { + break; + } + } + } + + println!("Done!"); + + // Exit code + 0 +} diff --git a/examples/jvm-interop/bridge.c b/examples/jvm-interop/bridge.c new file mode 100644 index 00000000000..0e2a9827532 --- /dev/null +++ b/examples/jvm-interop/bridge.c @@ -0,0 +1,384 @@ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include "javaSource_Demo.h" + +JavaVM* vm; + +#define ERR_MSG_MAX_SIZE 256 + +jmp_buf exception_buffer; +char* err_msg[ERR_MSG_MAX_SIZE] = {0}; + +jint JNI_OnLoad(JavaVM *loadedVM, void *reserved) +{ + // https://docs.oracle.com/javase/8/docs/technotes/guides/jni/spec/invocation.html + vm = loadedVM; + return JNI_VERSION_1_2; +} + +void *roc_alloc(size_t size, unsigned int alignment) +{ + return malloc(size); +} + +void *roc_realloc(void *ptr, size_t new_size, size_t old_size, + unsigned int alignment) +{ + return realloc(ptr, new_size); +} + +void roc_dealloc(void *ptr, unsigned int alignment) +{ + free(ptr); +} + +void *roc_memset(void *str, int c, size_t n) +{ + return memset(str, c, n); +} + +// Reference counting + +// If the refcount is set to this, that means the allocation is +// stored in readonly memory in the binary, and we must not +// attempt to increment or decrement it; if we do, we'll segfault! +const ssize_t REFCOUNT_READONLY = 0; +const ssize_t REFCOUNT_ONE = (ssize_t)PTRDIFF_MIN; +const size_t MASK = (size_t)PTRDIFF_MIN; + +// Increment reference count, given a pointer to the first element in a collection. +// We don't need to check for overflow because in order to overflow a usize worth of refcounts, +// you'd need to somehow have more pointers in memory than the OS's virtual address space can hold. +void incref(uint8_t* bytes, uint32_t alignment) +{ + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount + 1; + } +} + +// Decrement reference count, given a pointer to the first element in a collection. +// Then call roc_dealloc if nothing is referencing this collection anymore. +void decref(uint8_t* bytes, uint32_t alignment) +{ + if (bytes == NULL) { + return; + } + + size_t extra_bytes = (sizeof(size_t) >= (size_t)alignment) ? sizeof(size_t) : (size_t)alignment; + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount - 1; + + if (refcount == REFCOUNT_ONE) { + void *original_allocation = (void *)(refcount_ptr - (extra_bytes - sizeof(size_t))); + + roc_dealloc(original_allocation, alignment); + } + } +} + +struct RocListI32 +{ + int32_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocListI32 init_roclist_i32(int32_t *bytes, size_t len) +{ + if (len == 0) + { + struct RocListI32 ret = { + .len = 0, + .bytes = NULL, + .capacity = 0, + }; + + return ret; + } + else + { + size_t refcount_size = sizeof(size_t); + ssize_t* data = (ssize_t*)roc_alloc(len + refcount_size, alignof(size_t)); + data[0] = REFCOUNT_ONE; + int32_t *new_content = (int32_t *)(data + 1); + + struct RocListI32 ret; + + memcpy(new_content, bytes, len * sizeof(int32_t)); + + ret.bytes = new_content; + ret.len = len; + ret.capacity = len; + + return ret; + } +} +// RocListU8 (List U8) + +struct RocListU8 +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocListU8 init_roclist_u8(uint8_t *bytes, size_t len) +{ + if (len == 0) + { + struct RocListU8 ret = { + .len = 0, + .bytes = NULL, + .capacity = 0, + }; + + return ret; + } + else + { + + size_t refcount_size = sizeof(size_t); + ssize_t* data = (ssize_t*)roc_alloc(len + refcount_size, alignof(size_t)); + data[0] = REFCOUNT_ONE; + uint8_t *new_content = (uint8_t *)(data + 1); + + struct RocListU8 ret; + + memcpy(new_content, bytes, len * sizeof(uint8_t)); + + ret.bytes = new_content; + ret.len = len; + ret.capacity = len; + + return ret; + } +} + +// RocStr + +struct RocStr +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocStr init_rocstr(uint8_t *bytes, size_t len) +{ + if (len < sizeof(struct RocStr)) + { + // Start out with zeroed memory, so that + // if we end up comparing two small RocStr values + // for equality, we won't risk memory garbage resulting + // in two equal strings appearing unequal. + struct RocStr ret = { + .len = 0, + .bytes = NULL, + .capacity = 0, + }; + + // Copy the bytes into the stack allocation + memcpy(&ret, bytes, len); + + // Record the string's len in the last byte of the stack allocation + ((uint8_t *)&ret)[sizeof(struct RocStr) - 1] = (uint8_t)len | 0b10000000; + + return ret; + } + else + { + // A large RocStr is the same as a List U8 (aka RocListU8) in memory. + struct RocListU8 roc_bytes = init_roclist_u8(bytes, len); + + struct RocStr ret = { + .len = roc_bytes.len, + .bytes = roc_bytes.bytes, + .capacity = roc_bytes.capacity, + }; + + return ret; + } +} + +bool is_small_str(struct RocStr str) +{ + return ((ssize_t)str.capacity) < 0; +} + +bool is_seamless_str_slice(struct RocStr str) +{ + return ((ssize_t)str.len) < 0; +} + +bool is_seamless_listi32_slice(struct RocListI32 list) +{ + return ((ssize_t)list.capacity) < 0; +} + +// Determine the len of the string, taking into +// account the small string optimization +size_t roc_str_len(struct RocStr str) +{ + uint8_t *bytes = (uint8_t *)&str; + uint8_t last_byte = bytes[sizeof(str) - 1]; + uint8_t last_byte_xored = last_byte ^ 0b10000000; + size_t small_len = (size_t)(last_byte_xored); + size_t big_len = str.len; + + // Avoid branch misprediction costs by always + // determining both small_len and big_len, + // so this compiles to a cmov instruction. + if (is_small_str(str)) + { + return small_len; + } + else + { + return big_len; + } +} + +__attribute__((noreturn)) void roc_panic(struct RocStr *msg, unsigned int tag_id) +{ + char* bytes = is_small_str(*msg) ? (char*)msg : (char*)msg->bytes; + const size_t str_len = roc_str_len(*msg); + + int len = str_len > ERR_MSG_MAX_SIZE ? ERR_MSG_MAX_SIZE : str_len; + strncpy((char*)err_msg, bytes, len); + + // Free the underlying allocation if needed. + if (!is_small_str(*msg)) { + if (is_seamless_str_slice(*msg)){ + decref((uint8_t *)(msg->capacity << 1), alignof(uint8_t *)); + } + else { + decref(msg->bytes, alignof(uint8_t *)); + } + } + + longjmp(exception_buffer, 1); +} + +void roc_dbg(struct RocStr *loc, struct RocStr *msg, struct RocStr *src) { + char* loc_bytes = is_small_str(*loc) ? (char*)loc : (char*)loc->bytes; + char* src_bytes = is_small_str(*src) ? (char*)src : (char*)src->bytes; + char* msg_bytes = is_small_str(*msg) ? (char*)msg : (char*)msg->bytes; + fprintf(stderr, "[%s] %s = %s\n", loc_bytes, src_bytes, msg_bytes); +} + +extern void roc__program_for_host_1__InterpolateString_caller(struct RocStr *name, char *closure_data, struct RocStr *ret); + +extern void roc__program_for_host_1__MulArrByScalar_caller(struct RocListI32 *arr, int32_t *scalar, char *closure_data, struct RocListI32 *ret); + +extern void roc__program_for_host_1__Factorial_caller(int64_t *scalar, char *closure_data, int64_t *ret); + + +JNIEXPORT jstring JNICALL Java_javaSource_Demo_sayHello + (JNIEnv *env, jobject thisObj, jstring name) +{ + const char *jnameChars = (*env)->GetStringUTFChars(env, name, 0); + // we copy just in case the jvm would try to reclaim that mem + uint8_t *cnameChars = (uint8_t *)strdup(jnameChars); + size_t nameLength = (size_t) (*env)->GetStringLength(env, name); + (*env)->ReleaseStringUTFChars(env, name, jnameChars); + + + struct RocStr rocName = init_rocstr(cnameChars, nameLength); + struct RocStr ret = {0}; + + // Call the Roc function to populate `ret`'s bytes. + roc__program_for_host_1__InterpolateString_caller(&rocName, 0, &ret); + jbyte *bytes = (jbyte*)(is_small_str(ret) ? (uint8_t*)&ret : ret.bytes); + + // java being java making this a lot harder than it needs to be + // https://stackoverflow.com/questions/32205446/getting-true-utf-8-characters-in-java-jni + // https://docs.oracle.com/javase/1.5.0/docs/guide/jni/spec/types.html#wp16542 + // but as i refuse converting those manually to their correct form, we just let the jvm handle the conversion + // by first making a java byte array then converting the byte array to our final jstring + jbyteArray byteArray = (*env)->NewByteArray(env, ret.len); + (*env)->SetByteArrayRegion(env, byteArray, 0, ret.len, bytes); + + jstring charsetName = (*env)->NewStringUTF(env, "UTF-8"); + jclass stringClass = (*env)->FindClass(env, "java/lang/String"); + // https://docs.oracle.com/javase/7/docs/jdk/api/jpda/jdi/com/sun/jdi/doc-files/signature.html + jmethodID stringConstructor = (*env)->GetMethodID(env, stringClass, "", "([BLjava/lang/String;)V"); + jstring result = (*env)->NewObject(env, stringClass, stringConstructor, byteArray, charsetName); + + // cleanup + if (!is_seamless_str_slice(ret)) { + decref(ret.bytes, alignof(uint8_t *)); + } + + (*env)->DeleteLocalRef(env, charsetName); + (*env)->DeleteLocalRef(env, byteArray); + + free(cnameChars); + + return result; +} + + +JNIEXPORT jintArray JNICALL Java_javaSource_Demo_mulArrByScalar + (JNIEnv *env, jobject thisObj, jintArray arr, jint scalar) +{ + // extract data from jvm types + jint* jarr = (*env)->GetIntArrayElements(env, arr, NULL); + jsize len = (*env)->GetArrayLength(env, arr); + + // pass data to platform + struct RocListI32 originalArray = init_roclist_i32(jarr, len); + incref((void *)&originalArray, alignof(int32_t*)); + struct RocListI32 ret = {0}; + + roc__program_for_host_1__MulArrByScalar_caller(&originalArray, &scalar, 0, &ret); + + // create jvm constructs + jintArray multiplied = (*env)->NewIntArray(env, ret.len); + (*env)->SetIntArrayRegion(env, multiplied, 0, ret.len, (jint*) ret.bytes); + + // cleanup + (*env)->ReleaseIntArrayElements(env, arr, jarr, 0); + + if (is_seamless_listi32_slice(ret)) { + decref((void *)(ret.capacity << 1), alignof(uint8_t *)); + } + else { + decref((void *)ret.bytes, alignof(uint8_t *)); + } + + return multiplied; +} + +JNIEXPORT jlong JNICALL Java_javaSource_Demo_factorial + (JNIEnv *env, jobject thisObj, jlong num) +{ + int64_t ret; + // can crash - meaning call roc_panic, so we set a jump here + if (setjmp(exception_buffer)) { + // exception was thrown, handle it + jclass exClass = (*env)->FindClass(env, "java/lang/RuntimeException"); + const char *msg = (const char *)err_msg; + return (*env)->ThrowNew(env, exClass, msg); + } + else { + int64_t n = (int64_t)num; + roc__program_for_host_1__Factorial_caller(&n, 0, &ret); + return ret; + } +} diff --git a/examples/jvm-interop/impl.roc b/examples/jvm-interop/impl.roc new file mode 100644 index 00000000000..5b72fc724fa --- /dev/null +++ b/examples/jvm-interop/impl.roc @@ -0,0 +1,23 @@ +app [program] { pf: platform "platform.roc" } + +interpolate_string : Str -> Str +interpolate_string = \name -> + "Hello from Roc $(name)!!!🤘🤘🤘" + +# jint is i32 +mul_arr_by_scalar : List I32, I32 -> List I32 +mul_arr_by_scalar = \arr, scalar -> + List.map(arr, \x -> x * scalar) + +# java doesn't have unsigned numbers so we cope with long +# factorial : I64 -> I64 +factorial = \n -> + if n < 0 then + # while we get the chance, exemplify a roc panic in an interop + crash("No negatives here!!!") + else if n == 0 then + 1 + else + n * (factorial((n - 1))) + +program = { interpolate_string, factorial, mul_arr_by_scalar } diff --git a/examples/jvm-interop/platform.roc b/examples/jvm-interop/platform.roc new file mode 100644 index 00000000000..933b0243e16 --- /dev/null +++ b/examples/jvm-interop/platform.roc @@ -0,0 +1,13 @@ +platform "jvm-interop" + requires {} { program : _ } + exposes [] + packages {} + imports [] + provides [program_for_host] + +program_for_host : { + interpolate_string : (Str -> Str) as InterpolateString, + mul_arr_by_scalar : (List I32, I32 -> List I32) as MulArrByScalar, + factorial : (I64 -> I64) as Factorial, +} +program_for_host = program diff --git a/examples/nodejs-interop/native-c-api/demo.c b/examples/nodejs-interop/native-c-api/demo.c new file mode 100644 index 00000000000..a46462dbde4 --- /dev/null +++ b/examples/nodejs-interop/native-c-api/demo.c @@ -0,0 +1,418 @@ +#include +#include +#include +#include +#include +#include +#include +#include + +napi_env napi_global_env; + +void *roc_alloc(size_t size, unsigned int alignment) { return malloc(size); } + +void *roc_realloc(void *ptr, size_t new_size, size_t old_size, + unsigned int alignment) +{ + return realloc(ptr, new_size); +} + +void roc_dealloc(void *ptr, unsigned int alignment) { free(ptr); } + +void roc_panic(void *ptr, unsigned int alignment) +{ + // WARNING: If roc_panic is called before napi_global_env is set, + // the result will be undefined behavior. So never call any Roc + // functions before setting napi_global_env! + napi_throw_error(napi_global_env, NULL, (char *)ptr); +} + +void roc_dbg(char* loc, char* msg, char* src) { + fprintf(stderr, "[%s] %s = %s\n", loc, src, msg); +} + +void *roc_memset(void *str, int c, size_t n) { return memset(str, c, n); } + +// Reference counting + +// If the refcount is set to this, that means the allocation is +// stored in readonly memory in the binary, and we must not +// attempt to increment or decrement it; if we do, we'll segfault! +const ssize_t REFCOUNT_READONLY = 0; +const ssize_t REFCOUNT_ONE = (ssize_t)PTRDIFF_MIN; +const size_t MASK = (size_t)PTRDIFF_MIN; + +// Increment reference count, given a pointer to the first element in a collection. +// We don't need to check for overflow because in order to overflow a usize worth of refcounts, +// you'd need to somehow have more pointers in memory than the OS's virtual address space can hold. +void incref(uint8_t* bytes, uint32_t alignment) +{ + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount + 1; + } +} + +// Decrement reference count, given a pointer to the first byte of a collection's elements. +// Then call roc_dealloc if nothing is referencing this collection anymore. +void decref_heap_bytes(uint8_t* bytes, uint32_t alignment) +{ + size_t extra_bytes = (sizeof(size_t) >= (size_t)alignment) ? sizeof(size_t) : (size_t)alignment; + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount - 1; + + if (refcount == REFCOUNT_ONE) { + void *original_allocation = (void *)(refcount_ptr - (extra_bytes - sizeof(size_t))); + + roc_dealloc(original_allocation, alignment); + } + } +} + +// RocBytes (List U8) + +struct RocBytes +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocBytes empty_rocbytes() +{ + struct RocBytes ret = { + .len = 0, + .bytes = NULL, + .capacity = 0, + }; + + return ret; +} + +struct RocBytes init_rocbytes(uint8_t *bytes, size_t len) +{ + if (len == 0) + { + return empty_rocbytes(); + } + else + { + struct RocBytes ret; + size_t refcount_size = sizeof(size_t); + uint8_t *new_refcount = (uint8_t *)roc_alloc(len + refcount_size, __alignof__(size_t)); + uint8_t *new_content = new_refcount + refcount_size; + + ((ssize_t *)new_refcount)[0] = REFCOUNT_ONE; + + memcpy(new_content, bytes, len); + + ret.bytes = new_content; + ret.len = len; + ret.capacity = len; + + return ret; + } +} + +// RocStr + +struct RocStr +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocStr empty_roc_str() +{ + struct RocStr ret = { + .len = 0, + .bytes = NULL, + .capacity = MASK, + }; + + return ret; +} + +// Record the small string's length in the last byte of the given stack allocation +void write_small_str_len(size_t len, struct RocStr *str) { + ((uint8_t *)str)[sizeof(struct RocStr) - 1] = (uint8_t)len | 0b10000000; +} + +struct RocStr roc_str_init_small(uint8_t *bytes, size_t len) +{ + // Start out with zeroed memory, so that + // if we end up comparing two small RocStr values + // for equality, we won't risk memory garbage resulting + // in two equal strings appearing unequal. + struct RocStr ret = empty_roc_str(); + + // Copy the bytes into the stack allocation + memcpy(&ret, bytes, len); + + write_small_str_len(len, &ret); + + return ret; +} + +struct RocStr roc_str_init_large(uint8_t *bytes, size_t len, size_t capacity) +{ + // A large RocStr is the same as a List U8 (aka RocBytes) in memory. + struct RocBytes roc_bytes = init_rocbytes(bytes, len); + + struct RocStr ret = { + .len = roc_bytes.len, + .bytes = roc_bytes.bytes, + .capacity = roc_bytes.capacity, + }; + + return ret; +} + +bool is_small_str(struct RocStr str) { return ((ssize_t)str.capacity) < 0; } + +// Determine the length of the string, taking into +// account the small string optimization +size_t roc_str_len(struct RocStr str) +{ + uint8_t *bytes = (uint8_t *)&str; + uint8_t last_byte = bytes[sizeof(str) - 1]; + uint8_t last_byte_xored = last_byte ^ 0b10000000; + size_t small_len = (size_t)(last_byte_xored); + size_t big_len = str.len & PTRDIFF_MAX; // Account for seamless slices + + // Avoid branch misprediction costs by always + // determining both small_len and big_len, + // so this compiles to a cmov instruction. + if (is_small_str(str)) + { + return small_len; + } + else + { + return big_len; + } +} + +void decref_large_str(struct RocStr str) +{ + uint8_t* bytes; + + if ((ssize_t)str.len < 0) + { + // This is a seamless slice, so the bytes are located in the capacity slot. + bytes = (uint8_t*)(str.capacity << 1); + } + else + { + bytes = str.bytes; + } + + decref_heap_bytes(bytes, __alignof__(uint8_t)); +} + + +// Turn the given Node string into a RocStr and return it +napi_status node_string_into_roc_str(napi_env env, napi_value node_string, struct RocStr *roc_str) { + size_t len; + napi_status status; + + // Passing NULL for a buffer (and size 0) will make it write the length of the string into `len`. + // https://nodejs.org/api/n-api.html#napi_get_value_string_utf8 + status = napi_get_value_string_utf8(env, node_string, NULL, 0, &len); + + if (status != napi_ok) + { + return status; + } + + // Node's "write a string into this buffer" function always writes a null terminator, + // so capacity will need to be length + 1. + // https://nodejs.org/api/n-api.html#napi_get_value_string_utf8 + size_t capacity = len + 1; + + // Create a RocStr and write it into the out param + if (capacity < sizeof(struct RocStr)) + { + // If it can fit in a small string, use the string itself as the buffer. + // First, zero out those bytes; small strings need to have zeroes for any bytes + // that are not part of the string, or else comparisons between small strings might fail. + *roc_str = empty_roc_str(); + + // This writes the actual number of bytes copied into len. Theoretically they should be the same, + // but it could be different if the buffer was somehow smaller. This way we guarantee that + // the RocStr does not present any memory garbage to the user. + status = napi_get_value_string_utf8(env, node_string, (char*)roc_str, sizeof(struct RocStr), &len); + + if (status != napi_ok) + { + return status; + } + + // We have to write the length into the buffer *after* Node copies its bytes in, + // because Node will have written a null terminator, which we may need to overwrite. + write_small_str_len(len, roc_str); + } + else + { + // capacity was too big for a small string, so make a heap allocation and write into that. + uint8_t *buf = (uint8_t*)roc_alloc(capacity, __alignof__(char)); + + // This writes the actual number of bytes copied into len. Theoretically they should be the same, + // but it could be different if the buffer was somehow smaller. This way we guarantee that + // the RocStr does not present any memory garbage to the user. + status = napi_get_value_string_utf8(env, node_string, (char*)buf, capacity, &len); + + if (status != napi_ok) + { + // Something went wrong, so free the bytes we just allocated before returning. + roc_dealloc((void *)&buf, __alignof__(char *)); + + return status; + } + + *roc_str = roc_str_init_large(buf, len, capacity); + } + + return status; +} + +// Consume the given RocStr (decrement its refcount) after creating a Node string from it. +napi_value roc_str_into_node_string(napi_env env, struct RocStr roc_str) { + bool is_small = is_small_str(roc_str); + char* roc_str_contents; + + if (is_small) + { + // In a small string, the string itself contains its contents. + roc_str_contents = (char*)&roc_str; + } + else + { + roc_str_contents = (char*)roc_str.bytes; + } + + napi_status status; + napi_value answer; + + status = napi_create_string_utf8(env, roc_str_contents, roc_str_len(roc_str), &answer); + + if (status != napi_ok) + { + answer = NULL; + } + + // Decrement the RocStr because we consumed it. + if (!is_small) + { + decref_large_str(roc_str); + } + + return answer; +} + +// Create a Node string from the given RocStr. +// Don't decrement the RocStr's refcount. (To decrement it, use roc_str_into_node_string instead.) +napi_value roc_str_as_node_string(napi_env env, struct RocStr roc_str) { + bool is_small = is_small_str(roc_str); + char* roc_str_contents; + + if (is_small) + { + // In a small string, the string itself contains its contents. + roc_str_contents = (char*)&roc_str; + } + else + { + roc_str_contents = (char*)roc_str.bytes; + } + + napi_status status; + napi_value answer; + + status = napi_create_string_utf8(env, roc_str_contents, roc_str_len(roc_str), &answer); + + if (status != napi_ok) + { + return NULL; + } + + // Do not decrement the RocStr's refcount because we did not consume it. + + return answer; +} + +extern void roc__main_for_host_1_exposed_generic(struct RocStr *ret, struct RocStr *arg); + +// Receive a string value from Node and pass it to Roc as a RocStr, then get a RocStr +// back from Roc and convert it into a Node string. +napi_value call_roc(napi_env env, napi_callback_info info) { + napi_status status; + + // roc_panic needs a napi_env in order to throw a Node exception, so we provide this + // one globally in case roc_panic gets called during the execution of our Roc function. + // + // According to the docs - https://nodejs.org/api/n-api.html#napi_env - + // it's very important that the napi_env that was passed into "the initial + // native function" is the one that's "passed to any subsequent nested Node-API calls," + // so we must override this every time we call this function (as opposed to, say, + // setting it once during init). + napi_global_env = env; + + // Get the argument passed to the Node function + size_t argc = 1; + napi_value argv[1]; + + status = napi_get_cb_info(env, info, &argc, argv, NULL, NULL); + + if (status != napi_ok) + { + return NULL; + } + + napi_value node_arg = argv[0]; + + struct RocStr roc_arg; + + status = node_string_into_roc_str(env, node_arg, &roc_arg); + + if (status != napi_ok) + { + return NULL; + } + + struct RocStr roc_ret; + // Call the Roc function to populate `roc_ret`'s bytes. + roc__main_for_host_1_exposed_generic(&roc_ret, &roc_arg); + + // Consume the RocStr to create the Node string. + return roc_str_into_node_string(env, roc_ret); +} + +napi_value init(napi_env env, napi_value exports) { + napi_status status; + napi_value fn; + + status = napi_create_function(env, NULL, 0, call_roc, NULL, &fn); + + if (status != napi_ok) + { + return NULL; + } + + status = napi_set_named_property(env, exports, "hello", fn); + + if (status != napi_ok) + { + return NULL; + } + + return exports; +} + +NAPI_MODULE(NODE_GYP_MODULE_NAME, init) diff --git a/examples/nodejs-interop/native-c-api/platform/main.roc b/examples/nodejs-interop/native-c-api/platform/main.roc new file mode 100644 index 00000000000..b633421669d --- /dev/null +++ b/examples/nodejs-interop/native-c-api/platform/main.roc @@ -0,0 +1,10 @@ +platform "nodejs-interop" + requires {} { main : Str -> Str } + exposes [] + packages {} + imports [] + provides [main_for_host] + +main_for_host : Str -> Str +main_for_host = \message -> + main(message) diff --git a/examples/nodejs-interop/wasm/platform/host.zig b/examples/nodejs-interop/wasm/platform/host.zig new file mode 100644 index 00000000000..2eeab845b03 --- /dev/null +++ b/examples/nodejs-interop/wasm/platform/host.zig @@ -0,0 +1,53 @@ +const str = @import("glue").str; +const builtin = @import("builtin"); +const RocStr = str.RocStr; + +comptime { + if (builtin.target.cpu.arch != .wasm32) { + @compileError("This platform is for WebAssembly only. You need to pass `--target wasm32` to the Roc compiler."); + } +} + +const Align = extern struct { a: usize, b: usize }; +extern fn malloc(size: usize) callconv(.C) ?*align(@alignOf(Align)) anyopaque; +extern fn realloc(c_ptr: [*]align(@alignOf(Align)) u8, size: usize) callconv(.C) ?*anyopaque; +extern fn free(c_ptr: [*]align(@alignOf(Align)) u8) callconv(.C) void; +extern fn memcpy(dest: *anyopaque, src: *anyopaque, count: usize) *anyopaque; + +export fn roc_alloc(size: usize, alignment: u32) callconv(.C) ?*anyopaque { + _ = alignment; + + return malloc(size); +} + +export fn roc_realloc(c_ptr: *anyopaque, new_size: usize, old_size: usize, alignment: u32) callconv(.C) ?*anyopaque { + _ = old_size; + _ = alignment; + + return realloc(@as([*]align(@alignOf(Align)) u8, @alignCast(@ptrCast(c_ptr))), new_size); +} + +export fn roc_dealloc(c_ptr: *anyopaque, alignment: u32) callconv(.C) void { + _ = alignment; + + free(@as([*]align(@alignOf(Align)) u8, @alignCast(@ptrCast(c_ptr)))); +} + +// NOTE roc_panic and roc_dbg is provided in the JS file, so it can throw an exception + +extern fn roc__main_for_host_1_exposed(*RocStr) void; + +extern fn js_display_roc_string(str_bytes: ?[*]u8, str_len: usize) void; + +pub export fn main() u8 { + // actually call roc to populate the callresult + var callresult = RocStr.empty(); + roc__main_for_host_1_exposed(&callresult); + + // display the result using JavaScript + js_display_roc_string(callresult.asU8ptrMut(), callresult.len()); + + callresult.decref(); + + return 0; +} diff --git a/examples/nodejs-interop/wasm/platform/main.roc b/examples/nodejs-interop/wasm/platform/main.roc new file mode 100644 index 00000000000..d8d7292582e --- /dev/null +++ b/examples/nodejs-interop/wasm/platform/main.roc @@ -0,0 +1,9 @@ +platform "wasm-nodejs-example-platform" + requires {} { main : Str } + exposes [] + packages {} + imports [] + provides [main_for_host] + +main_for_host : Str +main_for_host = main diff --git a/examples/python-interop/README.md b/examples/python-interop/README.md new file mode 100644 index 00000000000..b58779c94dc --- /dev/null +++ b/examples/python-interop/README.md @@ -0,0 +1,82 @@ +# Python Interop + +This is a demo for calling Roc code from [Python](https://www.python.org/). + +## Installation + +The following was tested on NixOS, with `Python 3.10`, `clang 13.0.1`, `gcc 11.3.0` but should work with most recent versions of those on most modern Linux and MacOS.\ +Of course you're welcome to test on your machine and tell me (via [Zulip](https://roc.zulipchat.com/#narrow/pm-with/583319-dank)) if you ran into any issues or limitations. + +> Because of some rough edges, the linux installation may be a bit more involved (nothing too bad, mostly stuff like renames), so for your convenience I made a small shell script to help out. + +Now in favor of users of all OSs, let's first do a step by step walkthrough on how the build process works, and later, a few key notes on the implementation. + +## Building the Roc library + +First, `cd` into this directory and run this in your terminal: + +```sh +roc build --lib +``` + +This compiles your Roc code into a binary library in the current directory. The library's filename will be `libhello` plus an OS-specific extension (e.g. `libhello.dylib` on macOS). + +## Some Linux Specific Prep Work +As of the time of writing this document, `roc build --lib` generates a shared object with the suffix `.so.1.0`.\ +This `.0` suffix is not needed by neither the application nor Python, so we can simply rename it. + +``` sh +mv libhello.so.1.0 libhello.so.1 +``` +But, one of which does expect plain libhello.so, so we symlink it: + +```sh +ln -sf libhello.so.1 libhello.so +``` + +Also, one thing about dynamically linked applications like this one, is that they need to know where to look for its shared object dependencies, so we need to let CPython know that we hold libhello in this directory, so: + +``` sh +export LD_LIBRARY_PATH=$(pwd):$LD_LIBRARY_PATH +``` + +That wasn't so bad and we're already done with prep work, all that's left it to build our C extension. +## Building the C Extension +``` sh +# If you want, you can set the environment variable cc, to compile with clang instead of gcc +python -m venv .interop_env +source .interop_env/bin/activate # activate.fish if you like fish +python setup.py install +``` +For cleanness sake, we make virtual environment here, but do note you don't have to if you don't want to. +You can also run `python setup.py build` and grab the output shared object from the `build/lib.*` directory.\ +Shared objects are simply importable in CPython (which is great!), so you can just start up an interpreter in the same directory as your new `demo.so` and get the same result. + +**Note -** after all is said and done, for prolonged use, you may want to move your shared library (lib hello) to somewhere permanent on your `LD_LIBRARY_PATH`, or add your desired directory to `LD_LIBRARY_PATH` in some way (e.g put it in your shell .rc). + +## Try it out! + +Now we can see our work by entering an interactive shell and calling our function! + +```py +❯ python -q +>>> import demo +>>> demo.call_roc(21) +'The number was 21, OH YEAH!!! 🤘🤘' +``` + +## Notes on implementation +The structure of python-interop is very similar to a C-Extension, in fact, it is one.\ +We have: +- [`PyModuleDef demoModule`](https://docs.python.org/3/c-api/module.html#c.PyModuleDef) struct which declares the `demo` python module, +- [`PyMethodDef DemoMethods`](https://docs.python.org/3/c-api/structures.html#c.PyMethodDef) struct which declares `demo`'s methods, +- [`PyMODINIT_FUNC PyInit_demo`](https://docs.python.org/3/extending/extending.html) which is `demo`’s initialization function, and of course, +- [`PyObject * call_roc`] which is our demo function! Getting args and returning our string to the interpreter. The Roc-Python bridge lives here, all the above are merely CPython boilerplate to wrap up a C implementation into a valid Python module. + +The first three are basically the backbone of any C-API extension.\ +In addition, a couple more functions and notes you may want to pay attention to: +- [`void roc_panic`] - When creating such interpreter-dependent code, it is reasonable to make the implementation of this function fire up an interpreter Exception (e.g `RuntimeError` or whatever suits). +- When I first came across another implementation, I was a bit confused about `extern void roc__main_for_host_1_exposed_generic`, so let me clarify - this is an external function, implemented by the application, that goes (on the application side-) by the name `main_for_host`. + +And one last thing - +- When writing such the C glue (here, `demo.c`), you need to pay attention to not only Python's reference counting, but also Roc's, so remember to wear seatbelts and decrement your ref counts. diff --git a/examples/python-interop/demo.c b/examples/python-interop/demo.c new file mode 100644 index 00000000000..99ba3902b8b --- /dev/null +++ b/examples/python-interop/demo.c @@ -0,0 +1,253 @@ +#define PY_SSIZE_T_CLEAN +#include +#include +#include +#include +#include +#include +#include +#include +#include + +void *roc_alloc(size_t size, unsigned int alignment) +{ + return malloc(size); +} + +void *roc_realloc(void *ptr, size_t new_size, size_t old_size, + unsigned int alignment) +{ + return realloc(ptr, new_size); +} + +void roc_dealloc(void *ptr, unsigned int alignment) { free(ptr); } + +__attribute__((noreturn)) void roc_panic(void *ptr, unsigned int alignment) +{ + PyErr_SetString(PyExc_RuntimeError, (char *)ptr); +} + +void roc_dbg(char* loc, char* msg, char* src) { + fprintf(stderr, "[%s] %s = %s\n", loc, src, msg); +} + +void *roc_memset(void *str, int c, size_t n) { return memset(str, c, n); } + +// Reference counting + +// If the refcount is set to this, that means the allocation is +// stored in readonly memory in the binary, and we must not +// attempt to increment or decrement it; if we do, we'll segfault! +const ssize_t REFCOUNT_READONLY = 0; +const ssize_t REFCOUNT_ONE = (ssize_t)PTRDIFF_MIN; +const size_t MASK = (size_t)PTRDIFF_MIN; + +// Increment reference count, given a pointer to the first element in a collection. +// We don't need to check for overflow because in order to overflow a usize worth of refcounts, +// you'd need to somehow have more pointers in memory than the OS's virtual address space can hold. +void incref(uint8_t* bytes, uint32_t alignment) +{ + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount + 1; + } +} + +// Decrement reference count, given a pointer to the first element in a collection. +// Then call roc_dealloc if nothing is referencing this collection anymore. +void decref(uint8_t* bytes, uint32_t alignment) +{ + if (bytes == NULL) { + return; + } + + size_t extra_bytes = (sizeof(size_t) >= (size_t)alignment) ? sizeof(size_t) : (size_t)alignment; + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount - 1; + + if (refcount == REFCOUNT_ONE) { + void *original_allocation = (void *)(refcount_ptr - (extra_bytes - sizeof(size_t))); + + roc_dealloc(original_allocation, alignment); + } + } +} + +// RocBytes (List U8) + +struct RocBytes +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocBytes init_rocbytes(uint8_t *bytes, size_t len) +{ + if (len == 0) + { + struct RocBytes ret = { + .len = 0, + .bytes = NULL, + .capacity = 0, + }; + + return ret; + } + else + { + struct RocBytes ret; + size_t refcount_size = sizeof(size_t); + uint8_t *new_content = ((uint8_t *)roc_alloc(len + refcount_size, alignof(size_t))) + refcount_size; + + memcpy(new_content, bytes, len); + + ret.bytes = new_content; + ret.len = len; + ret.capacity = len; + + return ret; + } +} + +// RocStr + +struct RocStr +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocStr init_rocstr(uint8_t *bytes, size_t len) +{ + if (len == 0) + { + struct RocStr ret = { + .len = 0, + .bytes = NULL, + .capacity = MASK, + }; + + return ret; + } + else if (len < sizeof(struct RocStr)) + { + // Start out with zeroed memory, so that + // if we end up comparing two small RocStr values + // for equality, we won't risk memory garbage resulting + // in two equal strings appearing unequal. + struct RocStr ret = { + .len = 0, + .bytes = NULL, + .capacity = MASK, + }; + + // Copy the bytes into the stack allocation + memcpy(&ret, bytes, len); + + // Record the string's length in the last byte of the stack allocation + ((uint8_t *)&ret)[sizeof(struct RocStr) - 1] = (uint8_t)len | 0b10000000; + + return ret; + } + else + { + // A large RocStr is the same as a List U8 (aka RocBytes) in memory. + struct RocBytes roc_bytes = init_rocbytes(bytes, len); + + struct RocStr ret = { + .len = roc_bytes.len, + .bytes = roc_bytes.bytes, + .capacity = roc_bytes.capacity, + }; + + return ret; + } +} + +bool is_small_str(struct RocStr str) { return ((ssize_t)str.capacity) < 0; } + +// Determine the length of the string, taking into +// account the small string optimization +size_t roc_str_len(struct RocStr str) +{ + uint8_t *bytes = (uint8_t *)&str; + uint8_t last_byte = bytes[sizeof(str) - 1]; + uint8_t last_byte_xored = last_byte ^ 0b10000000; + size_t small_len = (size_t)(last_byte_xored); + size_t big_len = str.len; + + // Avoid branch misprediction costs by always + // determining both small_len and big_len, + // so this compiles to a cmov instruction. + if (is_small_str(str)) + { + return small_len; + } + else + { + return big_len; + } +} + +extern void roc__main_for_host_1_exposed_generic(struct RocBytes *ret, struct RocBytes *arg); + +// Receive a value from Python, JSON serialized it and pass it to Roc as a List U8 +// (at which point the Roc platform will decode it and crash if it's invalid, +// which roc_panic will translate into a Python exception), then get some JSON back from Roc +// - also as a List U8 - and have Python JSON.parse it into a plain Python value to return. +PyObject * call_roc(PyObject *self, PyObject *args) +{ + int num; + + if(!PyArg_ParseTuple(args, "i", &num)) { + return NULL; + } + + char str_num[256] = {0}; + sprintf(str_num, "%d", num); + + // can also be done with python objects but im not sure what would be the benefit here + // PyObject* py_num_str = PyUnicode_FromFormat("%d", num); + // const char* c_str = PyUnicode_AsUTF8(py_num_str); + // size_t length = (size_t *)PyUnicode_GetLength(py_num_str); + // ...init_rocbytes((uint8_t *)c_str, length); + + // Turn the given Python number into a JSON string. + struct RocBytes arg = init_rocbytes((uint8_t *)str_num, strlen(str_num)); + struct RocBytes ret; + + // Call the Roc function to populate `ret`'s bytes. + roc__main_for_host_1_exposed_generic(&ret, &arg); + + // Create a Python string from the heap-allocated JSON bytes the Roc function returned. + PyObject* py_obj = PyUnicode_FromStringAndSize((char*)ret.bytes, ret.len); + + // Now that we've created py_str, we're no longer referencing the RocBytes. + decref((void *)&ret, alignof(uint8_t *)); + + return py_obj; +} + +static PyMethodDef DemoMethods[] = { + {"call_roc", call_roc, METH_VARARGS, "Calls a Roc function with a number, returns a string interpolated with the number"}, + {NULL, NULL, 0, NULL} +}; + +static struct PyModuleDef demoModule = { + PyModuleDef_HEAD_INIT, + "call_roc", + "demo roc call", + -1, + DemoMethods +}; + +PyMODINIT_FUNC PyInit_demo(void) { + return PyModule_Create(&demoModule); +} diff --git a/examples/python-interop/libhello.roc b/examples/python-interop/libhello.roc new file mode 100644 index 00000000000..1ee460ee2a6 --- /dev/null +++ b/examples/python-interop/libhello.roc @@ -0,0 +1,10 @@ +app [main] { pf: platform "platform/main.roc" } + +main : U64 -> Str +main = \num -> + if num == 0 then + "I need a positive number here!" + else + str = Num.to_str(num) + + "The number was $(str), OH YEAH!!! 🤘🤘" diff --git a/examples/python-interop/platform/host.c b/examples/python-interop/platform/host.c new file mode 100644 index 00000000000..393790bf4d5 --- /dev/null +++ b/examples/python-interop/platform/host.c @@ -0,0 +1,115 @@ +#include +#include +#include +#include +#include +#include +#include // shm_open +#include // for mmap +#include // for kill + +void* roc_alloc(size_t size, unsigned int alignment) { return malloc(size); } + +void* roc_realloc(void* ptr, size_t new_size, size_t old_size, + unsigned int alignment) { + return realloc(ptr, new_size); +} + +void roc_dealloc(void* ptr, unsigned int alignment) { free(ptr); } + +void roc_panic(void* ptr, unsigned int alignment) { + char* msg = (char*)ptr; + fprintf(stderr, + "Application crashed with message\n\n %s\n\nShutting down\n", msg); + exit(1); +} + +void roc_dbg(char* loc, char* msg, char* src) { + fprintf(stderr, "[%s] %s = %s\n", loc, src, msg); +} + +void* roc_memset(void* str, int c, size_t n) { return memset(str, c, n); } + +int roc_shm_open(char* name, int oflag, int mode) { +#ifdef _WIN32 + return 0; +#else + return shm_open(name, oflag, mode); +#endif +} +void* roc_mmap(void* addr, int length, int prot, int flags, int fd, int offset) { +#ifdef _WIN32 + return addr; +#else + return mmap(addr, length, prot, flags, fd, offset); +#endif +} + +int roc_getppid() { +#ifdef _WIN32 + return 0; +#else + return getppid(); +#endif +} + +struct RocStr { + char* bytes; + size_t len; + size_t capacity; +}; + +bool is_small_str(struct RocStr str) { return ((ssize_t)str.capacity) < 0; } + +// Determine the length of the string, taking into +// account the small string optimization +size_t roc_str_len(struct RocStr str) { + char* bytes = (char*)&str; + char last_byte = bytes[sizeof(str) - 1]; + char last_byte_xored = last_byte ^ 0b10000000; + size_t small_len = (size_t)(last_byte_xored); + size_t big_len = str.len; + + // Avoid branch misprediction costs by always + // determining both small_len and big_len, + // so this compiles to a cmov instruction. + if (is_small_str(str)) { + return small_len; + } else { + return big_len; + } +} + +extern void roc__main_for_host_1_exposed_generic(struct RocStr *string); + +int main() { + + struct RocStr str; + roc__main_for_host_1_exposed_generic(&str); + + // Determine str_len and the str_bytes pointer, + // taking into account the small string optimization. + size_t str_len = roc_str_len(str); + char* str_bytes; + + if (is_small_str(str)) { + str_bytes = (char*)&str; + } else { + str_bytes = str.bytes; + } + + // Write to stdout + if (write(1, str_bytes, str_len) >= 0) { + // Writing succeeded! + + // NOTE: the string is a static string, read from in the binary + // if you make it a heap-allocated string, it'll be leaked here + return 0; + } else { + printf("Error writing to stdout: %s\n", strerror(errno)); + + // NOTE: the string is a static string, read from in the binary + // if you make it a heap-allocated string, it'll be leaked here + return 1; + } +} diff --git a/examples/python-interop/platform/main.roc b/examples/python-interop/platform/main.roc new file mode 100644 index 00000000000..e81dd52fb7a --- /dev/null +++ b/examples/python-interop/platform/main.roc @@ -0,0 +1,16 @@ +platform "python-interop" + requires {} { main : U64 -> Str } + exposes [] + packages {} + imports [] + provides [main_for_host] + +main_for_host : List U8 -> List U8 +main_for_host = \input -> + when Str.from_utf8(input) is + Ok(arg) -> + when Str.to_u64(arg) is + Ok(num) -> main(num) |> Str.to_utf8 + Err(_) -> [] + + Err(_) -> [] diff --git a/examples/ruby-interop/demo.c b/examples/ruby-interop/demo.c new file mode 100644 index 00000000000..f3a73f30fd8 --- /dev/null +++ b/examples/ruby-interop/demo.c @@ -0,0 +1,225 @@ +#include +#include +#include +#include +#include +#include +#include +#include +#include "extconf.h" + +void *roc_alloc(size_t size, unsigned int alignment) { return malloc(size); } + +void *roc_realloc(void *ptr, size_t new_size, size_t old_size, + unsigned int alignment) +{ + return realloc(ptr, new_size); +} + +void roc_dealloc(void *ptr, unsigned int alignment) { free(ptr); } + +__attribute__((noreturn)) void roc_panic(void *ptr, unsigned int alignment) +{ + rb_raise(rb_eException, "%s", (char *)ptr); +} + +void roc_dbg(char* loc, char* msg, char* src) { + fprintf(stderr, "[%s] %s = %s\n", loc, src, msg); +} + +void *roc_memset(void *str, int c, size_t n) { return memset(str, c, n); } + +// Reference counting + +// If the refcount is set to this, that means the allocation is +// stored in readonly memory in the binary, and we must not +// attempt to increment or decrement it; if we do, we'll segfault! +const ssize_t REFCOUNT_READONLY = 0; +const ssize_t REFCOUNT_ONE = (ssize_t)PTRDIFF_MIN; +const size_t MASK = (size_t)PTRDIFF_MIN; + +// Increment reference count, given a pointer to the first element in a collection. +// We don't need to check for overflow because in order to overflow a usize worth of refcounts, +// you'd need to somehow have more pointers in memory than the OS's virtual address space can hold. +void incref(uint8_t* bytes, uint32_t alignment) +{ + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount + 1; + } +} + +// Decrement reference count, given a pointer to the first element in a collection. +// Then call roc_dealloc if nothing is referencing this collection anymore. +void decref(uint8_t* bytes, uint32_t alignment) +{ + if (bytes == NULL) { + return; + } + + size_t extra_bytes = (sizeof(size_t) >= (size_t)alignment) ? sizeof(size_t) : (size_t)alignment; + ssize_t *refcount_ptr = ((ssize_t *)bytes) - 1; + ssize_t refcount = *refcount_ptr; + + if (refcount != REFCOUNT_READONLY) { + *refcount_ptr = refcount - 1; + + if (refcount == REFCOUNT_ONE) { + void *original_allocation = (void *)(refcount_ptr - (extra_bytes - sizeof(size_t))); + + roc_dealloc(original_allocation, alignment); + } + } +} + +// RocBytes (List U8) + +struct RocBytes +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocBytes init_rocbytes(uint8_t *bytes, size_t len) +{ + if (len == 0) + { + struct RocBytes ret = { + .len = 0, + .bytes = NULL, + .capacity = 0, + }; + + return ret; + } + else + { + struct RocBytes ret; + size_t refcount_size = sizeof(size_t); + uint8_t *new_content = (uint8_t *)roc_alloc(len + refcount_size, alignof(size_t)) + refcount_size; + + memcpy(new_content, bytes, len); + + ret.bytes = new_content; + ret.len = len; + ret.capacity = len; + + return ret; + } +} + +// RocStr + +struct RocStr +{ + uint8_t *bytes; + size_t len; + size_t capacity; +}; + +struct RocStr init_rocstr(uint8_t *bytes, size_t len) +{ + if (len == 0) + { + struct RocStr ret = { + .len = 0, + .bytes = NULL, + .capacity = MASK, + }; + + return ret; + } + else if (len < sizeof(struct RocStr)) + { + // Start out with zeroed memory, so that + // if we end up comparing two small RocStr values + // for equality, we won't risk memory garbage resulting + // in two equal strings appearing unequal. + struct RocStr ret = { + .len = 0, + .bytes = NULL, + .capacity = MASK, + }; + + // Copy the bytes into the stack allocation + memcpy(&ret, bytes, len); + + // Record the string's length in the last byte of the stack allocation + ((uint8_t *)&ret)[sizeof(struct RocStr) - 1] = (uint8_t)len | 0b10000000; + + return ret; + } + else + { + // A large RocStr is the same as a List U8 (aka RocBytes) in memory. + struct RocBytes roc_bytes = init_rocbytes(bytes, len); + + struct RocStr ret = { + .len = roc_bytes.len, + .bytes = roc_bytes.bytes, + .capacity = roc_bytes.capacity, + }; + + return ret; + } +} + +bool is_small_str(struct RocStr str) { return ((ssize_t)str.capacity) < 0; } + +// Determine the length of the string, taking into +// account the small string optimization +size_t roc_str_len(struct RocStr str) +{ + uint8_t *bytes = (uint8_t *)&str; + uint8_t last_byte = bytes[sizeof(str) - 1]; + uint8_t last_byte_xored = last_byte ^ 0b10000000; + size_t small_len = (size_t)(last_byte_xored); + size_t big_len = str.len; + + // Avoid branch misprediction costs by always + // determining both small_len and big_len, + // so this compiles to a cmov instruction. + if (is_small_str(str)) + { + return small_len; + } + else + { + return big_len; + } +} + +extern void roc__main_for_host_1_exposed_generic(struct RocBytes *ret, struct RocBytes *arg); + +// Receive a value from Ruby, serialize it and pass it to Roc as a List U8 +// (at which point the Roc platform will decode it and crash if it's invalid, +// which roc_panic will translate into a Ruby exception), then get some utf-8 string back from Roc +// - also as a List U8 - and have Ruby decode it into a plain Ruby value to return. +VALUE call_roc(VALUE self, VALUE rb_arg) +{ + VALUE str_arg = rb_funcall(rb_arg, rb_intern("to_s"), 0); + VALUE str_utf8_arg = rb_funcall(str_arg, rb_intern("force_encoding"), 1, rb_str_new_cstr("utf-8")); + + struct RocBytes arg = init_rocbytes((uint8_t *)RSTRING_PTR(str_utf8_arg), RSTRING_LEN(str_utf8_arg)); + struct RocBytes ret; + + // Call the Roc function to populate `ret`'s bytes. + roc__main_for_host_1_exposed_generic(&ret, &arg); + + // Create a rb_utf8_str from the heap-allocated utf-8 bytes the Roc function returned. + VALUE returned_str = rb_utf8_str_new((char *)ret.bytes, ret.len); + + // Now that we've created our Ruby string, we're no longer referencing the RocBytes. + decref((void *)&ret, alignof(uint8_t *)); + + return returned_str; +} + +void Init_demo() +{ + VALUE roc_app = rb_define_module("RocApp"); + rb_define_module_function(roc_app, "call_roc", &call_roc, 1); +} diff --git a/examples/ruby-interop/libhello.roc b/examples/ruby-interop/libhello.roc new file mode 100644 index 00000000000..1ee460ee2a6 --- /dev/null +++ b/examples/ruby-interop/libhello.roc @@ -0,0 +1,10 @@ +app [main] { pf: platform "platform/main.roc" } + +main : U64 -> Str +main = \num -> + if num == 0 then + "I need a positive number here!" + else + str = Num.to_str(num) + + "The number was $(str), OH YEAH!!! 🤘🤘" diff --git a/examples/ruby-interop/platform/host.c b/examples/ruby-interop/platform/host.c new file mode 100644 index 00000000000..f27aaefd991 --- /dev/null +++ b/examples/ruby-interop/platform/host.c @@ -0,0 +1,119 @@ +#include +#include +#include +#include +#include +#include +#include // shm_open +#include // for mmap +#include // for kill + +void* roc_alloc(size_t size, unsigned int alignment) { return malloc(size); } + +void* roc_realloc(void* ptr, size_t new_size, size_t old_size, + unsigned int alignment) { + return realloc(ptr, new_size); +} + +void roc_dealloc(void* ptr, unsigned int alignment) { free(ptr); } + +void roc_panic(void* ptr, unsigned int alignment) { + char* msg = (char*)ptr; + fprintf(stderr, + "Application crashed with message\n\n %s\n\nShutting down\n", msg); + exit(1); +} + +void roc_dbg(char* loc, char* msg, char* src) { + fprintf(stderr, "[%s] %s = %s\n", loc, src, msg); +} + +void* roc_memmove(void* dest, const void* src, size_t n){ + return memmove(dest, src, n); +} + +void* roc_memset(void* str, int c, size_t n) { return memset(str, c, n); } + +int roc_shm_open(char* name, int oflag, int mode) { +#ifdef _WIN32 + return 0; +#else + return shm_open(name, oflag, mode); +#endif +} +void* roc_mmap(void* addr, int length, int prot, int flags, int fd, int offset) { +#ifdef _WIN32 + return addr; +#else + return mmap(addr, length, prot, flags, fd, offset); +#endif +} + +int roc_getppid() { +#ifdef _WIN32 + return 0; +#else + return getppid(); +#endif +} + +struct RocStr { + char* bytes; + size_t len; + size_t capacity; +}; + +bool is_small_str(struct RocStr str) { return ((ssize_t)str.capacity) < 0; } + +// Determine the length of the string, taking into +// account the small string optimization +size_t roc_str_len(struct RocStr str) { + char* bytes = (char*)&str; + char last_byte = bytes[sizeof(str) - 1]; + char last_byte_xored = last_byte ^ 0b10000000; + size_t small_len = (size_t)(last_byte_xored); + size_t big_len = str.len; + + // Avoid branch misprediction costs by always + // determining both small_len and big_len, + // so this compiles to a cmov instruction. + if (is_small_str(str)) { + return small_len; + } else { + return big_len; + } +} + +extern void roc__main_for_host_1_exposed_generic(struct RocStr *string); + +int main() { + + struct RocStr str; + roc__main_for_host_1_exposed_generic(&str); + + // Determine str_len and the str_bytes pointer, + // taking into account the small string optimization. + size_t str_len = roc_str_len(str); + char* str_bytes; + + if (is_small_str(str)) { + str_bytes = (char*)&str; + } else { + str_bytes = str.bytes; + } + + // Write to stdout + if (write(1, str_bytes, str_len) >= 0) { + // Writing succeeded! + + // NOTE: the string is a static string, read from in the binary + // if you make it a heap-allocated string, it'll be leaked here + return 0; + } else { + printf("Error writing to stdout: %s\n", strerror(errno)); + + // NOTE: the string is a static string, read from in the binary + // if you make it a heap-allocated string, it'll be leaked here + return 1; + } +} diff --git a/examples/ruby-interop/platform/main.roc b/examples/ruby-interop/platform/main.roc new file mode 100644 index 00000000000..33ad40d532f --- /dev/null +++ b/examples/ruby-interop/platform/main.roc @@ -0,0 +1,16 @@ +platform "ruby-interop" + requires {} { main : U64 -> Str } + exposes [] + packages {} + imports [] + provides [main_for_host] + +main_for_host : List U8 -> List U8 +main_for_host = \input -> + when Str.from_utf8(input) is + Ok(arg) -> + when Str.to_u64(arg) is + Ok(num) -> main(num) |> Str.to_utf8 + Err(_) -> [] + + Err(_) -> [] # TODO panic so that Ruby raises an exception diff --git a/examples/virtual-dom-wip/ExampleApp.roc b/examples/virtual-dom-wip/ExampleApp.roc new file mode 100644 index 00000000000..9b08414bdbc --- /dev/null +++ b/examples/virtual-dom-wip/ExampleApp.roc @@ -0,0 +1,36 @@ +module [example_app, State] + +import pf.Html exposing [App, Html, html, head, body, div, text, h1] + +State : { + answer : U32, +} + +example_app : App State State +example_app = { + init, + render, + wasm_url: "assets/example-client.wasm", +} + +init = \result -> + when result is + Ok(state) -> state + Err(_) -> { answer: 0 } + +render : State -> Html State +render = \state -> + num = Num.to_str(state.answer) + + html([], [ + head([], []), + body([], [ + h1([], [text("The app")]), + div([], [text("The answer is $(num)")]), + ]), + ]) + +expect + Html.render_static(Html.translate_static(render({ answer: 42 }))) + == + "

The app

The answer is 42
" diff --git a/examples/virtual-dom-wip/example-client.roc b/examples/virtual-dom-wip/example-client.roc new file mode 100644 index 00000000000..9799c2185e8 --- /dev/null +++ b/examples/virtual-dom-wip/example-client.roc @@ -0,0 +1,5 @@ +app [app] { pf: platform "platform/client-side.roc" } + +import ExampleApp exposing [example_app] + +app = example_app diff --git a/examples/virtual-dom-wip/example-server.roc b/examples/virtual-dom-wip/example-server.roc new file mode 100644 index 00000000000..e2c3a14c1a1 --- /dev/null +++ b/examples/virtual-dom-wip/example-server.roc @@ -0,0 +1,5 @@ +app [app] { pf: platform "platform/server-side.roc" } + +import ExampleApp exposing [example_app] + +app = example_app diff --git a/examples/virtual-dom-wip/platform/Action.roc b/examples/virtual-dom-wip/platform/Action.roc new file mode 100644 index 00000000000..87d03160b54 --- /dev/null +++ b/examples/virtual-dom-wip/platform/Action.roc @@ -0,0 +1,15 @@ +module [Action, none, update, map] + +Action state : [None, Update state] + +none : Action * +none = None + +update : state -> Action state +update = Update + +map : Action a, (a -> b) -> Action b +map = \action, transform -> + when action is + None -> None + Update(state) -> Update(transform(state)) diff --git a/examples/virtual-dom-wip/platform/Html.roc b/examples/virtual-dom-wip/platform/Html.roc new file mode 100644 index 00000000000..6a11dc1a3a8 --- /dev/null +++ b/examples/virtual-dom-wip/platform/Html.roc @@ -0,0 +1,271 @@ +module [ + App, + Html, + Attribute, + render_static, + render_static_without_doc_type, + translate, + translate_static, + text, + none, + html, + base, + head, + link, + meta, + style, + title, + body, + address, + article, + aside, + footer, + header, + h1, + h2, + h3, + h4, + h5, + h6, + main, + nav, + section, + blockquote, + dd, + div, + dl, + dt, + figcaption, + figure, + hr, + li, + menu, + ol, + p, + pre, + ul, + a, + abbr, + b, + bdi, + bdo, + br, + cite, + code, + data, + dfn, + em, + i, + kbd, + mark, + q, + rp, + rt, + ruby, + s, + samp, + small, + span, + strong, + sub, + sup, + time, + u, + var, + wbr, + area, + audio, + img, + map, + track, + video, + embed, + iframe, + object, + picture, + portal, + source, + svg, + math, + canvas, + noscript, + script, + del, + ins, + caption, + col, + colgroup, + table, + tbody, + td, + tfoot, + th, + thead, + tr, + button, + datalist, + fieldset, + form, + input, + label, + legend, + meter, + optgroup, + option, + output, + progress, + select, + textarea, + details, + dialog, + summary, + slot, + template, +] + +import Html.Internal.Shared +import Html.Internal.Server + +App state init_data : Html.Internal.Shared.App state init_data +Html state : Html.Internal.Shared.Html state +Attribute state : Html.Internal.Shared.Attribute state + +element = Html.Internal.Shared.element +text = Html.Internal.Shared.text +none = Html.Internal.Shared.none + +translate = Html.Internal.Shared.translate +translate_static = Html.Internal.Shared.translate_static + +## Render a static Html node to a string, for saving to disk or sending over a network +## +## The output has no whitespace between nodes, to make it small. +## This is intended for generating full HTML documents, so it +## automatically adds `` to the start of the string. +## See also `renderStaticWithoutDocType`. +render_static : Html [] -> Str +render_static = \node -> + buffer = Str.reserve("", Html.Internal.Shared.node_size(node)) + + Html.Internal.Server.append_rendered_static(buffer, node) + +## Render a Html node to a static string, without a DOCTYPE +render_static_without_doc_type : Html [] -> Str +render_static_without_doc_type = \node -> + buffer = Str.reserve("", Html.Internal.Shared.node_size(node)) + + Html.Internal.Server.append_rendered_static(buffer, node) + +html = element("html") +base = element("base") +head = element("head") +link = element("link") +meta = element("meta") +style = element("style") +title = element("title") +body = element("body") +address = element("address") +article = element("article") +aside = element("aside") +footer = element("footer") +header = element("header") +h1 = element("h1") +h2 = element("h2") +h3 = element("h3") +h4 = element("h4") +h5 = element("h5") +h6 = element("h6") +main = element("main") +nav = element("nav") +section = element("section") +blockquote = element("blockquote") +dd = element("dd") +div = element("div") +dl = element("dl") +dt = element("dt") +figcaption = element("figcaption") +figure = element("figure") +hr = element("hr") +li = element("li") +menu = element("menu") +ol = element("ol") +p = element("p") +pre = element("pre") +ul = element("ul") +a = element("a") +abbr = element("abbr") +b = element("b") +bdi = element("bdi") +bdo = element("bdo") +br = element("br") +cite = element("cite") +code = element("code") +data = element("data") +dfn = element("dfn") +em = element("em") +i = element("i") +kbd = element("kbd") +mark = element("mark") +q = element("q") +rp = element("rp") +rt = element("rt") +ruby = element("ruby") +s = element("s") +samp = element("samp") +small = element("small") +span = element("span") +strong = element("strong") +sub = element("sub") +sup = element("sup") +time = element("time") +u = element("u") +var = element("var") +wbr = element("wbr") +area = element("area") +audio = element("audio") +img = element("img") +map = element("map") +track = element("track") +video = element("video") +embed = element("embed") +iframe = element("iframe") +object = element("object") +picture = element("picture") +portal = element("portal") +source = element("source") +svg = element("svg") +math = element("math") +canvas = element("canvas") +noscript = element("noscript") +script = element("script") +del = element("del") +ins = element("ins") +caption = element("caption") +col = element("col") +colgroup = element("colgroup") +table = element("table") +tbody = element("tbody") +td = element("td") +tfoot = element("tfoot") +th = element("th") +thead = element("thead") +tr = element("tr") +button = element("button") +datalist = element("datalist") +fieldset = element("fieldset") +form = element("form") +input = element("input") +label = element("label") +legend = element("legend") +meter = element("meter") +optgroup = element("optgroup") +option = element("option") +output = element("output") +progress = element("progress") +select = element("select") +textarea = element("textarea") +details = element("details") +dialog = element("dialog") +summary = element("summary") +slot = element("slot") +template = element("template") diff --git a/examples/virtual-dom-wip/platform/Html/Attributes.roc b/examples/virtual-dom-wip/platform/Html/Attributes.roc new file mode 100644 index 00000000000..8dd510ef035 --- /dev/null +++ b/examples/virtual-dom-wip/platform/Html/Attributes.roc @@ -0,0 +1,273 @@ +module [ + attribute, + accept, + accept_charset, + accesskey, + action, + align, + allow, + alt, + async, + autocapitalize, + autocomplete, + autofocus, + autoplay, + background, + bgcolor, + border, + buffered, + capture, + challenge, + charset, + checked, + cite, + class, + code, + codebase, + color, + cols, + colspan, + content, + contenteditable, + contextmenu, + controls, + coords, + crossorigin, + csp, + data, + # dataAttr, TODO + datetime, + decoding, + default, + defer, + dir, + dirname, + disabled, + download, + draggable, + enctype, + enterkeyhint, + for, + form, + formaction, + formenctype, + formmethod, + formnovalidate, + formtarget, + headers, + height, + hidden, + high, + href, + hreflang, + http_equiv, + icon, + id, + importance, + integrity, + intrinsicsize, + inputmode, + ismap, + itemprop, + keytype, + kind, + label, + lang, + language, + loading, + list, + loop, + low, + manifest, + max, + maxlength, + minlength, + media, + method, + min, + multiple, + muted, + name, + novalidate, + open, + optimum, + pattern, + ping, + placeholder, + poster, + preload, + radiogroup, + readonly, + referrerpolicy, + rel, + required, + reversed, + role, + rows, + rowspan, + sandbox, + scope, + scoped, + selected, + shape, + size, + sizes, + slot, + span, + spellcheck, + src, + srcdoc, + srclang, + srcset, + start, + step, + style, + summary, + tabindex, + target, + title, + translate, + type, + usemap, + value, + width, + wrap, +] + +import Html.Internal.Shared exposing [Attribute] + +attribute : Str -> (Str -> Attribute state) +attribute = \attr_type -> + \attr_value -> HtmlAttr(attr_type, attr_value) + +accept = attribute("accept") +accept_charset = attribute("acceptCharset") +accesskey = attribute("accesskey") +action = attribute("action") +align = attribute("align") +allow = attribute("allow") +alt = attribute("alt") +async = attribute("async") +autocapitalize = attribute("autocapitalize") +autocomplete = attribute("autocomplete") +autofocus = attribute("autofocus") +autoplay = attribute("autoplay") +background = attribute("background") +bgcolor = attribute("bgcolor") +border = attribute("border") +buffered = attribute("buffered") +capture = attribute("capture") +challenge = attribute("challenge") +charset = attribute("charset") +checked = attribute("checked") +cite = attribute("cite") +class = attribute("class") +code = attribute("code") +codebase = attribute("codebase") +color = attribute("color") +cols = attribute("cols") +colspan = attribute("colspan") +content = attribute("content") +contenteditable = attribute("contenteditable") +contextmenu = attribute("contextmenu") +controls = attribute("controls") +coords = attribute("coords") +crossorigin = attribute("crossorigin") +csp = attribute("csp") +data = attribute("data") +datetime = attribute("datetime") +decoding = attribute("decoding") +default = attribute("default") +defer = attribute("defer") +dir = attribute("dir") +dirname = attribute("dirname") +disabled = attribute("disabled") +download = attribute("download") +draggable = attribute("draggable") +enctype = attribute("enctype") +enterkeyhint = attribute("enterkeyhint") +for = attribute("for") +form = attribute("form") +formaction = attribute("formaction") +formenctype = attribute("formenctype") +formmethod = attribute("formmethod") +formnovalidate = attribute("formnovalidate") +formtarget = attribute("formtarget") +headers = attribute("headers") +height = attribute("height") +hidden = attribute("hidden") +high = attribute("high") +href = attribute("href") +hreflang = attribute("hreflang") +http_equiv = attribute("httpEquiv") +icon = attribute("icon") +id = attribute("id") +importance = attribute("importance") +integrity = attribute("integrity") +intrinsicsize = attribute("intrinsicsize") +inputmode = attribute("inputmode") +ismap = attribute("ismap") +itemprop = attribute("itemprop") +keytype = attribute("keytype") +kind = attribute("kind") +label = attribute("label") +lang = attribute("lang") +language = attribute("language") +loading = attribute("loading") +list = attribute("list") +loop = attribute("loop") +low = attribute("low") +manifest = attribute("manifest") +max = attribute("max") +maxlength = attribute("maxlength") +minlength = attribute("minlength") +media = attribute("media") +method = attribute("method") +min = attribute("min") +multiple = attribute("multiple") +muted = attribute("muted") +name = attribute("name") +novalidate = attribute("novalidate") +open = attribute("open") +optimum = attribute("optimum") +pattern = attribute("pattern") +ping = attribute("ping") +placeholder = attribute("placeholder") +poster = attribute("poster") +preload = attribute("preload") +radiogroup = attribute("radiogroup") +readonly = attribute("readonly") +referrerpolicy = attribute("referrerpolicy") +rel = attribute("rel") +required = attribute("required") +reversed = attribute("reversed") +role = attribute("role") +rows = attribute("rows") +rowspan = attribute("rowspan") +sandbox = attribute("sandbox") +scope = attribute("scope") +scoped = attribute("scoped") +selected = attribute("selected") +shape = attribute("shape") +size = attribute("size") +sizes = attribute("sizes") +slot = attribute("slot") +span = attribute("span") +spellcheck = attribute("spellcheck") +src = attribute("src") +srcdoc = attribute("srcdoc") +srclang = attribute("srclang") +srcset = attribute("srcset") +start = attribute("start") +step = attribute("step") +style = attribute("style") +summary = attribute("summary") +tabindex = attribute("tabindex") +target = attribute("target") +title = attribute("title") +translate = attribute("translate") +type = attribute("type") +usemap = attribute("usemap") +value = attribute("value") +width = attribute("width") +wrap = attribute("wrap") diff --git a/examples/virtual-dom-wip/platform/Html/Event.roc b/examples/virtual-dom-wip/platform/Html/Event.roc new file mode 100644 index 00000000000..a16c7afabb8 --- /dev/null +++ b/examples/virtual-dom-wip/platform/Html/Event.roc @@ -0,0 +1,77 @@ +module [ + Handler, + CyclicStructureAccessor, + on, + custom, + on_click, + on_double_click, + on_mouse_down, + on_mouse_up, + on_mouse_enter, + on_mouse_leave, + on_mouse_over, + on_mouse_out, + on_check, + on_blur, + on_focus, + on_input, + on_submit, +] + +import Action exposing [Action] +import Html.Internal.Shared exposing [Attribute] + +Handler state : Html.Internal.Shared.Handler state +CyclicStructureAccessor : Html.Internal.Shared.CyclicStructureAccessor + +custom : Str, List CyclicStructureAccessor, (state, List (List U8) -> { action : Action state, stop_propagation : Bool, prevent_default : Bool }) -> Attribute state +custom = \event_name, accessors, callback -> + EventListener(event_name, accessors, Custom(callback)) + +on : Str, List CyclicStructureAccessor, (state, List (List U8) -> Action state) -> Attribute state +on = \event_name, accessors, callback -> + EventListener(event_name, accessors, Normal(callback)) + +# Internal helper +curried_on : Str -> (List CyclicStructureAccessor, (state, List (List U8) -> Action state) -> Attribute state) +curried_on = \event_name -> + \accessors, callback -> + EventListener(event_name, accessors, Normal(callback)) + +on_click = curried_on("click") +on_double_click = curried_on("dblclick") +on_mouse_down = curried_on("mousedown") +on_mouse_up = curried_on("mouseup") +on_mouse_enter = curried_on("mouseenter") +on_mouse_leave = curried_on("mouseleave") +on_mouse_over = curried_on("mouseover") +on_mouse_out = curried_on("mouseout") +on_check = curried_on("check") +on_blur = curried_on("blur") +on_focus = curried_on("focus") + +on_input : List CyclicStructureAccessor, (state, List (List U8) -> Action state) -> Attribute state +on_input = \accessors, callback -> + custom_callback : state, List (List U8) -> { action : Action state, stop_propagation : Bool, prevent_default : Bool } + custom_callback = \state, jsons -> { + action: callback(state, jsons), + stop_propagation: Bool.true, + prevent_default: Bool.false, + } + + EventListener("input", accessors, Custom(custom_callback)) + +on_submit : List CyclicStructureAccessor, (state, List (List U8) -> Action state) -> Attribute state +on_submit = \accessors, callback -> + custom_callback = \state, jsons -> { + action: callback(state, jsons), + stop_propagation: Bool.false, + prevent_default: Bool.true, + } + + EventListener("submit", accessors, Custom(custom_callback)) + +# Notes from Elm: +# - stopPropagation causes immediate view update, without waiting for animationFrame, +# to prevent input state getting out of sync with model state when typing fast. +# - Security-sensitive events trigger an immediate update within the same user-instigated tick diff --git a/examples/virtual-dom-wip/platform/Html/Internal/Client.roc b/examples/virtual-dom-wip/platform/Html/Internal/Client.roc new file mode 100644 index 00000000000..24edce4f79d --- /dev/null +++ b/examples/virtual-dom-wip/platform/Html/Internal/Client.roc @@ -0,0 +1,801 @@ +module [ + PlatformState, + init_client_app, + dispatch_event, +] + +import PlatformTasks exposing [ + NodeId, + HandlerId, + TagName, + AttrType, + EventType, +] +import Html.Internal.Shared exposing [ + App, + Html, + Attribute, + CyclicStructureAccessor, + Handler, + translate_static, +] +import Json +import Action + +PlatformState state init_data : { + app : App state init_data, + state, + rendered : RenderedTree state, +} + +# The rendered tree uses indices rather than pointers +# This makes it easier to communicate with JS using integer indices. +# There is a JavaScript `nodes` array that matches the Roc `nodes` List +RenderedTree state : { + root : NodeId, + nodes : List (Result RenderedNode [DeletedNode]), + deleted_node_cache : List NodeId, + handlers : List (Result (Handler state) [DeletedHandler]), + deleted_handler_cache : List HandlerId, +} + +RenderedNode : [ + RenderedNone, + RenderedText Str, + RenderedElement Str RenderedAttributes (List NodeId), +] + +RenderedAttributes : { + event_listeners : Dict Str { accessors : List CyclicStructureAccessor, handler_id : HandlerId }, + html_attrs : Dict Str Str, + dom_props : Dict Str (List U8), + styles : Dict Str Str, +} + +empty_rendered_attrs = { + event_listeners: Dict.empty({}), + html_attrs: Dict.empty({}), + dom_props: Dict.empty({}), + styles: Dict.empty({}), +} + +Patch : [ + CreateElement NodeId TagName, + CreateTextNode NodeId Str, + UpdateTextNode NodeId Str, + AppendChild NodeId NodeId, + RemoveNode NodeId, + ReplaceNode NodeId NodeId, + SetAttribute NodeId AttrType Str, + RemoveAttribute NodeId AttrType, + SetProperty NodeId Str (List U8), + RemoveProperty NodeId Str, + SetStyle NodeId Str Str, + SetListener NodeId EventType (List U8) HandlerId, + RemoveListener NodeId HandlerId, +] + +DiffState state : { rendered : RenderedTree state, patches : List Patch } + +# ------------------------------- +# INITIALISATION +# ------------------------------- +init_client_app : List U8, App state init_data -> Task (PlatformState state init_data) * where init_data implements Decoding +init_client_app = \json, app -> + # Initialise the Roc representation of the rendered DOM, and calculate patches (for event listeners) + { state, rendered, patches } = + init_client_app_help(json, app) + + # Call out to JS to patch the DOM, attaching the event listeners + apply_patches!(patches) + + Task.ok({ + app, + state, + rendered, + }) + +# Testable helper function to initialise the app +init_client_app_help : List U8, App state init_data -> { state, rendered : RenderedTree state, patches : List Patch } where init_data implements Decoding +init_client_app_help = \json, app -> + state = + json + |> Decode.from_bytes(Json.json) + |> app.init + dynamic_view = + app.render(state) + static_unindexed = + translate_static(dynamic_view) + { nodes: static_nodes } = + index_nodes({ nodes: [], sibling_ids: [] }, static_unindexed) + static_rendered = { + root: List.len(static_nodes) - 1, + nodes: List.map(static_nodes, Ok), + deleted_node_cache: [], + handlers: [], + deleted_handler_cache: [], + } + + # Run our first diff. The only differences will be event listeners, so we will generate patches to attach those. + { rendered, patches } = + diff({ rendered: static_rendered, patches: [] }, dynamic_view) + + { state, rendered, patches } + +# Assign an index to each (virtual) DOM node. +# In JavaScript, we maintain an array of references to real DOM nodes. +# In Roc, we maintain a matching List of virtual DOM nodes with the same indices. +# They are both initialised separately, but use the same indexing algorithm. +# (We *could* pass this data in as JSON from the HTML file, but it would roughly double the size of that HTML file!) +index_nodes : { nodes : List RenderedNode, sibling_ids : List U64 }, Html state -> { nodes : List RenderedNode, sibling_ids : List U64 } +index_nodes = \{ nodes, sibling_ids }, unrendered -> + when unrendered is + Text(content) -> + { + nodes: List.append(nodes, RenderedText(content)), + sibling_ids: List.append(sibling_ids, List.len(nodes)), + } + + Element(name, _, attrs, children) -> + { nodes: list_with_children, sibling_ids: child_ids } = + List.walk(children, { nodes, sibling_ids: [] }, index_nodes) + rendered_attrs = + List.walk(attrs, empty_rendered_attrs, \walked_attrs, attr -> + when attr is + EventListener(_, _, _) -> walked_attrs # Dropped! Server-rendered HTML has no listeners + HtmlAttr(k, v) -> { walked_attrs & html_attrs: Dict.insert(walked_attrs.html_attrs, k, v) } + DomProp(k, v) -> { walked_attrs & dom_props: Dict.insert(walked_attrs.dom_props, k, v) } + Style(k, v) -> { walked_attrs & styles: Dict.insert(walked_attrs.styles, k, v) }) + + { + nodes: List.append(list_with_children, RenderedElement(name, rendered_attrs, child_ids)), + sibling_ids: List.append(sibling_ids, List.len(list_with_children)), + } + + None -> + { + nodes: List.append(nodes, RenderedNone), + sibling_ids: List.append(sibling_ids, List.len(nodes)), + } + +# ------------------------------- +# Patches +# ------------------------------- +apply_patch : Patch -> Task {} * +apply_patch = \patch -> + when patch is + CreateElement(node_id, tag_name) -> PlatformTasks.create_element(node_id, tag_name) + CreateTextNode(node_id, content) -> PlatformTasks.create_text_node(node_id, content) + UpdateTextNode(node_id, content) -> PlatformTasks.update_text_node(node_id, content) + AppendChild(parent_id, child_id) -> PlatformTasks.append_child(parent_id, child_id) + RemoveNode(id) -> PlatformTasks.remove_node(id) + ReplaceNode(old_id, new_id) -> PlatformTasks.replace_node(old_id, new_id) + SetAttribute(node_id, attr_name, value) -> PlatformTasks.set_attribute(node_id, attr_name, value) + RemoveAttribute(node_id, attr_name) -> PlatformTasks.remove_attribute(node_id, attr_name) + SetProperty(node_id, prop_name, json) -> PlatformTasks.set_property(node_id, prop_name, json) + RemoveProperty(node_id, prop_name) -> PlatformTasks.remove_property(node_id, prop_name) + SetStyle(node_id, key, value) -> PlatformTasks.set_style(node_id, key, value) + SetListener(node_id, event_type, accessors_json, handler_id) -> PlatformTasks.set_listener(node_id, event_type, accessors_json, handler_id) + RemoveListener(node_id, handler_id) -> PlatformTasks.remove_listener(node_id, handler_id) + +apply_patches : List Patch -> Task {} * +apply_patches = \patches -> + List.walk(patches, Task.ok({}), \previous_effects, patch -> + previous_effects! + apply_patch(patch)) + +# ------------------------------- +# EVENT HANDLING +# ------------------------------- +JsEventResult state init_data : { + platform_state : PlatformState state init_data, + stop_propagation : Bool, + prevent_default : Bool, +} + +## Dispatch a JavaScript event to a Roc handler, given the handler ID and some JSON event data. +dispatch_event : PlatformState state init_data, List (List U8), HandlerId -> Task (JsEventResult state init_data) * where init_data implements Decoding +dispatch_event = \platform_state, event_data, handler_id -> + { app, state, rendered } = + platform_state + maybe_handler = + List.get(rendered.handlers, handler_id) + |> Result.with_default(Err(DeletedHandler)) + { action, stop_propagation, prevent_default } = + when maybe_handler is + Err(DeletedHandler) -> + { action: Action.none, stop_propagation: Bool.false, prevent_default: Bool.false } + + Ok(Normal(handler)) -> + { action: handler(state, event_data), stop_propagation: Bool.false, prevent_default: Bool.false } + + Ok(Custom(handler)) -> + handler(state, event_data) + + when action is + Update(new_state) -> + new_view_unrendered = + app.render(new_state) + { rendered: new_rendered, patches } = + diff({ rendered, patches: [] }, new_view_unrendered) + + apply_patches!(patches) + Task.ok({ + platform_state: { + app, + state: new_state, + rendered: new_rendered, + }, + stop_propagation, + prevent_default, + }) + + None -> + Task.ok({ platform_state, stop_propagation, prevent_default }) + +# ------------------------------- +# DIFF +# ------------------------------- +diff : DiffState state, Html state -> DiffState state +diff = \{ rendered, patches }, new_node -> + root = + rendered.root + old_node = + List.get(rendered.nodes, root) + |> Result.with_default(Ok(RenderedNone)) + |> Result.with_default(RenderedNone) + + when { old_node, new_node } is + { old_node: RenderedText(old_content), new_node: Text(new_content) } -> + if new_content != old_content then + new_nodes = + List.set(rendered.nodes, rendered.root, Ok(RenderedText(new_content))) + + { + rendered: { rendered & + nodes: new_nodes, + }, + patches: List.append(patches, UpdateTextNode(rendered.root, new_content)), + } + else + { rendered, patches } + + { old_node: RenderedElement(old_name, old_attrs, old_children), new_node: Element(new_name, _, new_attrs, new_children) } -> + if new_name != old_name then + replace_node({ rendered, patches }, root, new_node) + else + state_attrs = + diff_attrs({ rendered, patches }, root, old_attrs, new_attrs) + state_child_pairs = + List.map2(old_children, new_children, \old_child_id, new_child -> { old_child_id, new_child }) + |> List.walk(state_attrs, \child_walk_state, { old_child_id, new_child } -> + { rendered: child_walk_rendered, patches: child_walk_patches } = child_walk_state + diff({ rendered: { child_walk_rendered & root: old_child_id }, patches: child_walk_patches }, new_child)) + { rendered: rendered_left_over_children, patches: patches_left_over_children } = + if List.len(old_children) > List.len(new_children) then + List.walk_from(old_children, List.len(new_children), state_child_pairs, delete_node) + else if List.len(old_children) < List.len(new_children) then + state_before_create = { + rendered: state_child_pairs.rendered, + patches: state_child_pairs.patches, + ids: [], + } + { rendered: rendered_after_create, patches: patches_after_create, ids: created_ids } = + List.walk_from(new_children, List.len(old_children), state_before_create, create_child_node) + # Look up the children again since they might have new node IDs! + node_with_updated_children = + when List.get(rendered_after_create.nodes, root) is + Ok(Ok(RenderedElement(n, a, c))) -> RenderedElement(n, a, List.concat(c, created_ids)) + _ -> crash("Bug in virtual-dom framework: nodeWithUpdatedChildren not found") + updated_nodes = + List.set(rendered_after_create.nodes, root, Ok(node_with_updated_children)) + + { + rendered: { rendered_after_create & nodes: updated_nodes }, + patches: List.walk(created_ids, patches_after_create, \p, id -> List.append(p, AppendChild(root, id))), + } + else + state_child_pairs + + { + rendered: { rendered_left_over_children & root }, + patches: patches_left_over_children, + } + + { old_node: RenderedNone, new_node: None } -> + { rendered, patches } + + _ -> + # old node has been replaced with a totally different variant. There's no point in diffing, just replace. + replace_node({ rendered, patches }, rendered.root, new_node) + +replace_node : DiffState state, NodeId, Html state -> DiffState state +replace_node = \diff_state, old_node_id, new_node -> + { rendered: create_rendered, patches: create_patches, id: create_node_id } = + create_node(diff_state, new_node) + pre_delete_state = { + rendered: create_rendered, + patches: List.append(create_patches, ReplaceNode(old_node_id, create_node_id)), + } + + delete_node(pre_delete_state, old_node_id) + +# Delete a node, and drop any JS references to its children and event listeners +# TODO: see if it would speed things up to leave this junk lying around until the slot is reused. +# Any danger of spurious events being sent to the wrong handler? +# Otherwise, can we sweep everything at once at the end of the diff? +# Let's be conservative on things like this until we have more test cases working. +delete_node : DiffState state, NodeId -> DiffState state +delete_node = \diff_state, id -> + { rendered, patches } = + when List.get(diff_state.rendered.nodes, id) is + Ok(node) -> + when node is + Ok(RenderedElement(_, _, children)) -> + List.walk(children, diff_state, delete_node) + + _ -> diff_state + + _ -> diff_state + + patches_remove_listeners = + when List.get(rendered.nodes, id) is + Ok(Ok(RenderedElement(_, attrs, _))) -> + Dict.walk(attrs.event_listeners, patches, \p, _, { handler_id } -> + List.append(p, RemoveListener(id, handler_id))) + + _ -> patches + + new_nodes = + List.set(rendered.nodes, id, Err(DeletedNode)) + new_deleted_node_cache = + List.append(rendered.deleted_node_cache, id) + new_patches = + List.append(patches_remove_listeners, RemoveNode(id)) + + { + rendered: { rendered & + nodes: new_nodes, + deleted_node_cache: new_deleted_node_cache, + }, + patches: new_patches, + } + +create_node : DiffState state, Html state -> { rendered : RenderedTree state, patches : List Patch, id : NodeId } +create_node = \{ rendered, patches }, new_node -> + when new_node is + Text(content) -> + { rendered: new_rendered, id } = + insert_node(rendered, RenderedText(content)) + + { + rendered: new_rendered, + patches: List.append(patches, CreateTextNode(id, content)), + id, + } + + None -> + { rendered: new_rendered, id } = + insert_node(rendered, RenderedNone) + + { rendered: new_rendered, patches, id } + + Element(tag_name, _, attrs, children) -> + { rendered: rendered_with_children, patches: patches_with_children, ids: child_ids } = + List.walk(children, { rendered, patches, ids: [] }, create_child_node) + node_id = + next_node_id(rendered_with_children) + patches_with_elem = + List.append(patches_with_children, CreateElement(node_id, tag_name)) + { rendered_attrs, rendered: rendered_with_attrs, patches: patches_with_attrs } = + render_attrs(attrs, rendered_with_children, patches_with_elem, node_id) + { rendered: rendered_with_node } = + insert_node(rendered_with_attrs, RenderedElement(tag_name, rendered_attrs, child_ids)) + + { + rendered: rendered_with_node, + patches: patches_with_attrs, + id: node_id, + } + +AttrDiffState state : { + node_id : NodeId, + attrs : RenderedAttributes, + patches : List Patch, + handlers : List (Result (Handler state) [DeletedHandler]), + deleted_handler_cache : List HandlerId, +} + +diff_attrs : DiffState state, NodeId, RenderedAttributes, List (Attribute state) -> DiffState state +diff_attrs = \{ rendered, patches }, node_id, attrs, new_attrs -> + init_state = { + node_id, + attrs, + patches, + handlers: rendered.handlers, + deleted_handler_cache: rendered.deleted_handler_cache, + } + final_state = + List.walk(new_attrs, init_state, diff_attr) + new_rendered = + { rendered & + handlers: final_state.handlers, + deleted_handler_cache: final_state.deleted_handler_cache, + } + + { + rendered: new_rendered, + patches: final_state.patches, + } + +diff_attr : AttrDiffState state, Attribute state -> AttrDiffState state +diff_attr = \{ node_id, attrs, patches, handlers, deleted_handler_cache }, attr -> + when attr is + EventListener(event_name, new_accessors, new_handler) -> + when Dict.get(attrs.event_listeners, event_name) is + Ok({ accessors, handler_id }) -> + Tuple(new_attrs, new_patches) = + if accessors == new_accessors then + Tuple(attrs, patches) + else + json = new_accessors |> Encode.to_bytes(Json.json) + + Tuple( + { attrs & event_listeners: Dict.insert(attrs.event_listeners, event_name, { accessors, handler_id }) }, + ( + patches + |> List.append(RemoveListener(node_id, handler_id)) + |> List.append(SetListener(node_id, event_name, json, handler_id)) + ), + ) + + { + node_id, + attrs: new_attrs, + patches: new_patches, + handlers: List.set(handlers, handler_id, Ok(new_handler)), + deleted_handler_cache, + } + + Err(KeyNotFound) -> + render_attr({ node_id, attrs, patches, handlers, deleted_handler_cache }, attr) + + HtmlAttr(k, v) -> + when Dict.get(attrs.html_attrs, k) is + Ok(old_val) -> + Tuple(new_attrs, new_patches) = + if old_val == v then + Tuple(attrs, patches) + else + Tuple( + { attrs & html_attrs: Dict.insert(attrs.html_attrs, k, v) }, + (patches |> List.append(SetAttribute(node_id, k, v))), + ) + { + node_id, + attrs: new_attrs, + patches: new_patches, + handlers, + deleted_handler_cache, + } + + Err(KeyNotFound) -> + render_attr({ node_id, attrs, patches, handlers, deleted_handler_cache }, attr) + + DomProp(k, v) -> + when Dict.get(attrs.dom_props, k) is + Ok(old_val) -> + Tuple(new_attrs, new_patches) = + if old_val == v then + Tuple(attrs, patches) + else + Tuple( + { attrs & dom_props: Dict.insert(attrs.dom_props, k, v) }, + (patches |> List.append(SetProperty(node_id, k, v))), + ) + { + node_id, + attrs: new_attrs, + patches: new_patches, + handlers, + deleted_handler_cache, + } + + Err(KeyNotFound) -> + render_attr({ node_id, attrs, patches, handlers, deleted_handler_cache }, attr) + + Style(k, v) -> + when Dict.get(attrs.styles, k) is + Ok(old_val) -> + Tuple(new_attrs, new_patches) = + if old_val == v then + Tuple(attrs, patches) + else + Tuple( + { attrs & styles: Dict.insert(attrs.styles, k, v) }, + (patches |> List.append(SetStyle(node_id, k, v))), + ) + { + node_id, + attrs: new_attrs, + patches: new_patches, + handlers, + deleted_handler_cache, + } + + Err(KeyNotFound) -> + render_attr({ node_id, attrs, patches, handlers, deleted_handler_cache }, attr) + +render_attrs : List (Attribute state), RenderedTree state, List Patch, NodeId -> { rendered_attrs : RenderedAttributes, rendered : RenderedTree state, patches : List Patch } +render_attrs = \attrs, rendered, patches, node_id -> + init_state = { + node_id, + attrs: empty_rendered_attrs, + patches, + handlers: rendered.handlers, + deleted_handler_cache: rendered.deleted_handler_cache, + } + final_state = + List.walk(attrs, init_state, render_attr) + + { + rendered_attrs: final_state.attrs, + rendered: { rendered & + handlers: final_state.handlers, + deleted_handler_cache: final_state.deleted_handler_cache, + }, + patches: final_state.patches, + } + +render_attr : AttrDiffState state, Attribute state -> AttrDiffState state +render_attr = \{ node_id, attrs, patches, handlers, deleted_handler_cache }, attr -> + when attr is + HtmlAttr(k, v) -> + { + node_id, + handlers, + deleted_handler_cache, + attrs: { attrs & html_attrs: Dict.insert(attrs.html_attrs, k, v) }, + patches: List.append(patches, SetAttribute(node_id, k, v)), + } + + DomProp(k, v) -> + { + node_id, + handlers, + deleted_handler_cache, + attrs: { attrs & dom_props: Dict.insert(attrs.dom_props, k, v) }, + patches: List.append(patches, SetProperty(node_id, k, v)), + } + + Style(k, v) -> + { + node_id, + handlers, + deleted_handler_cache, + attrs: { attrs & styles: Dict.insert(attrs.styles, k, v) }, + patches: List.append(patches, SetStyle(node_id, k, v)), + } + + EventListener(event_type, accessors, handler) -> + { handler_id, new_handlers, new_deleted_handler_cache } = + when List.last(deleted_handler_cache) is + Ok(id) -> + { + handler_id: id, + new_handlers: List.set(handlers, id, Ok(handler)), + new_deleted_handler_cache: List.drop_last(deleted_handler_cache, 1), + } + + Err(_) -> + { + handler_id: List.len(handlers), + new_handlers: List.append(handlers, Ok(handler)), + new_deleted_handler_cache: deleted_handler_cache, + } + accessors_json = + accessors |> Encode.to_bytes(Json.json) + patch = + SetListener(node_id, event_type, accessors_json, handler_id) + + { + node_id, + attrs: { attrs & event_listeners: Dict.insert(attrs.event_listeners, event_type, { accessors, handler_id }) }, + handlers: new_handlers, + deleted_handler_cache: new_deleted_handler_cache, + patches: List.append(patches, patch), + } + +create_child_node : + { rendered : RenderedTree state, patches : List Patch, ids : List NodeId }, + Html state + -> { rendered : RenderedTree state, patches : List Patch, ids : List NodeId } +create_child_node = \{ rendered, patches, ids }, child_html -> + { rendered: rendered_child, patches: child_patches, id } = + create_node({ rendered, patches }, child_html) + + { + rendered: rendered_child, + patches: child_patches, + ids: List.append(ids, id), + } + +# insert a node into the nodes list, assigning it a NodeId +insert_node : RenderedTree state, RenderedNode -> { rendered : RenderedTree state, id : NodeId } +insert_node = \rendered, node -> + when List.last(rendered.deleted_node_cache) is + Ok(id) -> + new_rendered = + { rendered & + nodes: List.set(rendered.nodes, id, Ok(node)), + deleted_node_cache: List.drop_last(rendered.deleted_node_cache, 1), + } + + { rendered: new_rendered, id } + + Err(_) -> + new_rendered = + { rendered & + nodes: List.append(rendered.nodes, Ok(node)), + } + + { rendered: new_rendered, id: List.len(rendered.nodes) } + +# Predict what NodeId will be assigned next, without actually assigning it +next_node_id : RenderedTree state -> NodeId +next_node_id = \rendered -> + when List.last(rendered.deleted_node_cache) is + Ok(id) -> id + Err(_) -> List.len(rendered.nodes) + +# ------------------------------- +# TESTS +# ------------------------------- +eq_rendered_tree : RenderedTree state, RenderedTree state -> Bool +eq_rendered_tree = \a, b -> + (a.root == b.root) + && (a.nodes == b.nodes) + && (List.len(a.handlers) == List.len(b.handlers)) + && (a.deleted_node_cache == b.deleted_node_cache) + && (a.deleted_handler_cache == b.deleted_handler_cache) + +# indexNodes +expect + html : Html {} + html = + Element("a", 43, [HtmlAttr("href", "https://www.roc-lang.org/")], [Text("Roc")]) + + actual : { nodes : List RenderedNode, sibling_ids : List U64 } + actual = + index_nodes({ nodes: [], sibling_ids: [] }, html) + + expected : { nodes : List RenderedNode, sibling_ids : List U64 } + expected = { + nodes: [ + RenderedText("Roc"), + RenderedElement("a", { empty_rendered_attrs & html_attrs: Dict.from_list([("href", "https://www.roc-lang.org/")]) }, [0]), + ], + sibling_ids: [1], + } + + (actual.nodes == expected.nodes) + && (actual.sibling_ids == expected.sibling_ids) + +# diff +expect + State : { answer : U32 } + + diff_state_before : DiffState State + diff_state_before = { + rendered: { + root: 4, + nodes: [ + Ok(RenderedText("The app")), + Ok(RenderedElement("h1", empty_rendered_attrs, [0])), + Ok(RenderedText("The answer is 42")), + Ok(RenderedElement("div", empty_rendered_attrs, [2])), + Ok(RenderedElement("body", empty_rendered_attrs, [1, 3])), + ], + deleted_node_cache: [], + handlers: [], + deleted_handler_cache: [], + }, + patches: [], + } + + # Sizes don't matter, use zero. We are not creating a HTML string so we don't care what size it would be. + new_node : Html State + new_node = + Element("body", 0, [], [ + Element("h1", 0, [], [Text("The app")]), + Element("div", 0, [], [Text("The answer is 111")]), + ]) + + expected : DiffState State + expected = { + rendered: { + root: 4, + nodes: [ + Ok(RenderedText("The app")), + Ok(RenderedElement("h1", empty_rendered_attrs, [0])), + Ok(RenderedText("The answer is 111")), + Ok(RenderedElement("div", empty_rendered_attrs, [2])), + Ok(RenderedElement("body", empty_rendered_attrs, [1, 3])), + ], + deleted_node_cache: [], + handlers: [], + deleted_handler_cache: [], + }, + patches: [UpdateTextNode(2, "The answer is 111")], + } + + actual : DiffState State + actual = + diff(diff_state_before, new_node) + + (actual.patches == expected.patches) + && eq_rendered_tree(actual.rendered, expected.rendered) + +# initClientAppHelp +expect + State : { answer : U32 } + + init = \result -> + when result is + Ok(state) -> state + Err(_) -> { answer: 0 } + + on_click_handler : Handler State + on_click_handler = + Normal(\state, _ -> Action.update({ answer: state.answer + 1 })) + + render : State -> Html State + render = \state -> + num = Num.to_str(state.answer) + + on_click_attr : Attribute State + on_click_attr = + EventListener("click", [], on_click_handler) + + # Sizes don't matter, use zero. We are not creating a HTML string so we don't care what size it would be. + Element("body", 0, [], [ + Element("h1", 0, [], [Text("The app")]), + Element("div", 0, [on_click_attr], [Text("The answer is $(num)")]), + ]) + + app : App State State + app = { + init, + render, + wasm_url: "assets/test.wasm", + } + + init_json : List U8 + init_json = + { answer: 42 } |> Encode.to_bytes(Json.json) # panics at mono/src/ir.rs:5739:56 + expected : { state : State, rendered : RenderedTree State, patches : List Patch } + expected = { + state: { answer: 42 }, + rendered: { + root: 4, + nodes: [ + Ok(RenderedText("The app")), + Ok(RenderedElement("h1", empty_rendered_attrs, [0])), + Ok(RenderedText("The answer is 42")), + Ok(RenderedElement("div", { empty_rendered_attrs & event_listeners: Dict.from_list([("click", { accessors: [], handler_id: 0 })]) }, [2])), + Ok(RenderedElement("body", empty_rendered_attrs, [1, 3])), + ], + deleted_node_cache: [], + handlers: [Ok(on_click_handler)], + deleted_handler_cache: [], + }, + patches: [SetListener(3, "click", [], 0)], + } + + actual : { state : State, rendered : RenderedTree State, patches : List Patch } + actual = + init_client_app_help(init_json, app) + + (actual.state == expected.state) + && eq_rendered_tree(actual.rendered, expected.rendered) + && (actual.patches == expected.patches) diff --git a/examples/virtual-dom-wip/platform/Html/Internal/Server.roc b/examples/virtual-dom-wip/platform/Html/Internal/Server.roc new file mode 100644 index 00000000000..51ebc096506 --- /dev/null +++ b/examples/virtual-dom-wip/platform/Html/Internal/Server.roc @@ -0,0 +1,122 @@ +module [ + append_rendered_static, + init_server_app, +] + +import Html.Internal.Shared exposing [Html, Attribute, App, translate_static, text, element] +import Json + +# ------------------------------- +# STATIC HTML +# ------------------------------- +append_rendered_static : Str, Html [] -> Str +append_rendered_static = \buffer, node -> + when node is + Text(content) -> + Str.concat(buffer, content) + + Element(name, _, attrs, children) -> + with_tag_name = "$(buffer)<$(name)" + with_attrs = + if List.is_empty(attrs) then + with_tag_name + else + init = { buffer: Str.concat(with_tag_name, " "), styles: "" } + { buffer: attr_buffer, styles } = + List.walk(attrs, init, append_rendered_static_attr) + + if Str.is_empty(styles) then + attr_buffer + else + "$(attr_buffer) style=\"$(styles)\"" + + with_tag = Str.concat(with_attrs, ">") + with_children = List.walk(children, with_tag, append_rendered_static) + + "$(with_children)" + + None -> buffer + +append_rendered_static_attr : { buffer : Str, styles : Str }, Attribute [] -> { buffer : Str, styles : Str } +append_rendered_static_attr = \{ buffer, styles }, attr -> + when attr is + HtmlAttr(key, value) -> + new_buffer = "$(buffer) $(key)=\"$(value)\"" + + { buffer: new_buffer, styles } + + Style(key, value) -> + new_styles = "$(styles) $(key): $(value);" + + { buffer, styles: new_styles } + + DomProp(_, _) -> { buffer, styles } + +# ------------------------------- +# INITIALISATION +# ------------------------------- +init_server_app : App state init_data, init_data, Str -> Result (Html []) [InvalidDocument] where init_data implements Encoding +init_server_app = \app, init_data, host_java_script -> + init_data + |> Ok + |> app.init + |> app.render + |> translate_static + |> insert_roc_script(init_data, app.wasm_url, host_java_script) + +insert_roc_script : Html [], init_data, Str, Str -> Result (Html []) [InvalidDocument] where init_data implements Encoding +insert_roc_script = \document, init_data, wasm_url, host_java_script -> + encode = + \value -> + value + |> Encode.to_bytes(Json.json) + |> Str.from_utf8 + |> Result.with_default("") + + # Convert initData to JSON as a Roc Str, then convert the Roc Str to a JS string. + # JSON won't have invalid UTF-8 in it, since it would be escaped as part of JSON encoding. + js_init_data = + init_data |> encode |> encode + + js_wasm_url = + encode(wasm_url) + + script : Html [] + script = element("script")([], [ + text( + """ + $(host_java_script) + (function(){ + const initData = $(js_init_data); + const wasmUrl = $(js_wasm_url); + window.roc = roc_init(initData, wasmUrl); + })(); + """, + ), + ]) + + # append the