diff options
author | Mikael Pettersson <[email protected]> | 2017-09-24 12:46:28 +0200 |
---|---|---|
committer | Mikael Pettersson <[email protected]> | 2017-09-24 12:46:28 +0200 |
commit | ec2b785a09959b7c0a85ac8e9ad9b36e7b2166a3 (patch) | |
tree | 016551723562153ac1b80c8ee434fb7e74a3a11f | |
parent | 8b2705934fc8df02fd54dae20c1127faa1e3308d (diff) | |
download | otp-ec2b785a09959b7c0a85ac8e9ad9b36e7b2166a3.tar.gz otp-ec2b785a09959b7c0a85ac8e9ad9b36e7b2166a3.tar.bz2 otp-ec2b785a09959b7c0a85ac8e9ad9b36e7b2166a3.zip |
base64:decode(List) put the List parameter first for improved performance
-rw-r--r-- | lib/stdlib/src/base64.erl | 38 |
1 files changed, 19 insertions, 19 deletions
diff --git a/lib/stdlib/src/base64.erl b/lib/stdlib/src/base64.erl index 0eea2c0f1a..6e96f7d1f7 100644 --- a/lib/stdlib/src/base64.erl +++ b/lib/stdlib/src/base64.erl @@ -115,7 +115,7 @@ encode_binary(Bin) -> decode(Bin) when is_binary(Bin) -> decode_binary(<<>>, Bin); decode(List) when is_list(List) -> - decode_list(<<>>, List). + decode_list(List, <<>>). -spec mime_decode(Base64) -> Data when Base64 :: ascii_string() | ascii_binary(), @@ -262,39 +262,39 @@ mime_decode_binary_after_eq(Result0, <<>>, Eq) -> Result end. -decode_list(A, [C1 | Cs]) -> +decode_list([C1 | Cs], A) -> case element(C1, ?DECODE_MAP) of - ws -> decode_list(A, Cs); - B1 -> decode_list(A, B1, Cs) + ws -> decode_list(Cs, A); + B1 -> decode_list(Cs, A, B1) end; -decode_list(A, []) -> +decode_list([], A) -> A. -decode_list(A, B1, [C2 | Cs]) -> +decode_list([C2 | Cs], A, B1) -> case element(C2, ?DECODE_MAP) of - ws -> decode_list(A, B1, Cs); - B2 -> decode_list(A, B1, B2, Cs) + ws -> decode_list(Cs, A, B1); + B2 -> decode_list(Cs, A, B1, B2) end. -decode_list(A, B1, B2, [C3 | Cs]) -> +decode_list([C3 | Cs], A, B1, B2) -> case element(C3, ?DECODE_MAP) of - ws -> decode_list(A, B1, B2, Cs); - B3 -> decode_list(A, B1, B2, B3, Cs) + ws -> decode_list(Cs, A, B1, B2); + B3 -> decode_list(Cs, A, B1, B2, B3) end. -decode_list(A, B1, B2, B3, [C4 | Cs]) -> +decode_list([C4 | Cs], A, B1, B2, B3) -> case element(C4, ?DECODE_MAP) of - ws -> decode_list(A, B1, B2, B3, Cs); - eq when B3 =:= eq -> only_ws(<<A/binary,B1:6,(B2 bsr 4):2>>, Cs); - eq -> only_ws(<<A/binary,B1:6,B2:6,(B3 bsr 2):4>>, Cs); - B4 -> decode_list(<<A/binary,B1:6,B2:6,B3:6,B4:6>>, Cs) + ws -> decode_list(Cs, A, B1, B2, B3); + eq when B3 =:= eq -> only_ws(Cs, <<A/binary,B1:6,(B2 bsr 4):2>>); + eq -> only_ws(Cs, <<A/binary,B1:6,B2:6,(B3 bsr 2):4>>); + B4 -> decode_list(Cs, <<A/binary,B1:6,B2:6,B3:6,B4:6>>) end. -only_ws(A, []) -> +only_ws([], A) -> A; -only_ws(A, [C | Cs]) -> +only_ws([C | Cs], A) -> case element(C, ?DECODE_MAP) of - ws -> only_ws(A, Cs); + ws -> only_ws(Cs, A); _ -> erlang:error(function_clause) end. |