|                            |  | 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;
 |