deep-grep
v0.4.2
Published
Scours arbitrarily-nested objects finding the things you want.
Downloads
15,304
Maintainers
Readme
deep-grep
Too many haystacks, not enough needles — or, "when you have a grep, everything looks like a list."
var needles = dg.deeply( [
foo, [
bar, baz, [
bletch, [
qip
]
]
] ], function (t) { if t == qip return t }
)
usage
For grep on simple, flat (non-nested) lists:
dg.in()
dg.in( list, 'value' )
- returnstrue
orfalse
depending upon whetherlist
containsvalue
.
dg.all_in()
dg.all_in( list_a, list_b )
- returns a list of all values inlist_a
that exist inlist_b
.
dg.unique()
dg.unique( list )
- returns all unique values oflist
. Note: flattens.
dg.flatten( )
dg.flatten( nested_list )
- returns a list of all the lists contained innested_list
, concatenated into a single scope.
For doing greppy things on nested lists:
var haystack = [
'zebra', 'lion', [
'tiger', 'unicorn', 'emperor penguin'
],
'leprechaun',
'cockerel'
];
var needles = dg.deeply( list, function (t) {
if (new RegExp( ('(unicorn|leprechaun)s?' ).test(t))) return true
} );
For more complex data, options are available to you:
var needles = dg.deeply( arks['Noah'], function (t) { ... }, {
// Any of these may be defined
//
// If items in the provided object have methods, check these methods for
// return values that evaluate as true in the provided function.
//
'check-object-methods': [ 'get_species', 'list_passengers' ],
// Provide optionally as argument to calls from check-object-methods, above
//
'object-method-arguments': [ argument, function, 'etc' ],
// Return hash keys that evaluate true also?
// default: false
//
'check-keys': true,
// Return hash values that evaluate true?
// default: false
//
'check-values': true,
// Return key/value tuples rather than just keys or just values?
// default: false
//
'return-hash-tuples': true,
} );
deprecated methods
dg.sync()
dg.sync( list, expression )
- evaluateslist
, returning a new list of every element that matchesexpression.test
(likeRegExp
).dg.sync( list, func )
- same as above, only executesfunc
for every element of list, returning a new list.
dg.async()
dg.async( list, expression )
- same as withsync()
, above, only returns a promise to the list of matches.dg.async( list, func, callback )
- same assync()
, above, except the callback is called with a promise to the list of matches.