@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.
Files changed (233) hide show
  1. package/bundles/core-testing.umd.js +61 -237
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +11 -4
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +591 -2007
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +4 -32
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.metadata.json +1 -1
  10. package/esm2015/core.externs.js +3 -3
  11. package/esm2015/src/application_init.js +2 -9
  12. package/esm2015/src/application_module.js +1 -10
  13. package/esm2015/src/application_ref.js +15 -30
  14. package/esm2015/src/change_detection/change_detector_ref.js +7 -5
  15. package/esm2015/src/change_detection/differs/iterable_differs.js +4 -3
  16. package/esm2015/src/change_detection/differs/keyvalue_differs.js +4 -3
  17. package/esm2015/src/change_detection/pipe_transform.js +3 -6
  18. package/esm2015/src/console.js +0 -11
  19. package/esm2015/src/di/forward_ref.js +8 -6
  20. package/esm2015/src/di/injectable.js +1 -4
  21. package/esm2015/src/di/injection_token.js +6 -8
  22. package/esm2015/src/di/injector.js +5 -10
  23. package/esm2015/src/di/metadata.js +1 -16
  24. package/esm2015/src/di/provider.js +47 -138
  25. package/esm2015/src/di/reflective_errors.js +14 -7
  26. package/esm2015/src/di/reflective_injector.js +22 -24
  27. package/esm2015/src/di/reflective_provider.js +11 -12
  28. package/esm2015/src/error_handler.js +2 -5
  29. package/esm2015/src/event_emitter.js +6 -3
  30. package/esm2015/src/i18n/tokens.js +7 -4
  31. package/esm2015/src/linker/compiler.js +1 -12
  32. package/esm2015/src/linker/query_list.js +4 -4
  33. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +3 -10
  34. package/esm2015/src/linker/view_ref.js +10 -7
  35. package/esm2015/src/metadata/di.js +10 -16
  36. package/esm2015/src/metadata/directives.js +111 -33
  37. package/esm2015/src/metadata/lifecycle_hooks.js +9 -9
  38. package/esm2015/src/metadata/ng_module.js +19 -11
  39. package/esm2015/src/render3/node_manipulation.js +2 -3
  40. package/esm2015/src/render3/view_ref.js +7 -3
  41. package/esm2015/src/testability/testability.js +2 -16
  42. package/esm2015/src/version.js +1 -1
  43. package/esm2015/src/view/ng_module.js +4 -1
  44. package/esm2015/src/zone/ng_zone.js +2 -1
  45. package/esm2015/testing/src/fake_async.js +5 -3
  46. package/esm2015/testing/src/fake_async_fallback.js +5 -3
  47. package/esm2015/testing/src/logger.js +0 -7
  48. package/esm2015/testing/src/metadata_override.js +1 -1
  49. package/esm2015/testing/src/ng_zone_mock.js +0 -7
  50. package/esm2015/testing/src/test_bed.js +1 -34
  51. package/esm2015/testing/src/test_compiler.js +1 -12
  52. package/esm5/index.js +5 -1
  53. package/esm5/public_api.js +6 -1
  54. package/esm5/src/application_init.js +3 -5
  55. package/esm5/src/application_module.js +2 -2
  56. package/esm5/src/application_ref.js +35 -211
  57. package/esm5/src/application_tokens.js +1 -1
  58. package/esm5/src/change_detection/change_detection.js +1 -1
  59. package/esm5/src/change_detection/change_detection_util.js +7 -72
  60. package/esm5/src/change_detection/change_detector_ref.js +1 -1
  61. package/esm5/src/change_detection/constants.js +1 -24
  62. package/esm5/src/change_detection/differs/default_iterable_differ.js +26 -209
  63. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +7 -38
  64. package/esm5/src/change_detection/differs/iterable_differs.js +5 -42
  65. package/esm5/src/change_detection/differs/keyvalue_differs.js +6 -51
  66. package/esm5/src/change_detection/pipe_transform.js +1 -1
  67. package/esm5/src/change_detection.js +6 -1
  68. package/esm5/src/codegen_private_exports.js +1 -1
  69. package/esm5/src/console.js +2 -7
  70. package/esm5/src/core.js +6 -1
  71. package/esm5/src/core_private_export.js +1 -1
  72. package/esm5/src/core_render3_private_export.js +2 -1
  73. package/esm5/src/debug/debug_node.js +3 -15
  74. package/esm5/src/di/defs.js +1 -1
  75. package/esm5/src/di/forward_ref.js +7 -6
  76. package/esm5/src/di/injectable.js +2 -3
  77. package/esm5/src/di/injection_token.js +5 -83
  78. package/esm5/src/di/injector.js +13 -27
  79. package/esm5/src/di/metadata.js +1 -6
  80. package/esm5/src/di/provider.js +1 -1
  81. package/esm5/src/di/r3_injector.js +13 -39
  82. package/esm5/src/di/reflective_errors.js +14 -7
  83. package/esm5/src/di/reflective_injector.js +19 -265
  84. package/esm5/src/di/reflective_key.js +4 -45
  85. package/esm5/src/di/reflective_provider.js +17 -35
  86. package/esm5/src/di/scope.js +1 -1
  87. package/esm5/src/di.js +6 -1
  88. package/esm5/src/error_handler.js +7 -66
  89. package/esm5/src/errors.js +1 -1
  90. package/esm5/src/event_emitter.js +4 -95
  91. package/esm5/src/i18n/tokens.js +9 -49
  92. package/esm5/src/linker/compiler.js +9 -69
  93. package/esm5/src/linker/component_factory.js +2 -18
  94. package/esm5/src/linker/component_factory_resolver.js +1 -1
  95. package/esm5/src/linker/element_ref.js +2 -32
  96. package/esm5/src/linker/ng_module_factory.js +3 -25
  97. package/esm5/src/linker/ng_module_factory_loader.js +2 -10
  98. package/esm5/src/linker/query_list.js +12 -112
  99. package/esm5/src/linker/system_js_ng_module_factory_loader.js +4 -16
  100. package/esm5/src/linker/template_ref.js +2 -26
  101. package/esm5/src/linker/view_container_ref.js +2 -38
  102. package/esm5/src/linker/view_ref.js +10 -115
  103. package/esm5/src/linker.js +2 -1
  104. package/esm5/src/metadata/di.js +7 -25
  105. package/esm5/src/metadata/directives.js +111 -20
  106. package/esm5/src/metadata/lifecycle_hooks.js +1 -1
  107. package/esm5/src/metadata/ng_module.js +14 -9
  108. package/esm5/src/metadata/view.js +1 -20
  109. package/esm5/src/metadata.js +1 -1
  110. package/esm5/src/platform_core_providers.js +1 -1
  111. package/esm5/src/profile/profile.js +1 -1
  112. package/esm5/src/profile/wtf_impl.js +1 -1
  113. package/esm5/src/reflection/platform_reflection_capabilities.js +1 -1
  114. package/esm5/src/reflection/reflection.js +1 -1
  115. package/esm5/src/reflection/reflection_capabilities.js +3 -8
  116. package/esm5/src/reflection/reflector.js +2 -10
  117. package/esm5/src/reflection/types.js +1 -1
  118. package/esm5/src/render/api.js +7 -71
  119. package/esm5/src/render.js +2 -1
  120. package/esm5/src/render3/assert.js +1 -1
  121. package/esm5/src/render3/component.js +6 -5
  122. package/esm5/src/render3/definition.js +6 -8
  123. package/esm5/src/render3/di.js +9 -14
  124. package/esm5/src/render3/errors.js +1 -1
  125. package/esm5/src/render3/hooks.js +2 -2
  126. package/esm5/src/render3/index.js +11 -1
  127. package/esm5/src/render3/instructions.js +52 -38
  128. package/esm5/src/render3/interfaces/container.js +1 -1
  129. package/esm5/src/render3/interfaces/definition.js +1 -1
  130. package/esm5/src/render3/interfaces/injector.js +1 -1
  131. package/esm5/src/render3/interfaces/node.js +1 -1
  132. package/esm5/src/render3/interfaces/projection.js +1 -1
  133. package/esm5/src/render3/interfaces/query.js +1 -1
  134. package/esm5/src/render3/interfaces/renderer.js +1 -3
  135. package/esm5/src/render3/interfaces/view.js +1 -1
  136. package/esm5/src/render3/ng_dev_mode.js +1 -1
  137. package/esm5/src/render3/node_assert.js +1 -1
  138. package/esm5/src/render3/node_manipulation.js +12 -15
  139. package/esm5/src/render3/node_selector_matcher.js +2 -2
  140. package/esm5/src/render3/pipe.js +1 -1
  141. package/esm5/src/render3/pure_function.js +1 -1
  142. package/esm5/src/render3/query.js +11 -59
  143. package/esm5/src/render3/util.js +1 -1
  144. package/esm5/src/render3/view_ref.js +15 -345
  145. package/esm5/src/sanitization/html_sanitizer.js +8 -12
  146. package/esm5/src/sanitization/inert_body.js +8 -72
  147. package/esm5/src/sanitization/sanitization.js +1 -1
  148. package/esm5/src/sanitization/security.js +2 -37
  149. package/esm5/src/sanitization/style_sanitizer.js +1 -1
  150. package/esm5/src/sanitization/url_sanitizer.js +1 -1
  151. package/esm5/src/testability/testability.js +21 -143
  152. package/esm5/src/type.js +1 -1
  153. package/esm5/src/util/decorators.js +1 -1
  154. package/esm5/src/util/lang.js +1 -1
  155. package/esm5/src/util/property.js +1 -1
  156. package/esm5/src/util.js +6 -1
  157. package/esm5/src/version.js +3 -13
  158. package/esm5/src/view/element.js +7 -7
  159. package/esm5/src/view/entrypoint.js +1 -1
  160. package/esm5/src/view/errors.js +1 -1
  161. package/esm5/src/view/index.js +1 -1
  162. package/esm5/src/view/ng_content.js +1 -1
  163. package/esm5/src/view/ng_module.js +4 -1
  164. package/esm5/src/view/provider.js +12 -12
  165. package/esm5/src/view/pure_expression.js +1 -1
  166. package/esm5/src/view/query.js +6 -6
  167. package/esm5/src/view/refs.js +8 -14
  168. package/esm5/src/view/services.js +16 -20
  169. package/esm5/src/view/text.js +1 -1
  170. package/esm5/src/view/types.js +19 -41
  171. package/esm5/src/view/util.js +5 -5
  172. package/esm5/src/view/view.js +4 -6
  173. package/esm5/src/view/view_attach.js +5 -5
  174. package/esm5/src/zone/ng_zone.js +22 -257
  175. package/esm5/src/zone.js +2 -1
  176. package/esm5/testing/index.js +5 -1
  177. package/esm5/testing/public_api.js +6 -1
  178. package/esm5/testing/src/async.js +1 -1
  179. package/esm5/testing/src/async_fallback.js +1 -1
  180. package/esm5/testing/src/async_test_completer.js +2 -8
  181. package/esm5/testing/src/before_each.js +6 -1
  182. package/esm5/testing/src/component_fixture.js +9 -75
  183. package/esm5/testing/src/fake_async.js +12 -3
  184. package/esm5/testing/src/fake_async_fallback.js +5 -3
  185. package/esm5/testing/src/lang_utils.js +1 -1
  186. package/esm5/testing/src/logger.js +1 -1
  187. package/esm5/testing/src/metadata_override.js +1 -1
  188. package/esm5/testing/src/ng_zone_mock.js +1 -1
  189. package/esm5/testing/src/private_export_testing.js +1 -1
  190. package/esm5/testing/src/render3.js +1 -5
  191. package/esm5/testing/src/test_bed.js +20 -172
  192. package/esm5/testing/src/test_compiler.js +5 -43
  193. package/esm5/testing/src/testing.js +6 -1
  194. package/esm5/testing/src/testing_internal.js +3 -9
  195. package/fesm2015/core.js +248 -177
  196. package/fesm2015/core.js.map +1 -1
  197. package/fesm2015/testing.js +9 -13
  198. package/fesm2015/testing.js.map +1 -1
  199. package/fesm5/core.js +591 -2007
  200. package/fesm5/core.js.map +1 -1
  201. package/fesm5/testing.js +61 -237
  202. package/fesm5/testing.js.map +1 -1
  203. package/package.json +1 -1
  204. package/src/application_ref.d.ts +7 -8
  205. package/src/change_detection/change_detector_ref.d.ts +6 -4
  206. package/src/change_detection/differs/iterable_differs.d.ts +3 -2
  207. package/src/change_detection/differs/keyvalue_differs.d.ts +3 -2
  208. package/src/change_detection/pipe_transform.d.ts +2 -5
  209. package/src/di/forward_ref.d.ts +7 -5
  210. package/src/di/injectable.d.ts +4 -14
  211. package/src/di/injection_token.d.ts +5 -7
  212. package/src/di/injector.d.ts +7 -10
  213. package/src/di/metadata.d.ts +13 -86
  214. package/src/di/provider.d.ts +55 -150
  215. package/src/di/reflective_errors.d.ts +13 -6
  216. package/src/di/reflective_injector.d.ts +21 -23
  217. package/src/di/reflective_provider.d.ts +7 -8
  218. package/src/error_handler.d.ts +1 -4
  219. package/src/event_emitter.d.ts +3 -0
  220. package/src/i18n/tokens.d.ts +8 -4
  221. package/src/linker/query_list.d.ts +2 -2
  222. package/src/linker/view_ref.d.ts +9 -6
  223. package/src/metadata/di.d.ts +41 -59
  224. package/src/metadata/directives.d.ts +410 -460
  225. package/src/metadata/lifecycle_hooks.d.ts +8 -8
  226. package/src/metadata/ng_module.d.ts +49 -38
  227. package/src/render3/view_ref.d.ts +6 -2
  228. package/src/zone/ng_zone.d.ts +1 -0
  229. package/testing/src/fake_async.d.ts +4 -2
  230. package/testing/src/fake_async_fallback.d.ts +4 -2
  231. package/testing/src/metadata_override.d.ts +3 -3
  232. package/testing.d.ts +0 -5
  233. 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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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 {\@linkDocs guide/dependency-injection "Dependency Injection Guide"}.
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
- * ### Example ([live demo](http://plnkr.co/edit/vq8D3FRB9aGbnWJqtEPE?p=preview))
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
- * ### Example ([live demo](http://plnkr.co/edit/wYQdNos0Tzql3ei1EV9j?p=info))
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
- * ### Example ([live demo](http://plnkr.co/edit/7aWYdcqTQsP0eNqEdUAf?p=preview))
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
- * ### Example ([live demo](http://plnkr.co/edit/YatCFbPAMCL0JSSQ4mvH?p=preview))
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
- * ### Example ([live demo](http://plnkr.co/edit/rHnZtlNS7vJOPQ6pcVkm?p=preview))
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
- * ### Example ([live demo](http://plnkr.co/edit/bRs0SX2OTQiJzqvjgl8P?p=preview))
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"]}