aboutsummaryrefslogtreecommitdiffstats
path: root/src/rlx_string.erl
diff options
context:
space:
mode:
authorLuis Rascão <[email protected]>2017-11-11 02:01:51 +0000
committerGitHub <[email protected]>2017-11-11 02:01:51 +0000
commit1d051663982502620dbdd2b372aee52894981568 (patch)
tree5859cfa77aeca68f30c03ceec8ee31cd2d3e943c /src/rlx_string.erl
parentfb91587091ad8a9da7c22598e962d0f21dcc17ee (diff)
parent2868d7a7ae79829c740ff9a49e22e2ccf9e6296c (diff)
downloadrelx-1d051663982502620dbdd2b372aee52894981568.tar.gz
relx-1d051663982502620dbdd2b372aee52894981568.tar.bz2
relx-1d051663982502620dbdd2b372aee52894981568.zip
Merge pull request #618 from ferd/otp-20-unicode-support
OTP-20 unicode support and OTP-21 readiness
Diffstat (limited to 'src/rlx_string.erl')
-rw-r--r--src/rlx_string.erl23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/rlx_string.erl b/src/rlx_string.erl
new file mode 100644
index 0000000..1f9cc0c
--- /dev/null
+++ b/src/rlx_string.erl
@@ -0,0 +1,23 @@
+%% Compatibility module for the string API changes between
+%% OTP-19 and OTP-21, where Unicode support means the deprecation
+%% of a lot of string functions.
+-module(rlx_string).
+-export([concat/2, lexemes/2, join/2]).
+
+-ifdef(unicode_str).
+concat(Str1, Str2) -> unicode:characters_to_list([Str1,Str2]).
+lexemes(Str, Separators) -> string:lexemes(Str, Separators).
+-else.
+concat(Str1, Str2) -> string:concat(Str1, Str2).
+lexemes(Str, Separators) -> string:tokens(Str, Separators).
+-endif.
+
+%% string:join/2 copy; string:join/2 is getting obsoleted
+%% and replaced by lists:join/2, but lists:join/2 is too new
+%% for version support (only appeared in 19.0) so it cannot be
+%% used. Instead we just adopt join/2 locally and hope it works
+%% for most unicode use cases anyway.
+join([], Sep) when is_list(Sep) ->
+ [];
+join([H|T], Sep) ->
+ H ++ lists:append([Sep ++ X || X <- T]).