pnpm
Version:
Fast, disk space efficient package manager
44 lines (40 loc) • 1.12 kB
JavaScript
var _curry2 = /*#__PURE__*/require('./internal/_curry2');
var _has = /*#__PURE__*/require('./internal/_has');
/**
* Returns whether or not a path exists in an object. Only the object's
* own properties are checked.
*
* @func
* @memberOf R
* @since v0.26.0
* @category Object
* @typedefn Idx = String | Int
* @sig [Idx] -> {a} -> Boolean
* @param {Array} path The path to use.
* @param {Object} obj The object to check the path in.
* @return {Boolean} Whether the path exists.
* @see R.has
* @example
*
* R.hasPath(['a', 'b'], {a: {b: 2}}); // => true
* R.hasPath(['a', 'b'], {a: {b: undefined}}); // => true
* R.hasPath(['a', 'b'], {a: {c: 2}}); // => false
* R.hasPath(['a', 'b'], {}); // => false
*/
var hasPath = /*#__PURE__*/_curry2(function hasPath(_path, obj) {
if (_path.length === 0) {
return false;
}
var val = obj;
var idx = 0;
while (idx < _path.length) {
if (_has(_path[idx], val)) {
val = val[_path[idx]];
idx += 1;
} else {
return false;
}
}
return true;
});
module.exports = hasPath;