From e9721170b26f02ef6a3fb86a7058ae3975c00d50 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?William=20Fank=20Thom=C3=A9?= Date: Mon, 29 Jul 2024 01:45:23 -0300 Subject: [PATCH] Remove 'default' from encoder opts and tweak README --- README.md | 70 +++++++++++++++++++++++------------------- src/euneus_encoder.erl | 21 ++++++------- 2 files changed, 48 insertions(+), 43 deletions(-) diff --git a/README.md b/README.md index 294a853..652b339 100644 --- a/README.md +++ b/README.md @@ -38,26 +38,29 @@ The second argument of `euneus:encode/2` are options, and this is the spec: -type options() :: #{ nulls => [term()], skip_values => [term()], - escape => default | fun((binary()) -> iodata()), - integer => default | encode(integer()), - float => default | encode(float()), - atom => default | encode(atom()), - list => default | encode(list()), + escape => fun((binary()) -> iodata()), + integer => encode(integer()), + float => encode(float()), + atom => encode(atom()), + list => encode(list()), proplist => boolean() | {true, is_proplist()}, - map => default | encode(map()), + map => encode(map()), sort_keys => boolean(), - tuple => default - | encode(tuple()) - | [ datetime - | timestamp - | ipv4 - | ipv6 - | {record, #{Name :: atom() => {Fields :: [atom()], Size :: pos_integer()}} - | [{Name :: atom(), Fields :: [atom()]}]} - | fun((tuple()) -> next | {halt, term()})], - pid => default | encode(pid()), - port => default | encode(port()), - reference => default | encode(reference()) + tuple => + encode(tuple()) + | [ + datetime + | timestamp + | ipv4 + | ipv6 + | {record, + #{Name :: atom() => {Fields :: [atom()], Size :: pos_integer()}} + | [{Name :: atom(), Fields :: [atom()]}]} + | fun((tuple()) -> next | {halt, term()}) + ], + pid => encode(pid()), + port => encode(port()), + reference => encode(reference()) }. ``` @@ -83,24 +86,27 @@ The second argument of `euneus:decode/2` are options, and this is the spec: ```erlang -type options() :: #{ - codecs => [ copy - | timestamp - | datetime - | ipv4 - | ipv6 - | pid - | port - | reference - | fun((binary()) -> next | {halt, term()})], + codecs => [ + copy + | timestamp + | datetime + | ipv4 + | ipv6 + | pid + | port + | reference + | fun((binary()) -> next | {halt, term()}) + ], array_start => json:array_start_fun(), array_push => json:array_push_fun(), array_finish => json:array_finish_fun(), object_start => json:object_start_fun(), - object_keys => binary - | copy - | atom - | existing_atom - | json:from_binary_fun(), + object_keys => + binary + | copy + | atom + | existing_atom + | json:from_binary_fun(), object_push => json:object_push_fun(), object_finish => json:object_finish_fun(), float => json:from_binary_fun(), diff --git a/src/euneus_encoder.erl b/src/euneus_encoder.erl index 3737ca2..c50e0dd 100644 --- a/src/euneus_encoder.erl +++ b/src/euneus_encoder.erl @@ -65,17 +65,16 @@ -type options() :: #{ nulls => [term()], skip_values => [term()], - escape => default | fun((binary()) -> iodata()), - integer => default | encode(integer()), - float => default | encode(float()), - atom => default | encode(atom()), - list => default | encode(list()), + escape => fun((binary()) -> iodata()), + integer => encode(integer()), + float => encode(float()), + atom => encode(atom()), + list => encode(list()), proplist => boolean() | {true, is_proplist()}, - map => default | encode(map()), + map => encode(map()), sort_keys => boolean(), tuple => - default - | encode(tuple()) + encode(tuple()) | [ datetime | timestamp @@ -86,9 +85,9 @@ | [{Name :: atom(), Fields :: [atom()]}]} | fun((tuple()) -> next | {halt, term()}) ], - pid => default | encode(pid()), - port => default | encode(port()), - reference => default | encode(reference()) + pid => encode(pid()), + port => encode(port()), + reference => encode(reference()) }. -export_type([options/0]).