123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- /**
- * Copyright (c) 2013-present, Facebook, Inc.
- *
- * This source code is licensed under the MIT license found in the
- * LICENSE file in the root directory of this source tree.
- *
- * @providesModule someObject
- * @flow
- * @typechecks
- */
- 'use strict';
- var hasOwnProperty = Object.prototype.hasOwnProperty;
- /**
- * Executes the provided `callback` once for each enumerable own property in the
- * object until it finds one where callback returns a truthy value. If such a
- * property is found, `someObject` immediately returns true. Otherwise, it
- * returns false.
- *
- * The `callback` is invoked with three arguments:
- *
- * - the property value
- * - the property name
- * - the object being traversed
- *
- * Properties that are added after the call to `someObject` will not be
- * visited by `callback`. If the values of existing properties are changed, the
- * value passed to `callback` will be the value at the time `someObject`
- * visits them. Properties that are deleted before being visited are not
- * visited.
- */
- function someObject(object: ?Object, callback: (value: any, name: string, object: Object) => any, context?: any): boolean {
- for (var name in object) {
- if (hasOwnProperty.call(object, name)) {
- if (callback.call(context, object[name], name, object)) {
- return true;
- }
- }
- }
- return false;
- }
- module.exports = someObject;
|