summaryrefslogtreecommitdiff
path: root/tools/eslint/node_modules/lodash/assignWith.js
diff options
context:
space:
mode:
Diffstat (limited to 'tools/eslint/node_modules/lodash/assignWith.js')
-rw-r--r--tools/eslint/node_modules/lodash/assignWith.js35
1 files changed, 35 insertions, 0 deletions
diff --git a/tools/eslint/node_modules/lodash/assignWith.js b/tools/eslint/node_modules/lodash/assignWith.js
new file mode 100644
index 0000000000..eb7915b508
--- /dev/null
+++ b/tools/eslint/node_modules/lodash/assignWith.js
@@ -0,0 +1,35 @@
+var copyObjectWith = require('./_copyObjectWith'),
+ createAssigner = require('./_createAssigner'),
+ keys = require('./keys');
+
+/**
+ * This method is like `_.assign` except that it accepts `customizer` which
+ * is invoked to produce the assigned values. If `customizer` returns `undefined`
+ * assignment is handled by the method instead. The `customizer` is invoked
+ * with five arguments: (objValue, srcValue, key, object, source).
+ *
+ * **Note:** This method mutates `object`.
+ *
+ * @static
+ * @memberOf _
+ * @category Object
+ * @param {Object} object The destination object.
+ * @param {...Object} sources The source objects.
+ * @param {Function} [customizer] The function to customize assigned values.
+ * @returns {Object} Returns `object`.
+ * @example
+ *
+ * function customizer(objValue, srcValue) {
+ * return _.isUndefined(objValue) ? srcValue : objValue;
+ * }
+ *
+ * var defaults = _.partialRight(_.assignWith, customizer);
+ *
+ * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });
+ * // => { 'a': 1, 'b': 2 }
+ */
+var assignWith = createAssigner(function(object, source, srcIndex, customizer) {
+ copyObjectWith(source, keys(source), object, customizer);
+});
+
+module.exports = assignWith;