aboutsummaryrefslogtreecommitdiff
path: root/gen/tuple.erl
diff options
context:
space:
mode:
authorLouis Pilfold <louis@lpil.uk>2019-03-23 10:58:52 +0000
committerLouis Pilfold <louis@lpil.uk>2019-03-23 10:58:52 +0000
commit27fec2149c765de657d45382af91c361eb3c953c (patch)
tree2736c4e1320c7f6b144071b2a11e10df598982ce /gen/tuple.erl
parent6af3f431609b2c530ae3f8598ac16815e26748d2 (diff)
downloadgleam_stdlib-27fec2149c765de657d45382af91c361eb3c953c.tar.gz
gleam_stdlib-27fec2149c765de657d45382af91c361eb3c953c.zip
stdlib additions
Diffstat (limited to 'gen/tuple.erl')
-rw-r--r--gen/tuple.erl37
1 files changed, 36 insertions, 1 deletions
diff --git a/gen/tuple.erl b/gen/tuple.erl
index 270bb29..ec38901 100644
--- a/gen/tuple.erl
+++ b/gen/tuple.erl
@@ -2,7 +2,16 @@
-compile(no_auto_import).
-include_lib("eunit/include/eunit.hrl").
--export([first/1, second/1]).
+-export([new/2, first/1, second/1, swap/1, fetch/2]).
+
+new(A, B) ->
+ {A, B}.
+
+-ifdef(TEST).
+new_test() ->
+ expect:equal(new(1, 2), {1, 2}),
+ expect:equal(new(2, <<"3">>), {2, <<"3">>}).
+-endif.
first(Tup) ->
{A, _} = Tup,
@@ -21,3 +30,29 @@ second(Tup) ->
second_test() ->
expect:equal(second({1, 2}), 2).
-endif.
+
+swap(Tup) ->
+ {A, B} = Tup,
+ {B, A}.
+
+-ifdef(TEST).
+swap_test() ->
+ expect:equal(swap({1, <<"2">>}), {<<"2">>, 1}).
+-endif.
+
+fetch(Haystack, Needle) ->
+ list:find(Haystack, fun(Tuple) -> case first(Tuple) =:= Needle of
+ true ->
+ {ok, second(Tuple)};
+
+ false ->
+ {error, []}
+ end end).
+
+-ifdef(TEST).
+fetch_test() ->
+ Proplist = [{0, <<"1">>}, {1, <<"2">>}],
+ expect:equal(fetch(Proplist, 0), {ok, <<"1">>}),
+ expect:equal(fetch(Proplist, 1), {ok, <<"2">>}),
+ expect:is_error(fetch(Proplist, 2)).
+-endif.