| 12345678910111213141516171819202122232425262728 | var baseMerge = require('./_baseMerge'),    isObject = require('./isObject');/** * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source * objects into destination objects that are passed thru. * * @private * @param {*} objValue The destination value. * @param {*} srcValue The source value. * @param {string} key The key of the property to merge. * @param {Object} object The parent object of `objValue`. * @param {Object} source The parent object of `srcValue`. * @param {Object} [stack] Tracks traversed source values and their merged *  counterparts. * @returns {*} Returns the value to assign. */function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {  if (isObject(objValue) && isObject(srcValue)) {    // Recursively merge objects and arrays (susceptible to call stack limits).    stack.set(srcValue, objValue);    baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);    stack['delete'](srcValue);  }  return objValue;}module.exports = customDefaultsMerge;
 |