mirror of
https://github.com/status-im/react-native.git
synced 2025-01-23 16:00:37 +00:00
d5e9e55fa3
Summary: This PR removes the need for having the `providesModule` tags in all the modules in the repository. It configures Flow, Jest and Metro to get the module names from the filenames (`Libraries/Animated/src/nodes/AnimatedInterpolation.js` => `AnimatedInterpolation`) * Checked the Flow configuration by running flow on the project root (no errors): ``` yarn flow ``` * Checked the Jest configuration by running the tests with a clean cache: ``` yarn jest --clearCache && yarn test ``` * Checked the Metro configuration by starting the server with a clean cache and requesting some bundles: ``` yarn run start --reset-cache curl 'localhost:8081/IntegrationTests/AccessibilityManagerTest.bundle?platform=android' curl 'localhost:8081/Libraries/Alert/Alert.bundle?platform=ios' ``` [INTERNAL] [FEATURE] [All] - Removed providesModule from all modules and configured tools. Closes https://github.com/facebook/react-native/pull/18995 Reviewed By: mjesun Differential Revision: D7729509 Pulled By: rubennorte fbshipit-source-id: 892f760a05ce1fddb088ff0cd2e97e521fb8e825
59 lines
1.6 KiB
JavaScript
59 lines
1.6 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-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.
|
|
*
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
const EventSubscription = require('EventSubscription');
|
|
|
|
import type EventEmitter from 'EventEmitter';
|
|
import type EventSubscriptionVendor from 'EventSubscriptionVendor';
|
|
|
|
/**
|
|
* EmitterSubscription represents a subscription with listener and context data.
|
|
*/
|
|
class EmitterSubscription extends EventSubscription {
|
|
|
|
emitter: EventEmitter;
|
|
listener: Function;
|
|
context: ?Object;
|
|
|
|
/**
|
|
* @param {EventEmitter} emitter - The event emitter that registered this
|
|
* subscription
|
|
* @param {EventSubscriptionVendor} subscriber - The subscriber that controls
|
|
* this subscription
|
|
* @param {function} listener - Function to invoke when the specified event is
|
|
* emitted
|
|
* @param {*} context - Optional context object to use when invoking the
|
|
* listener
|
|
*/
|
|
constructor(
|
|
emitter: EventEmitter,
|
|
subscriber: EventSubscriptionVendor,
|
|
listener: Function,
|
|
context: ?Object
|
|
) {
|
|
super(subscriber);
|
|
this.emitter = emitter;
|
|
this.listener = listener;
|
|
this.context = context;
|
|
}
|
|
|
|
/**
|
|
* Removes this subscription from the emitter that registered it.
|
|
* Note: we're overriding the `remove()` method of EventSubscription here
|
|
* but deliberately not calling `super.remove()` as the responsibility
|
|
* for removing the subscription lies with the EventEmitter.
|
|
*/
|
|
remove() {
|
|
this.emitter.removeSubscription(this);
|
|
}
|
|
}
|
|
|
|
module.exports = EmitterSubscription;
|