| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 | var arrayMap = require('./_arrayMap'),    baseClone = require('./_baseClone'),    baseUnset = require('./_baseUnset'),    castPath = require('./_castPath'),    copyObject = require('./_copyObject'),    customOmitClone = require('./_customOmitClone'),    flatRest = require('./_flatRest'),    getAllKeysIn = require('./_getAllKeysIn');/** Used to compose bitmasks for cloning. */var CLONE_DEEP_FLAG = 1,    CLONE_FLAT_FLAG = 2,    CLONE_SYMBOLS_FLAG = 4;/** * The opposite of `_.pick`; this method creates an object composed of the * own and inherited enumerable property paths of `object` that are not omitted. * * **Note:** This method is considerably slower than `_.pick`. * * @static * @since 0.1.0 * @memberOf _ * @category Object * @param {Object} object The source object. * @param {...(string|string[])} [paths] The property paths to omit. * @returns {Object} Returns the new object. * @example * * var object = { 'a': 1, 'b': '2', 'c': 3 }; * * _.omit(object, ['a', 'c']); * // => { 'b': '2' } */var omit = flatRest(function(object, paths) {  var result = {};  if (object == null) {    return result;  }  var isDeep = false;  paths = arrayMap(paths, function(path) {    path = castPath(path, object);    isDeep || (isDeep = path.length > 1);    return path;  });  copyObject(object, getAllKeysIn(object), result);  if (isDeep) {    result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);  }  var length = paths.length;  while (length--) {    baseUnset(result, paths[length]);  }  return result;});module.exports = omit;
 |