Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
64 changes: 64 additions & 0 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -1039,6 +1039,70 @@
[Fn(a, $.Boolean), m(a), m(a)],
Z.filterM);

//# takeWhile :: (Foldable f, Alternative f) => (a -> Boolean) -> f a -> f a
//.
//. Discards the first inner value which does not satisfy the predicate, and
//. all subsequent inner values.
//.
//. ```javascript
//. > S.takeWhile(S.odd, [3, 3, 3, 7, 6, 3, 5, 4])
//. [3, 3, 3, 7]
//.
//. > S.takeWhile(S.even, [3, 3, 3, 7, 6, 3, 5, 4])
//. []
//. ```
function Array$takeWhile(pred, xs) {
var idx = 0;
while (idx < xs.length && pred(xs[idx])) idx += 1;
return xs.slice(0, idx);
}

function takeWhile(pred, xs) {
if (Array.isArray(xs)) return Array$takeWhile(pred, xs);
var done = false;
function takeWhileReducer(xs, x) {
return !done && pred(x) ? append(x, xs) : (done = true, xs);
}
return Z.reduce(takeWhileReducer, Z.empty(xs.constructor), xs);
}
S.takeWhile =
def('takeWhile',
{f: [Z.Foldable, Z.Alternative]},
[Pred(a), f(a), f(a)],
takeWhile);

//# dropWhile :: (Foldable f, Alternative f) => (a -> Boolean) -> f a -> f a
//.
//. Retains the first inner value which does not satisfy the predicate, and
//. all subsequent inner values.
//.
//. ```javascript
//. > S.dropWhile(S.odd, [3, 3, 3, 7, 6, 3, 5, 4])
//. [6, 3, 5, 4]
//.
//. > S.dropWhile(S.even, [3, 3, 3, 7, 6, 3, 5, 4])
//. [3, 3, 3, 7, 6, 3, 5, 4]
//. ```
function Array$dropWhile(pred, xs) {
var idx = 0;
while (idx < xs.length && pred(xs[idx])) idx += 1;
return xs.slice(idx);
}

function dropWhile(pred, xs) {
if (Array.isArray(xs)) return Array$dropWhile(pred, xs);
var done = false;
function dropWhileReducer(xs, x) {
return !done && pred(x) ? xs : (done = true, append(x, xs));
}
return Z.reduce(dropWhileReducer, Z.empty(xs.constructor), xs);
}
S.dropWhile =
def('dropWhile',
{f: [Z.Foldable, Z.Alternative]},
[Pred(a), f(a), f(a)],
dropWhile);

//. ### Combinator

//# I :: a -> a
Expand Down
22 changes: 22 additions & 0 deletions test/dropWhile.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
'use strict';

var S = require('..');

var eq = require('./internal/eq');


test('dropWhile', function() {

eq(typeof S.dropWhile, 'function');
eq(S.dropWhile.length, 2);
eq(S.dropWhile.toString(), 'dropWhile :: (Foldable f, Alternative f) => (a -> Boolean) -> f a -> f a');

eq(S.dropWhile(S.odd, [3, 3, 3, 7, 6, 3, 5, 4]), [6, 3, 5, 4]);
eq(S.dropWhile(S.even, [3, 3, 3, 7, 6, 3, 5, 4]), [3, 3, 3, 7, 6, 3, 5, 4]);
eq(S.dropWhile(S.odd, []), []);

eq(S.dropWhile(S.odd, S.Just(1)), S.Nothing);
eq(S.dropWhile(S.even, S.Just(1)), S.Just(1));
eq(S.dropWhile(S.odd, S.Nothing), S.Nothing);

});
22 changes: 22 additions & 0 deletions test/takeWhile.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
'use strict';

var S = require('..');

var eq = require('./internal/eq');


test('takeWhile', function() {

eq(typeof S.takeWhile, 'function');
eq(S.takeWhile.length, 2);
eq(S.takeWhile.toString(), 'takeWhile :: (Foldable f, Alternative f) => (a -> Boolean) -> f a -> f a');

eq(S.takeWhile(S.odd, [3, 3, 3, 7, 6, 3, 5, 4]), [3, 3, 3, 7]);
eq(S.takeWhile(S.even, [3, 3, 3, 7, 6, 3, 5, 4]), []);
eq(S.takeWhile(S.odd, []), []);

eq(S.takeWhile(S.odd, S.Just(1)), S.Just(1));
eq(S.takeWhile(S.even, S.Just(1)), S.Nothing);
eq(S.takeWhile(S.odd, S.Nothing), S.Nothing);

});