aboutsummaryrefslogtreecommitdiff
path: root/gen
diff options
context:
space:
mode:
authorBrett Snyder <bsnyder@digitalocean.com>2019-05-11 14:08:45 -0500
committerLouis Pilfold <louis@lpil.uk>2019-05-11 20:16:06 +0100
commitae854f69b8f40609c0ee6fb1aec8957bd3eac1c2 (patch)
tree24ae4e63429c1e45ffa549254a813ef87016aa1c /gen
parentf7d6fe3105fbf650f0f0f95568aca801048f6d15 (diff)
downloadgleam_stdlib-ae854f69b8f40609c0ee6fb1aec8957bd3eac1c2.tar.gz
gleam_stdlib-ae854f69b8f40609c0ee6fb1aec8957bd3eac1c2.zip
list:split_while
Diffstat (limited to 'gen')
-rw-r--r--gen/src/list.erl20
-rw-r--r--gen/test/list_test.erl13
2 files changed, 31 insertions, 2 deletions
diff --git a/gen/src/list.erl b/gen/src/list.erl
index 1395112..8df10f6 100644
--- a/gen/src/list.erl
+++ b/gen/src/list.erl
@@ -1,7 +1,7 @@
-module(list).
-compile(no_auto_import).
--export([length/1, reverse/1, is_empty/1, contains/2, head/1, tail/1, filter/2, map/2, index_map/2, traverse/2, drop/2, take/2, new/0, append/2, flatten/1, fold/3, fold_right/3, find/2, all/2, any/2, zip/2, strict_zip/2, intersperse/2, at/2, unique/1, sort/1, range/2, repeat/2, split/2]).
+-export([length/1, reverse/1, is_empty/1, contains/2, head/1, tail/1, filter/2, map/2, index_map/2, traverse/2, drop/2, take/2, new/0, append/2, flatten/1, fold/3, fold_right/3, find/2, all/2, any/2, zip/2, strict_zip/2, intersperse/2, at/2, unique/1, sort/1, range/2, repeat/2, split/2, split_while/2]).
length(A) ->
erlang:length(A).
@@ -349,3 +349,21 @@ do_split(List, N, Taken) ->
split(List, N) ->
do_split(List, N, []).
+
+do_split_while(List, F, Acc) ->
+ case List of
+ [] ->
+ {reverse(Acc), []};
+
+ [X | Xs] ->
+ case F(X) of
+ false ->
+ {reverse(Acc), List};
+
+ _ ->
+ do_split_while(Xs, F, [X | Acc])
+ end
+ end.
+
+split_while(List, F) ->
+ do_split_while(List, F, []).
diff --git a/gen/test/list_test.erl b/gen/test/list_test.erl
index 705cb3c..6cfe07f 100644
--- a/gen/test/list_test.erl
+++ b/gen/test/list_test.erl
@@ -1,7 +1,7 @@
-module(list_test).
-compile(no_auto_import).
--export([length_test/0, reverse_test/0, is_empty_test/0, contains_test/0, head_test/0, tail_test/0, filter_test/0, map_test/0, traverse_test/0, drop_test/0, take_test/0, new_test/0, append_test/0, flatten_test/0, fold_test/0, fold_right_test/0, find_test/0, all_test/0, any_test/0, zip_test/0, strict_zip_test/0, intersperse_test/0, at_test/0, unique_test/0, sort_test/0, index_map_test/0, range_test/0, repeat_test/0, split_test/0]).
+-export([length_test/0, reverse_test/0, is_empty_test/0, contains_test/0, head_test/0, tail_test/0, filter_test/0, map_test/0, traverse_test/0, drop_test/0, take_test/0, new_test/0, append_test/0, flatten_test/0, fold_test/0, fold_right_test/0, find_test/0, all_test/0, any_test/0, zip_test/0, strict_zip_test/0, intersperse_test/0, at_test/0, unique_test/0, sort_test/0, index_map_test/0, range_test/0, repeat_test/0, split_test/0, split_while_test/0]).
length_test() ->
expect:equal(list:length([]), 0),
@@ -170,3 +170,14 @@ split_test() ->
expect:equal(list:split([0, 1, 2, 3, 4], 1), {[0], [1, 2, 3, 4]}),
expect:equal(list:split([0, 1, 2, 3, 4], 3), {[0, 1, 2], [3, 4]}),
expect:equal(list:split([0, 1, 2, 3, 4], 9), {[0, 1, 2, 3, 4], []}).
+
+split_while_test() ->
+ expect:equal(list:split_while([], fun(X) -> X =< 5 end), {[], []}),
+ expect:equal(list:split_while([1, 2, 3, 4, 5], fun(X) -> X =< 5 end),
+ {[1, 2, 3, 4, 5], []}),
+ expect:equal(list:split_while([1, 2, 3, 4, 5], fun(X) -> X =:= 2 end),
+ {[], [1, 2, 3, 4, 5]}),
+ expect:equal(list:split_while([1, 2, 3, 4, 5], fun(X) -> X =< 3 end),
+ {[1, 2, 3], [4, 5]}),
+ expect:equal(list:split_while([1, 2, 3, 4, 5], fun(X) -> X =< -3 end),
+ {[], [1, 2, 3, 4, 5]}).