diff --git a/src/jsx_decoder.hrl b/src/jsx_decoder.hrl index c5dda0a..0d1d21a 100644 --- a/src/jsx_decoder.hrl +++ b/src/jsx_decoder.hrl @@ -357,7 +357,9 @@ key(Bin, Stack, Opts) -> string(Bin, Stack, Opts) -> string(Bin, Stack, Opts, []). string(<>, [key|_] = Stack, Opts, Acc) -> - {jsx, {key, unicode:characters_to_binary(lists:reverse(Acc))}, fun() -> colon(Rest, Stack, Opts) end}; + {jsx, {key, unicode:characters_to_binary(lists:reverse(Acc))}, fun() -> + colon(Rest, Stack, Opts) + end}; string(<>, Stack, Opts, Acc) -> {jsx, {string, unicode:characters_to_binary(lists:reverse(Acc))}, fun() -> maybe_done(Rest, Stack, Opts) @@ -1228,7 +1230,11 @@ check_bad(List) -> ). check_replaced(List) -> - lists:dropwhile(fun({_, [{string, <<16#fffd/utf8>>}|_]}) -> true ; (_) -> false end, + lists:dropwhile(fun({_, [{string, <<16#fffd/utf8>>}|_]}) -> + true + ; (_) -> + false + end, check(List, [loose_unicode], []) ). diff --git a/src/jsx_encoder.erl b/src/jsx_encoder.erl index c4b054a..d5cc49d 100644 --- a/src/jsx_encoder.erl +++ b/src/jsx_encoder.erl @@ -76,7 +76,9 @@ list_or_object(Forms, _, _) -> {error, {badjson, Forms}}. key([{key, Key}|Forms], Stack, Opts) when is_binary(Key) -> - {jsx, {key, json_escape(Key, Opts)}, fun() -> value(Forms, Stack, Opts) end}; + {jsx, {key, json_escape(Key, Opts)}, fun() -> + value(Forms, Stack, Opts) + end}; key([end_object|Forms], [object|Stack], Opts) -> {jsx, end_object, fun() -> maybe_done(Forms, Stack, Opts) end}; key([], Stack, Opts) -> @@ -89,7 +91,9 @@ key(Forms, _, _) -> {error, {badjson, Forms}}. value([{string, S}|Forms], Stack, Opts) when is_binary(S) -> - {jsx, {string, json_escape(S, Opts)}, fun() -> maybe_done(Forms, Stack, Opts) end}; + {jsx, {string, json_escape(S, Opts)}, fun() -> + maybe_done(Forms, Stack, Opts) + end}; value([{float, F}|Forms], Stack, Opts) when is_float(F) -> {jsx, {float, F}, fun() -> maybe_done(Forms, Stack, Opts) end}; value([{integer, I}|Forms], Stack, Opts) when is_integer(I) -> @@ -164,10 +168,11 @@ json_escape(<>, Opts, Acc) when C >= 0, C < $\s -> json_escape(Rest, Opts, <>); %% escape forward slashes -- optionally -- to faciliate microsoft's retarded %% date format -json_escape(<<$/, Rest/binary>>, Opts = #opts{escape_forward_slash = true}, Acc) -> +json_escape(<<$/, Rest/binary>>, Opts=#opts{escape_forward_slash=true}, Acc) -> json_escape(Rest, Opts, <>); %% escape u+2028 and u+2029 to avoid problems with jsonp -json_escape(<>, Opts, Acc) when C == 16#2028; C == 16#2029 -> +json_escape(<>, Opts, Acc) + when C == 16#2028; C == 16#2029 -> json_escape(Rest, Opts, <>); %% any other legal codepoint json_escape(<>, Opts, Acc) -> @@ -233,7 +238,8 @@ encode_incremental([Term|Terms], F, Expected, Acc) -> loop({error, _}, _) -> error; -loop({jsx, incomplete, Next}, Acc) -> {jsx, incomplete, Next, lists:reverse(Acc)}; +loop({jsx, incomplete, Next}, Acc) -> + {jsx, incomplete, Next, lists:reverse(Acc)}; loop({jsx, end_json, Next}, Acc) -> {jsx, incomplete, F} = Next(), {error, {badjson, []}} = F([]), @@ -311,8 +317,8 @@ escape_test_() -> ) }, {"microsoft i hate your date format", - ?_assert(json_escape( - <<"/Date(1303502009425)/">>, #opts{escape_forward_slash=true} + ?_assert(json_escape(<<"/Date(1303502009425)/">>, + #opts{escape_forward_slash=true} ) =:= <<"\\/Date(1303502009425)\\/">> ) } diff --git a/src/jsx_terms.erl b/src/jsx_terms.erl index 8f70f58..c2c9605 100644 --- a/src/jsx_terms.erl +++ b/src/jsx_terms.erl @@ -411,7 +411,9 @@ repeated_keys_test_() -> ) }, {"nested repeated key", - ?_assert(json_to_term(<<"[{\"a\":false,\"a\":true},{\"a\":false,\"a\":true}]">>, []) + ?_assert(json_to_term( + <<"[{\"a\":false,\"a\":true},{\"a\":false,\"a\":true}]">>, + []) =:= [[{<<"a">>, true}], [{<<"a">>, true}]] ) }, @@ -448,7 +450,9 @@ stream_test_() -> [ {"streaming mode", ?_assert(begin - {jsx, incomplete, F} = json_to_term(<<"{">>, [{stream, true}]), + {jsx, incomplete, F} = json_to_term(<<"{">>, + [{stream, true}] + ), F(<<"}">>) end =:= [{}]) } diff --git a/src/jsx_utils.erl b/src/jsx_utils.erl index bb06334..0b4c36c 100644 --- a/src/jsx_utils.erl +++ b/src/jsx_utils.erl @@ -233,7 +233,8 @@ detect_encoding(<<0, X>>, Opts) when X =/= 0 -> {jsx, incomplete, fun(end_stream) -> try - {jsx, incomplete, Next} = (jsx_utf16:decoder(Opts))(<<0, X>>), + {jsx, incomplete, Next} + = (jsx_utf16:decoder(Opts))(<<0, X>>), Next(end_stream) catch error:function_clause -> {error, {badjson, <<0, X>>}} @@ -246,7 +247,8 @@ detect_encoding(<>, Opts) when X =/= 0 -> {jsx, incomplete, fun(end_stream) -> try - {jsx, incomplete, Next} = (jsx_utf16le:decoder(Opts))(<>), + {jsx, incomplete, Next} + = (jsx_utf16le:decoder(Opts))(<>), Next(end_stream) catch error:function_clause -> {error, {badjson, <>}}