@angular/core 7.1.0 → 7.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/core-testing.umd.js +1 -1
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core-testing.umd.min.js +1 -1
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +48 -33
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +106 -98
- package/bundles/core.umd.min.js.map +1 -1
- package/core.metadata.json +1 -1
- package/esm2015/core.externs.js +44 -34
- package/esm2015/core.js +1 -2
- package/esm2015/index.js +3 -4
- package/esm2015/public_api.js +3 -5
- package/esm2015/src/application_init.js +6 -6
- package/esm2015/src/application_module.js +6 -5
- package/esm2015/src/application_ref.js +31 -22
- package/esm2015/src/application_tokens.js +21 -16
- package/esm2015/src/change_detection/change_detection.js +8 -7
- package/esm2015/src/change_detection/change_detection_util.js +2 -4
- package/esm2015/src/change_detection/change_detector_ref.js +2 -3
- package/esm2015/src/change_detection/constants.js +30 -32
- package/esm2015/src/change_detection/differs/default_iterable_differ.js +51 -15
- package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +7 -6
- package/esm2015/src/change_detection/differs/iterable_differs.js +100 -90
- package/esm2015/src/change_detection/differs/keyvalue_differs.js +85 -73
- package/esm2015/src/change_detection/pipe_transform.js +10 -5
- package/esm2015/src/change_detection.js +7 -3
- package/esm2015/src/codegen_private_exports.js +2 -3
- package/esm2015/src/console.js +3 -3
- package/esm2015/src/core.js +3 -4
- package/esm2015/src/core_private_export.js +2 -3
- package/esm2015/src/core_render3_private_export.js +7 -4
- package/esm2015/src/debug/debug_node.js +4 -4
- package/esm2015/src/di/defs.js +59 -50
- package/esm2015/src/di/forward_ref.js +5 -6
- package/esm2015/src/di/injectable.js +11 -11
- package/esm2015/src/di/injection_token.js +6 -5
- package/esm2015/src/di/injector.js +55 -48
- package/esm2015/src/di/injector_compatibility.js +27 -20
- package/esm2015/src/di/metadata.js +22 -13
- package/esm2015/src/di/provider.js +137 -120
- package/esm2015/src/di/r3_injector.js +61 -38
- package/esm2015/src/di/reflective_errors.js +19 -13
- package/esm2015/src/di/reflective_injector.js +10 -15
- package/esm2015/src/di/reflective_key.js +3 -4
- package/esm2015/src/di/reflective_provider.js +21 -20
- package/esm2015/src/di/scope.js +5 -5
- package/esm2015/src/di/util.js +13 -14
- package/esm2015/src/di.js +3 -4
- package/esm2015/src/error_handler.js +5 -4
- package/esm2015/src/errors.js +7 -8
- package/esm2015/src/event_emitter.js +3 -3
- package/esm2015/src/i18n/tokens.js +12 -10
- package/esm2015/src/is_dev_mode.js +2 -3
- package/esm2015/src/ivy_switch.js +2 -3
- package/esm2015/src/linker/compiler.js +5 -8
- package/esm2015/src/linker/component_factory.js +2 -3
- package/esm2015/src/linker/component_factory_resolver.js +4 -5
- package/esm2015/src/linker/element_ref.js +5 -3
- package/esm2015/src/linker/ng_module_factory.js +6 -5
- package/esm2015/src/linker/ng_module_factory_loader.js +2 -3
- package/esm2015/src/linker/query_list.js +12 -13
- package/esm2015/src/linker/system_js_ng_module_factory_loader.js +2 -3
- package/esm2015/src/linker/template_ref.js +2 -3
- package/esm2015/src/linker/view_container_ref.js +2 -3
- package/esm2015/src/linker/view_ref.js +13 -7
- package/esm2015/src/linker.js +3 -3
- package/esm2015/src/metadata/di.js +22 -15
- package/esm2015/src/metadata/directives.js +34 -19
- package/esm2015/src/metadata/lifecycle_hooks.js +81 -66
- package/esm2015/src/metadata/ng_module.js +82 -68
- package/esm2015/src/metadata/resource_loading.js +4 -3
- package/esm2015/src/metadata/view.js +25 -26
- package/esm2015/src/metadata.js +6 -3
- package/esm2015/src/platform_core_providers.js +5 -5
- package/esm2015/src/profile/profile.js +17 -13
- package/esm2015/src/profile/wtf_impl.js +36 -16
- package/esm2015/src/r3_symbols.js +18 -5
- package/esm2015/src/reflection/platform_reflection_capabilities.js +81 -40
- package/esm2015/src/reflection/reflection.js +5 -5
- package/esm2015/src/reflection/reflection_capabilities.js +31 -26
- package/esm2015/src/reflection/reflector.js +2 -3
- package/esm2015/src/reflection/types.js +2 -12
- package/esm2015/src/render/api.js +67 -47
- package/esm2015/src/render.js +3 -3
- package/esm2015/src/render3/assert.js +5 -3
- package/esm2015/src/render3/component.js +66 -64
- package/esm2015/src/render3/component_ref.js +24 -21
- package/esm2015/src/render3/context_discovery.js +37 -17
- package/esm2015/src/render3/debug.js +9 -6
- package/esm2015/src/render3/definition.js +28 -28
- package/esm2015/src/render3/di.js +66 -39
- package/esm2015/src/render3/di_setup.js +34 -14
- package/esm2015/src/render3/discovery_utils.js +16 -17
- package/esm2015/src/render3/errors.js +2 -3
- package/esm2015/src/render3/features/inherit_definition_feature.js +12 -8
- package/esm2015/src/render3/features/ng_onchanges_feature.js +5 -6
- package/esm2015/src/render3/features/providers_feature.js +2 -3
- package/esm2015/src/render3/fields.js +5 -5
- package/esm2015/src/render3/global_utils.js +19 -6
- package/esm2015/src/render3/global_utils_api.js +12 -6
- package/esm2015/src/render3/hooks.js +4 -5
- package/esm2015/src/render3/i18n.js +112 -89
- package/esm2015/src/render3/index.js +11 -3
- package/esm2015/src/render3/instructions.js +201 -150
- package/esm2015/src/render3/interfaces/container.js +27 -5
- package/esm2015/src/render3/interfaces/context.js +38 -36
- package/esm2015/src/render3/interfaces/definition.js +234 -261
- package/esm2015/src/render3/interfaces/i18n.js +154 -126
- package/esm2015/src/render3/interfaces/injector.js +93 -10
- package/esm2015/src/render3/interfaces/node.js +369 -373
- package/esm2015/src/render3/interfaces/player.js +78 -37
- package/esm2015/src/render3/interfaces/projection.js +5 -10
- package/esm2015/src/render3/interfaces/query.js +66 -60
- package/esm2015/src/render3/interfaces/renderer.js +288 -117
- package/esm2015/src/render3/interfaces/sanitization.js +2 -6
- package/esm2015/src/render3/interfaces/styling.js +26 -6
- package/esm2015/src/render3/interfaces/view.js +326 -285
- package/esm2015/src/render3/jit/compiler_facade.js +10 -4
- package/esm2015/src/render3/jit/compiler_facade_interface.js +189 -152
- package/esm2015/src/render3/jit/directive.js +6 -6
- package/esm2015/src/render3/jit/environment.js +5 -5
- package/esm2015/src/render3/jit/injectable.js +6 -8
- package/esm2015/src/render3/jit/module.js +17 -13
- package/esm2015/src/render3/jit/pipe.js +2 -3
- package/esm2015/src/render3/jit/util.js +2 -3
- package/esm2015/src/render3/metadata.js +11 -10
- package/esm2015/src/render3/ng_dev_mode.js +5 -6
- package/esm2015/src/render3/ng_module_ref.js +11 -10
- package/esm2015/src/render3/node_assert.js +2 -3
- package/esm2015/src/render3/node_manipulation.js +86 -73
- package/esm2015/src/render3/node_selector_matcher.js +13 -12
- package/esm2015/src/render3/pipe.js +4 -5
- package/esm2015/src/render3/players.js +11 -5
- package/esm2015/src/render3/pure_function.js +29 -3
- package/esm2015/src/render3/query.js +74 -70
- package/esm2015/src/render3/state.js +44 -33
- package/esm2015/src/render3/styling/class_and_style_bindings.js +62 -43
- package/esm2015/src/render3/styling/core_player_handler.js +2 -3
- package/esm2015/src/render3/styling/player_factory.js +3 -4
- package/esm2015/src/render3/styling/util.js +18 -13
- package/esm2015/src/render3/tokens.js +7 -6
- package/esm2015/src/render3/util.js +18 -16
- package/esm2015/src/render3/view_engine_compatibility.js +18 -18
- package/esm2015/src/render3/view_engine_compatibility_prebound.js +2 -3
- package/esm2015/src/render3/view_ref.js +7 -10
- package/esm2015/src/sanitization/bypass.js +29 -6
- package/esm2015/src/sanitization/html_sanitizer.js +41 -15
- package/esm2015/src/sanitization/inert_body.js +14 -12
- package/esm2015/src/sanitization/sanitization.js +7 -7
- package/esm2015/src/sanitization/security.js +3 -4
- package/esm2015/src/sanitization/style_sanitizer.js +10 -7
- package/esm2015/src/sanitization/url_sanitizer.js +9 -7
- package/esm2015/src/testability/testability.js +47 -37
- package/esm2015/src/type.js +6 -8
- package/esm2015/src/util/decorators.js +19 -14
- package/esm2015/src/util/lang.js +2 -3
- package/esm2015/src/util/noop.js +2 -3
- package/esm2015/src/util/property.js +3 -4
- package/esm2015/src/util.js +12 -4
- package/esm2015/src/version.js +6 -6
- package/esm2015/src/view/element.js +17 -17
- package/esm2015/src/view/entrypoint.js +7 -3
- package/esm2015/src/view/errors.js +4 -5
- package/esm2015/src/view/index.js +2 -3
- package/esm2015/src/view/ng_content.js +3 -4
- package/esm2015/src/view/ng_module.js +2 -3
- package/esm2015/src/view/provider.js +89 -24
- package/esm2015/src/view/pure_expression.js +14 -15
- package/esm2015/src/view/query.js +14 -14
- package/esm2015/src/view/refs.js +24 -22
- package/esm2015/src/view/services.js +41 -31
- package/esm2015/src/view/text.js +5 -6
- package/esm2015/src/view/types.js +386 -324
- package/esm2015/src/view/util.js +29 -24
- package/esm2015/src/view/view.js +43 -36
- package/esm2015/src/view/view_attach.js +9 -10
- package/esm2015/src/zone/ng_zone.js +29 -28
- package/esm2015/src/zone.js +3 -3
- package/esm2015/testing/index.js +2 -3
- package/esm2015/testing/public_api.js +4 -4
- package/esm2015/testing/src/async.js +2 -3
- package/esm2015/testing/src/async_fallback.js +8 -7
- package/esm2015/testing/src/async_test_completer.js +2 -3
- package/esm2015/testing/src/before_each.js +10 -4
- package/esm2015/testing/src/component_fixture.js +6 -7
- package/esm2015/testing/src/fake_async.js +9 -3
- package/esm2015/testing/src/fake_async_fallback.js +5 -5
- package/esm2015/testing/src/lang_utils.js +3 -4
- package/esm2015/testing/src/logger.js +2 -3
- package/esm2015/testing/src/metadata_override.js +2 -6
- package/esm2015/testing/src/metadata_overrider.js +5 -7
- package/esm2015/testing/src/ng_zone_mock.js +2 -3
- package/esm2015/testing/src/private_export_testing.js +2 -3
- package/esm2015/testing/src/r3_test_bed.js +34 -27
- package/esm2015/testing/src/resolvers.js +9 -5
- package/esm2015/testing/src/test_bed.js +38 -34
- package/esm2015/testing/src/test_bed_common.js +142 -85
- package/esm2015/testing/src/test_compiler.js +2 -3
- package/esm2015/testing/src/testing.js +3 -3
- package/esm2015/testing/src/testing_internal.js +8 -9
- package/esm2015/testing/testing.js +1 -2
- package/esm5/core.js +1 -2
- package/esm5/index.js +1 -2
- package/esm5/public_api.js +1 -2
- package/esm5/src/application_init.js +1 -2
- package/esm5/src/application_module.js +1 -2
- package/esm5/src/application_ref.js +1 -2
- package/esm5/src/application_tokens.js +1 -2
- package/esm5/src/change_detection/change_detection.js +1 -2
- package/esm5/src/change_detection/change_detection_util.js +1 -2
- package/esm5/src/change_detection/change_detector_ref.js +1 -2
- package/esm5/src/change_detection/constants.js +1 -2
- package/esm5/src/change_detection/differs/default_iterable_differ.js +1 -2
- package/esm5/src/change_detection/differs/default_keyvalue_differ.js +1 -2
- package/esm5/src/change_detection/differs/iterable_differs.js +1 -2
- package/esm5/src/change_detection/differs/keyvalue_differs.js +1 -2
- package/esm5/src/change_detection/pipe_transform.js +1 -2
- package/esm5/src/change_detection.js +1 -2
- package/esm5/src/codegen_private_exports.js +1 -2
- package/esm5/src/console.js +1 -2
- package/esm5/src/core.js +1 -2
- package/esm5/src/core_private_export.js +1 -2
- package/esm5/src/core_render3_private_export.js +1 -2
- package/esm5/src/debug/debug_node.js +1 -2
- package/esm5/src/di/defs.js +1 -2
- package/esm5/src/di/forward_ref.js +1 -2
- package/esm5/src/di/injectable.js +1 -2
- package/esm5/src/di/injection_token.js +1 -2
- package/esm5/src/di/injector.js +7 -8
- package/esm5/src/di/injector_compatibility.js +30 -10
- package/esm5/src/di/metadata.js +1 -2
- package/esm5/src/di/provider.js +1 -2
- package/esm5/src/di/r3_injector.js +5 -6
- package/esm5/src/di/reflective_errors.js +1 -2
- package/esm5/src/di/reflective_injector.js +1 -2
- package/esm5/src/di/reflective_key.js +1 -2
- package/esm5/src/di/reflective_provider.js +1 -2
- package/esm5/src/di/scope.js +1 -2
- package/esm5/src/di/util.js +1 -2
- package/esm5/src/di.js +2 -3
- package/esm5/src/error_handler.js +1 -2
- package/esm5/src/errors.js +1 -2
- package/esm5/src/event_emitter.js +1 -2
- package/esm5/src/i18n/tokens.js +1 -2
- package/esm5/src/is_dev_mode.js +1 -2
- package/esm5/src/ivy_switch.js +1 -2
- package/esm5/src/linker/compiler.js +1 -2
- package/esm5/src/linker/component_factory.js +1 -2
- package/esm5/src/linker/component_factory_resolver.js +1 -2
- package/esm5/src/linker/element_ref.js +1 -2
- package/esm5/src/linker/ng_module_factory.js +1 -2
- package/esm5/src/linker/ng_module_factory_loader.js +1 -2
- package/esm5/src/linker/query_list.js +1 -2
- package/esm5/src/linker/system_js_ng_module_factory_loader.js +1 -2
- package/esm5/src/linker/template_ref.js +1 -2
- package/esm5/src/linker/view_container_ref.js +1 -2
- package/esm5/src/linker/view_ref.js +1 -2
- package/esm5/src/linker.js +1 -2
- package/esm5/src/metadata/di.js +1 -2
- package/esm5/src/metadata/directives.js +1 -2
- package/esm5/src/metadata/lifecycle_hooks.js +1 -2
- package/esm5/src/metadata/ng_module.js +1 -2
- package/esm5/src/metadata/resource_loading.js +1 -2
- package/esm5/src/metadata/view.js +1 -2
- package/esm5/src/metadata.js +1 -2
- package/esm5/src/platform_core_providers.js +1 -2
- package/esm5/src/profile/profile.js +1 -2
- package/esm5/src/profile/wtf_impl.js +1 -2
- package/esm5/src/r3_symbols.js +1 -2
- package/esm5/src/reflection/platform_reflection_capabilities.js +1 -2
- package/esm5/src/reflection/reflection.js +1 -2
- package/esm5/src/reflection/reflection_capabilities.js +1 -2
- package/esm5/src/reflection/reflector.js +1 -2
- package/esm5/src/reflection/types.js +1 -2
- package/esm5/src/render/api.js +1 -2
- package/esm5/src/render.js +1 -2
- package/esm5/src/render3/assert.js +1 -2
- package/esm5/src/render3/component.js +1 -2
- package/esm5/src/render3/component_ref.js +1 -2
- package/esm5/src/render3/context_discovery.js +1 -2
- package/esm5/src/render3/debug.js +1 -2
- package/esm5/src/render3/definition.js +1 -2
- package/esm5/src/render3/di.js +12 -13
- package/esm5/src/render3/di_setup.js +1 -2
- package/esm5/src/render3/discovery_utils.js +1 -2
- package/esm5/src/render3/errors.js +1 -2
- package/esm5/src/render3/features/inherit_definition_feature.js +1 -2
- package/esm5/src/render3/features/ng_onchanges_feature.js +1 -2
- package/esm5/src/render3/features/providers_feature.js +1 -2
- package/esm5/src/render3/fields.js +1 -2
- package/esm5/src/render3/global_utils.js +1 -2
- package/esm5/src/render3/global_utils_api.js +1 -2
- package/esm5/src/render3/hooks.js +1 -2
- package/esm5/src/render3/i18n.js +1 -2
- package/esm5/src/render3/index.js +1 -2
- package/esm5/src/render3/instructions.js +3 -3
- package/esm5/src/render3/interfaces/container.js +1 -2
- package/esm5/src/render3/interfaces/context.js +1 -2
- package/esm5/src/render3/interfaces/definition.js +1 -2
- package/esm5/src/render3/interfaces/i18n.js +1 -2
- package/esm5/src/render3/interfaces/injector.js +1 -2
- package/esm5/src/render3/interfaces/node.js +1 -2
- package/esm5/src/render3/interfaces/player.js +1 -2
- package/esm5/src/render3/interfaces/projection.js +1 -2
- package/esm5/src/render3/interfaces/query.js +1 -2
- package/esm5/src/render3/interfaces/renderer.js +1 -2
- package/esm5/src/render3/interfaces/sanitization.js +1 -2
- package/esm5/src/render3/interfaces/styling.js +1 -2
- package/esm5/src/render3/interfaces/view.js +1 -2
- package/esm5/src/render3/jit/compiler_facade.js +1 -2
- package/esm5/src/render3/jit/compiler_facade_interface.js +1 -2
- package/esm5/src/render3/jit/directive.js +1 -2
- package/esm5/src/render3/jit/environment.js +1 -2
- package/esm5/src/render3/jit/injectable.js +1 -2
- package/esm5/src/render3/jit/module.js +1 -2
- package/esm5/src/render3/jit/pipe.js +1 -2
- package/esm5/src/render3/jit/util.js +1 -2
- package/esm5/src/render3/metadata.js +1 -2
- package/esm5/src/render3/ng_dev_mode.js +1 -2
- package/esm5/src/render3/ng_module_ref.js +1 -2
- package/esm5/src/render3/node_assert.js +1 -2
- package/esm5/src/render3/node_manipulation.js +1 -2
- package/esm5/src/render3/node_selector_matcher.js +1 -2
- package/esm5/src/render3/pipe.js +1 -2
- package/esm5/src/render3/players.js +1 -2
- package/esm5/src/render3/pure_function.js +1 -2
- package/esm5/src/render3/query.js +1 -2
- package/esm5/src/render3/state.js +1 -2
- package/esm5/src/render3/styling/class_and_style_bindings.js +1 -2
- package/esm5/src/render3/styling/core_player_handler.js +1 -2
- package/esm5/src/render3/styling/player_factory.js +1 -2
- package/esm5/src/render3/styling/util.js +1 -2
- package/esm5/src/render3/tokens.js +1 -2
- package/esm5/src/render3/util.js +1 -2
- package/esm5/src/render3/view_engine_compatibility.js +3 -3
- package/esm5/src/render3/view_engine_compatibility_prebound.js +1 -2
- package/esm5/src/render3/view_ref.js +1 -2
- package/esm5/src/sanitization/bypass.js +1 -2
- package/esm5/src/sanitization/html_sanitizer.js +1 -2
- package/esm5/src/sanitization/inert_body.js +1 -2
- package/esm5/src/sanitization/sanitization.js +1 -2
- package/esm5/src/sanitization/security.js +1 -2
- package/esm5/src/sanitization/style_sanitizer.js +1 -2
- package/esm5/src/sanitization/url_sanitizer.js +1 -2
- package/esm5/src/testability/testability.js +1 -2
- package/esm5/src/type.js +1 -2
- package/esm5/src/util/decorators.js +1 -2
- package/esm5/src/util/lang.js +1 -2
- package/esm5/src/util/noop.js +1 -2
- package/esm5/src/util/property.js +1 -2
- package/esm5/src/util.js +1 -2
- package/esm5/src/version.js +2 -3
- package/esm5/src/view/element.js +1 -2
- package/esm5/src/view/entrypoint.js +1 -2
- package/esm5/src/view/errors.js +1 -2
- package/esm5/src/view/index.js +1 -2
- package/esm5/src/view/ng_content.js +1 -2
- package/esm5/src/view/ng_module.js +1 -2
- package/esm5/src/view/provider.js +1 -2
- package/esm5/src/view/pure_expression.js +1 -2
- package/esm5/src/view/query.js +1 -2
- package/esm5/src/view/refs.js +5 -5
- package/esm5/src/view/services.js +1 -2
- package/esm5/src/view/text.js +1 -2
- package/esm5/src/view/types.js +1 -2
- package/esm5/src/view/util.js +1 -2
- package/esm5/src/view/view.js +1 -2
- package/esm5/src/view/view_attach.js +1 -2
- package/esm5/src/zone/ng_zone.js +1 -2
- package/esm5/src/zone.js +1 -2
- package/esm5/testing/index.js +1 -2
- package/esm5/testing/public_api.js +1 -2
- package/esm5/testing/src/async.js +1 -2
- package/esm5/testing/src/async_fallback.js +1 -2
- package/esm5/testing/src/async_test_completer.js +1 -2
- package/esm5/testing/src/before_each.js +1 -2
- package/esm5/testing/src/component_fixture.js +1 -2
- package/esm5/testing/src/fake_async.js +1 -2
- package/esm5/testing/src/fake_async_fallback.js +1 -2
- package/esm5/testing/src/lang_utils.js +1 -2
- package/esm5/testing/src/logger.js +1 -2
- package/esm5/testing/src/metadata_override.js +1 -2
- package/esm5/testing/src/metadata_overrider.js +1 -2
- package/esm5/testing/src/ng_zone_mock.js +1 -2
- package/esm5/testing/src/private_export_testing.js +1 -2
- package/esm5/testing/src/r3_test_bed.js +1 -2
- package/esm5/testing/src/resolvers.js +1 -2
- package/esm5/testing/src/test_bed.js +1 -2
- package/esm5/testing/src/test_bed_common.js +1 -2
- package/esm5/testing/src/test_compiler.js +1 -2
- package/esm5/testing/src/testing.js +1 -2
- package/esm5/testing/src/testing_internal.js +1 -2
- package/esm5/testing/testing.js +1 -2
- package/fesm2015/core.js +2040 -1354
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +123 -89
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +55 -34
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +1 -1
- package/fesm5/testing.js.map +1 -1
- package/package.json +1 -1
- package/src/di/injector_compatibility.d.ts +1 -1
- package/testing.d.ts +5 -0
- package/npm_package.es6/external/ngdeps/node_modules/tslib/tslib.d.ts +0 -33
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @fileoverview added by tsickle
|
|
3
|
-
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
|
|
3
|
+
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
|
|
4
4
|
*/
|
|
5
5
|
/**
|
|
6
6
|
* @license
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
* found in the LICENSE file at https://angular.io/license
|
|
11
11
|
*/
|
|
12
12
|
import { getInjectableDef, getInjectorDef } from '../di/defs';
|
|
13
|
-
import { injectRootLimpMode, setInjectImplementation } from '../di/injector_compatibility';
|
|
13
|
+
import { InjectFlags, injectRootLimpMode, setInjectImplementation } from '../di/injector_compatibility';
|
|
14
14
|
import { assertDefined, assertEqual } from './assert';
|
|
15
15
|
import { getComponentDef, getDirectiveDef, getPipeDef } from './definition';
|
|
16
16
|
import { NG_ELEMENT_ID } from './fields';
|
|
@@ -19,7 +19,7 @@ import { DECLARATION_VIEW, HOST_NODE, INJECTOR, TVIEW } from './interfaces/view'
|
|
|
19
19
|
import { assertNodeOfPossibleTypes } from './node_assert';
|
|
20
20
|
import { getPreviousOrParentTNode, getViewData, setTNodeAndViewData } from './state';
|
|
21
21
|
import { getParentInjectorIndex, getParentInjectorView, hasParentInjector, isComponent, stringify } from './util';
|
|
22
|
-
/**
|
|
22
|
+
/**
|
|
23
23
|
* Defines if the call to `inject` should include `viewProviders` in its resolution.
|
|
24
24
|
*
|
|
25
25
|
* This is set to true when we try to instantiate a component. This value is reset in
|
|
@@ -54,7 +54,8 @@ import { getParentInjectorIndex, getParentInjectorView, hasParentInjector, isCom
|
|
|
54
54
|
* }
|
|
55
55
|
*
|
|
56
56
|
* ```
|
|
57
|
-
|
|
57
|
+
* @type {?}
|
|
58
|
+
*/
|
|
58
59
|
let includeViewProviders = false;
|
|
59
60
|
/**
|
|
60
61
|
* @param {?} v
|
|
@@ -66,17 +67,19 @@ function setIncludeViewProviders(v) {
|
|
|
66
67
|
includeViewProviders = v;
|
|
67
68
|
return oldValue;
|
|
68
69
|
}
|
|
69
|
-
/**
|
|
70
|
+
/**
|
|
70
71
|
* The number of slots in each bloom filter (used by DI). The larger this number, the fewer
|
|
71
72
|
* directives that will share slots, and thus, the fewer false positives when checking for
|
|
72
73
|
* the existence of a directive.
|
|
73
|
-
|
|
74
|
+
* @type {?}
|
|
75
|
+
*/
|
|
74
76
|
const BLOOM_SIZE = 256;
|
|
75
77
|
/** @type {?} */
|
|
76
78
|
const BLOOM_MASK = BLOOM_SIZE - 1;
|
|
77
|
-
/**
|
|
79
|
+
/**
|
|
78
80
|
* Counter used to generate unique IDs for directives.
|
|
79
|
-
|
|
81
|
+
* @type {?}
|
|
82
|
+
*/
|
|
80
83
|
let nextNgElementId = 0;
|
|
81
84
|
/**
|
|
82
85
|
* Registers this directive as present in its node's injector by flipping the directive's
|
|
@@ -90,16 +93,23 @@ let nextNgElementId = 0;
|
|
|
90
93
|
export function bloomAdd(injectorIndex, tView, type) {
|
|
91
94
|
ngDevMode && assertEqual(tView.firstTemplatePass, true, 'expected firstTemplatePass to be true');
|
|
92
95
|
/** @type {?} */
|
|
93
|
-
let id = (/** @type {?} */ (type))[NG_ELEMENT_ID];
|
|
96
|
+
let id = ((/** @type {?} */ (type)))[NG_ELEMENT_ID];
|
|
94
97
|
// Set a unique ID on the directive type, so if something tries to inject the directive,
|
|
95
98
|
// we can easily retrieve the ID and hash it into the bloom bit that should be checked.
|
|
96
99
|
if (id == null) {
|
|
97
|
-
id = (/** @type {?} */ (type))[NG_ELEMENT_ID] = nextNgElementId++;
|
|
100
|
+
id = ((/** @type {?} */ (type)))[NG_ELEMENT_ID] = nextNgElementId++;
|
|
98
101
|
}
|
|
102
|
+
// We only have BLOOM_SIZE (256) slots in our bloom filter (8 buckets * 32 bits each),
|
|
103
|
+
// so all unique IDs must be modulo-ed into a number from 0 - 255 to fit into the filter.
|
|
99
104
|
/** @type {?} */
|
|
100
105
|
const bloomBit = id & BLOOM_MASK;
|
|
106
|
+
// Create a mask that targets the specific bit associated with the directive.
|
|
107
|
+
// JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding
|
|
108
|
+
// to bit positions 0 - 31 in a 32 bit integer.
|
|
101
109
|
/** @type {?} */
|
|
102
110
|
const mask = 1 << bloomBit;
|
|
111
|
+
// Use the raw bloomBit number to determine which bloom filter bucket we should check
|
|
112
|
+
// e.g: bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc
|
|
103
113
|
/** @type {?} */
|
|
104
114
|
const b7 = bloomBit & 0x80;
|
|
105
115
|
/** @type {?} */
|
|
@@ -107,7 +117,7 @@ export function bloomAdd(injectorIndex, tView, type) {
|
|
|
107
117
|
/** @type {?} */
|
|
108
118
|
const b5 = bloomBit & 0x20;
|
|
109
119
|
/** @type {?} */
|
|
110
|
-
const tData = /** @type {?} */ (tView.data);
|
|
120
|
+
const tData = (/** @type {?} */ (tView.data));
|
|
111
121
|
if (b7) {
|
|
112
122
|
b6 ? (b5 ? (tData[injectorIndex + 7] |= mask) : (tData[injectorIndex + 6] |= mask)) :
|
|
113
123
|
(b5 ? (tData[injectorIndex + 5] |= mask) : (tData[injectorIndex + 4] |= mask));
|
|
@@ -151,7 +161,7 @@ export function getOrCreateNodeInjectorForNode(tNode, hostView) {
|
|
|
151
161
|
// In that case, we don't need to set up a cumulative bloom
|
|
152
162
|
if (hasParentInjector(parentLoc)) {
|
|
153
163
|
/** @type {?} */
|
|
154
|
-
const parentData = /** @type {?} */ (parentView[TVIEW].data);
|
|
164
|
+
const parentData = (/** @type {?} */ (parentView[TVIEW].data));
|
|
155
165
|
// Creates a cumulative bloom filter that merges the parent's bloom filter
|
|
156
166
|
// and its own cumulative bloom (which contains tokens for all ancestors)
|
|
157
167
|
for (let i = 0; i < 8; i++) {
|
|
@@ -199,15 +209,18 @@ export function getInjectorIndex(tNode, hostView) {
|
|
|
199
209
|
*/
|
|
200
210
|
export function getParentInjectorLocation(tNode, view) {
|
|
201
211
|
if (tNode.parent && tNode.parent.injectorIndex !== -1) {
|
|
202
|
-
return /** @type {?} */ (tNode.parent.injectorIndex); // ViewOffset is 0, AcrossHostBoundary is 0
|
|
212
|
+
return (/** @type {?} */ (tNode.parent.injectorIndex)); // ViewOffset is 0, AcrossHostBoundary is 0
|
|
203
213
|
}
|
|
214
|
+
// For most cases, the parent injector index can be found on the host node (e.g. for component
|
|
215
|
+
// or container), so this loop will be skipped, but we must keep the loop here to support
|
|
216
|
+
// the rarer case of deeply nested <ng-template> tags or inline views.
|
|
204
217
|
/** @type {?} */
|
|
205
218
|
let hostTNode = view[HOST_NODE];
|
|
206
219
|
/** @type {?} */
|
|
207
220
|
let viewOffset = 1;
|
|
208
221
|
while (hostTNode && hostTNode.injectorIndex === -1) {
|
|
209
|
-
view = /** @type {?} */ (
|
|
210
|
-
hostTNode = /** @type {?} */ (
|
|
222
|
+
view = (/** @type {?} */ (view[DECLARATION_VIEW]));
|
|
223
|
+
hostTNode = (/** @type {?} */ (view[HOST_NODE]));
|
|
211
224
|
viewOffset++;
|
|
212
225
|
}
|
|
213
226
|
/** @type {?} */
|
|
@@ -216,7 +229,8 @@ export function getParentInjectorLocation(tNode, view) {
|
|
|
216
229
|
0;
|
|
217
230
|
return hostTNode ?
|
|
218
231
|
hostTNode.injectorIndex | (viewOffset << 16 /* ViewOffsetShift */) |
|
|
219
|
-
acrossHostBoundary :
|
|
232
|
+
acrossHostBoundary :
|
|
233
|
+
(/** @type {?} */ (-1));
|
|
220
234
|
}
|
|
221
235
|
/**
|
|
222
236
|
* Makes a type or an injection token public to the DI system by adding it to an
|
|
@@ -276,7 +290,7 @@ export function injectAttributeImpl(tNode, attrNameToInject) {
|
|
|
276
290
|
if (attrName === 1 /* SelectOnly */)
|
|
277
291
|
break;
|
|
278
292
|
if (attrName == attrNameToInject) {
|
|
279
|
-
return /** @type {?} */ (attrs[i + 1]);
|
|
293
|
+
return (/** @type {?} */ (attrs[i + 1]));
|
|
280
294
|
}
|
|
281
295
|
}
|
|
282
296
|
}
|
|
@@ -296,7 +310,7 @@ export function injectAttributeImpl(tNode, attrNameToInject) {
|
|
|
296
310
|
* @param {?=} notFoundValue
|
|
297
311
|
* @return {?} the value from the injector or `null` when not found
|
|
298
312
|
*/
|
|
299
|
-
export function getOrCreateInjectable(tNode, lViewData, token, flags =
|
|
313
|
+
export function getOrCreateInjectable(tNode, lViewData, token, flags = InjectFlags.Default, notFoundValue) {
|
|
300
314
|
/** @type {?} */
|
|
301
315
|
const bloomHash = bloomHashBitOrFactory(token);
|
|
302
316
|
// If the ID stored here is a function, this is a special object like ElementRef or TemplateRef
|
|
@@ -310,7 +324,7 @@ export function getOrCreateInjectable(tNode, lViewData, token, flags = 0 /* Defa
|
|
|
310
324
|
try {
|
|
311
325
|
/** @type {?} */
|
|
312
326
|
const value = bloomHash();
|
|
313
|
-
if (value == null && !(flags &
|
|
327
|
+
if (value == null && !(flags & InjectFlags.Optional)) {
|
|
314
328
|
throw new Error(`No provider for ${stringify(token)}`);
|
|
315
329
|
}
|
|
316
330
|
else {
|
|
@@ -322,6 +336,9 @@ export function getOrCreateInjectable(tNode, lViewData, token, flags = 0 /* Defa
|
|
|
322
336
|
}
|
|
323
337
|
}
|
|
324
338
|
else if (typeof bloomHash == 'number') {
|
|
339
|
+
// If the token has a bloom hash, then it is a token which could be in NodeInjector.
|
|
340
|
+
// A reference to the previous injector TView that was found while climbing the element injector
|
|
341
|
+
// tree. This is used to know if viewProviders can be accessed on the current injector.
|
|
325
342
|
/** @type {?} */
|
|
326
343
|
let previousTView = null;
|
|
327
344
|
/** @type {?} */
|
|
@@ -330,7 +347,7 @@ export function getOrCreateInjectable(tNode, lViewData, token, flags = 0 /* Defa
|
|
|
330
347
|
let parentLocation = NO_PARENT_INJECTOR;
|
|
331
348
|
// If we should skip this injector, or if there is no injector on this node, start by searching
|
|
332
349
|
// the parent injector.
|
|
333
|
-
if (injectorIndex === -1 || flags &
|
|
350
|
+
if (injectorIndex === -1 || flags & InjectFlags.SkipSelf) {
|
|
334
351
|
parentLocation = injectorIndex === -1 ? getParentInjectorLocation(tNode, lViewData) :
|
|
335
352
|
lViewData[injectorIndex + PARENT_INJECTOR];
|
|
336
353
|
if (!shouldSearchParent(flags, parentLocation)) {
|
|
@@ -346,9 +363,13 @@ export function getOrCreateInjectable(tNode, lViewData, token, flags = 0 /* Defa
|
|
|
346
363
|
// *isn't* a match.
|
|
347
364
|
while (injectorIndex !== -1) {
|
|
348
365
|
parentLocation = lViewData[injectorIndex + PARENT_INJECTOR];
|
|
366
|
+
// Check the current injector. If it matches, see if it contains token.
|
|
349
367
|
/** @type {?} */
|
|
350
368
|
const tView = lViewData[TVIEW];
|
|
351
369
|
if (bloomHasToken(bloomHash, injectorIndex, tView.data)) {
|
|
370
|
+
// At this point, we have an injector which *may* contain the token, so we step through
|
|
371
|
+
// the providers and directives associated with the injector's corresponding node to get
|
|
372
|
+
// the instance.
|
|
352
373
|
/** @type {?} */
|
|
353
374
|
const instance = searchTokensOnInjector(injectorIndex, lViewData, token, previousTView);
|
|
354
375
|
if (instance !== NOT_FOUND) {
|
|
@@ -371,21 +392,21 @@ export function getOrCreateInjectable(tNode, lViewData, token, flags = 0 /* Defa
|
|
|
371
392
|
}
|
|
372
393
|
}
|
|
373
394
|
}
|
|
374
|
-
if (flags &
|
|
395
|
+
if (flags & InjectFlags.Optional && notFoundValue === undefined) {
|
|
375
396
|
// This must be set or the NullInjector will throw for optional deps
|
|
376
397
|
notFoundValue = null;
|
|
377
398
|
}
|
|
378
|
-
if ((flags & (
|
|
399
|
+
if ((flags & (InjectFlags.Self | InjectFlags.Host)) === 0) {
|
|
379
400
|
/** @type {?} */
|
|
380
401
|
const moduleInjector = lViewData[INJECTOR];
|
|
381
402
|
if (moduleInjector) {
|
|
382
|
-
return moduleInjector.get(token, notFoundValue, flags &
|
|
403
|
+
return moduleInjector.get(token, notFoundValue, flags & InjectFlags.Optional);
|
|
383
404
|
}
|
|
384
405
|
else {
|
|
385
|
-
return injectRootLimpMode(token, notFoundValue, flags &
|
|
406
|
+
return injectRootLimpMode(token, notFoundValue, flags & InjectFlags.Optional);
|
|
386
407
|
}
|
|
387
408
|
}
|
|
388
|
-
if (flags &
|
|
409
|
+
if (flags & InjectFlags.Optional) {
|
|
389
410
|
return notFoundValue;
|
|
390
411
|
}
|
|
391
412
|
else {
|
|
@@ -406,13 +427,14 @@ function searchTokensOnInjector(injectorIndex, injectorView, token, previousTVie
|
|
|
406
427
|
/** @type {?} */
|
|
407
428
|
const currentTView = injectorView[TVIEW];
|
|
408
429
|
/** @type {?} */
|
|
409
|
-
const tNode = /** @type {?} */ (currentTView.data[injectorIndex + TNODE]);
|
|
430
|
+
const tNode = (/** @type {?} */ (currentTView.data[injectorIndex + TNODE]));
|
|
410
431
|
/** @type {?} */
|
|
411
432
|
const nodeFlags = tNode.flags;
|
|
412
433
|
/** @type {?} */
|
|
413
434
|
const nodeProviderIndexes = tNode.providerIndexes;
|
|
414
435
|
/** @type {?} */
|
|
415
436
|
const tInjectables = currentTView.data;
|
|
437
|
+
// First, we step through providers
|
|
416
438
|
/** @type {?} */
|
|
417
439
|
let canAccessViewProviders = false;
|
|
418
440
|
// We need to determine if view providers can be accessed by the starting element.
|
|
@@ -426,7 +448,7 @@ function searchTokensOnInjector(injectorIndex, injectorView, token, previousTVie
|
|
|
426
448
|
// and check the host node of the current view to identify component views.
|
|
427
449
|
if (previousTView == null && isComponent(tNode) && includeViewProviders ||
|
|
428
450
|
previousTView != null && previousTView != currentTView &&
|
|
429
|
-
(currentTView.node == null || /** @type {?} */ (
|
|
451
|
+
(currentTView.node == null || (/** @type {?} */ (currentTView.node)).type === 3 /* Element */)) {
|
|
430
452
|
canAccessViewProviders = true;
|
|
431
453
|
}
|
|
432
454
|
/** @type {?} */
|
|
@@ -441,10 +463,10 @@ function searchTokensOnInjector(injectorIndex, injectorView, token, previousTVie
|
|
|
441
463
|
const directiveCount = nodeFlags & 4095 /* DirectiveCountMask */;
|
|
442
464
|
for (let i = startingIndex; i < startDirectives + directiveCount; i++) {
|
|
443
465
|
/** @type {?} */
|
|
444
|
-
const providerTokenOrDef = /** @type {?} */ (tInjectables[i]);
|
|
466
|
+
const providerTokenOrDef = (/** @type {?} */ (tInjectables[i]));
|
|
445
467
|
if (i < startDirectives && token === providerTokenOrDef ||
|
|
446
|
-
i >= startDirectives && (/** @type {?} */ (providerTokenOrDef)).type === token) {
|
|
447
|
-
return getNodeInjectable(tInjectables, injectorView, i, /** @type {?} */ (tNode));
|
|
468
|
+
i >= startDirectives && ((/** @type {?} */ (providerTokenOrDef))).type === token) {
|
|
469
|
+
return getNodeInjectable(tInjectables, injectorView, i, (/** @type {?} */ (tNode)));
|
|
448
470
|
}
|
|
449
471
|
}
|
|
450
472
|
return NOT_FOUND;
|
|
@@ -510,7 +532,7 @@ export function getNodeInjectable(tData, lData, index, tNode) {
|
|
|
510
532
|
export function bloomHashBitOrFactory(token) {
|
|
511
533
|
ngDevMode && assertDefined(token, 'token must be defined');
|
|
512
534
|
/** @type {?} */
|
|
513
|
-
const tokenId = (/** @type {?} */ (token))[NG_ELEMENT_ID];
|
|
535
|
+
const tokenId = ((/** @type {?} */ (token)))[NG_ELEMENT_ID];
|
|
514
536
|
return typeof tokenId === 'number' ? tokenId & BLOOM_MASK : tokenId;
|
|
515
537
|
}
|
|
516
538
|
/**
|
|
@@ -520,6 +542,9 @@ export function bloomHashBitOrFactory(token) {
|
|
|
520
542
|
* @return {?}
|
|
521
543
|
*/
|
|
522
544
|
export function bloomHasToken(bloomHash, injectorIndex, injectorView) {
|
|
545
|
+
// Create a mask that targets the specific bit associated with the directive we're looking for.
|
|
546
|
+
// JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding
|
|
547
|
+
// to bit positions 0 - 31 in a 32 bit integer.
|
|
523
548
|
/** @type {?} */
|
|
524
549
|
const mask = 1 << bloomHash;
|
|
525
550
|
/** @type {?} */
|
|
@@ -528,6 +553,9 @@ export function bloomHasToken(bloomHash, injectorIndex, injectorView) {
|
|
|
528
553
|
const b6 = bloomHash & 0x40;
|
|
529
554
|
/** @type {?} */
|
|
530
555
|
const b5 = bloomHash & 0x20;
|
|
556
|
+
// Our bloom filter size is 256 bits, which is eight 32-bit bloom filter buckets:
|
|
557
|
+
// bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc.
|
|
558
|
+
// Get the bloom filter value from the appropriate bucket based on the directive's bloomBit.
|
|
531
559
|
/** @type {?} */
|
|
532
560
|
let value;
|
|
533
561
|
if (b7) {
|
|
@@ -549,16 +577,16 @@ export function bloomHasToken(bloomHash, injectorIndex, injectorView) {
|
|
|
549
577
|
* @return {?}
|
|
550
578
|
*/
|
|
551
579
|
function shouldSearchParent(flags, parentLocation) {
|
|
552
|
-
return !(flags &
|
|
553
|
-
(flags &
|
|
554
|
-
((/** @type {?} */ ((parentLocation))) & 32768 /* AcrossHostBoundary */)));
|
|
580
|
+
return !(flags & InjectFlags.Self ||
|
|
581
|
+
(flags & InjectFlags.Host &&
|
|
582
|
+
(((/** @type {?} */ ((/** @type {?} */ (parentLocation))))) & 32768 /* AcrossHostBoundary */)));
|
|
555
583
|
}
|
|
556
584
|
/**
|
|
557
585
|
* @return {?}
|
|
558
586
|
*/
|
|
559
587
|
export function injectInjector() {
|
|
560
588
|
/** @type {?} */
|
|
561
|
-
const tNode = /** @type {?} */ (getPreviousOrParentTNode());
|
|
589
|
+
const tNode = (/** @type {?} */ (getPreviousOrParentTNode()));
|
|
562
590
|
return new NodeInjector(tNode, getViewData());
|
|
563
591
|
}
|
|
564
592
|
export class NodeInjector {
|
|
@@ -595,7 +623,7 @@ if (false) {
|
|
|
595
623
|
*/
|
|
596
624
|
export function getFactoryOf(type) {
|
|
597
625
|
/** @type {?} */
|
|
598
|
-
const typeAny = /** @type {?} */ (type);
|
|
626
|
+
const typeAny = (/** @type {?} */ (type));
|
|
599
627
|
/** @type {?} */
|
|
600
628
|
const def = getComponentDef(typeAny) || getDirectiveDef(typeAny) ||
|
|
601
629
|
getPipeDef(typeAny) || getInjectableDef(typeAny) || getInjectorDef(typeAny);
|
|
@@ -611,7 +639,7 @@ export function getFactoryOf(type) {
|
|
|
611
639
|
*/
|
|
612
640
|
export function getInheritedFactory(type) {
|
|
613
641
|
/** @type {?} */
|
|
614
|
-
const proto = /** @type {?} */ (Object.getPrototypeOf(type.prototype).constructor);
|
|
642
|
+
const proto = (/** @type {?} */ (Object.getPrototypeOf(type.prototype).constructor));
|
|
615
643
|
/** @type {?} */
|
|
616
644
|
const factory = getFactoryOf(proto);
|
|
617
645
|
if (factory !== null) {
|
|
@@ -625,5 +653,4 @@ export function getInheritedFactory(type) {
|
|
|
625
653
|
return (t) => new t();
|
|
626
654
|
}
|
|
627
655
|
}
|
|
628
|
-
|
|
629
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"di.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/di.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {getInjectableDef, getInjectorDef} from '../di/defs';\nimport {InjectionToken} from '../di/injection_token';\nimport {Injector} from '../di/injector';\nimport {InjectFlags, injectRootLimpMode, setInjectImplementation} from '../di/injector_compatibility';\nimport {Type} from '../type';\n\nimport {assertDefined, assertEqual} from './assert';\nimport {getComponentDef, getDirectiveDef, getPipeDef} from './definition';\nimport {NG_ELEMENT_ID} from './fields';\nimport {DirectiveDef} from './interfaces/definition';\nimport {NO_PARENT_INJECTOR, NodeInjectorFactory, PARENT_INJECTOR, RelativeInjectorLocation, RelativeInjectorLocationFlags, TNODE, isFactory} from './interfaces/injector';\nimport {AttributeMarker, TContainerNode, TElementContainerNode, TElementNode, TNode, TNodeFlags, TNodeProviderIndexes, TNodeType} from './interfaces/node';\nimport {DECLARATION_VIEW, HOST_NODE, INJECTOR, LViewData, TData, TVIEW, TView} from './interfaces/view';\nimport {assertNodeOfPossibleTypes} from './node_assert';\nimport {getPreviousOrParentTNode, getViewData, setTNodeAndViewData} from './state';\nimport {getParentInjectorIndex, getParentInjectorView, hasParentInjector, isComponent, stringify} from './util';\n\n/**\n * Defines if the call to `inject` should include `viewProviders` in its resolution.\n *\n * This is set to true when we try to instantiate a component. This value is reset in\n * `getNodeInjectable` to a value which matches the declaration location of the token about to be\n * instantiated. This is done so that if we are injecting a token which was declared outside of\n * `viewProviders` we don't accidentally pull `viewProviders` in.\n *\n * Example:\n *\n * ```\n * @Injectable()\n * class MyService {\n *   constructor(public value: String) {}\n * }\n *\n * @Component({\n *   providers: [\n *     MyService,\n *     {provide: String, value: 'providers' }\n *   ]\n *   viewProviders: [\n *     {provide: String, value: 'viewProviders'}\n *   ]\n * })\n * class MyComponent {\n *   constructor(myService: MyService, value: String) {\n *     // We expect that Component can see into `viewProviders`.\n *     expect(value).toEqual('viewProviders');\n *     // `MyService` was not declared in `viewProviders` hence it can't see it.\n *     expect(myService.value).toEqual('providers');\n *   }\n * }\n *\n * ```\n */\nlet includeViewProviders = false;\n\nfunction setIncludeViewProviders(v: boolean): boolean {\n  const oldValue = includeViewProviders;\n  includeViewProviders = v;\n  return oldValue;\n}\n\n/**\n * The number of slots in each bloom filter (used by DI). The larger this number, the fewer\n * directives that will share slots, and thus, the fewer false positives when checking for\n * the existence of a directive.\n */\nconst BLOOM_SIZE = 256;\nconst BLOOM_MASK = BLOOM_SIZE - 1;\n\n/** Counter used to generate unique IDs for directives. */\nlet nextNgElementId = 0;\n\n/**\n * Registers this directive as present in its node's injector by flipping the directive's\n * corresponding bit in the injector's bloom filter.\n *\n * @param injectorIndex The index of the node injector where this token should be registered\n * @param tView The TView for the injector's bloom filters\n * @param type The directive token to register\n */\nexport function bloomAdd(\n    injectorIndex: number, tView: TView, type: Type<any>| InjectionToken<any>): void {\n  ngDevMode && assertEqual(tView.firstTemplatePass, true, 'expected firstTemplatePass to be true');\n  let id: number|undefined = (type as any)[NG_ELEMENT_ID];\n\n  // Set a unique ID on the directive type, so if something tries to inject the directive,\n  // we can easily retrieve the ID and hash it into the bloom bit that should be checked.\n  if (id == null) {\n    id = (type as any)[NG_ELEMENT_ID] = nextNgElementId++;\n  }\n\n  // We only have BLOOM_SIZE (256) slots in our bloom filter (8 buckets * 32 bits each),\n  // so all unique IDs must be modulo-ed into a number from 0 - 255 to fit into the filter.\n  const bloomBit = id & BLOOM_MASK;\n\n  // Create a mask that targets the specific bit associated with the directive.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomBit;\n\n  // Use the raw bloomBit number to determine which bloom filter bucket we should check\n  // e.g: bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc\n  const b7 = bloomBit & 0x80;\n  const b6 = bloomBit & 0x40;\n  const b5 = bloomBit & 0x20;\n  const tData = tView.data as number[];\n\n  if (b7) {\n    b6 ? (b5 ? (tData[injectorIndex + 7] |= mask) : (tData[injectorIndex + 6] |= mask)) :\n         (b5 ? (tData[injectorIndex + 5] |= mask) : (tData[injectorIndex + 4] |= mask));\n  } else {\n    b6 ? (b5 ? (tData[injectorIndex + 3] |= mask) : (tData[injectorIndex + 2] |= mask)) :\n         (b5 ? (tData[injectorIndex + 1] |= mask) : (tData[injectorIndex] |= mask));\n  }\n}\n\n/**\n * Creates (or gets an existing) injector for a given element or container.\n *\n * @param tNode for which an injector should be retrieved / created.\n * @param hostView View where the node is stored\n * @returns Node injector\n */\nexport function getOrCreateNodeInjectorForNode(\n    tNode: TElementNode | TContainerNode | TElementContainerNode, hostView: LViewData): number {\n  const existingInjectorIndex = getInjectorIndex(tNode, hostView);\n  if (existingInjectorIndex !== -1) {\n    return existingInjectorIndex;\n  }\n\n  const tView = hostView[TVIEW];\n  if (tView.firstTemplatePass) {\n    tNode.injectorIndex = hostView.length;\n    insertBloom(tView.data, tNode);  // foundation for node bloom\n    insertBloom(hostView, null);     // foundation for cumulative bloom\n    insertBloom(tView.blueprint, null);\n\n    ngDevMode && assertEqual(\n                     tNode.flags === 0 || tNode.flags === TNodeFlags.isComponent, true,\n                     'expected tNode.flags to not be initialized');\n  }\n\n  const parentLoc = getParentInjectorLocation(tNode, hostView);\n  const parentIndex = getParentInjectorIndex(parentLoc);\n  const parentView: LViewData = getParentInjectorView(parentLoc, hostView);\n\n  const injectorIndex = tNode.injectorIndex;\n\n  // If a parent injector can't be found, its location is set to -1.\n  // In that case, we don't need to set up a cumulative bloom\n  if (hasParentInjector(parentLoc)) {\n    const parentData = parentView[TVIEW].data as any;\n    // Creates a cumulative bloom filter that merges the parent's bloom filter\n    // and its own cumulative bloom (which contains tokens for all ancestors)\n    for (let i = 0; i < 8; i++) {\n      hostView[injectorIndex + i] = parentView[parentIndex + i] | parentData[parentIndex + i];\n    }\n  }\n\n  hostView[injectorIndex + PARENT_INJECTOR] = parentLoc;\n  return injectorIndex;\n}\n\nfunction insertBloom(arr: any[], footer: TNode | null): void {\n  arr.push(0, 0, 0, 0, 0, 0, 0, 0, footer);\n}\n\n\nexport function getInjectorIndex(tNode: TNode, hostView: LViewData): number {\n  if (tNode.injectorIndex === -1 ||\n      // If the injector index is the same as its parent's injector index, then the index has been\n      // copied down from the parent node. No injector has been created yet on this node.\n      (tNode.parent && tNode.parent.injectorIndex === tNode.injectorIndex) ||\n      // After the first template pass, the injector index might exist but the parent values\n      // might not have been calculated yet for this instance\n      hostView[tNode.injectorIndex + PARENT_INJECTOR] == null) {\n    return -1;\n  } else {\n    return tNode.injectorIndex;\n  }\n}\n\n/**\n * Finds the index of the parent injector, with a view offset if applicable. Used to set the\n * parent injector initially.\n *\n * Returns a combination of number of `ViewData` we have to go up and index in that `Viewdata`\n */\nexport function getParentInjectorLocation(tNode: TNode, view: LViewData): RelativeInjectorLocation {\n  if (tNode.parent && tNode.parent.injectorIndex !== -1) {\n    return tNode.parent.injectorIndex as any;  // ViewOffset is 0, AcrossHostBoundary is 0\n  }\n\n  // For most cases, the parent injector index can be found on the host node (e.g. for component\n  // or container), so this loop will be skipped, but we must keep the loop here to support\n  // the rarer case of deeply nested <ng-template> tags or inline views.\n  let hostTNode = view[HOST_NODE];\n  let viewOffset = 1;\n  while (hostTNode && hostTNode.injectorIndex === -1) {\n    view = view[DECLARATION_VIEW] !;\n    hostTNode = view[HOST_NODE] !;\n    viewOffset++;\n  }\n  const acrossHostBoundary = hostTNode && hostTNode.type === TNodeType.Element ?\n      RelativeInjectorLocationFlags.AcrossHostBoundary :\n      0;\n\n  return hostTNode ?\n      hostTNode.injectorIndex | (viewOffset << RelativeInjectorLocationFlags.ViewOffsetShift) |\n          acrossHostBoundary :\n      -1 as any;\n}\n\n/**\n * Makes a type or an injection token public to the DI system by adding it to an\n * injector's bloom filter.\n *\n * @param di The node injector in which a directive will be added\n * @param token The type or the injection token to be made public\n */\nexport function diPublicInInjector(\n    injectorIndex: number, view: LViewData, token: InjectionToken<any>| Type<any>): void {\n  bloomAdd(injectorIndex, view[TVIEW], token);\n}\n\n/**\n * Inject static attribute value into directive constructor.\n *\n * This method is used with `factory` functions which are generated as part of\n * `defineDirective` or `defineComponent`. The method retrieves the static value\n * of an attribute. (Dynamic attributes are not supported since they are not resolved\n *  at the time of injection and can change over time.)\n *\n * # Example\n * Given:\n * ```\n * @Component(...)\n * class MyComponent {\n *   constructor(@Attribute('title') title: string) { ... }\n * }\n * ```\n * When instantiated with\n * ```\n * <my-component title=\"Hello\"></my-component>\n * ```\n *\n * Then factory method generated is:\n * ```\n * MyComponent.ngComponentDef = defineComponent({\n *   factory: () => new MyComponent(injectAttribute('title'))\n *   ...\n * })\n * ```\n *\n * @publicApi\n */\nexport function injectAttributeImpl(tNode: TNode, attrNameToInject: string): string|undefined {\n  ngDevMode && assertNodeOfPossibleTypes(\n                   tNode, TNodeType.Container, TNodeType.Element, TNodeType.ElementContainer);\n  ngDevMode && assertDefined(tNode, 'expecting tNode');\n  const attrs = tNode.attrs;\n  if (attrs) {\n    for (let i = 0; i < attrs.length; i = i + 2) {\n      const attrName = attrs[i];\n      if (attrName === AttributeMarker.SelectOnly) break;\n      if (attrName == attrNameToInject) {\n        return attrs[i + 1] as string;\n      }\n    }\n  }\n  return undefined;\n}\n\n\n/**\n * Returns the value associated to the given token from the NodeInjectors => ModuleInjector.\n *\n * Look for the injector providing the token by walking up the node injector tree and then\n * the module injector tree.\n *\n * @param nodeInjector Node injector where the search should start\n * @param token The token to look for\n * @param flags Injection flags\n * @returns the value from the injector or `null` when not found\n */\nexport function getOrCreateInjectable<T>(\n    tNode: TElementNode | TContainerNode | TElementContainerNode, lViewData: LViewData,\n    token: Type<T>| InjectionToken<T>, flags: InjectFlags = InjectFlags.Default,\n    notFoundValue?: any): T|null {\n  const bloomHash = bloomHashBitOrFactory(token);\n  // If the ID stored here is a function, this is a special object like ElementRef or TemplateRef\n  // so just call the factory function to create it.\n  if (typeof bloomHash === 'function') {\n    const savePreviousOrParentTNode = getPreviousOrParentTNode();\n    const saveViewData = getViewData();\n    setTNodeAndViewData(tNode, lViewData);\n    try {\n      const value = bloomHash();\n      if (value == null && !(flags & InjectFlags.Optional)) {\n        throw new Error(`No provider for ${stringify(token)}`);\n      } else {\n        return value;\n      }\n    } finally {\n      setTNodeAndViewData(savePreviousOrParentTNode, saveViewData);\n    }\n  } else if (typeof bloomHash == 'number') {\n    // If the token has a bloom hash, then it is a token which could be in NodeInjector.\n\n    // A reference to the previous injector TView that was found while climbing the element injector\n    // tree. This is used to know if viewProviders can be accessed on the current injector.\n    let previousTView: TView|null = null;\n    let injectorIndex = getInjectorIndex(tNode, lViewData);\n    let parentLocation: RelativeInjectorLocation = NO_PARENT_INJECTOR;\n\n    // If we should skip this injector, or if there is no injector on this node, start by searching\n    // the parent injector.\n    if (injectorIndex === -1 || flags & InjectFlags.SkipSelf) {\n      parentLocation = injectorIndex === -1 ? getParentInjectorLocation(tNode, lViewData) :\n                                              lViewData[injectorIndex + PARENT_INJECTOR];\n\n      if (!shouldSearchParent(flags, parentLocation)) {\n        injectorIndex = -1;\n      } else {\n        previousTView = lViewData[TVIEW];\n        injectorIndex = getParentInjectorIndex(parentLocation);\n        lViewData = getParentInjectorView(parentLocation, lViewData);\n      }\n    }\n\n    // Traverse up the injector tree until we find a potential match or until we know there\n    // *isn't* a match.\n    while (injectorIndex !== -1) {\n      parentLocation = lViewData[injectorIndex + PARENT_INJECTOR];\n\n      // Check the current injector. If it matches, see if it contains token.\n      const tView = lViewData[TVIEW];\n      if (bloomHasToken(bloomHash, injectorIndex, tView.data)) {\n        // At this point, we have an injector which *may* contain the token, so we step through\n        // the providers and directives associated with the injector's corresponding node to get\n        // the instance.\n        const instance: T|null =\n            searchTokensOnInjector<T>(injectorIndex, lViewData, token, previousTView);\n        if (instance !== NOT_FOUND) {\n          return instance;\n        }\n      }\n      if (shouldSearchParent(flags, parentLocation) &&\n          bloomHasToken(bloomHash, injectorIndex, lViewData)) {\n        // The def wasn't found anywhere on this node, so it was a false positive.\n        // Traverse up the tree and continue searching.\n        previousTView = tView;\n        injectorIndex = getParentInjectorIndex(parentLocation);\n        lViewData = getParentInjectorView(parentLocation, lViewData);\n      } else {\n        // If we should not search parent OR If the ancestor bloom filter value does not have the\n        // bit corresponding to the directive we can give up on traversing up to find the specific\n        // injector.\n        injectorIndex = -1;\n      }\n    }\n  }\n\n  if (flags & InjectFlags.Optional && notFoundValue === undefined) {\n    // This must be set or the NullInjector will throw for optional deps\n    notFoundValue = null;\n  }\n\n  if ((flags & (InjectFlags.Self | InjectFlags.Host)) === 0) {\n    const moduleInjector = lViewData[INJECTOR];\n    if (moduleInjector) {\n      return moduleInjector.get(token, notFoundValue, flags & InjectFlags.Optional);\n    } else {\n      return injectRootLimpMode(token, notFoundValue, flags & InjectFlags.Optional);\n    }\n  }\n  if (flags & InjectFlags.Optional) {\n    return notFoundValue;\n  } else {\n    throw new Error(`NodeInjector: NOT_FOUND [${stringify(token)}]`);\n  }\n}\n\nconst NOT_FOUND = {};\n\nfunction searchTokensOnInjector<T>(\n    injectorIndex: number, injectorView: LViewData, token: Type<T>| InjectionToken<T>,\n    previousTView: TView | null) {\n  const currentTView = injectorView[TVIEW];\n  const tNode = currentTView.data[injectorIndex + TNODE] as TNode;\n  const nodeFlags = tNode.flags;\n  const nodeProviderIndexes = tNode.providerIndexes;\n  const tInjectables = currentTView.data;\n  // First, we step through providers\n  let canAccessViewProviders = false;\n  // We need to determine if view providers can be accessed by the starting element.\n  // It happens in 2 cases:\n  // 1) On the initial element injector , if we are instantiating a token which can see the\n  // viewProviders of the component of that element. Such token are:\n  // - the component itself (but not other directives)\n  // - viewProviders tokens of the component (but not providers tokens)\n  // 2) Upper in the element injector tree, if the starting element is actually in the view of\n  // the current element. To determine this, we track the transition of view during the climb,\n  // and check the host node of the current view to identify component views.\n  if (previousTView == null && isComponent(tNode) && includeViewProviders ||\n      previousTView != null && previousTView != currentTView &&\n          (currentTView.node == null || currentTView.node !.type === TNodeType.Element)) {\n    canAccessViewProviders = true;\n  }\n  const startInjectables = nodeProviderIndexes & TNodeProviderIndexes.ProvidersStartIndexMask;\n  const startDirectives = nodeFlags >> TNodeFlags.DirectiveStartingIndexShift;\n  const cptViewProvidersCount =\n      nodeProviderIndexes >> TNodeProviderIndexes.CptViewProvidersCountShift;\n  const startingIndex =\n      canAccessViewProviders ? startInjectables : startInjectables + cptViewProvidersCount;\n  const directiveCount = nodeFlags & TNodeFlags.DirectiveCountMask;\n  for (let i = startingIndex; i < startDirectives + directiveCount; i++) {\n    const providerTokenOrDef = tInjectables[i] as InjectionToken<any>| Type<any>| DirectiveDef<any>;\n    if (i < startDirectives && token === providerTokenOrDef ||\n        i >= startDirectives && (providerTokenOrDef as DirectiveDef<any>).type === token) {\n      return getNodeInjectable(tInjectables, injectorView, i, tNode as TElementNode);\n    }\n  }\n  return NOT_FOUND;\n}\n\n/**\n* Retrieve or instantiate the injectable from the `lData` at particular `index`.\n*\n* This function checks to see if the value has already been instantiated and if so returns the\n* cached `injectable`. Otherwise if it detects that the value is still a factory it\n* instantiates the `injectable` and caches the value.\n*/\nexport function getNodeInjectable(\n    tData: TData, lData: LViewData, index: number, tNode: TElementNode): any {\n  let value = lData[index];\n  if (isFactory(value)) {\n    const factory: NodeInjectorFactory = value;\n    if (factory.resolving) {\n      throw new Error(`Circular dep for ${stringify(tData[index])}`);\n    }\n    const previousIncludeViewProviders = setIncludeViewProviders(factory.canSeeViewProviders);\n    factory.resolving = true;\n    let previousInjectImplementation;\n    if (factory.injectImpl) {\n      previousInjectImplementation = setInjectImplementation(factory.injectImpl);\n    }\n    const savePreviousOrParentTNode = getPreviousOrParentTNode();\n    const saveViewData = getViewData();\n    setTNodeAndViewData(tNode, lData);\n    try {\n      value = lData[index] = factory.factory(null, tData, lData, tNode);\n    } finally {\n      if (factory.injectImpl) setInjectImplementation(previousInjectImplementation);\n      setIncludeViewProviders(previousIncludeViewProviders);\n      factory.resolving = false;\n      setTNodeAndViewData(savePreviousOrParentTNode, saveViewData);\n    }\n  }\n  return value;\n}\n\n/**\n * Returns the bit in an injector's bloom filter that should be used to determine whether or not\n * the directive might be provided by the injector.\n *\n * When a directive is public, it is added to the bloom filter and given a unique ID that can be\n * retrieved on the Type. When the directive isn't public or the token is not a directive `null`\n * is returned as the node injector can not possibly provide that token.\n *\n * @param token the injection token\n * @returns the matching bit to check in the bloom filter or `null` if the token is not known.\n */\nexport function bloomHashBitOrFactory(token: Type<any>| InjectionToken<any>): number|Function|\n    undefined {\n  ngDevMode && assertDefined(token, 'token must be defined');\n  const tokenId: number|undefined = (token as any)[NG_ELEMENT_ID];\n  return typeof tokenId === 'number' ? tokenId & BLOOM_MASK : tokenId;\n}\n\nexport function bloomHasToken(\n    bloomHash: number, injectorIndex: number, injectorView: LViewData | TData) {\n  // Create a mask that targets the specific bit associated with the directive we're looking for.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomHash;\n  const b7 = bloomHash & 0x80;\n  const b6 = bloomHash & 0x40;\n  const b5 = bloomHash & 0x20;\n\n  // Our bloom filter size is 256 bits, which is eight 32-bit bloom filter buckets:\n  // bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc.\n  // Get the bloom filter value from the appropriate bucket based on the directive's bloomBit.\n  let value: number;\n\n  if (b7) {\n    value = b6 ? (b5 ? injectorView[injectorIndex + 7] : injectorView[injectorIndex + 6]) :\n                 (b5 ? injectorView[injectorIndex + 5] : injectorView[injectorIndex + 4]);\n  } else {\n    value = b6 ? (b5 ? injectorView[injectorIndex + 3] : injectorView[injectorIndex + 2]) :\n                 (b5 ? injectorView[injectorIndex + 1] : injectorView[injectorIndex]);\n  }\n\n  // If the bloom filter value has the bit corresponding to the directive's bloomBit flipped on,\n  // this injector is a potential match.\n  return !!(value & mask);\n}\n\n/** Returns true if flags prevent parent injector from being searched for tokens */\nfunction shouldSearchParent(flags: InjectFlags, parentLocation: RelativeInjectorLocation): boolean|\n    number {\n  return !(\n      flags & InjectFlags.Self ||\n      (flags & InjectFlags.Host &&\n       ((parentLocation as any as number) & RelativeInjectorLocationFlags.AcrossHostBoundary)));\n}\n\nexport function injectInjector() {\n  const tNode = getPreviousOrParentTNode() as TElementNode | TContainerNode | TElementContainerNode;\n  return new NodeInjector(tNode, getViewData());\n}\n\nexport class NodeInjector implements Injector {\n  private _injectorIndex: number;\n\n  constructor(\n      private _tNode: TElementNode|TContainerNode|TElementContainerNode,\n      private _hostView: LViewData) {\n    this._injectorIndex = getOrCreateNodeInjectorForNode(_tNode, _hostView);\n  }\n\n  get(token: any): any {\n    setTNodeAndViewData(this._tNode, this._hostView);\n    return getOrCreateInjectable(this._tNode, this._hostView, token);\n  }\n}\n\nexport function getFactoryOf<T>(type: Type<any>): ((type: Type<T>| null) => T)|null {\n  const typeAny = type as any;\n  const def = getComponentDef<T>(typeAny) || getDirectiveDef<T>(typeAny) ||\n      getPipeDef<T>(typeAny) || getInjectableDef<T>(typeAny) || getInjectorDef<T>(typeAny);\n  if (!def || def.factory === undefined) {\n    return null;\n  }\n  return def.factory;\n}\n\nexport function getInheritedFactory<T>(type: Type<any>): (type: Type<T>) => T {\n  const proto = Object.getPrototypeOf(type.prototype).constructor as Type<any>;\n  const factory = getFactoryOf<T>(proto);\n  if (factory !== null) {\n    return factory;\n  } else {\n    // There is no factory defined. Either this was improper usage of inheritance\n    // (no Angular decorator on the superclass) or there is no constructor at all\n    // in the inheritance chain. Since the two cases cannot be distinguished, the\n    // latter has to be assumed.\n    return (t) => new t();\n  }\n}\n"]}
|
|
656
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"di.js","sourceRoot":"../../","sources":["packages/core/src/render3/di.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {getInjectableDef, getInjectorDef} from '../di/defs';\nimport {InjectionToken} from '../di/injection_token';\nimport {Injector} from '../di/injector';\nimport {InjectFlags, injectRootLimpMode, setInjectImplementation} from '../di/injector_compatibility';\nimport {Type} from '../type';\n\nimport {assertDefined, assertEqual} from './assert';\nimport {getComponentDef, getDirectiveDef, getPipeDef} from './definition';\nimport {NG_ELEMENT_ID} from './fields';\nimport {DirectiveDef} from './interfaces/definition';\nimport {NO_PARENT_INJECTOR, NodeInjectorFactory, PARENT_INJECTOR, RelativeInjectorLocation, RelativeInjectorLocationFlags, TNODE, isFactory} from './interfaces/injector';\nimport {AttributeMarker, TContainerNode, TElementContainerNode, TElementNode, TNode, TNodeFlags, TNodeProviderIndexes, TNodeType} from './interfaces/node';\nimport {DECLARATION_VIEW, HOST_NODE, INJECTOR, LViewData, TData, TVIEW, TView} from './interfaces/view';\nimport {assertNodeOfPossibleTypes} from './node_assert';\nimport {getPreviousOrParentTNode, getViewData, setTNodeAndViewData} from './state';\nimport {getParentInjectorIndex, getParentInjectorView, hasParentInjector, isComponent, stringify} from './util';\n\n/**\n * Defines if the call to `inject` should include `viewProviders` in its resolution.\n *\n * This is set to true when we try to instantiate a component. This value is reset in\n * `getNodeInjectable` to a value which matches the declaration location of the token about to be\n * instantiated. This is done so that if we are injecting a token which was declared outside of\n * `viewProviders` we don't accidentally pull `viewProviders` in.\n *\n * Example:\n *\n * ```\n * @Injectable()\n * class MyService {\n *   constructor(public value: String) {}\n * }\n *\n * @Component({\n *   providers: [\n *     MyService,\n *     {provide: String, value: 'providers' }\n *   ]\n *   viewProviders: [\n *     {provide: String, value: 'viewProviders'}\n *   ]\n * })\n * class MyComponent {\n *   constructor(myService: MyService, value: String) {\n *     // We expect that Component can see into `viewProviders`.\n *     expect(value).toEqual('viewProviders');\n *     // `MyService` was not declared in `viewProviders` hence it can't see it.\n *     expect(myService.value).toEqual('providers');\n *   }\n * }\n *\n * ```\n */\nlet includeViewProviders = false;\n\nfunction setIncludeViewProviders(v: boolean): boolean {\n  const oldValue = includeViewProviders;\n  includeViewProviders = v;\n  return oldValue;\n}\n\n/**\n * The number of slots in each bloom filter (used by DI). The larger this number, the fewer\n * directives that will share slots, and thus, the fewer false positives when checking for\n * the existence of a directive.\n */\nconst BLOOM_SIZE = 256;\nconst BLOOM_MASK = BLOOM_SIZE - 1;\n\n/** Counter used to generate unique IDs for directives. */\nlet nextNgElementId = 0;\n\n/**\n * Registers this directive as present in its node's injector by flipping the directive's\n * corresponding bit in the injector's bloom filter.\n *\n * @param injectorIndex The index of the node injector where this token should be registered\n * @param tView The TView for the injector's bloom filters\n * @param type The directive token to register\n */\nexport function bloomAdd(\n    injectorIndex: number, tView: TView, type: Type<any>| InjectionToken<any>): void {\n  ngDevMode && assertEqual(tView.firstTemplatePass, true, 'expected firstTemplatePass to be true');\n  let id: number|undefined = (type as any)[NG_ELEMENT_ID];\n\n  // Set a unique ID on the directive type, so if something tries to inject the directive,\n  // we can easily retrieve the ID and hash it into the bloom bit that should be checked.\n  if (id == null) {\n    id = (type as any)[NG_ELEMENT_ID] = nextNgElementId++;\n  }\n\n  // We only have BLOOM_SIZE (256) slots in our bloom filter (8 buckets * 32 bits each),\n  // so all unique IDs must be modulo-ed into a number from 0 - 255 to fit into the filter.\n  const bloomBit = id & BLOOM_MASK;\n\n  // Create a mask that targets the specific bit associated with the directive.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomBit;\n\n  // Use the raw bloomBit number to determine which bloom filter bucket we should check\n  // e.g: bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc\n  const b7 = bloomBit & 0x80;\n  const b6 = bloomBit & 0x40;\n  const b5 = bloomBit & 0x20;\n  const tData = tView.data as number[];\n\n  if (b7) {\n    b6 ? (b5 ? (tData[injectorIndex + 7] |= mask) : (tData[injectorIndex + 6] |= mask)) :\n         (b5 ? (tData[injectorIndex + 5] |= mask) : (tData[injectorIndex + 4] |= mask));\n  } else {\n    b6 ? (b5 ? (tData[injectorIndex + 3] |= mask) : (tData[injectorIndex + 2] |= mask)) :\n         (b5 ? (tData[injectorIndex + 1] |= mask) : (tData[injectorIndex] |= mask));\n  }\n}\n\n/**\n * Creates (or gets an existing) injector for a given element or container.\n *\n * @param tNode for which an injector should be retrieved / created.\n * @param hostView View where the node is stored\n * @returns Node injector\n */\nexport function getOrCreateNodeInjectorForNode(\n    tNode: TElementNode | TContainerNode | TElementContainerNode, hostView: LViewData): number {\n  const existingInjectorIndex = getInjectorIndex(tNode, hostView);\n  if (existingInjectorIndex !== -1) {\n    return existingInjectorIndex;\n  }\n\n  const tView = hostView[TVIEW];\n  if (tView.firstTemplatePass) {\n    tNode.injectorIndex = hostView.length;\n    insertBloom(tView.data, tNode);  // foundation for node bloom\n    insertBloom(hostView, null);     // foundation for cumulative bloom\n    insertBloom(tView.blueprint, null);\n\n    ngDevMode && assertEqual(\n                     tNode.flags === 0 || tNode.flags === TNodeFlags.isComponent, true,\n                     'expected tNode.flags to not be initialized');\n  }\n\n  const parentLoc = getParentInjectorLocation(tNode, hostView);\n  const parentIndex = getParentInjectorIndex(parentLoc);\n  const parentView: LViewData = getParentInjectorView(parentLoc, hostView);\n\n  const injectorIndex = tNode.injectorIndex;\n\n  // If a parent injector can't be found, its location is set to -1.\n  // In that case, we don't need to set up a cumulative bloom\n  if (hasParentInjector(parentLoc)) {\n    const parentData = parentView[TVIEW].data as any;\n    // Creates a cumulative bloom filter that merges the parent's bloom filter\n    // and its own cumulative bloom (which contains tokens for all ancestors)\n    for (let i = 0; i < 8; i++) {\n      hostView[injectorIndex + i] = parentView[parentIndex + i] | parentData[parentIndex + i];\n    }\n  }\n\n  hostView[injectorIndex + PARENT_INJECTOR] = parentLoc;\n  return injectorIndex;\n}\n\nfunction insertBloom(arr: any[], footer: TNode | null): void {\n  arr.push(0, 0, 0, 0, 0, 0, 0, 0, footer);\n}\n\n\nexport function getInjectorIndex(tNode: TNode, hostView: LViewData): number {\n  if (tNode.injectorIndex === -1 ||\n      // If the injector index is the same as its parent's injector index, then the index has been\n      // copied down from the parent node. No injector has been created yet on this node.\n      (tNode.parent && tNode.parent.injectorIndex === tNode.injectorIndex) ||\n      // After the first template pass, the injector index might exist but the parent values\n      // might not have been calculated yet for this instance\n      hostView[tNode.injectorIndex + PARENT_INJECTOR] == null) {\n    return -1;\n  } else {\n    return tNode.injectorIndex;\n  }\n}\n\n/**\n * Finds the index of the parent injector, with a view offset if applicable. Used to set the\n * parent injector initially.\n *\n * Returns a combination of number of `ViewData` we have to go up and index in that `Viewdata`\n */\nexport function getParentInjectorLocation(tNode: TNode, view: LViewData): RelativeInjectorLocation {\n  if (tNode.parent && tNode.parent.injectorIndex !== -1) {\n    return tNode.parent.injectorIndex as any;  // ViewOffset is 0, AcrossHostBoundary is 0\n  }\n\n  // For most cases, the parent injector index can be found on the host node (e.g. for component\n  // or container), so this loop will be skipped, but we must keep the loop here to support\n  // the rarer case of deeply nested <ng-template> tags or inline views.\n  let hostTNode = view[HOST_NODE];\n  let viewOffset = 1;\n  while (hostTNode && hostTNode.injectorIndex === -1) {\n    view = view[DECLARATION_VIEW] !;\n    hostTNode = view[HOST_NODE] !;\n    viewOffset++;\n  }\n  const acrossHostBoundary = hostTNode && hostTNode.type === TNodeType.Element ?\n      RelativeInjectorLocationFlags.AcrossHostBoundary :\n      0;\n\n  return hostTNode ?\n      hostTNode.injectorIndex | (viewOffset << RelativeInjectorLocationFlags.ViewOffsetShift) |\n          acrossHostBoundary :\n      -1 as any;\n}\n\n/**\n * Makes a type or an injection token public to the DI system by adding it to an\n * injector's bloom filter.\n *\n * @param di The node injector in which a directive will be added\n * @param token The type or the injection token to be made public\n */\nexport function diPublicInInjector(\n    injectorIndex: number, view: LViewData, token: InjectionToken<any>| Type<any>): void {\n  bloomAdd(injectorIndex, view[TVIEW], token);\n}\n\n/**\n * Inject static attribute value into directive constructor.\n *\n * This method is used with `factory` functions which are generated as part of\n * `defineDirective` or `defineComponent`. The method retrieves the static value\n * of an attribute. (Dynamic attributes are not supported since they are not resolved\n *  at the time of injection and can change over time.)\n *\n * # Example\n * Given:\n * ```\n * @Component(...)\n * class MyComponent {\n *   constructor(@Attribute('title') title: string) { ... }\n * }\n * ```\n * When instantiated with\n * ```\n * <my-component title=\"Hello\"></my-component>\n * ```\n *\n * Then factory method generated is:\n * ```\n * MyComponent.ngComponentDef = defineComponent({\n *   factory: () => new MyComponent(injectAttribute('title'))\n *   ...\n * })\n * ```\n *\n * @publicApi\n */\nexport function injectAttributeImpl(tNode: TNode, attrNameToInject: string): string|undefined {\n  ngDevMode && assertNodeOfPossibleTypes(\n                   tNode, TNodeType.Container, TNodeType.Element, TNodeType.ElementContainer);\n  ngDevMode && assertDefined(tNode, 'expecting tNode');\n  const attrs = tNode.attrs;\n  if (attrs) {\n    for (let i = 0; i < attrs.length; i = i + 2) {\n      const attrName = attrs[i];\n      if (attrName === AttributeMarker.SelectOnly) break;\n      if (attrName == attrNameToInject) {\n        return attrs[i + 1] as string;\n      }\n    }\n  }\n  return undefined;\n}\n\n\n/**\n * Returns the value associated to the given token from the NodeInjectors => ModuleInjector.\n *\n * Look for the injector providing the token by walking up the node injector tree and then\n * the module injector tree.\n *\n * @param nodeInjector Node injector where the search should start\n * @param token The token to look for\n * @param flags Injection flags\n * @returns the value from the injector or `null` when not found\n */\nexport function getOrCreateInjectable<T>(\n    tNode: TElementNode | TContainerNode | TElementContainerNode, lViewData: LViewData,\n    token: Type<T>| InjectionToken<T>, flags: InjectFlags = InjectFlags.Default,\n    notFoundValue?: any): T|null {\n  const bloomHash = bloomHashBitOrFactory(token);\n  // If the ID stored here is a function, this is a special object like ElementRef or TemplateRef\n  // so just call the factory function to create it.\n  if (typeof bloomHash === 'function') {\n    const savePreviousOrParentTNode = getPreviousOrParentTNode();\n    const saveViewData = getViewData();\n    setTNodeAndViewData(tNode, lViewData);\n    try {\n      const value = bloomHash();\n      if (value == null && !(flags & InjectFlags.Optional)) {\n        throw new Error(`No provider for ${stringify(token)}`);\n      } else {\n        return value;\n      }\n    } finally {\n      setTNodeAndViewData(savePreviousOrParentTNode, saveViewData);\n    }\n  } else if (typeof bloomHash == 'number') {\n    // If the token has a bloom hash, then it is a token which could be in NodeInjector.\n\n    // A reference to the previous injector TView that was found while climbing the element injector\n    // tree. This is used to know if viewProviders can be accessed on the current injector.\n    let previousTView: TView|null = null;\n    let injectorIndex = getInjectorIndex(tNode, lViewData);\n    let parentLocation: RelativeInjectorLocation = NO_PARENT_INJECTOR;\n\n    // If we should skip this injector, or if there is no injector on this node, start by searching\n    // the parent injector.\n    if (injectorIndex === -1 || flags & InjectFlags.SkipSelf) {\n      parentLocation = injectorIndex === -1 ? getParentInjectorLocation(tNode, lViewData) :\n                                              lViewData[injectorIndex + PARENT_INJECTOR];\n\n      if (!shouldSearchParent(flags, parentLocation)) {\n        injectorIndex = -1;\n      } else {\n        previousTView = lViewData[TVIEW];\n        injectorIndex = getParentInjectorIndex(parentLocation);\n        lViewData = getParentInjectorView(parentLocation, lViewData);\n      }\n    }\n\n    // Traverse up the injector tree until we find a potential match or until we know there\n    // *isn't* a match.\n    while (injectorIndex !== -1) {\n      parentLocation = lViewData[injectorIndex + PARENT_INJECTOR];\n\n      // Check the current injector. If it matches, see if it contains token.\n      const tView = lViewData[TVIEW];\n      if (bloomHasToken(bloomHash, injectorIndex, tView.data)) {\n        // At this point, we have an injector which *may* contain the token, so we step through\n        // the providers and directives associated with the injector's corresponding node to get\n        // the instance.\n        const instance: T|null =\n            searchTokensOnInjector<T>(injectorIndex, lViewData, token, previousTView);\n        if (instance !== NOT_FOUND) {\n          return instance;\n        }\n      }\n      if (shouldSearchParent(flags, parentLocation) &&\n          bloomHasToken(bloomHash, injectorIndex, lViewData)) {\n        // The def wasn't found anywhere on this node, so it was a false positive.\n        // Traverse up the tree and continue searching.\n        previousTView = tView;\n        injectorIndex = getParentInjectorIndex(parentLocation);\n        lViewData = getParentInjectorView(parentLocation, lViewData);\n      } else {\n        // If we should not search parent OR If the ancestor bloom filter value does not have the\n        // bit corresponding to the directive we can give up on traversing up to find the specific\n        // injector.\n        injectorIndex = -1;\n      }\n    }\n  }\n\n  if (flags & InjectFlags.Optional && notFoundValue === undefined) {\n    // This must be set or the NullInjector will throw for optional deps\n    notFoundValue = null;\n  }\n\n  if ((flags & (InjectFlags.Self | InjectFlags.Host)) === 0) {\n    const moduleInjector = lViewData[INJECTOR];\n    if (moduleInjector) {\n      return moduleInjector.get(token, notFoundValue, flags & InjectFlags.Optional);\n    } else {\n      return injectRootLimpMode(token, notFoundValue, flags & InjectFlags.Optional);\n    }\n  }\n  if (flags & InjectFlags.Optional) {\n    return notFoundValue;\n  } else {\n    throw new Error(`NodeInjector: NOT_FOUND [${stringify(token)}]`);\n  }\n}\n\nconst NOT_FOUND = {};\n\nfunction searchTokensOnInjector<T>(\n    injectorIndex: number, injectorView: LViewData, token: Type<T>| InjectionToken<T>,\n    previousTView: TView | null) {\n  const currentTView = injectorView[TVIEW];\n  const tNode = currentTView.data[injectorIndex + TNODE] as TNode;\n  const nodeFlags = tNode.flags;\n  const nodeProviderIndexes = tNode.providerIndexes;\n  const tInjectables = currentTView.data;\n  // First, we step through providers\n  let canAccessViewProviders = false;\n  // We need to determine if view providers can be accessed by the starting element.\n  // It happens in 2 cases:\n  // 1) On the initial element injector , if we are instantiating a token which can see the\n  // viewProviders of the component of that element. Such token are:\n  // - the component itself (but not other directives)\n  // - viewProviders tokens of the component (but not providers tokens)\n  // 2) Upper in the element injector tree, if the starting element is actually in the view of\n  // the current element. To determine this, we track the transition of view during the climb,\n  // and check the host node of the current view to identify component views.\n  if (previousTView == null && isComponent(tNode) && includeViewProviders ||\n      previousTView != null && previousTView != currentTView &&\n          (currentTView.node == null || currentTView.node !.type === TNodeType.Element)) {\n    canAccessViewProviders = true;\n  }\n  const startInjectables = nodeProviderIndexes & TNodeProviderIndexes.ProvidersStartIndexMask;\n  const startDirectives = nodeFlags >> TNodeFlags.DirectiveStartingIndexShift;\n  const cptViewProvidersCount =\n      nodeProviderIndexes >> TNodeProviderIndexes.CptViewProvidersCountShift;\n  const startingIndex =\n      canAccessViewProviders ? startInjectables : startInjectables + cptViewProvidersCount;\n  const directiveCount = nodeFlags & TNodeFlags.DirectiveCountMask;\n  for (let i = startingIndex; i < startDirectives + directiveCount; i++) {\n    const providerTokenOrDef = tInjectables[i] as InjectionToken<any>| Type<any>| DirectiveDef<any>;\n    if (i < startDirectives && token === providerTokenOrDef ||\n        i >= startDirectives && (providerTokenOrDef as DirectiveDef<any>).type === token) {\n      return getNodeInjectable(tInjectables, injectorView, i, tNode as TElementNode);\n    }\n  }\n  return NOT_FOUND;\n}\n\n/**\n* Retrieve or instantiate the injectable from the `lData` at particular `index`.\n*\n* This function checks to see if the value has already been instantiated and if so returns the\n* cached `injectable`. Otherwise if it detects that the value is still a factory it\n* instantiates the `injectable` and caches the value.\n*/\nexport function getNodeInjectable(\n    tData: TData, lData: LViewData, index: number, tNode: TElementNode): any {\n  let value = lData[index];\n  if (isFactory(value)) {\n    const factory: NodeInjectorFactory = value;\n    if (factory.resolving) {\n      throw new Error(`Circular dep for ${stringify(tData[index])}`);\n    }\n    const previousIncludeViewProviders = setIncludeViewProviders(factory.canSeeViewProviders);\n    factory.resolving = true;\n    let previousInjectImplementation;\n    if (factory.injectImpl) {\n      previousInjectImplementation = setInjectImplementation(factory.injectImpl);\n    }\n    const savePreviousOrParentTNode = getPreviousOrParentTNode();\n    const saveViewData = getViewData();\n    setTNodeAndViewData(tNode, lData);\n    try {\n      value = lData[index] = factory.factory(null, tData, lData, tNode);\n    } finally {\n      if (factory.injectImpl) setInjectImplementation(previousInjectImplementation);\n      setIncludeViewProviders(previousIncludeViewProviders);\n      factory.resolving = false;\n      setTNodeAndViewData(savePreviousOrParentTNode, saveViewData);\n    }\n  }\n  return value;\n}\n\n/**\n * Returns the bit in an injector's bloom filter that should be used to determine whether or not\n * the directive might be provided by the injector.\n *\n * When a directive is public, it is added to the bloom filter and given a unique ID that can be\n * retrieved on the Type. When the directive isn't public or the token is not a directive `null`\n * is returned as the node injector can not possibly provide that token.\n *\n * @param token the injection token\n * @returns the matching bit to check in the bloom filter or `null` if the token is not known.\n */\nexport function bloomHashBitOrFactory(token: Type<any>| InjectionToken<any>): number|Function|\n    undefined {\n  ngDevMode && assertDefined(token, 'token must be defined');\n  const tokenId: number|undefined = (token as any)[NG_ELEMENT_ID];\n  return typeof tokenId === 'number' ? tokenId & BLOOM_MASK : tokenId;\n}\n\nexport function bloomHasToken(\n    bloomHash: number, injectorIndex: number, injectorView: LViewData | TData) {\n  // Create a mask that targets the specific bit associated with the directive we're looking for.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomHash;\n  const b7 = bloomHash & 0x80;\n  const b6 = bloomHash & 0x40;\n  const b5 = bloomHash & 0x20;\n\n  // Our bloom filter size is 256 bits, which is eight 32-bit bloom filter buckets:\n  // bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc.\n  // Get the bloom filter value from the appropriate bucket based on the directive's bloomBit.\n  let value: number;\n\n  if (b7) {\n    value = b6 ? (b5 ? injectorView[injectorIndex + 7] : injectorView[injectorIndex + 6]) :\n                 (b5 ? injectorView[injectorIndex + 5] : injectorView[injectorIndex + 4]);\n  } else {\n    value = b6 ? (b5 ? injectorView[injectorIndex + 3] : injectorView[injectorIndex + 2]) :\n                 (b5 ? injectorView[injectorIndex + 1] : injectorView[injectorIndex]);\n  }\n\n  // If the bloom filter value has the bit corresponding to the directive's bloomBit flipped on,\n  // this injector is a potential match.\n  return !!(value & mask);\n}\n\n/** Returns true if flags prevent parent injector from being searched for tokens */\nfunction shouldSearchParent(flags: InjectFlags, parentLocation: RelativeInjectorLocation): boolean|\n    number {\n  return !(\n      flags & InjectFlags.Self ||\n      (flags & InjectFlags.Host &&\n       ((parentLocation as any as number) & RelativeInjectorLocationFlags.AcrossHostBoundary)));\n}\n\nexport function injectInjector() {\n  const tNode = getPreviousOrParentTNode() as TElementNode | TContainerNode | TElementContainerNode;\n  return new NodeInjector(tNode, getViewData());\n}\n\nexport class NodeInjector implements Injector {\n  private _injectorIndex: number;\n\n  constructor(\n      private _tNode: TElementNode|TContainerNode|TElementContainerNode,\n      private _hostView: LViewData) {\n    this._injectorIndex = getOrCreateNodeInjectorForNode(_tNode, _hostView);\n  }\n\n  get(token: any): any {\n    setTNodeAndViewData(this._tNode, this._hostView);\n    return getOrCreateInjectable(this._tNode, this._hostView, token);\n  }\n}\n\nexport function getFactoryOf<T>(type: Type<any>): ((type: Type<T>| null) => T)|null {\n  const typeAny = type as any;\n  const def = getComponentDef<T>(typeAny) || getDirectiveDef<T>(typeAny) ||\n      getPipeDef<T>(typeAny) || getInjectableDef<T>(typeAny) || getInjectorDef<T>(typeAny);\n  if (!def || def.factory === undefined) {\n    return null;\n  }\n  return def.factory;\n}\n\nexport function getInheritedFactory<T>(type: Type<any>): (type: Type<T>) => T {\n  const proto = Object.getPrototypeOf(type.prototype).constructor as Type<any>;\n  const factory = getFactoryOf<T>(proto);\n  if (factory !== null) {\n    return factory;\n  } else {\n    // There is no factory defined. Either this was improper usage of inheritance\n    // (no Angular decorator on the superclass) or there is no constructor at all\n    // in the inheritance chain. Since the two cases cannot be distinguished, the\n    // latter has to be assumed.\n    return (t) => new t();\n  }\n}\n"]}
|