Initial commit
[yaffs-website] / node_modules / sass-graph / node_modules / lodash / omit.js
1 var arrayMap = require('./_arrayMap'),
2     baseClone = require('./_baseClone'),
3     baseUnset = require('./_baseUnset'),
4     castPath = require('./_castPath'),
5     copyObject = require('./_copyObject'),
6     customOmitClone = require('./_customOmitClone'),
7     flatRest = require('./_flatRest'),
8     getAllKeysIn = require('./_getAllKeysIn');
9
10 /** Used to compose bitmasks for cloning. */
11 var CLONE_DEEP_FLAG = 1,
12     CLONE_FLAT_FLAG = 2,
13     CLONE_SYMBOLS_FLAG = 4;
14
15 /**
16  * The opposite of `_.pick`; this method creates an object composed of the
17  * own and inherited enumerable property paths of `object` that are not omitted.
18  *
19  * **Note:** This method is considerably slower than `_.pick`.
20  *
21  * @static
22  * @since 0.1.0
23  * @memberOf _
24  * @category Object
25  * @param {Object} object The source object.
26  * @param {...(string|string[])} [paths] The property paths to omit.
27  * @returns {Object} Returns the new object.
28  * @example
29  *
30  * var object = { 'a': 1, 'b': '2', 'c': 3 };
31  *
32  * _.omit(object, ['a', 'c']);
33  * // => { 'b': '2' }
34  */
35 var omit = flatRest(function(object, paths) {
36   var result = {};
37   if (object == null) {
38     return result;
39   }
40   var isDeep = false;
41   paths = arrayMap(paths, function(path) {
42     path = castPath(path, object);
43     isDeep || (isDeep = path.length > 1);
44     return path;
45   });
46   copyObject(object, getAllKeysIn(object), result);
47   if (isDeep) {
48     result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);
49   }
50   var length = paths.length;
51   while (length--) {
52     baseUnset(result, paths[length]);
53   }
54   return result;
55 });
56
57 module.exports = omit;