| /** |
| * Lo-Dash 2.4.1 (Custom Build) <http://lodash.com/> |
| * Build: `lodash modularize exports="node" -o ./compat/` |
| * Copyright 2012-2013 The Dojo Foundation <http://dojofoundation.org/> |
| * Based on Underscore.js 1.5.2 <http://underscorejs.org/LICENSE> |
| * Copyright 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors |
| * Available under MIT license <http://lodash.com/license> |
| */ |
| var createIterator = require('../internals/createIterator'), |
| eachIteratorOptions = require('../internals/eachIteratorOptions'), |
| forOwnIteratorOptions = require('../internals/forOwnIteratorOptions'); |
| |
| /** |
| * Iterates over own and inherited enumerable properties of an object, |
| * executing the callback for each property. The callback is bound to `thisArg` |
| * and invoked with three arguments; (value, key, object). Callbacks may exit |
| * iteration early by explicitly returning `false`. |
| * |
| * @static |
| * @memberOf _ |
| * @type Function |
| * @category Objects |
| * @param {Object} object The object to iterate over. |
| * @param {Function} [callback=identity] The function called per iteration. |
| * @param {*} [thisArg] The `this` binding of `callback`. |
| * @returns {Object} Returns `object`. |
| * @example |
| * |
| * function Shape() { |
| * this.x = 0; |
| * this.y = 0; |
| * } |
| * |
| * Shape.prototype.move = function(x, y) { |
| * this.x += x; |
| * this.y += y; |
| * }; |
| * |
| * _.forIn(new Shape, function(value, key) { |
| * console.log(key); |
| * }); |
| * // => logs 'x', 'y', and 'move' (property order is not guaranteed across environments) |
| */ |
| var forIn = createIterator(eachIteratorOptions, forOwnIteratorOptions, { |
| 'useHas': false |
| }); |
| |
| module.exports = forIn; |