aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorPatrik Nyblom <[email protected]>2009-11-02 15:31:21 +0100
committerBjörn Gustavsson <[email protected]>2010-05-17 15:51:49 +0200
commitfdc8980231b1e791ec4b8f8f3d61a7ba7dda539b (patch)
treea9f3ddcda6a8691c98dae02fef18cd1e3a80e580 /lib
parent5fe8d47a60c89f1235f9fc727e650ada491246a3 (diff)
downloadotp-fdc8980231b1e791ec4b8f8f3d61a7ba7dda539b.tar.gz
otp-fdc8980231b1e791ec4b8f8f3d61a7ba7dda539b.tar.bz2
otp-fdc8980231b1e791ec4b8f8f3d61a7ba7dda539b.zip
Initial commit of the binary EEP
Diffstat (limited to 'lib')
-rw-r--r--lib/stdlib/src/Makefile1
-rw-r--r--lib/stdlib/src/binary.erl80
2 files changed, 81 insertions, 0 deletions
diff --git a/lib/stdlib/src/Makefile b/lib/stdlib/src/Makefile
index 237818c08b..600303d7e1 100644
--- a/lib/stdlib/src/Makefile
+++ b/lib/stdlib/src/Makefile
@@ -43,6 +43,7 @@ MODULES= \
array \
base64 \
beam_lib \
+ binary \
c \
calendar \
dets \
diff --git a/lib/stdlib/src/binary.erl b/lib/stdlib/src/binary.erl
new file mode 100644
index 0000000000..f2774f8c84
--- /dev/null
+++ b/lib/stdlib/src/binary.erl
@@ -0,0 +1,80 @@
+%%
+%% %CopyrightBegin%
+%%
+%% Copyright Ericsson AB 2009. All Rights Reserved.
+%%
+%% The contents of this file are subject to the Erlang Public License,
+%% Version 1.1, (the "License"); you may not use this file except in
+%% compliance with the License. You should have received a copy of the
+%% Erlang Public License along with this software. If not, it can be
+%% retrieved online at http://www.erlang.org/.
+%%
+%% Software distributed under the License is distributed on an "AS IS"
+%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
+%% the License for the specific language governing rights and limitations
+%% under the License.
+%%
+%% %CopyrightEnd%
+%%
+-module(binary).
+%%
+%% The following functions implemented as BIF's
+%% binary:match_compile/1
+%% binary:match/3
+%% XXX:PaN more to come...
+
+-export([first/1,first/2,last/1,last/2,nth/2,extract/3]).
+
+first(<<F:1/binary,_/binary>>) ->
+ F;
+first(_) ->
+ erlang:error(badarg).
+first(N,Bin) when is_integer(N), N >= 0 ->
+ case Bin of
+ <<F:N/binary,_/binary>> ->
+ F;
+ _ ->
+ erlang:error(badarg)
+ end;
+first(_,_) ->
+ erlang:error(badarg).
+last(<<>>) ->
+ erlang:error(badarg);
+last(Bin) when is_binary(Bin) ->
+ Sz = byte_size(Bin) - 1,
+ <<_:Sz/binary,L:1/binary>> = Bin,
+ L;
+last(_) ->
+ erlang:error(badarg).
+last(N,Bin) when is_integer(N), N >= 0, is_binary(Bin) ->
+ Sz = byte_size(Bin) - N,
+ case Bin of
+ <<_:Sz/binary,L:N/binary>> ->
+ L;
+ _ ->
+ erlang:error(badarg)
+ end;
+last(_,_) ->
+ erlang:error(badarg).
+
+nth(N, Bin) when is_integer(N), N > 0 ->
+ M = N - 1,
+ case Bin of
+ <<_:M/binary,V:1/binary,_/binary>> ->
+ V;
+ _ ->
+ erlang:error(badarg)
+ end;
+nth(_,_) ->
+ erlang:error(badarg).
+
+extract(N,Size,Bin) when is_integer(N), is_integer(Size), is_binary(Bin) ->
+ M = N - 1,
+ case Bin of
+ <<_:M/binary,V:Size/binary,_/binary>> ->
+ V;
+ _ ->
+ erlang:error(badarg)
+ end;
+extract(_,_,_) ->
+ erlang:error(badarg).