@angular/core 6.0.3 → 6.0.7
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 +61 -237
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core-testing.umd.min.js +11 -4
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +591 -2007
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +4 -32
- package/bundles/core.umd.min.js.map +1 -1
- package/core.metadata.json +1 -1
- package/esm2015/core.externs.js +3 -3
- package/esm2015/src/application_init.js +2 -9
- package/esm2015/src/application_module.js +1 -10
- package/esm2015/src/application_ref.js +15 -30
- package/esm2015/src/change_detection/change_detector_ref.js +7 -5
- package/esm2015/src/change_detection/differs/iterable_differs.js +4 -3
- package/esm2015/src/change_detection/differs/keyvalue_differs.js +4 -3
- package/esm2015/src/change_detection/pipe_transform.js +3 -6
- package/esm2015/src/console.js +0 -11
- package/esm2015/src/di/forward_ref.js +8 -6
- package/esm2015/src/di/injectable.js +1 -4
- package/esm2015/src/di/injection_token.js +6 -8
- package/esm2015/src/di/injector.js +5 -10
- package/esm2015/src/di/metadata.js +1 -16
- package/esm2015/src/di/provider.js +47 -138
- package/esm2015/src/di/reflective_errors.js +14 -7
- package/esm2015/src/di/reflective_injector.js +22 -24
- package/esm2015/src/di/reflective_provider.js +11 -12
- package/esm2015/src/error_handler.js +2 -5
- package/esm2015/src/event_emitter.js +6 -3
- package/esm2015/src/i18n/tokens.js +7 -4
- package/esm2015/src/linker/compiler.js +1 -12
- package/esm2015/src/linker/query_list.js +4 -4
- package/esm2015/src/linker/system_js_ng_module_factory_loader.js +3 -10
- package/esm2015/src/linker/view_ref.js +10 -7
- package/esm2015/src/metadata/di.js +10 -16
- package/esm2015/src/metadata/directives.js +111 -33
- package/esm2015/src/metadata/lifecycle_hooks.js +9 -9
- package/esm2015/src/metadata/ng_module.js +19 -11
- package/esm2015/src/render3/node_manipulation.js +2 -3
- package/esm2015/src/render3/view_ref.js +7 -3
- package/esm2015/src/testability/testability.js +2 -16
- package/esm2015/src/version.js +1 -1
- package/esm2015/src/view/ng_module.js +4 -1
- package/esm2015/src/zone/ng_zone.js +2 -1
- package/esm2015/testing/src/fake_async.js +5 -3
- package/esm2015/testing/src/fake_async_fallback.js +5 -3
- package/esm2015/testing/src/logger.js +0 -7
- package/esm2015/testing/src/metadata_override.js +1 -1
- package/esm2015/testing/src/ng_zone_mock.js +0 -7
- package/esm2015/testing/src/test_bed.js +1 -34
- package/esm2015/testing/src/test_compiler.js +1 -12
- package/esm5/index.js +5 -1
- package/esm5/public_api.js +6 -1
- package/esm5/src/application_init.js +3 -5
- package/esm5/src/application_module.js +2 -2
- package/esm5/src/application_ref.js +35 -211
- package/esm5/src/application_tokens.js +1 -1
- package/esm5/src/change_detection/change_detection.js +1 -1
- package/esm5/src/change_detection/change_detection_util.js +7 -72
- package/esm5/src/change_detection/change_detector_ref.js +1 -1
- package/esm5/src/change_detection/constants.js +1 -24
- package/esm5/src/change_detection/differs/default_iterable_differ.js +26 -209
- package/esm5/src/change_detection/differs/default_keyvalue_differ.js +7 -38
- package/esm5/src/change_detection/differs/iterable_differs.js +5 -42
- package/esm5/src/change_detection/differs/keyvalue_differs.js +6 -51
- package/esm5/src/change_detection/pipe_transform.js +1 -1
- package/esm5/src/change_detection.js +6 -1
- package/esm5/src/codegen_private_exports.js +1 -1
- package/esm5/src/console.js +2 -7
- package/esm5/src/core.js +6 -1
- package/esm5/src/core_private_export.js +1 -1
- package/esm5/src/core_render3_private_export.js +2 -1
- package/esm5/src/debug/debug_node.js +3 -15
- package/esm5/src/di/defs.js +1 -1
- package/esm5/src/di/forward_ref.js +7 -6
- package/esm5/src/di/injectable.js +2 -3
- package/esm5/src/di/injection_token.js +5 -83
- package/esm5/src/di/injector.js +13 -27
- package/esm5/src/di/metadata.js +1 -6
- package/esm5/src/di/provider.js +1 -1
- package/esm5/src/di/r3_injector.js +13 -39
- package/esm5/src/di/reflective_errors.js +14 -7
- package/esm5/src/di/reflective_injector.js +19 -265
- package/esm5/src/di/reflective_key.js +4 -45
- package/esm5/src/di/reflective_provider.js +17 -35
- package/esm5/src/di/scope.js +1 -1
- package/esm5/src/di.js +6 -1
- package/esm5/src/error_handler.js +7 -66
- package/esm5/src/errors.js +1 -1
- package/esm5/src/event_emitter.js +4 -95
- package/esm5/src/i18n/tokens.js +9 -49
- package/esm5/src/linker/compiler.js +9 -69
- package/esm5/src/linker/component_factory.js +2 -18
- package/esm5/src/linker/component_factory_resolver.js +1 -1
- package/esm5/src/linker/element_ref.js +2 -32
- package/esm5/src/linker/ng_module_factory.js +3 -25
- package/esm5/src/linker/ng_module_factory_loader.js +2 -10
- package/esm5/src/linker/query_list.js +12 -112
- package/esm5/src/linker/system_js_ng_module_factory_loader.js +4 -16
- package/esm5/src/linker/template_ref.js +2 -26
- package/esm5/src/linker/view_container_ref.js +2 -38
- package/esm5/src/linker/view_ref.js +10 -115
- package/esm5/src/linker.js +2 -1
- package/esm5/src/metadata/di.js +7 -25
- package/esm5/src/metadata/directives.js +111 -20
- package/esm5/src/metadata/lifecycle_hooks.js +1 -1
- package/esm5/src/metadata/ng_module.js +14 -9
- package/esm5/src/metadata/view.js +1 -20
- package/esm5/src/metadata.js +1 -1
- package/esm5/src/platform_core_providers.js +1 -1
- package/esm5/src/profile/profile.js +1 -1
- package/esm5/src/profile/wtf_impl.js +1 -1
- package/esm5/src/reflection/platform_reflection_capabilities.js +1 -1
- package/esm5/src/reflection/reflection.js +1 -1
- package/esm5/src/reflection/reflection_capabilities.js +3 -8
- package/esm5/src/reflection/reflector.js +2 -10
- package/esm5/src/reflection/types.js +1 -1
- package/esm5/src/render/api.js +7 -71
- package/esm5/src/render.js +2 -1
- package/esm5/src/render3/assert.js +1 -1
- package/esm5/src/render3/component.js +6 -5
- package/esm5/src/render3/definition.js +6 -8
- package/esm5/src/render3/di.js +9 -14
- package/esm5/src/render3/errors.js +1 -1
- package/esm5/src/render3/hooks.js +2 -2
- package/esm5/src/render3/index.js +11 -1
- package/esm5/src/render3/instructions.js +52 -38
- package/esm5/src/render3/interfaces/container.js +1 -1
- package/esm5/src/render3/interfaces/definition.js +1 -1
- package/esm5/src/render3/interfaces/injector.js +1 -1
- package/esm5/src/render3/interfaces/node.js +1 -1
- package/esm5/src/render3/interfaces/projection.js +1 -1
- package/esm5/src/render3/interfaces/query.js +1 -1
- package/esm5/src/render3/interfaces/renderer.js +1 -3
- package/esm5/src/render3/interfaces/view.js +1 -1
- package/esm5/src/render3/ng_dev_mode.js +1 -1
- package/esm5/src/render3/node_assert.js +1 -1
- package/esm5/src/render3/node_manipulation.js +12 -15
- package/esm5/src/render3/node_selector_matcher.js +2 -2
- package/esm5/src/render3/pipe.js +1 -1
- package/esm5/src/render3/pure_function.js +1 -1
- package/esm5/src/render3/query.js +11 -59
- package/esm5/src/render3/util.js +1 -1
- package/esm5/src/render3/view_ref.js +15 -345
- package/esm5/src/sanitization/html_sanitizer.js +8 -12
- package/esm5/src/sanitization/inert_body.js +8 -72
- package/esm5/src/sanitization/sanitization.js +1 -1
- package/esm5/src/sanitization/security.js +2 -37
- package/esm5/src/sanitization/style_sanitizer.js +1 -1
- package/esm5/src/sanitization/url_sanitizer.js +1 -1
- package/esm5/src/testability/testability.js +21 -143
- package/esm5/src/type.js +1 -1
- package/esm5/src/util/decorators.js +1 -1
- package/esm5/src/util/lang.js +1 -1
- package/esm5/src/util/property.js +1 -1
- package/esm5/src/util.js +6 -1
- package/esm5/src/version.js +3 -13
- package/esm5/src/view/element.js +7 -7
- package/esm5/src/view/entrypoint.js +1 -1
- package/esm5/src/view/errors.js +1 -1
- package/esm5/src/view/index.js +1 -1
- package/esm5/src/view/ng_content.js +1 -1
- package/esm5/src/view/ng_module.js +4 -1
- package/esm5/src/view/provider.js +12 -12
- package/esm5/src/view/pure_expression.js +1 -1
- package/esm5/src/view/query.js +6 -6
- package/esm5/src/view/refs.js +8 -14
- package/esm5/src/view/services.js +16 -20
- package/esm5/src/view/text.js +1 -1
- package/esm5/src/view/types.js +19 -41
- package/esm5/src/view/util.js +5 -5
- package/esm5/src/view/view.js +4 -6
- package/esm5/src/view/view_attach.js +5 -5
- package/esm5/src/zone/ng_zone.js +22 -257
- package/esm5/src/zone.js +2 -1
- package/esm5/testing/index.js +5 -1
- package/esm5/testing/public_api.js +6 -1
- package/esm5/testing/src/async.js +1 -1
- package/esm5/testing/src/async_fallback.js +1 -1
- package/esm5/testing/src/async_test_completer.js +2 -8
- package/esm5/testing/src/before_each.js +6 -1
- package/esm5/testing/src/component_fixture.js +9 -75
- package/esm5/testing/src/fake_async.js +12 -3
- package/esm5/testing/src/fake_async_fallback.js +5 -3
- package/esm5/testing/src/lang_utils.js +1 -1
- package/esm5/testing/src/logger.js +1 -1
- package/esm5/testing/src/metadata_override.js +1 -1
- package/esm5/testing/src/ng_zone_mock.js +1 -1
- package/esm5/testing/src/private_export_testing.js +1 -1
- package/esm5/testing/src/render3.js +1 -5
- package/esm5/testing/src/test_bed.js +20 -172
- package/esm5/testing/src/test_compiler.js +5 -43
- package/esm5/testing/src/testing.js +6 -1
- package/esm5/testing/src/testing_internal.js +3 -9
- package/fesm2015/core.js +248 -177
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +9 -13
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +591 -2007
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +61 -237
- package/fesm5/testing.js.map +1 -1
- package/package.json +1 -1
- package/src/application_ref.d.ts +7 -8
- package/src/change_detection/change_detector_ref.d.ts +6 -4
- package/src/change_detection/differs/iterable_differs.d.ts +3 -2
- package/src/change_detection/differs/keyvalue_differs.d.ts +3 -2
- package/src/change_detection/pipe_transform.d.ts +2 -5
- package/src/di/forward_ref.d.ts +7 -5
- package/src/di/injectable.d.ts +4 -14
- package/src/di/injection_token.d.ts +5 -7
- package/src/di/injector.d.ts +7 -10
- package/src/di/metadata.d.ts +13 -86
- package/src/di/provider.d.ts +55 -150
- package/src/di/reflective_errors.d.ts +13 -6
- package/src/di/reflective_injector.d.ts +21 -23
- package/src/di/reflective_provider.d.ts +7 -8
- package/src/error_handler.d.ts +1 -4
- package/src/event_emitter.d.ts +3 -0
- package/src/i18n/tokens.d.ts +8 -4
- package/src/linker/query_list.d.ts +2 -2
- package/src/linker/view_ref.d.ts +9 -6
- package/src/metadata/di.d.ts +41 -59
- package/src/metadata/directives.d.ts +410 -460
- package/src/metadata/lifecycle_hooks.d.ts +8 -8
- package/src/metadata/ng_module.d.ts +49 -38
- package/src/render3/view_ref.d.ts +6 -2
- package/src/zone/ng_zone.d.ts +1 -0
- package/testing/src/fake_async.d.ts +4 -2
- package/testing/src/fake_async_fallback.d.ts +4 -2
- package/testing/src/metadata_override.d.ts +3 -3
- package/testing.d.ts +0 -5
- package/testing.metadata.json +1 -1
|
@@ -10,17 +10,11 @@
|
|
|
10
10
|
* found in the LICENSE file at https://angular.io/license
|
|
11
11
|
*/
|
|
12
12
|
/**
|
|
13
|
-
* \@usageNotes
|
|
14
|
-
* ```
|
|
15
|
-
* \@Injectable(SomeModule, {useValue: 'someValue'})
|
|
16
|
-
* class SomeClass {}
|
|
17
|
-
* ```
|
|
18
|
-
*
|
|
19
|
-
* \@description
|
|
20
13
|
* Configures the `Injector` to return a value for a token.
|
|
21
14
|
*
|
|
22
|
-
* For more details, see the
|
|
15
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
23
16
|
*
|
|
17
|
+
* \@usageNotes
|
|
24
18
|
* ### Example
|
|
25
19
|
*
|
|
26
20
|
* {\@example core/di/ts/provider_spec.ts region='ValueSansProvider'}
|
|
@@ -37,21 +31,18 @@ function ValueSansProvider_tsickle_Closure_declarations() {
|
|
|
37
31
|
ValueSansProvider.prototype.useValue;
|
|
38
32
|
}
|
|
39
33
|
/**
|
|
40
|
-
* \@usageNotes
|
|
41
|
-
* ```
|
|
42
|
-
* const provider: ValueProvider = {provide: 'someToken', useValue: 'someValue'};
|
|
43
|
-
* ```
|
|
44
|
-
*
|
|
45
|
-
* \@description
|
|
46
34
|
* Configures the `Injector` to return a value for a token.
|
|
47
35
|
*
|
|
48
|
-
* For more details, see the
|
|
36
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
49
37
|
*
|
|
38
|
+
* \@usageNotes
|
|
50
39
|
* ### Example
|
|
51
40
|
*
|
|
52
41
|
* {\@example core/di/ts/provider_spec.ts region='ValueProvider'}
|
|
53
42
|
*
|
|
43
|
+
* ### Multi-value example
|
|
54
44
|
*
|
|
45
|
+
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
55
46
|
* @record
|
|
56
47
|
*/
|
|
57
48
|
export function ValueProvider() { }
|
|
@@ -64,26 +55,16 @@ function ValueProvider_tsickle_Closure_declarations() {
|
|
|
64
55
|
/**
|
|
65
56
|
* If true, then injector returns an array of instances. This is useful to allow multiple
|
|
66
57
|
* providers spread across many files to provide configuration information to a common token.
|
|
67
|
-
*
|
|
68
|
-
* ### Example
|
|
69
|
-
*
|
|
70
|
-
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
71
58
|
* @type {?|undefined}
|
|
72
59
|
*/
|
|
73
60
|
ValueProvider.prototype.multi;
|
|
74
61
|
}
|
|
75
62
|
/**
|
|
76
|
-
* \@usageNotes
|
|
77
|
-
* ```
|
|
78
|
-
* \@Injectable(SomeModule, {useClass: MyService, deps: []})
|
|
79
|
-
* class MyService {}
|
|
80
|
-
* ```
|
|
81
|
-
*
|
|
82
|
-
* \@description
|
|
83
63
|
* Configures the `Injector` to return an instance of `useClass` for a token.
|
|
84
64
|
*
|
|
85
|
-
* For more details, see the
|
|
65
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
86
66
|
*
|
|
67
|
+
* \@usageNotes
|
|
87
68
|
* ### Example
|
|
88
69
|
*
|
|
89
70
|
* {\@example core/di/ts/provider_spec.ts region='StaticClassSansProvider'}
|
|
@@ -107,27 +88,22 @@ function StaticClassSansProvider_tsickle_Closure_declarations() {
|
|
|
107
88
|
StaticClassSansProvider.prototype.deps;
|
|
108
89
|
}
|
|
109
90
|
/**
|
|
110
|
-
* \@usageNotes
|
|
111
|
-
* ```
|
|
112
|
-
* \@Injectable()
|
|
113
|
-
* class MyService {}
|
|
114
|
-
*
|
|
115
|
-
* const provider: ClassProvider = {provide: 'someToken', useClass: MyService, deps: []};
|
|
116
|
-
* ```
|
|
117
|
-
*
|
|
118
|
-
* \@description
|
|
119
91
|
* Configures the `Injector` to return an instance of `useClass` for a token.
|
|
120
92
|
*
|
|
121
|
-
* For more details, see the
|
|
93
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
122
94
|
*
|
|
95
|
+
* \@usageNotes
|
|
123
96
|
* ### Example
|
|
124
97
|
*
|
|
125
98
|
* {\@example core/di/ts/provider_spec.ts region='StaticClassProvider'}
|
|
126
99
|
*
|
|
127
100
|
* Note that following two providers are not equal:
|
|
101
|
+
*
|
|
128
102
|
* {\@example core/di/ts/provider_spec.ts region='StaticClassProviderDifference'}
|
|
129
103
|
*
|
|
104
|
+
* ### Multi-value example
|
|
130
105
|
*
|
|
106
|
+
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
131
107
|
* @record
|
|
132
108
|
*/
|
|
133
109
|
export function StaticClassProvider() { }
|
|
@@ -140,16 +116,18 @@ function StaticClassProvider_tsickle_Closure_declarations() {
|
|
|
140
116
|
/**
|
|
141
117
|
* If true, then injector returns an array of instances. This is useful to allow multiple
|
|
142
118
|
* providers spread across many files to provide configuration information to a common token.
|
|
143
|
-
*
|
|
144
|
-
* ### Example
|
|
145
|
-
*
|
|
146
|
-
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
147
119
|
* @type {?|undefined}
|
|
148
120
|
*/
|
|
149
121
|
StaticClassProvider.prototype.multi;
|
|
150
122
|
}
|
|
151
123
|
/**
|
|
124
|
+
* Configures the `Injector` to return an instance of a token.
|
|
125
|
+
*
|
|
126
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
127
|
+
*
|
|
152
128
|
* \@usageNotes
|
|
129
|
+
* ### Example
|
|
130
|
+
*
|
|
153
131
|
* ```
|
|
154
132
|
* \@Injectable(SomeModule, {deps: []})
|
|
155
133
|
* class MyService {}
|
|
@@ -158,7 +136,7 @@ function StaticClassProvider_tsickle_Closure_declarations() {
|
|
|
158
136
|
* \@description
|
|
159
137
|
* Configures the `Injector` to return an instance of a token.
|
|
160
138
|
*
|
|
161
|
-
* For more details, see the
|
|
139
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
162
140
|
*
|
|
163
141
|
* ### Example
|
|
164
142
|
*
|
|
@@ -177,24 +155,18 @@ function ConstructorSansProvider_tsickle_Closure_declarations() {
|
|
|
177
155
|
ConstructorSansProvider.prototype.deps;
|
|
178
156
|
}
|
|
179
157
|
/**
|
|
180
|
-
* \@usageNotes
|
|
181
|
-
* ```
|
|
182
|
-
* \@Injectable()
|
|
183
|
-
* class MyService {}
|
|
184
|
-
*
|
|
185
|
-
* const provider: ClassProvider = {provide: MyClass, deps: []};
|
|
186
|
-
* ```
|
|
187
|
-
*
|
|
188
|
-
* \@description
|
|
189
158
|
* Configures the `Injector` to return an instance of a token.
|
|
190
159
|
*
|
|
191
|
-
* For more details, see the
|
|
160
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
192
161
|
*
|
|
162
|
+
* \@usageNotes
|
|
193
163
|
* ### Example
|
|
194
164
|
*
|
|
195
165
|
* {\@example core/di/ts/provider_spec.ts region='ConstructorProvider'}
|
|
196
166
|
*
|
|
167
|
+
* ### Multi-value example
|
|
197
168
|
*
|
|
169
|
+
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
198
170
|
* @record
|
|
199
171
|
*/
|
|
200
172
|
export function ConstructorProvider() { }
|
|
@@ -207,31 +179,19 @@ function ConstructorProvider_tsickle_Closure_declarations() {
|
|
|
207
179
|
/**
|
|
208
180
|
* If true, then injector returns an array of instances. This is useful to allow multiple
|
|
209
181
|
* providers spread across many files to provide configuration information to a common token.
|
|
210
|
-
*
|
|
211
|
-
* ### Example
|
|
212
|
-
*
|
|
213
|
-
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
214
182
|
* @type {?|undefined}
|
|
215
183
|
*/
|
|
216
184
|
ConstructorProvider.prototype.multi;
|
|
217
185
|
}
|
|
218
186
|
/**
|
|
219
|
-
* \@usageNotes
|
|
220
|
-
* ```
|
|
221
|
-
* \@Injectable(SomeModule, {useExisting: 'someOtherToken'})
|
|
222
|
-
* class SomeClass {}
|
|
223
|
-
* ```
|
|
224
|
-
*
|
|
225
|
-
* \@description
|
|
226
187
|
* Configures the `Injector` to return a value of another `useExisting` token.
|
|
227
188
|
*
|
|
228
|
-
* For more details, see the
|
|
189
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
229
190
|
*
|
|
191
|
+
* \@usageNotes
|
|
230
192
|
* ### Example
|
|
231
193
|
*
|
|
232
194
|
* {\@example core/di/ts/provider_spec.ts region='ExistingSansProvider'}
|
|
233
|
-
*
|
|
234
|
-
*
|
|
235
195
|
* @record
|
|
236
196
|
*/
|
|
237
197
|
export function ExistingSansProvider() { }
|
|
@@ -243,21 +203,18 @@ function ExistingSansProvider_tsickle_Closure_declarations() {
|
|
|
243
203
|
ExistingSansProvider.prototype.useExisting;
|
|
244
204
|
}
|
|
245
205
|
/**
|
|
246
|
-
* \@usageNotes
|
|
247
|
-
* ```
|
|
248
|
-
* const provider: ExistingProvider = {provide: 'someToken', useExisting: 'someOtherToken'};
|
|
249
|
-
* ```
|
|
250
|
-
*
|
|
251
|
-
* \@description
|
|
252
206
|
* Configures the `Injector` to return a value of another `useExisting` token.
|
|
253
207
|
*
|
|
254
|
-
* For more details, see the
|
|
208
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
255
209
|
*
|
|
210
|
+
* \@usageNotes
|
|
256
211
|
* ### Example
|
|
257
212
|
*
|
|
258
213
|
* {\@example core/di/ts/provider_spec.ts region='ExistingProvider'}
|
|
259
214
|
*
|
|
215
|
+
* ### Multi-value example
|
|
260
216
|
*
|
|
217
|
+
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
261
218
|
* @record
|
|
262
219
|
*/
|
|
263
220
|
export function ExistingProvider() { }
|
|
@@ -270,28 +227,16 @@ function ExistingProvider_tsickle_Closure_declarations() {
|
|
|
270
227
|
/**
|
|
271
228
|
* If true, then injector returns an array of instances. This is useful to allow multiple
|
|
272
229
|
* providers spread across many files to provide configuration information to a common token.
|
|
273
|
-
*
|
|
274
|
-
* ### Example
|
|
275
|
-
*
|
|
276
|
-
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
277
230
|
* @type {?|undefined}
|
|
278
231
|
*/
|
|
279
232
|
ExistingProvider.prototype.multi;
|
|
280
233
|
}
|
|
281
234
|
/**
|
|
282
|
-
* \@usageNotes
|
|
283
|
-
* ```
|
|
284
|
-
* function serviceFactory() { ... }
|
|
285
|
-
*
|
|
286
|
-
* \@Injectable(SomeModule, {useFactory: serviceFactory, deps: []})
|
|
287
|
-
* class SomeClass {}
|
|
288
|
-
* ```
|
|
289
|
-
*
|
|
290
|
-
* \@description
|
|
291
235
|
* Configures the `Injector` to return a value by invoking a `useFactory` function.
|
|
292
236
|
*
|
|
293
|
-
* For more details, see the
|
|
237
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
294
238
|
*
|
|
239
|
+
* \@usageNotes
|
|
295
240
|
* ### Example
|
|
296
241
|
*
|
|
297
242
|
* {\@example core/di/ts/provider_spec.ts region='FactorySansProvider'}
|
|
@@ -315,26 +260,22 @@ function FactorySansProvider_tsickle_Closure_declarations() {
|
|
|
315
260
|
FactorySansProvider.prototype.deps;
|
|
316
261
|
}
|
|
317
262
|
/**
|
|
318
|
-
* \@usageNotes
|
|
319
|
-
* ```
|
|
320
|
-
* function serviceFactory() { ... }
|
|
321
|
-
*
|
|
322
|
-
* const provider: FactoryProvider = {provide: 'someToken', useFactory: serviceFactory, deps: []};
|
|
323
|
-
* ```
|
|
324
|
-
*
|
|
325
|
-
* \@description
|
|
326
263
|
* Configures the `Injector` to return a value by invoking a `useFactory` function.
|
|
327
264
|
*
|
|
328
|
-
* For more details, see the
|
|
265
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
329
266
|
*
|
|
267
|
+
* \@usageNotes
|
|
330
268
|
* ### Example
|
|
331
269
|
*
|
|
332
270
|
* {\@example core/di/ts/provider_spec.ts region='FactoryProvider'}
|
|
333
271
|
*
|
|
334
272
|
* Dependencies can also be marked as optional:
|
|
273
|
+
*
|
|
335
274
|
* {\@example core/di/ts/provider_spec.ts region='FactoryProviderOptionalDeps'}
|
|
336
275
|
*
|
|
276
|
+
* ### Multi-value example
|
|
337
277
|
*
|
|
278
|
+
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
338
279
|
* @record
|
|
339
280
|
*/
|
|
340
281
|
export function FactoryProvider() { }
|
|
@@ -347,56 +288,33 @@ function FactoryProvider_tsickle_Closure_declarations() {
|
|
|
347
288
|
/**
|
|
348
289
|
* If true, then injector returns an array of instances. This is useful to allow multiple
|
|
349
290
|
* providers spread across many files to provide configuration information to a common token.
|
|
350
|
-
*
|
|
351
|
-
* ### Example
|
|
352
|
-
*
|
|
353
|
-
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
354
291
|
* @type {?|undefined}
|
|
355
292
|
*/
|
|
356
293
|
FactoryProvider.prototype.multi;
|
|
357
294
|
}
|
|
358
295
|
/**
|
|
359
|
-
* \@usageNotes
|
|
360
|
-
* ```
|
|
361
|
-
* \@Injectable()
|
|
362
|
-
* class MyService {}
|
|
363
|
-
*
|
|
364
|
-
* const provider: TypeProvider = MyService;
|
|
365
|
-
* ```
|
|
366
|
-
*
|
|
367
|
-
* \@description
|
|
368
296
|
* Configures the `Injector` to return an instance of `Type` when `Type' is used as the token.
|
|
369
297
|
*
|
|
370
298
|
* Create an instance by invoking the `new` operator and supplying additional arguments.
|
|
371
299
|
* This form is a short form of `TypeProvider`;
|
|
372
300
|
*
|
|
373
|
-
* For more details, see the
|
|
301
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
374
302
|
*
|
|
303
|
+
* \@usageNotes
|
|
375
304
|
* ### Example
|
|
376
305
|
*
|
|
377
306
|
* {\@example core/di/ts/provider_spec.ts region='TypeProvider'}
|
|
378
|
-
*
|
|
379
|
-
*
|
|
380
307
|
* @record
|
|
381
308
|
*/
|
|
382
309
|
export function TypeProvider() { }
|
|
383
310
|
function TypeProvider_tsickle_Closure_declarations() {
|
|
384
311
|
}
|
|
385
312
|
/**
|
|
386
|
-
* \@usageNotes
|
|
387
|
-
* ```
|
|
388
|
-
*
|
|
389
|
-
* class SomeClassImpl {}
|
|
390
|
-
*
|
|
391
|
-
* \@Injectable(SomeModule, {useClass: SomeClassImpl})
|
|
392
|
-
* class SomeClass {}
|
|
393
|
-
* ```
|
|
394
|
-
*
|
|
395
|
-
* \@description
|
|
396
313
|
* Configures the `Injector` to return a value by invoking a `useClass` function.
|
|
397
314
|
*
|
|
398
|
-
* For more details, see the
|
|
315
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
399
316
|
*
|
|
317
|
+
* \@usageNotes
|
|
400
318
|
* ### Example
|
|
401
319
|
*
|
|
402
320
|
* {\@example core/di/ts/provider_spec.ts region='ClassSansProvider'}
|
|
@@ -413,27 +331,22 @@ function ClassSansProvider_tsickle_Closure_declarations() {
|
|
|
413
331
|
ClassSansProvider.prototype.useClass;
|
|
414
332
|
}
|
|
415
333
|
/**
|
|
416
|
-
* \@usageNotes
|
|
417
|
-
* ```
|
|
418
|
-
* \@Injectable()
|
|
419
|
-
* class MyService {}
|
|
420
|
-
*
|
|
421
|
-
* const provider: ClassProvider = {provide: 'someToken', useClass: MyService};
|
|
422
|
-
* ```
|
|
423
|
-
*
|
|
424
|
-
* \@description
|
|
425
334
|
* Configures the `Injector` to return an instance of `useClass` for a token.
|
|
426
335
|
*
|
|
427
|
-
* For more details, see the
|
|
336
|
+
* For more details, see the ["Dependency Injection Guide"](guide/dependency-injection).
|
|
428
337
|
*
|
|
338
|
+
* \@usageNotes
|
|
429
339
|
* ### Example
|
|
430
340
|
*
|
|
431
341
|
* {\@example core/di/ts/provider_spec.ts region='ClassProvider'}
|
|
432
342
|
*
|
|
433
343
|
* Note that following two providers are not equal:
|
|
344
|
+
*
|
|
434
345
|
* {\@example core/di/ts/provider_spec.ts region='ClassProviderDifference'}
|
|
435
346
|
*
|
|
347
|
+
* ### Multi-value example
|
|
436
348
|
*
|
|
349
|
+
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
437
350
|
* @record
|
|
438
351
|
*/
|
|
439
352
|
export function ClassProvider() { }
|
|
@@ -446,13 +359,9 @@ function ClassProvider_tsickle_Closure_declarations() {
|
|
|
446
359
|
/**
|
|
447
360
|
* If true, then injector returns an array of instances. This is useful to allow multiple
|
|
448
361
|
* providers spread across many files to provide configuration information to a common token.
|
|
449
|
-
*
|
|
450
|
-
* ### Example
|
|
451
|
-
*
|
|
452
|
-
* {\@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}
|
|
453
362
|
* @type {?|undefined}
|
|
454
363
|
*/
|
|
455
364
|
ClassProvider.prototype.multi;
|
|
456
365
|
}
|
|
457
366
|
|
|
458
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/di/provider.ts"],"names":[],"mappings":"","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 {Type} from '../type';\n\n/**\n * @usageNotes\n * ```\n * @Injectable(SomeModule, {useValue: 'someValue'})\n * class SomeClass {}\n * ```\n *\n * @description\n * Configures the `Injector` to return a value for a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ValueSansProvider'}\n *\n * @experimental\n */\nexport interface ValueSansProvider {\n  /**\n   * The value to inject.\n   */\n  useValue: any;\n}\n\n/**\n * @usageNotes\n * ```\n * const provider: ValueProvider = {provide: 'someToken', useValue: 'someValue'};\n * ```\n *\n * @description\n * Configures the `Injector` to return a value for a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ValueProvider'}\n *\n *\n */\nexport interface ValueProvider extends ValueSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   *\n   * ### Example\n   *\n   * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n   */\n  multi?: boolean;\n}\n\n/**\n * @usageNotes\n * ```\n * @Injectable(SomeModule, {useClass: MyService, deps: []})\n * class MyService {}\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of `useClass` for a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='StaticClassSansProvider'}\n *\n * @experimental\n */\nexport interface StaticClassSansProvider {\n  /**\n   * An optional class to instantiate for the `token`. (If not provided `provide` is assumed to be a\n   * class to instantiate)\n   */\n  useClass: Type<any>;\n\n  /**\n   * A list of `token`s which need to be resolved by the injector. The list of values is then\n   * used as arguments to the `useClass` constructor.\n   */\n  deps: any[];\n}\n\n/**\n * @usageNotes\n * ```\n * @Injectable()\n * class MyService {}\n *\n * const provider: ClassProvider = {provide: 'someToken', useClass: MyService, deps: []};\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of `useClass` for a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='StaticClassProvider'}\n *\n * Note that following two providers are not equal:\n * {@example core/di/ts/provider_spec.ts region='StaticClassProviderDifference'}\n *\n *\n */\nexport interface StaticClassProvider extends StaticClassSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   *\n   * ### Example\n   *\n   * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n   */\n  multi?: boolean;\n}\n\n/**\n * @usageNotes\n * ```\n * @Injectable(SomeModule, {deps: []})\n * class MyService {}\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ConstructorSansProvider'}\n *\n * @experimental\n */\nexport interface ConstructorSansProvider {\n  /**\n   * A list of `token`s which need to be resolved by the injector. The list of values is then\n   * used as arguments to the `useClass` constructor.\n   */\n  deps?: any[];\n}\n\n/**\n * @usageNotes\n * ```\n * @Injectable()\n * class MyService {}\n *\n * const provider: ClassProvider = {provide: MyClass, deps: []};\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ConstructorProvider'}\n *\n *\n */\nexport interface ConstructorProvider extends ConstructorSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: Type<any>;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   *\n   * ### Example\n   *\n   * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n   */\n  multi?: boolean;\n}\n\n/**\n * @usageNotes\n * ```\n * @Injectable(SomeModule, {useExisting: 'someOtherToken'})\n * class SomeClass {}\n * ```\n *\n * @description\n * Configures the `Injector` to return a value of another `useExisting` token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ExistingSansProvider'}\n *\n *\n */\nexport interface ExistingSansProvider {\n  /**\n   * Existing `token` to return. (equivalent to `injector.get(useExisting)`)\n   */\n  useExisting: any;\n}\n\n/**\n * @usageNotes\n * ```\n * const provider: ExistingProvider = {provide: 'someToken', useExisting: 'someOtherToken'};\n * ```\n *\n * @description\n * Configures the `Injector` to return a value of another `useExisting` token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ExistingProvider'}\n *\n *\n */\nexport interface ExistingProvider extends ExistingSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   *\n   * ### Example\n   *\n   * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n   */\n  multi?: boolean;\n}\n\n/**\n * @usageNotes\n * ```\n * function serviceFactory() { ... }\n *\n * @Injectable(SomeModule, {useFactory: serviceFactory, deps: []})\n * class SomeClass {}\n * ```\n *\n * @description\n * Configures the `Injector` to return a value by invoking a `useFactory` function.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='FactorySansProvider'}\n *\n * @experimental\n   */\nexport interface FactorySansProvider {\n  /**\n   * A function to invoke to create a value for this `token`. The function is invoked with\n   * resolved values of `token`s in the `deps` field.\n   */\n  useFactory: Function;\n\n  /**\n   * A list of `token`s which need to be resolved by the injector. The list of values is then\n   * used as arguments to the `useFactory` function.\n   */\n  deps?: any[];\n}\n\n/**\n * @usageNotes\n * ```\n * function serviceFactory() { ... }\n *\n * const provider: FactoryProvider = {provide: 'someToken', useFactory: serviceFactory, deps: []};\n * ```\n *\n * @description\n * Configures the `Injector` to return a value by invoking a `useFactory` function.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='FactoryProvider'}\n *\n * Dependencies can also be marked as optional:\n * {@example core/di/ts/provider_spec.ts region='FactoryProviderOptionalDeps'}\n *\n *\n */\nexport interface FactoryProvider extends FactorySansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   *\n   * ### Example\n   *\n   * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n   */\n  multi?: boolean;\n}\n\n/**\n * @usageNotes\n * See {@link ValueProvider}, {@link ExistingProvider}, {@link FactoryProvider}.\n *\n * @description\n * Describes how the `Injector` should be configured in a static way (Without reflection).\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n *\n */\nexport type StaticProvider = ValueProvider | ExistingProvider | StaticClassProvider |\n    ConstructorProvider | FactoryProvider | any[];\n\n\n/**\n * @usageNotes\n * ```\n * @Injectable()\n * class MyService {}\n *\n * const provider: TypeProvider = MyService;\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of `Type` when `Type' is used as the token.\n *\n * Create an instance by invoking the `new` operator and supplying additional arguments.\n * This form is a short form of `TypeProvider`;\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='TypeProvider'}\n *\n *\n */\nexport interface TypeProvider extends Type<any> {}\n\n/**\n * @usageNotes\n * ```\n *\n * class SomeClassImpl {}\n *\n * @Injectable(SomeModule, {useClass: SomeClassImpl})\n * class SomeClass {}\n * ```\n *\n * @description\n * Configures the `Injector` to return a value by invoking a `useClass` function.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ClassSansProvider'}\n *\n * @experimental\n */\nexport interface ClassSansProvider {\n  /**\n   * Class to instantiate for the `token`.\n   */\n  useClass: Type<any>;\n}\n\n/**\n * @usageNotes\n * ```\n * @Injectable()\n * class MyService {}\n *\n * const provider: ClassProvider = {provide: 'someToken', useClass: MyService};\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of `useClass` for a token.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ClassProvider'}\n *\n * Note that following two providers are not equal:\n * {@example core/di/ts/provider_spec.ts region='ClassProviderDifference'}\n *\n *\n */\nexport interface ClassProvider extends ClassSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   *\n   * ### Example\n   *\n   * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n   */\n  multi?: boolean;\n}\n\n/**\n * @usageNotes\n * See {@link TypeProvider}, {@link ClassProvider}, {@link StaticProvider}.\n *\n * @description\n * Describes how the `Injector` should be configured.\n *\n * For more details, see the {@linkDocs guide/dependency-injection \"Dependency Injection Guide\"}.\n *\n *\n */\nexport type Provider =\n    TypeProvider | ValueProvider | ClassProvider | ExistingProvider | FactoryProvider | any[];\n"]}
|
|
367
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/di/provider.ts"],"names":[],"mappings":"","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 {Type} from '../type';\n\n/**\n * Configures the `Injector` to return a value for a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ValueSansProvider'}\n *\n * @experimental\n */\nexport interface ValueSansProvider {\n  /**\n   * The value to inject.\n   */\n  useValue: any;\n}\n\n/**\n * Configures the `Injector` to return a value for a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ValueProvider'}\n *\n * ### Multi-value example\n *\n * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n */\nexport interface ValueProvider extends ValueSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   */\n  multi?: boolean;\n}\n\n/**\n * Configures the `Injector` to return an instance of `useClass` for a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='StaticClassSansProvider'}\n *\n * @experimental\n */\nexport interface StaticClassSansProvider {\n  /**\n   * An optional class to instantiate for the `token`. (If not provided `provide` is assumed to be a\n   * class to instantiate)\n   */\n  useClass: Type<any>;\n\n  /**\n   * A list of `token`s which need to be resolved by the injector. The list of values is then\n   * used as arguments to the `useClass` constructor.\n   */\n  deps: any[];\n}\n\n/**\n * Configures the `Injector` to return an instance of `useClass` for a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='StaticClassProvider'}\n *\n * Note that following two providers are not equal:\n *\n * {@example core/di/ts/provider_spec.ts region='StaticClassProviderDifference'}\n *\n * ### Multi-value example\n *\n * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n */\nexport interface StaticClassProvider extends StaticClassSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   */\n  multi?: boolean;\n}\n\n/**\n * Configures the `Injector` to return an instance of a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * ```\n * @Injectable(SomeModule, {deps: []})\n * class MyService {}\n * ```\n *\n * @description\n * Configures the `Injector` to return an instance of a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ConstructorSansProvider'}\n *\n * @experimental\n */\nexport interface ConstructorSansProvider {\n  /**\n   * A list of `token`s which need to be resolved by the injector. The list of values is then\n   * used as arguments to the `useClass` constructor.\n   */\n  deps?: any[];\n}\n\n/**\n * Configures the `Injector` to return an instance of a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ConstructorProvider'}\n *\n * ### Multi-value example\n *\n * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n */\nexport interface ConstructorProvider extends ConstructorSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: Type<any>;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   */\n  multi?: boolean;\n}\n\n/**\n * Configures the `Injector` to return a value of another `useExisting` token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ExistingSansProvider'}\n */\nexport interface ExistingSansProvider {\n  /**\n   * Existing `token` to return. (equivalent to `injector.get(useExisting)`)\n   */\n  useExisting: any;\n}\n\n/**\n * Configures the `Injector` to return a value of another `useExisting` token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ExistingProvider'}\n *\n * ### Multi-value example\n *\n * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n */\nexport interface ExistingProvider extends ExistingSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   */\n  multi?: boolean;\n}\n\n/**\n * Configures the `Injector` to return a value by invoking a `useFactory` function.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='FactorySansProvider'}\n *\n * @experimental\n */\nexport interface FactorySansProvider {\n  /**\n   * A function to invoke to create a value for this `token`. The function is invoked with\n   * resolved values of `token`s in the `deps` field.\n   */\n  useFactory: Function;\n\n  /**\n   * A list of `token`s which need to be resolved by the injector. The list of values is then\n   * used as arguments to the `useFactory` function.\n   */\n  deps?: any[];\n}\n\n/**\n * Configures the `Injector` to return a value by invoking a `useFactory` function.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='FactoryProvider'}\n *\n * Dependencies can also be marked as optional:\n *\n * {@example core/di/ts/provider_spec.ts region='FactoryProviderOptionalDeps'}\n *\n * ### Multi-value example\n *\n * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n */\nexport interface FactoryProvider extends FactorySansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   */\n  multi?: boolean;\n}\n\n/**\n * Describes how the `Injector` should be configured in a static way (Without reflection).\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @see `ValueProvider`\n * @see `ExistingProvider`\n * @see `FactoryProvider`\n */\nexport type StaticProvider = ValueProvider | ExistingProvider | StaticClassProvider |\n    ConstructorProvider | FactoryProvider | any[];\n\n\n/**\n * Configures the `Injector` to return an instance of `Type` when `Type' is used as the token.\n *\n * Create an instance by invoking the `new` operator and supplying additional arguments.\n * This form is a short form of `TypeProvider`;\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='TypeProvider'}\n */\nexport interface TypeProvider extends Type<any> {}\n\n/**\n * Configures the `Injector` to return a value by invoking a `useClass` function.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ClassSansProvider'}\n *\n * @experimental\n */\nexport interface ClassSansProvider {\n  /**\n   * Class to instantiate for the `token`.\n   */\n  useClass: Type<any>;\n}\n\n/**\n * Configures the `Injector` to return an instance of `useClass` for a token.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/provider_spec.ts region='ClassProvider'}\n *\n * Note that following two providers are not equal:\n *\n * {@example core/di/ts/provider_spec.ts region='ClassProviderDifference'}\n *\n * ### Multi-value example\n *\n * {@example core/di/ts/provider_spec.ts region='MultiProviderAspect'}\n */\nexport interface ClassProvider extends ClassSansProvider {\n  /**\n   * An injection token. (Typically an instance of `Type` or `InjectionToken`, but can be `any`).\n   */\n  provide: any;\n\n  /**\n   * If true, then injector returns an array of instances. This is useful to allow multiple\n   * providers spread across many files to provide configuration information to a common token.\n   */\n  multi?: boolean;\n}\n\n/**\n * Describes how the `Injector` should be configured.\n *\n * For more details, see the [\"Dependency Injection Guide\"](guide/dependency-injection).\n *\n * @see `TypeProvider`\n * @see `ClassProvider`\n * @see `StaticProvider`\n */\nexport type Provider =\n    TypeProvider | ValueProvider | ClassProvider | ExistingProvider | FactoryProvider | any[];\n"]}
|
|
@@ -87,7 +87,8 @@ function addKey(injector, key) {
|
|
|
87
87
|
* Thrown when trying to retrieve a dependency by key from {\@link Injector}, but the
|
|
88
88
|
* {\@link Injector} does not have a {\@link Provider} for the given key.
|
|
89
89
|
*
|
|
90
|
-
*
|
|
90
|
+
* \@usageNotes
|
|
91
|
+
* ### Example
|
|
91
92
|
*
|
|
92
93
|
* ```typescript
|
|
93
94
|
* class A {
|
|
@@ -109,7 +110,8 @@ export function noProviderError(injector, key) {
|
|
|
109
110
|
/**
|
|
110
111
|
* Thrown when dependencies form a cycle.
|
|
111
112
|
*
|
|
112
|
-
*
|
|
113
|
+
* \@usageNotes
|
|
114
|
+
* ### Example
|
|
113
115
|
*
|
|
114
116
|
* ```typescript
|
|
115
117
|
* var injector = Injector.resolveAndCreate([
|
|
@@ -136,7 +138,8 @@ export function cyclicDependencyError(injector, key) {
|
|
|
136
138
|
* The `InstantiationError` class contains the original error plus the dependency graph which caused
|
|
137
139
|
* this object to be instantiated.
|
|
138
140
|
*
|
|
139
|
-
*
|
|
141
|
+
* \@usageNotes
|
|
142
|
+
* ### Example
|
|
140
143
|
*
|
|
141
144
|
* ```typescript
|
|
142
145
|
* class A {
|
|
@@ -170,7 +173,8 @@ export function instantiationError(injector, originalException, originalStack, k
|
|
|
170
173
|
* Thrown when an object other then {\@link Provider} (or `Type`) is passed to {\@link Injector}
|
|
171
174
|
* creation.
|
|
172
175
|
*
|
|
173
|
-
*
|
|
176
|
+
* \@usageNotes
|
|
177
|
+
* ### Example
|
|
174
178
|
*
|
|
175
179
|
* ```typescript
|
|
176
180
|
* expect(() => Injector.resolveAndCreate(["not a type"])).toThrowError();
|
|
@@ -187,7 +191,8 @@ export function invalidProviderError(provider) {
|
|
|
187
191
|
* Lack of annotation information prevents the {\@link Injector} from determining which dependencies
|
|
188
192
|
* need to be injected into the constructor.
|
|
189
193
|
*
|
|
190
|
-
*
|
|
194
|
+
* \@usageNotes
|
|
195
|
+
* ### Example
|
|
191
196
|
*
|
|
192
197
|
* ```typescript
|
|
193
198
|
* class A {
|
|
@@ -232,7 +237,8 @@ export function noAnnotationError(typeOrFunc, params) {
|
|
|
232
237
|
/**
|
|
233
238
|
* Thrown when getting an object by index.
|
|
234
239
|
*
|
|
235
|
-
*
|
|
240
|
+
* \@usageNotes
|
|
241
|
+
* ### Example
|
|
236
242
|
*
|
|
237
243
|
* ```typescript
|
|
238
244
|
* class A {}
|
|
@@ -251,6 +257,7 @@ export function outOfBoundsError(index) {
|
|
|
251
257
|
/**
|
|
252
258
|
* Thrown when a multi provider and a regular provider are bound to the same token.
|
|
253
259
|
*
|
|
260
|
+
* \@usageNotes
|
|
254
261
|
* ### Example
|
|
255
262
|
*
|
|
256
263
|
* ```typescript
|
|
@@ -267,4 +274,4 @@ export function mixingMultiProvidersWithRegularProvidersError(provider1, provide
|
|
|
267
274
|
return Error(`Cannot mix multi providers and regular providers, got: ${provider1} ${provider2}`);
|
|
268
275
|
}
|
|
269
276
|
|
|
270
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reflective_errors.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/di/reflective_errors.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 {wrappedError} from '../error_handler';\nimport {ERROR_ORIGINAL_ERROR, getOriginalError} from '../errors';\nimport {Type} from '../type';\nimport {stringify} from '../util';\n\nimport {ReflectiveInjector} from './reflective_injector';\nimport {ReflectiveKey} from './reflective_key';\n\nfunction findFirstClosedCycle(keys: any[]): any[] {\n  const res: any[] = [];\n  for (let i = 0; i < keys.length; ++i) {\n    if (res.indexOf(keys[i]) > -1) {\n      res.push(keys[i]);\n      return res;\n    }\n    res.push(keys[i]);\n  }\n  return res;\n}\n\nfunction constructResolvingPath(keys: any[]): string {\n  if (keys.length > 1) {\n    const reversed = findFirstClosedCycle(keys.slice().reverse());\n    const tokenStrs = reversed.map(k => stringify(k.token));\n    return ' (' + tokenStrs.join(' -> ') + ')';\n  }\n\n  return '';\n}\n\nexport interface InjectionError extends Error {\n  keys: ReflectiveKey[];\n  injectors: ReflectiveInjector[];\n  constructResolvingMessage: (keys: ReflectiveKey[]) => string;\n  addKey(injector: ReflectiveInjector, key: ReflectiveKey): void;\n}\n\nfunction injectionError(\n    injector: ReflectiveInjector, key: ReflectiveKey,\n    constructResolvingMessage: (keys: ReflectiveKey[]) => string,\n    originalError?: Error): InjectionError {\n  const keys = [key];\n  const errMsg = constructResolvingMessage(keys);\n  const error =\n      (originalError ? wrappedError(errMsg, originalError) : Error(errMsg)) as InjectionError;\n  error.addKey = addKey;\n  error.keys = keys;\n  error.injectors = [injector];\n  error.constructResolvingMessage = constructResolvingMessage;\n  (error as any)[ERROR_ORIGINAL_ERROR] = originalError;\n  return error;\n}\n\nfunction addKey(this: InjectionError, injector: ReflectiveInjector, key: ReflectiveKey): void {\n  this.injectors.push(injector);\n  this.keys.push(key);\n  // Note: This updated message won't be reflected in the `.stack` property\n  this.message = this.constructResolvingMessage(this.keys);\n}\n\n/**\n * Thrown when trying to retrieve a dependency by key from {@link Injector}, but the\n * {@link Injector} does not have a {@link Provider} for the given key.\n *\n * ### Example ([live demo](http://plnkr.co/edit/vq8D3FRB9aGbnWJqtEPE?p=preview))\n *\n * ```typescript\n * class A {\n *   constructor(b:B) {}\n * }\n *\n * expect(() => Injector.resolveAndCreate([A])).toThrowError();\n * ```\n */\nexport function noProviderError(injector: ReflectiveInjector, key: ReflectiveKey): InjectionError {\n  return injectionError(injector, key, function(keys: ReflectiveKey[]) {\n    const first = stringify(keys[0].token);\n    return `No provider for ${first}!${constructResolvingPath(keys)}`;\n  });\n}\n\n/**\n * Thrown when dependencies form a cycle.\n *\n * ### Example ([live demo](http://plnkr.co/edit/wYQdNos0Tzql3ei1EV9j?p=info))\n *\n * ```typescript\n * var injector = Injector.resolveAndCreate([\n *   {provide: \"one\", useFactory: (two) => \"two\", deps: [[new Inject(\"two\")]]},\n *   {provide: \"two\", useFactory: (one) => \"one\", deps: [[new Inject(\"one\")]]}\n * ]);\n *\n * expect(() => injector.get(\"one\")).toThrowError();\n * ```\n *\n * Retrieving `A` or `B` throws a `CyclicDependencyError` as the graph above cannot be constructed.\n */\nexport function cyclicDependencyError(\n    injector: ReflectiveInjector, key: ReflectiveKey): InjectionError {\n  return injectionError(injector, key, function(keys: ReflectiveKey[]) {\n    return `Cannot instantiate cyclic dependency!${constructResolvingPath(keys)}`;\n  });\n}\n\n/**\n * Thrown when a constructing type returns with an Error.\n *\n * The `InstantiationError` class contains the original error plus the dependency graph which caused\n * this object to be instantiated.\n *\n * ### Example ([live demo](http://plnkr.co/edit/7aWYdcqTQsP0eNqEdUAf?p=preview))\n *\n * ```typescript\n * class A {\n *   constructor() {\n *     throw new Error('message');\n *   }\n * }\n *\n * var injector = Injector.resolveAndCreate([A]);\n\n * try {\n *   injector.get(A);\n * } catch (e) {\n *   expect(e instanceof InstantiationError).toBe(true);\n *   expect(e.originalException.message).toEqual(\"message\");\n *   expect(e.originalStack).toBeDefined();\n * }\n * ```\n */\nexport function instantiationError(\n    injector: ReflectiveInjector, originalException: any, originalStack: any,\n    key: ReflectiveKey): InjectionError {\n  return injectionError(injector, key, function(keys: ReflectiveKey[]) {\n    const first = stringify(keys[0].token);\n    return `${originalException.message}: Error during instantiation of ${first}!${constructResolvingPath(keys)}.`;\n  }, originalException);\n}\n\n/**\n * Thrown when an object other then {@link Provider} (or `Type`) is passed to {@link Injector}\n * creation.\n *\n * ### Example ([live demo](http://plnkr.co/edit/YatCFbPAMCL0JSSQ4mvH?p=preview))\n *\n * ```typescript\n * expect(() => Injector.resolveAndCreate([\"not a type\"])).toThrowError();\n * ```\n */\nexport function invalidProviderError(provider: any) {\n  return Error(\n      `Invalid provider - only instances of Provider and Type are allowed, got: ${provider}`);\n}\n\n/**\n * Thrown when the class has no annotation information.\n *\n * Lack of annotation information prevents the {@link Injector} from determining which dependencies\n * need to be injected into the constructor.\n *\n * ### Example ([live demo](http://plnkr.co/edit/rHnZtlNS7vJOPQ6pcVkm?p=preview))\n *\n * ```typescript\n * class A {\n *   constructor(b) {}\n * }\n *\n * expect(() => Injector.resolveAndCreate([A])).toThrowError();\n * ```\n *\n * This error is also thrown when the class not marked with {@link Injectable} has parameter types.\n *\n * ```typescript\n * class B {}\n *\n * class A {\n *   constructor(b:B) {} // no information about the parameter types of A is available at runtime.\n * }\n *\n * expect(() => Injector.resolveAndCreate([A,B])).toThrowError();\n * ```\n *\n */\nexport function noAnnotationError(typeOrFunc: Type<any>| Function, params: any[][]): Error {\n  const signature: string[] = [];\n  for (let i = 0, ii = params.length; i < ii; i++) {\n    const parameter = params[i];\n    if (!parameter || parameter.length == 0) {\n      signature.push('?');\n    } else {\n      signature.push(parameter.map(stringify).join(' '));\n    }\n  }\n  return Error(\n      'Cannot resolve all parameters for \\'' + stringify(typeOrFunc) + '\\'(' +\n      signature.join(', ') + '). ' +\n      'Make sure that all the parameters are decorated with Inject or have valid type annotations and that \\'' +\n      stringify(typeOrFunc) + '\\' is decorated with Injectable.');\n}\n\n/**\n * Thrown when getting an object by index.\n *\n * ### Example ([live demo](http://plnkr.co/edit/bRs0SX2OTQiJzqvjgl8P?p=preview))\n *\n * ```typescript\n * class A {}\n *\n * var injector = Injector.resolveAndCreate([A]);\n *\n * expect(() => injector.getAt(100)).toThrowError();\n * ```\n *\n */\nexport function outOfBoundsError(index: number) {\n  return Error(`Index ${index} is out-of-bounds.`);\n}\n\n// TODO: add a working example after alpha38 is released\n/**\n * Thrown when a multi provider and a regular provider are bound to the same token.\n *\n * ### Example\n *\n * ```typescript\n * expect(() => Injector.resolveAndCreate([\n *   { provide: \"Strings\", useValue: \"string1\", multi: true},\n *   { provide: \"Strings\", useValue: \"string2\", multi: false}\n * ])).toThrowError();\n * ```\n */\nexport function mixingMultiProvidersWithRegularProvidersError(\n    provider1: any, provider2: any): Error {\n  return Error(`Cannot mix multi providers and regular providers, got: ${provider1} ${provider2}`);\n}\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reflective_errors.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/di/reflective_errors.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 {wrappedError} from '../error_handler';\nimport {ERROR_ORIGINAL_ERROR, getOriginalError} from '../errors';\nimport {Type} from '../type';\nimport {stringify} from '../util';\n\nimport {ReflectiveInjector} from './reflective_injector';\nimport {ReflectiveKey} from './reflective_key';\n\nfunction findFirstClosedCycle(keys: any[]): any[] {\n  const res: any[] = [];\n  for (let i = 0; i < keys.length; ++i) {\n    if (res.indexOf(keys[i]) > -1) {\n      res.push(keys[i]);\n      return res;\n    }\n    res.push(keys[i]);\n  }\n  return res;\n}\n\nfunction constructResolvingPath(keys: any[]): string {\n  if (keys.length > 1) {\n    const reversed = findFirstClosedCycle(keys.slice().reverse());\n    const tokenStrs = reversed.map(k => stringify(k.token));\n    return ' (' + tokenStrs.join(' -> ') + ')';\n  }\n\n  return '';\n}\n\nexport interface InjectionError extends Error {\n  keys: ReflectiveKey[];\n  injectors: ReflectiveInjector[];\n  constructResolvingMessage: (keys: ReflectiveKey[]) => string;\n  addKey(injector: ReflectiveInjector, key: ReflectiveKey): void;\n}\n\nfunction injectionError(\n    injector: ReflectiveInjector, key: ReflectiveKey,\n    constructResolvingMessage: (keys: ReflectiveKey[]) => string,\n    originalError?: Error): InjectionError {\n  const keys = [key];\n  const errMsg = constructResolvingMessage(keys);\n  const error =\n      (originalError ? wrappedError(errMsg, originalError) : Error(errMsg)) as InjectionError;\n  error.addKey = addKey;\n  error.keys = keys;\n  error.injectors = [injector];\n  error.constructResolvingMessage = constructResolvingMessage;\n  (error as any)[ERROR_ORIGINAL_ERROR] = originalError;\n  return error;\n}\n\nfunction addKey(this: InjectionError, injector: ReflectiveInjector, key: ReflectiveKey): void {\n  this.injectors.push(injector);\n  this.keys.push(key);\n  // Note: This updated message won't be reflected in the `.stack` property\n  this.message = this.constructResolvingMessage(this.keys);\n}\n\n/**\n * Thrown when trying to retrieve a dependency by key from {@link Injector}, but the\n * {@link Injector} does not have a {@link Provider} for the given key.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * class A {\n *   constructor(b:B) {}\n * }\n *\n * expect(() => Injector.resolveAndCreate([A])).toThrowError();\n * ```\n */\nexport function noProviderError(injector: ReflectiveInjector, key: ReflectiveKey): InjectionError {\n  return injectionError(injector, key, function(keys: ReflectiveKey[]) {\n    const first = stringify(keys[0].token);\n    return `No provider for ${first}!${constructResolvingPath(keys)}`;\n  });\n}\n\n/**\n * Thrown when dependencies form a cycle.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * var injector = Injector.resolveAndCreate([\n *   {provide: \"one\", useFactory: (two) => \"two\", deps: [[new Inject(\"two\")]]},\n *   {provide: \"two\", useFactory: (one) => \"one\", deps: [[new Inject(\"one\")]]}\n * ]);\n *\n * expect(() => injector.get(\"one\")).toThrowError();\n * ```\n *\n * Retrieving `A` or `B` throws a `CyclicDependencyError` as the graph above cannot be constructed.\n */\nexport function cyclicDependencyError(\n    injector: ReflectiveInjector, key: ReflectiveKey): InjectionError {\n  return injectionError(injector, key, function(keys: ReflectiveKey[]) {\n    return `Cannot instantiate cyclic dependency!${constructResolvingPath(keys)}`;\n  });\n}\n\n/**\n * Thrown when a constructing type returns with an Error.\n *\n * The `InstantiationError` class contains the original error plus the dependency graph which caused\n * this object to be instantiated.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * class A {\n *   constructor() {\n *     throw new Error('message');\n *   }\n * }\n *\n * var injector = Injector.resolveAndCreate([A]);\n\n * try {\n *   injector.get(A);\n * } catch (e) {\n *   expect(e instanceof InstantiationError).toBe(true);\n *   expect(e.originalException.message).toEqual(\"message\");\n *   expect(e.originalStack).toBeDefined();\n * }\n * ```\n */\nexport function instantiationError(\n    injector: ReflectiveInjector, originalException: any, originalStack: any,\n    key: ReflectiveKey): InjectionError {\n  return injectionError(injector, key, function(keys: ReflectiveKey[]) {\n    const first = stringify(keys[0].token);\n    return `${originalException.message}: Error during instantiation of ${first}!${constructResolvingPath(keys)}.`;\n  }, originalException);\n}\n\n/**\n * Thrown when an object other then {@link Provider} (or `Type`) is passed to {@link Injector}\n * creation.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * expect(() => Injector.resolveAndCreate([\"not a type\"])).toThrowError();\n * ```\n */\nexport function invalidProviderError(provider: any) {\n  return Error(\n      `Invalid provider - only instances of Provider and Type are allowed, got: ${provider}`);\n}\n\n/**\n * Thrown when the class has no annotation information.\n *\n * Lack of annotation information prevents the {@link Injector} from determining which dependencies\n * need to be injected into the constructor.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * class A {\n *   constructor(b) {}\n * }\n *\n * expect(() => Injector.resolveAndCreate([A])).toThrowError();\n * ```\n *\n * This error is also thrown when the class not marked with {@link Injectable} has parameter types.\n *\n * ```typescript\n * class B {}\n *\n * class A {\n *   constructor(b:B) {} // no information about the parameter types of A is available at runtime.\n * }\n *\n * expect(() => Injector.resolveAndCreate([A,B])).toThrowError();\n * ```\n *\n */\nexport function noAnnotationError(typeOrFunc: Type<any>| Function, params: any[][]): Error {\n  const signature: string[] = [];\n  for (let i = 0, ii = params.length; i < ii; i++) {\n    const parameter = params[i];\n    if (!parameter || parameter.length == 0) {\n      signature.push('?');\n    } else {\n      signature.push(parameter.map(stringify).join(' '));\n    }\n  }\n  return Error(\n      'Cannot resolve all parameters for \\'' + stringify(typeOrFunc) + '\\'(' +\n      signature.join(', ') + '). ' +\n      'Make sure that all the parameters are decorated with Inject or have valid type annotations and that \\'' +\n      stringify(typeOrFunc) + '\\' is decorated with Injectable.');\n}\n\n/**\n * Thrown when getting an object by index.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * class A {}\n *\n * var injector = Injector.resolveAndCreate([A]);\n *\n * expect(() => injector.getAt(100)).toThrowError();\n * ```\n *\n */\nexport function outOfBoundsError(index: number) {\n  return Error(`Index ${index} is out-of-bounds.`);\n}\n\n// TODO: add a working example after alpha38 is released\n/**\n * Thrown when a multi provider and a regular provider are bound to the same token.\n *\n * @usageNotes\n * ### Example\n *\n * ```typescript\n * expect(() => Injector.resolveAndCreate([\n *   { provide: \"Strings\", useValue: \"string1\", multi: true},\n *   { provide: \"Strings\", useValue: \"string2\", multi: false}\n * ])).toThrowError();\n * ```\n */\nexport function mixingMultiProvidersWithRegularProvidersError(\n    provider1: any, provider2: any): Error {\n  return Error(`Cannot mix multi providers and regular providers, got: ${provider1} ${provider2}`);\n}\n"]}
|