diff options
author | Louis Pilfold <louis@lpil.uk> | 2022-01-14 22:42:56 +0000 |
---|---|---|
committer | Louis Pilfold <louis@lpil.uk> | 2022-01-14 22:42:56 +0000 |
commit | 476195211e99133c7ef0fedf5a0d8ad3d0de5ede (patch) | |
tree | 570e50eb3d37833c8c49af6e69ee1c8fd6ac7a79 /src/gleam_stdlib.erl | |
parent | 09e64691040430c4e73f587518db2658ec96a2e7 (diff) | |
download | gleam_stdlib-476195211e99133c7ef0fedf5a0d8ad3d0de5ede.tar.gz gleam_stdlib-476195211e99133c7ef0fedf5a0d8ad3d0de5ede.zip |
Fix field error
Diffstat (limited to 'src/gleam_stdlib.erl')
-rw-r--r-- | src/gleam_stdlib.erl | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/gleam_stdlib.erl b/src/gleam_stdlib.erl index c757857..e9d6391 100644 --- a/src/gleam_stdlib.erl +++ b/src/gleam_stdlib.erl @@ -49,8 +49,10 @@ iodata_append(Iodata, String) -> [Iodata, String]. identity(X) -> X. -decode_error_msg(Expected, Data) -> - {error, [{decode_error, Expected, classify_dynamic(Data), []}]}. +decode_error_msg(Expected, Data) when is_binary(Expected) -> + decode_error(Expected, classify_dynamic(Data)). +decode_error(Expected, Got) when is_binary(Expected) andalso is_binary(Got) -> + {error, [{decode_error, Expected, Got, []}]}. classify_dynamic(X) when is_atom(X) -> <<"Atom">>; classify_dynamic(X) when is_binary(X) -> <<"String">>; @@ -94,7 +96,8 @@ decode_list(Data) -> decode_error_msg(<<"List">>, Data). decode_field(Data, Key) -> case Data of #{Key := Value} -> {ok, Value}; - _ -> decode_error_msg("object", Data) + _ -> + decode_error(<<"field"/utf8>>, <<"nothing"/utf8>>) end. size_of_tuple(Data) -> tuple_size(Data). |