@angular/core 6.0.0-rc.3 → 6.0.0

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 (198) hide show
  1. package/bundles/core-testing.umd.js +95 -19
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -11
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +555 -389
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +77 -77
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.metadata.json +1 -1
  10. package/esm2015/index.js +2 -2
  11. package/esm2015/public_api.js +2 -2
  12. package/esm2015/src/application_ref.js +6 -6
  13. package/esm2015/src/change_detection/change_detection_util.js +3 -3
  14. package/esm2015/src/change_detection/change_detector_ref.js +2 -2
  15. package/esm2015/src/change_detection/constants.js +1 -1
  16. package/esm2015/src/change_detection/differs/default_iterable_differ.js +15 -15
  17. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +2 -2
  18. package/esm2015/src/change_detection/differs/iterable_differs.js +15 -7
  19. package/esm2015/src/change_detection/differs/keyvalue_differs.js +6 -6
  20. package/esm2015/src/change_detection/pipe_transform.js +2 -2
  21. package/esm2015/src/core.js +4 -4
  22. package/esm2015/src/core_private_export.js +2 -2
  23. package/esm2015/src/core_render3_private_export.js +2 -2
  24. package/esm2015/src/di/defs.js +36 -19
  25. package/esm2015/src/di/injectable.js +3 -3
  26. package/esm2015/src/di/injection_token.js +2 -2
  27. package/esm2015/src/di/injector.js +35 -14
  28. package/esm2015/src/di/metadata.js +11 -11
  29. package/esm2015/src/di/provider.js +9 -9
  30. package/esm2015/src/di/r3_injector.js +12 -12
  31. package/esm2015/src/di/reflective_errors.js +3 -3
  32. package/esm2015/src/di.js +1 -1
  33. package/esm2015/src/error_handler.js +2 -2
  34. package/esm2015/src/event_emitter.js +2 -2
  35. package/esm2015/src/linker/compiler.js +2 -2
  36. package/esm2015/src/linker/component_factory.js +3 -3
  37. package/esm2015/src/linker/component_factory_resolver.js +2 -2
  38. package/esm2015/src/linker/element_ref.js +3 -3
  39. package/esm2015/src/linker/ng_module_factory.js +2 -2
  40. package/esm2015/src/linker/ng_module_factory_loader.js +2 -2
  41. package/esm2015/src/linker/query_list.js +2 -2
  42. package/esm2015/src/linker/template_ref.js +2 -2
  43. package/esm2015/src/linker/view_container_ref.js +2 -2
  44. package/esm2015/src/linker/view_ref.js +2 -2
  45. package/esm2015/src/metadata/di.js +12 -12
  46. package/esm2015/src/metadata/directives.js +15 -15
  47. package/esm2015/src/metadata/lifecycle_hooks.js +10 -10
  48. package/esm2015/src/metadata/ng_module.js +5 -5
  49. package/esm2015/src/metadata/view.js +1 -1
  50. package/esm2015/src/render3/assert.js +13 -1
  51. package/esm2015/src/render3/component.js +2 -1
  52. package/esm2015/src/render3/definition.js +4 -4
  53. package/esm2015/src/render3/di.js +61 -89
  54. package/esm2015/src/render3/hooks.js +7 -7
  55. package/esm2015/src/render3/index.js +1 -1
  56. package/esm2015/src/render3/instructions.js +128 -79
  57. package/esm2015/src/render3/interfaces/definition.js +9 -1
  58. package/esm2015/src/render3/interfaces/injector.js +1 -3
  59. package/esm2015/src/render3/interfaces/node.js +7 -11
  60. package/esm2015/src/render3/interfaces/view.js +17 -3
  61. package/esm2015/src/render3/node_manipulation.js +23 -3
  62. package/esm2015/src/render3/query.js +9 -7
  63. package/esm2015/src/sanitization/security.js +2 -2
  64. package/esm2015/src/type.js +2 -2
  65. package/esm2015/src/util/decorators.js +2 -2
  66. package/esm2015/src/util/lang.js +2 -2
  67. package/esm2015/src/version.js +4 -4
  68. package/esm2015/src/view/ng_module.js +5 -2
  69. package/esm2015/src/view/refs.js +1 -1
  70. package/esm2015/testing/src/async.js +2 -2
  71. package/esm2015/testing/src/async_fallback.js +2 -2
  72. package/esm2015/testing/src/component_fixture.js +2 -2
  73. package/esm2015/testing/src/test_bed.js +3 -3
  74. package/esm5/src/application_ref.js +7 -7
  75. package/esm5/src/change_detection/change_detection_util.js +7 -7
  76. package/esm5/src/change_detection/change_detector_ref.js +4 -4
  77. package/esm5/src/change_detection/constants.js +4 -4
  78. package/esm5/src/change_detection/differs/default_iterable_differ.js +18 -18
  79. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +3 -3
  80. package/esm5/src/change_detection/differs/iterable_differs.js +9 -11
  81. package/esm5/src/change_detection/differs/keyvalue_differs.js +4 -4
  82. package/esm5/src/change_detection/pipe_transform.js +1 -1
  83. package/esm5/src/core_private_export.js +2 -2
  84. package/esm5/src/core_render3_private_export.js +2 -2
  85. package/esm5/src/di/defs.js +3 -6
  86. package/esm5/src/di/injectable.js +2 -2
  87. package/esm5/src/di/injection_token.js +4 -4
  88. package/esm5/src/di/injector.js +26 -11
  89. package/esm5/src/di/metadata.js +6 -6
  90. package/esm5/src/di/provider.js +1 -1
  91. package/esm5/src/di/r3_injector.js +12 -12
  92. package/esm5/src/di/reflective_errors.js +3 -3
  93. package/esm5/src/di.js +2 -2
  94. package/esm5/src/error_handler.js +4 -4
  95. package/esm5/src/event_emitter.js +4 -4
  96. package/esm5/src/linker/compiler.js +2 -2
  97. package/esm5/src/linker/component_factory.js +7 -7
  98. package/esm5/src/linker/component_factory_resolver.js +2 -2
  99. package/esm5/src/linker/element_ref.js +4 -4
  100. package/esm5/src/linker/ng_module_factory.js +4 -4
  101. package/esm5/src/linker/ng_module_factory_loader.js +4 -4
  102. package/esm5/src/linker/query_list.js +4 -4
  103. package/esm5/src/linker/template_ref.js +4 -4
  104. package/esm5/src/linker/view_container_ref.js +4 -4
  105. package/esm5/src/linker/view_ref.js +4 -4
  106. package/esm5/src/metadata/di.js +9 -9
  107. package/esm5/src/metadata/directives.js +8 -8
  108. package/esm5/src/metadata/lifecycle_hooks.js +1 -1
  109. package/esm5/src/metadata/ng_module.js +3 -3
  110. package/esm5/src/metadata/view.js +4 -4
  111. package/esm5/src/render3/assert.js +6 -1
  112. package/esm5/src/render3/component.js +2 -1
  113. package/esm5/src/render3/definition.js +1 -1
  114. package/esm5/src/render3/di.js +51 -74
  115. package/esm5/src/render3/hooks.js +6 -6
  116. package/esm5/src/render3/index.js +1 -1
  117. package/esm5/src/render3/instructions.js +123 -76
  118. package/esm5/src/render3/interfaces/definition.js +1 -1
  119. package/esm5/src/render3/interfaces/injector.js +1 -1
  120. package/esm5/src/render3/interfaces/node.js +1 -1
  121. package/esm5/src/render3/interfaces/view.js +1 -1
  122. package/esm5/src/render3/node_manipulation.js +20 -2
  123. package/esm5/src/render3/query.js +9 -7
  124. package/esm5/src/sanitization/security.js +7 -7
  125. package/esm5/src/type.js +2 -2
  126. package/esm5/src/util/decorators.js +1 -1
  127. package/esm5/src/util/lang.js +2 -2
  128. package/esm5/src/version.js +6 -6
  129. package/esm5/src/view/ng_module.js +5 -2
  130. package/esm5/src/view/refs.js +1 -1
  131. package/esm5/testing/src/async.js +2 -2
  132. package/esm5/testing/src/async_fallback.js +2 -2
  133. package/esm5/testing/src/component_fixture.js +4 -4
  134. package/esm5/testing/src/test_bed.js +5 -5
  135. package/fesm2015/core.js +468 -372
  136. package/fesm2015/core.js.map +1 -1
  137. package/fesm2015/testing.js +6 -6
  138. package/fesm2015/testing.js.map +1 -1
  139. package/fesm5/core.js +403 -321
  140. package/fesm5/core.js.map +1 -1
  141. package/fesm5/testing.js +6 -6
  142. package/fesm5/testing.js.map +1 -1
  143. package/package.json +5 -4
  144. package/src/application_ref.d.ts +5 -5
  145. package/src/change_detection/change_detection_util.d.ts +2 -2
  146. package/src/change_detection/change_detector_ref.d.ts +1 -1
  147. package/src/change_detection/constants.d.ts +1 -1
  148. package/src/change_detection/differs/default_iterable_differ.d.ts +1 -1
  149. package/src/change_detection/differs/iterable_differs.d.ts +8 -7
  150. package/src/change_detection/differs/keyvalue_differs.d.ts +5 -5
  151. package/src/change_detection/pipe_transform.d.ts +1 -1
  152. package/src/core_private_export.d.ts +1 -1
  153. package/src/core_render3_private_export.d.ts +1 -1
  154. package/src/di/defs.d.ts +29 -10
  155. package/src/di/injectable.d.ts +3 -3
  156. package/src/di/injection_token.d.ts +3 -4
  157. package/src/di/injector.d.ts +14 -11
  158. package/src/di/metadata.d.ts +20 -20
  159. package/src/di/provider.d.ts +10 -10
  160. package/src/di/r3_injector.d.ts +3 -3
  161. package/src/di/reflective_errors.d.ts +2 -2
  162. package/src/di.d.ts +1 -1
  163. package/src/error_handler.d.ts +1 -1
  164. package/src/event_emitter.d.ts +1 -1
  165. package/src/linker/compiler.d.ts +1 -1
  166. package/src/linker/component_factory.d.ts +2 -2
  167. package/src/linker/component_factory_resolver.d.ts +1 -1
  168. package/src/linker/element_ref.d.ts +2 -2
  169. package/src/linker/ng_module_factory.d.ts +1 -1
  170. package/src/linker/ng_module_factory_loader.d.ts +1 -1
  171. package/src/linker/query_list.d.ts +1 -1
  172. package/src/linker/template_ref.d.ts +1 -1
  173. package/src/linker/view_container_ref.d.ts +1 -1
  174. package/src/linker/view_ref.d.ts +1 -1
  175. package/src/metadata/di.d.ts +21 -21
  176. package/src/metadata/directives.d.ts +28 -28
  177. package/src/metadata/lifecycle_hooks.d.ts +9 -9
  178. package/src/metadata/ng_module.d.ts +5 -5
  179. package/src/metadata/view.d.ts +1 -1
  180. package/src/render3/assert.d.ts +1 -0
  181. package/src/render3/definition.d.ts +3 -3
  182. package/src/render3/di.d.ts +4 -14
  183. package/src/render3/index.d.ts +2 -1
  184. package/src/render3/instructions.d.ts +3 -3
  185. package/src/render3/interfaces/definition.d.ts +23 -4
  186. package/src/render3/interfaces/injector.d.ts +0 -2
  187. package/src/render3/interfaces/node.d.ts +7 -13
  188. package/src/render3/interfaces/view.d.ts +16 -3
  189. package/src/render3/node_manipulation.d.ts +3 -2
  190. package/src/sanitization/security.d.ts +2 -2
  191. package/src/type.d.ts +1 -1
  192. package/src/util/decorators.d.ts +1 -1
  193. package/src/version.d.ts +2 -2
  194. package/testing/src/async.d.ts +1 -1
  195. package/testing/src/async_fallback.d.ts +1 -1
  196. package/testing/src/component_fixture.d.ts +1 -1
  197. package/testing/src/test_bed.d.ts +2 -2
  198. package/testing.d.ts +1 -1
@@ -9,11 +9,12 @@
9
9
  * Use of this source code is governed by an MIT-style license that can be
10
10
  * found in the LICENSE file at https://angular.io/license
11
11
  */
12
- import { assertLessThan, assertNotNull } from './assert';
12
+ import { inject, setCurrentInjector } from '../di/injector';
13
+ import { assertGreaterThan, assertLessThan, assertNotNull } from './assert';
13
14
  import { addToViewTree, assertPreviousIsParent, createLContainer, createLNodeObject, getDirectiveInstance, getPreviousOrParentNode, getRenderer, isComponent, renderEmbeddedTemplate, resolveDirective } from './instructions';
14
15
  import { assertNodeOfPossibleTypes, assertNodeType } from './node_assert';
15
16
  import { insertView, removeView } from './node_manipulation';
16
- import { notImplemented, stringify } from './util';
17
+ import { notImplemented } from './util';
17
18
  import { EmbeddedViewRef, addDestroyable, createViewRef } from './view_ref';
18
19
  /**
19
20
  * If a directive is diPublic, bloomAdd sets a property on the instance with this constant as
@@ -105,36 +106,12 @@ export function getOrCreateNodeInjectorForNode(node) {
105
106
  cbf5: parentInjector == null ? 0 : parentInjector.cbf5 | parentInjector.bf5,
106
107
  cbf6: parentInjector == null ? 0 : parentInjector.cbf6 | parentInjector.bf6,
107
108
  cbf7: parentInjector == null ? 0 : parentInjector.cbf7 | parentInjector.bf7,
108
- injector: null,
109
109
  templateRef: null,
110
110
  viewContainerRef: null,
111
111
  elementRef: null,
112
112
  changeDetectorRef: null
113
113
  };
114
114
  }
115
- /** @enum {number} */
116
- const InjectFlags = {
117
- /** Dependency is not required. Null will be injected if there is no provider for the dependency.
118
- */
119
- Optional: 1,
120
- /** When resolving a dependency, include the node that is requesting injection. */
121
- CheckSelf: 2,
122
- /** When resolving a dependency, include ancestors of the node requesting injection. */
123
- CheckParent: 4,
124
- /** Default injection options: required, checks both self and ancestors. */
125
- Default: 6,
126
- };
127
- export { InjectFlags };
128
- /**
129
- * Constructs an injection error with the given text and token.
130
- *
131
- * @param {?} text The text of the error
132
- * @param {?} token The token associated with the error
133
- * @return {?} The error that was created
134
- */
135
- function createInjectionError(text, token) {
136
- return new Error(`ElementInjector: ${text} [${stringify(token)}]`);
137
- }
138
115
  /**
139
116
  * Makes a directive public to the DI system by adding it to an injector's bloom filter.
140
117
  *
@@ -155,34 +132,13 @@ export function diPublic(def) {
155
132
  diPublicInInjector(getOrCreateNodeInjector(), def);
156
133
  }
157
134
  /**
158
- * Searches for an instance of the given type up the injector tree and returns
159
- * that instance if found.
160
- *
161
- * If not found, it will propagate up to the next parent injector until the token
162
- * is found or the top is reached.
163
- *
164
- * Usage example (in factory function):
165
- *
166
- * class SomeDirective {
167
- * constructor(directive: DirectiveA) {}
168
- *
169
- * static ngDirectiveDef = defineDirective({
170
- * type: SomeDirective,
171
- * factory: () => new SomeDirective(directiveInject(DirectiveA))
172
- * });
173
- * }
174
- *
175
- * NOTE: use `directiveInject` with `\@Directive`, `\@Component`, and `\@Pipe`. For
176
- * all other injection use `inject` which does not walk the DOM render tree.
177
- *
178
135
  * @template T
179
- * @param {?} token The directive type to search for
180
- * @param {?=} flags Injection flags (e.g. CheckParent)
181
- * @param {?=} defaultValue
182
- * @return {?} The instance found
136
+ * @param {?} token
137
+ * @param {?=} flags
138
+ * @return {?}
183
139
  */
184
- export function directiveInject(token, flags, defaultValue) {
185
- return getOrCreateInjectable(getOrCreateNodeInjector(), token, flags, defaultValue);
140
+ export function directiveInject(token, flags = 0 /* Default */) {
141
+ return getOrCreateInjectable(getOrCreateNodeInjector(), token, flags);
186
142
  }
187
143
  /**
188
144
  * Creates an ElementRef and stores it on the injector.
@@ -299,7 +255,8 @@ function getOrCreateHostChangeDetector(currentNode) {
299
255
  const /** @type {?} */ existingRef = hostInjector && hostInjector.changeDetectorRef;
300
256
  return existingRef ?
301
257
  existingRef :
302
- createViewRef(/** @type {?} */ (hostNode.data), /** @type {?} */ ((hostNode.view.directives))[/** @type {?} */ ((hostNode.tNode)).flags >> 13 /* INDX_SHIFT */]);
258
+ createViewRef(/** @type {?} */ (hostNode.data), /** @type {?} */ ((hostNode.view
259
+ .directives))[/** @type {?} */ ((hostNode.tNode)).flags >> 13 /* DirectiveStartingIndexShift */]);
303
260
  }
304
261
  /**
305
262
  * If the node is an embedded view, traverses up the view tree to return the closest
@@ -330,22 +287,21 @@ function getClosestComponentAncestor(node) {
330
287
  * @param {?} di Node injector where the search should start
331
288
  * @param {?} token The directive type to search for
332
289
  * @param {?=} flags Injection flags (e.g. CheckParent)
333
- * @param {?=} defaultValue
334
290
  * @return {?} The instance found
335
291
  */
336
- export function getOrCreateInjectable(di, token, flags, defaultValue) {
292
+ export function getOrCreateInjectable(di, token, flags) {
337
293
  const /** @type {?} */ bloomHash = bloomHashBit(token);
338
294
  // If the token has a bloom hash, then it is a directive that is public to the injection system
339
295
  // (diPublic). If there is no hash, fall back to the module injector.
340
296
  if (bloomHash === null) {
341
- const /** @type {?} */ moduleInjector = di.injector;
342
- if (!moduleInjector) {
343
- if (defaultValue != null) {
344
- return defaultValue;
345
- }
346
- throw createInjectionError('NotFound', token);
297
+ const /** @type {?} */ moduleInjector = getPreviousOrParentNode().view.injector;
298
+ const /** @type {?} */ formerInjector = setCurrentInjector(moduleInjector);
299
+ try {
300
+ return inject(token, flags);
301
+ }
302
+ finally {
303
+ setCurrentInjector(formerInjector);
347
304
  }
348
- moduleInjector.get(token);
349
305
  }
350
306
  else {
351
307
  let /** @type {?} */ injector = di;
@@ -361,20 +317,17 @@ export function getOrCreateInjectable(di, token, flags, defaultValue) {
361
317
  // At this point, we have an injector which *may* contain the token, so we step through the
362
318
  // directives associated with the injector's corresponding node to get the directive instance.
363
319
  const /** @type {?} */ node = injector.node;
364
- // The size of the node's directive's list is stored in certain bits of the node's flags,
365
- // so exact it with a mask and shift it back such that the bits reflect the real value.
366
320
  const /** @type {?} */ flags = /** @type {?} */ ((node.tNode)).flags;
367
- const /** @type {?} */ size = (flags & 8190 /* SIZE_MASK */) >> 1 /* SIZE_SHIFT */;
368
- if (size !== 0) {
369
- // The start index of the directives list is also part of the node's flags, but there is
370
- // nothing to the "left" of it so it doesn't need a mask.
371
- const /** @type {?} */ start = flags >> 13 /* INDX_SHIFT */;
321
+ const /** @type {?} */ count = flags & 4095 /* DirectiveCountMask */;
322
+ if (count !== 0) {
323
+ const /** @type {?} */ start = flags >> 13 /* DirectiveStartingIndexShift */;
324
+ const /** @type {?} */ end = start + count;
372
325
  const /** @type {?} */ defs = /** @type {?} */ ((node.view.tView.directives));
373
- for (let /** @type {?} */ i = start, /** @type {?} */ ii = start + size; i < ii; i++) {
326
+ for (let /** @type {?} */ i = start; i < end; i++) {
374
327
  // Get the definition for the directive at this index and, if it is injectable (diPublic),
375
328
  // and matches the given token, return the directive instance.
376
329
  const /** @type {?} */ directiveDef = /** @type {?} */ (defs[i]);
377
- if (directiveDef.diPublic && directiveDef.type == token) {
330
+ if (directiveDef.type === token && directiveDef.diPublic) {
378
331
  return getDirectiveInstance(/** @type {?} */ ((node.view.directives))[i]);
379
332
  }
380
333
  }
@@ -392,7 +345,7 @@ export function getOrCreateInjectable(di, token, flags, defaultValue) {
392
345
  }
393
346
  // No directive was found for the given token.
394
347
  // TODO: implement optional, check-self, and check-parent.
395
- throw createInjectionError('Not found', token);
348
+ throw new Error('Implement');
396
349
  }
397
350
  /**
398
351
  * @template T
@@ -626,7 +579,7 @@ class ViewContainerRef {
626
579
  */
627
580
  insert(viewRef, index) {
628
581
  const /** @type {?} */ lViewNode = (/** @type {?} */ (viewRef))._lViewNode;
629
- const /** @type {?} */ adjustedIdx = this._adjustAndAssertIndex(index);
582
+ const /** @type {?} */ adjustedIdx = this._adjustIndex(index);
630
583
  insertView(this._lContainerNode, lViewNode, adjustedIdx);
631
584
  // invalidate cache of next sibling RNode (we do similar operation in the containerRefreshEnd
632
585
  // instruction)
@@ -648,42 +601,52 @@ class ViewContainerRef {
648
601
  }
649
602
  /**
650
603
  * @param {?} viewRef
651
- * @param {?} currentIndex
604
+ * @param {?} newIndex
652
605
  * @return {?}
653
606
  */
654
- move(viewRef, currentIndex) {
655
- throw notImplemented();
607
+ move(viewRef, newIndex) {
608
+ const /** @type {?} */ index = this.indexOf(viewRef);
609
+ this.detach(index);
610
+ this.insert(viewRef, this._adjustIndex(newIndex));
611
+ return viewRef;
656
612
  }
657
613
  /**
658
614
  * @param {?} viewRef
659
615
  * @return {?}
660
616
  */
661
- indexOf(viewRef) { throw notImplemented(); }
617
+ indexOf(viewRef) { return this._viewRefs.indexOf(viewRef); }
662
618
  /**
663
619
  * @param {?=} index
664
620
  * @return {?}
665
621
  */
666
622
  remove(index) {
667
- const /** @type {?} */ adjustedIdx = this._adjustAndAssertIndex(index);
668
- removeView(this._lContainerNode, adjustedIdx);
669
- this._viewRefs.splice(adjustedIdx, 1);
623
+ this.detach(index);
624
+ // TODO(ml): proper destroy of the ViewRef, i.e. recursively destroy the LviewNode and its
625
+ // children, delete DOM nodes and QueryList, trigger hooks (onDestroy), destroy the renderer,
626
+ // detach projected nodes
670
627
  }
671
628
  /**
672
629
  * @param {?=} index
673
630
  * @return {?}
674
631
  */
675
- detach(index) { throw notImplemented(); }
632
+ detach(index) {
633
+ const /** @type {?} */ adjustedIdx = this._adjustIndex(index, -1);
634
+ removeView(this._lContainerNode, adjustedIdx);
635
+ return this._viewRefs.splice(adjustedIdx, 1)[0] || null;
636
+ }
676
637
  /**
677
638
  * @param {?=} index
639
+ * @param {?=} shift
678
640
  * @return {?}
679
641
  */
680
- _adjustAndAssertIndex(index) {
642
+ _adjustIndex(index, shift = 0) {
681
643
  if (index == null) {
682
- index = this._lContainerNode.data.views.length;
644
+ return this._lContainerNode.data.views.length + shift;
683
645
  }
684
- else {
646
+ if (ngDevMode) {
647
+ assertGreaterThan(index, -1, 'index must be positive');
685
648
  // +1 because it's legal to insert at the end.
686
- ngDevMode && assertLessThan(index, this._lContainerNode.data.views.length + 1, 'index');
649
+ assertLessThan(index, this._lContainerNode.data.views.length + 1 + shift, 'index');
687
650
  }
688
651
  return index;
689
652
  }
@@ -711,7 +674,8 @@ function ViewContainerRef_tsickle_Closure_declarations() {
711
674
  export function getOrCreateTemplateRef(di) {
712
675
  ngDevMode && assertNodeType(di.node, 0 /* Container */);
713
676
  const /** @type {?} */ data = (/** @type {?} */ (di.node)).data;
714
- return di.templateRef || (di.templateRef = new TemplateRef(getOrCreateElementRef(di), /** @type {?} */ ((data.template)), getRenderer()));
677
+ const /** @type {?} */ tView = di.node.view.tView;
678
+ return di.templateRef || (di.templateRef = new TemplateRef(getOrCreateElementRef(di), /** @type {?} */ ((data.template)), getRenderer(), tView.directiveRegistry, tView.pipeRegistry));
715
679
  }
716
680
  /**
717
681
  * @template T
@@ -721,9 +685,13 @@ class TemplateRef {
721
685
  * @param {?} elementRef
722
686
  * @param {?} template
723
687
  * @param {?} _renderer
688
+ * @param {?} _directives
689
+ * @param {?} _pipes
724
690
  */
725
- constructor(elementRef, template, _renderer) {
691
+ constructor(elementRef, template, _renderer, _directives, _pipes) {
726
692
  this._renderer = _renderer;
693
+ this._directives = _directives;
694
+ this._pipes = _pipes;
727
695
  this.elementRef = elementRef;
728
696
  this._template = template;
729
697
  }
@@ -732,7 +700,7 @@ class TemplateRef {
732
700
  * @return {?}
733
701
  */
734
702
  createEmbeddedView(context) {
735
- const /** @type {?} */ viewNode = renderEmbeddedTemplate(null, this._template, context, this._renderer);
703
+ const /** @type {?} */ viewNode = renderEmbeddedTemplate(null, this._template, context, this._renderer, this._directives, this._pipes);
736
704
  return addDestroyable(new EmbeddedViewRef(viewNode, this._template, context));
737
705
  }
738
706
  }
@@ -743,6 +711,10 @@ function TemplateRef_tsickle_Closure_declarations() {
743
711
  TemplateRef.prototype._template;
744
712
  /** @type {?} */
745
713
  TemplateRef.prototype._renderer;
714
+ /** @type {?} */
715
+ TemplateRef.prototype._directives;
716
+ /** @type {?} */
717
+ TemplateRef.prototype._pipes;
746
718
  }
747
719
 
748
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"di.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/di.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// We are temporarily importing the existing viewEngine_from core so we can be sure we are\n// correctly implementing its interfaces for backwards compatibility.\nimport {ChangeDetectorRef as viewEngine_ChangeDetectorRef} from '../change_detection/change_detector_ref';\nimport {Injector} from '../di/injector';\nimport {ComponentFactory as viewEngine_ComponentFactory, ComponentRef as viewEngine_ComponentRef} from '../linker/component_factory';\nimport {ElementRef as viewEngine_ElementRef} from '../linker/element_ref';\nimport {NgModuleRef as viewEngine_NgModuleRef} from '../linker/ng_module_factory';\nimport {TemplateRef as viewEngine_TemplateRef} from '../linker/template_ref';\nimport {ViewContainerRef as viewEngine_ViewContainerRef} from '../linker/view_container_ref';\nimport {EmbeddedViewRef as viewEngine_EmbeddedViewRef, ViewRef as viewEngine_ViewRef} from '../linker/view_ref';\nimport {Type} from '../type';\n\nimport {assertLessThan, assertNotNull} from './assert';\nimport {addToViewTree, assertPreviousIsParent, createLContainer, createLNodeObject, getDirectiveInstance, getPreviousOrParentNode, getRenderer, isComponent, renderEmbeddedTemplate, resolveDirective} from './instructions';\nimport {ComponentTemplate, DirectiveDef} from './interfaces/definition';\nimport {LInjector} from './interfaces/injector';\nimport {LContainerNode, LElementNode, LNode, LNodeType, LViewNode, TNodeFlags} from './interfaces/node';\nimport {QueryReadType} from './interfaces/query';\nimport {Renderer3} from './interfaces/renderer';\nimport {LView} from './interfaces/view';\nimport {assertNodeOfPossibleTypes, assertNodeType} from './node_assert';\nimport {insertView, removeView} from './node_manipulation';\nimport {notImplemented, stringify} from './util';\nimport {EmbeddedViewRef, ViewRef, addDestroyable, createViewRef} from './view_ref';\n\n\n\n/**\n * If a directive is diPublic, bloomAdd sets a property on the instance with this constant as\n * the key and the directive's unique ID as the value. This allows us to map directives to their\n * bloom filter bit for DI.\n */\nconst NG_ELEMENT_ID = '__NG_ELEMENT_ID__';\n\n/**\n * The number of slots in each bloom filter (used by DI). The larger this number, the fewer\n * directives that will share slots, and thus, the fewer false positives when checking for\n * the existence of a directive.\n */\nconst BLOOM_SIZE = 256;\n\n/** Counter used to generate unique IDs for directives. */\nlet nextNgElementId = 0;\n\n/**\n * Registers this directive as present in its node's injector by flipping the directive's\n * corresponding bit in the injector's bloom filter.\n *\n * @param injector The node injector in which the directive should be registered\n * @param type The directive to register\n */\nexport function bloomAdd(injector: LInjector, type: Type<any>): void {\n  let id: number|undefined = (type as any)[NG_ELEMENT_ID];\n\n  // Set a unique ID on the directive type, so if something tries to inject the directive,\n  // we can easily retrieve the ID and hash it into the bloom bit that should be checked.\n  if (id == null) {\n    id = (type as any)[NG_ELEMENT_ID] = nextNgElementId++;\n  }\n\n  // We only have BLOOM_SIZE (256) slots in our bloom filter (8 buckets * 32 bits each),\n  // so all unique IDs must be modulo-ed into a number from 0 - 255 to fit into the filter.\n  // This means that after 255, some directives will share slots, leading to some false positives\n  // when checking for a directive's presence.\n  const bloomBit = id % BLOOM_SIZE;\n\n  // Create a mask that targets the specific bit associated with the directive.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomBit;\n\n  // Use the raw bloomBit number to determine which bloom filter bucket we should check\n  // e.g: bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc\n  if (bloomBit < 128) {\n    // Then use the mask to flip on the bit (0-31) associated with the directive in that bucket\n    bloomBit < 64 ? (bloomBit < 32 ? (injector.bf0 |= mask) : (injector.bf1 |= mask)) :\n                    (bloomBit < 96 ? (injector.bf2 |= mask) : (injector.bf3 |= mask));\n  } else {\n    bloomBit < 192 ? (bloomBit < 160 ? (injector.bf4 |= mask) : (injector.bf5 |= mask)) :\n                     (bloomBit < 224 ? (injector.bf6 |= mask) : (injector.bf7 |= mask));\n  }\n}\n\nexport function getOrCreateNodeInjector(): LInjector {\n  ngDevMode && assertPreviousIsParent();\n  return getOrCreateNodeInjectorForNode(getPreviousOrParentNode() as LElementNode | LContainerNode);\n}\n\n/**\n * Creates (or gets an existing) injector for a given element or container.\n *\n * @param node for which an injector should be retrieved / created.\n * @returns Node injector\n */\nexport function getOrCreateNodeInjectorForNode(node: LElementNode | LContainerNode): LInjector {\n  const nodeInjector = node.nodeInjector;\n  const parentInjector = node.parent && node.parent.nodeInjector;\n  if (nodeInjector != parentInjector) {\n    return nodeInjector !;\n  }\n  return node.nodeInjector = {\n    parent: parentInjector,\n    node: node,\n    bf0: 0,\n    bf1: 0,\n    bf2: 0,\n    bf3: 0,\n    bf4: 0,\n    bf5: 0,\n    bf6: 0,\n    bf7: 0,\n    cbf0: parentInjector == null ? 0 : parentInjector.cbf0 | parentInjector.bf0,\n    cbf1: parentInjector == null ? 0 : parentInjector.cbf1 | parentInjector.bf1,\n    cbf2: parentInjector == null ? 0 : parentInjector.cbf2 | parentInjector.bf2,\n    cbf3: parentInjector == null ? 0 : parentInjector.cbf3 | parentInjector.bf3,\n    cbf4: parentInjector == null ? 0 : parentInjector.cbf4 | parentInjector.bf4,\n    cbf5: parentInjector == null ? 0 : parentInjector.cbf5 | parentInjector.bf5,\n    cbf6: parentInjector == null ? 0 : parentInjector.cbf6 | parentInjector.bf6,\n    cbf7: parentInjector == null ? 0 : parentInjector.cbf7 | parentInjector.bf7,\n    injector: null,\n    templateRef: null,\n    viewContainerRef: null,\n    elementRef: null,\n    changeDetectorRef: null\n  };\n}\n\n/** Injection flags for DI. */\nexport const enum InjectFlags {\n  /** Dependency is not required. Null will be injected if there is no provider for the dependency.\n     */\n  Optional = 1 << 0,\n  /** When resolving a dependency, include the node that is requesting injection. */\n  CheckSelf = 1 << 1,\n  /** When resolving a dependency, include ancestors of the node requesting injection. */\n  CheckParent = 1 << 2,\n  /** Default injection options: required, checks both self and ancestors. */\n  Default = CheckSelf | CheckParent,\n}\n\n/**\n * Constructs an injection error with the given text and token.\n *\n * @param text The text of the error\n * @param token The token associated with the error\n * @returns The error that was created\n */\nfunction createInjectionError(text: string, token: any) {\n  return new Error(`ElementInjector: ${text} [${stringify(token)}]`);\n}\n\n/**\n * Makes a directive public to the DI system by adding it to an injector's bloom filter.\n *\n * @param di The node injector in which a directive will be added\n * @param def The definition of the directive to be made public\n */\nexport function diPublicInInjector(di: LInjector, def: DirectiveDef<any>): void {\n  bloomAdd(di, def.type);\n}\n\n/**\n * Makes a directive public to the DI system by adding it to an injector's bloom filter.\n *\n * @param def The definition of the directive to be made public\n */\nexport function diPublic(def: DirectiveDef<any>): void {\n  diPublicInInjector(getOrCreateNodeInjector(), def);\n}\n\n/**\n * Searches for an instance of the given type up the injector tree and returns\n * that instance if found.\n *\n * If not found, it will propagate up to the next parent injector until the token\n * is found or the top is reached.\n *\n * Usage example (in factory function):\n *\n * class SomeDirective {\n *   constructor(directive: DirectiveA) {}\n *\n *   static ngDirectiveDef = defineDirective({\n *     type: SomeDirective,\n *     factory: () => new SomeDirective(directiveInject(DirectiveA))\n *   });\n * }\n *\n * NOTE: use `directiveInject` with `@Directive`, `@Component`, and `@Pipe`. For\n * all other injection use `inject` which does not walk the DOM render tree.\n *\n * @param token The directive type to search for\n * @param flags Injection flags (e.g. CheckParent)\n * @returns The instance found\n */\nexport function directiveInject<T>(token: Type<T>, flags?: InjectFlags, defaultValue?: T): T {\n  return getOrCreateInjectable<T>(getOrCreateNodeInjector(), token, flags, defaultValue);\n}\n\n/**\n * Creates an ElementRef and stores it on the injector.\n * Or, if the ElementRef already exists, retrieves the existing ElementRef.\n *\n * @returns The ElementRef instance to use\n */\nexport function injectElementRef(): viewEngine_ElementRef {\n  return getOrCreateElementRef(getOrCreateNodeInjector());\n}\n\n/**\n * Creates a TemplateRef and stores it on the injector. Or, if the TemplateRef already\n * exists, retrieves the existing TemplateRef.\n *\n * @returns The TemplateRef instance to use\n */\nexport function injectTemplateRef<T>(): viewEngine_TemplateRef<T> {\n  return getOrCreateTemplateRef<T>(getOrCreateNodeInjector());\n}\n\n/**\n * Creates a ViewContainerRef and stores it on the injector. Or, if the ViewContainerRef\n * already exists, retrieves the existing ViewContainerRef.\n *\n * @returns The ViewContainerRef instance to use\n */\nexport function injectViewContainerRef(): viewEngine_ViewContainerRef {\n  return getOrCreateContainerRef(getOrCreateNodeInjector());\n}\n\n/** Returns a ChangeDetectorRef (a.k.a. a ViewRef) */\nexport function injectChangeDetectorRef(): viewEngine_ChangeDetectorRef {\n  return getOrCreateChangeDetectorRef(getOrCreateNodeInjector(), null);\n}\n\n/**\n * Inject static attribute value into directive constructor.\n *\n * This method is used with `factory` functions which are generated as part of\n * `defineDirective` or `defineComponent`. The method retrieves the static value\n * of an attribute. (Dynamic attributes are not supported since they are not resolved\n *  at the time of injection and can change over time.)\n *\n * # Example\n * Given:\n * ```\n * @Component(...)\n * class MyComponent {\n *   constructor(@Attribute('title') title: string) { ... }\n * }\n * ```\n * When instantiated with\n * ```\n * <my-component title=\"Hello\"></my-component>\n * ```\n *\n * Then factory method generated is:\n * ```\n * MyComponent.ngComponentDef = defineComponent({\n *   factory: () => new MyComponent(injectAttribute('title'))\n *   ...\n * })\n * ```\n *\n * @experimental\n */\nexport function injectAttribute(attrName: string): string|undefined {\n  ngDevMode && assertPreviousIsParent();\n  const lElement = getPreviousOrParentNode() as LElementNode;\n  ngDevMode && assertNodeType(lElement, LNodeType.Element);\n  const tElement = lElement.tNode !;\n  ngDevMode && assertNotNull(tElement, 'expecting tNode');\n  const attrs = tElement.attrs;\n  if (attrs) {\n    for (let i = 0; i < attrs.length; i = i + 2) {\n      if (attrs[i] == attrName) {\n        return attrs[i + 1];\n      }\n    }\n  }\n  return undefined;\n}\n\n/**\n * Creates a ViewRef and stores it on the injector as ChangeDetectorRef (public alias).\n * Or, if it already exists, retrieves the existing instance.\n *\n * @returns The ChangeDetectorRef to use\n */\nexport function getOrCreateChangeDetectorRef(\n    di: LInjector, context: any): viewEngine_ChangeDetectorRef {\n  if (di.changeDetectorRef) return di.changeDetectorRef;\n\n  const currentNode = di.node;\n  if (isComponent(currentNode.tNode !)) {\n    return di.changeDetectorRef = createViewRef(currentNode.data as LView, context);\n  } else if (currentNode.type === LNodeType.Element) {\n    return di.changeDetectorRef = getOrCreateHostChangeDetector(currentNode.view.node);\n  }\n  return null !;\n}\n\n/** Gets or creates ChangeDetectorRef for the closest host component */\nfunction getOrCreateHostChangeDetector(currentNode: LViewNode | LElementNode):\n    viewEngine_ChangeDetectorRef {\n  const hostNode = getClosestComponentAncestor(currentNode);\n  const hostInjector = hostNode.nodeInjector;\n  const existingRef = hostInjector && hostInjector.changeDetectorRef;\n\n  return existingRef ?\n      existingRef :\n      createViewRef(\n          hostNode.data as LView,\n          hostNode.view.directives ![hostNode.tNode !.flags >> TNodeFlags.INDX_SHIFT]);\n}\n\n/**\n * If the node is an embedded view, traverses up the view tree to return the closest\n * ancestor view that is attached to a component. If it's already a component node,\n * returns itself.\n */\nfunction getClosestComponentAncestor(node: LViewNode | LElementNode): LElementNode {\n  while (node.type === LNodeType.View) {\n    node = node.view.node;\n  }\n  return node as LElementNode;\n}\n\n/**\n * Searches for an instance of the given directive type up the injector tree and returns\n * that instance if found.\n *\n * Specifically, it gets the bloom filter bit associated with the directive (see bloomHashBit),\n * checks that bit against the bloom filter structure to identify an injector that might have\n * the directive (see bloomFindPossibleInjector), then searches the directives on that injector\n * for a match.\n *\n * If not found, it will propagate up to the next parent injector until the token\n * is found or the top is reached.\n *\n * @param di Node injector where the search should start\n * @param token The directive type to search for\n * @param flags Injection flags (e.g. CheckParent)\n * @returns The instance found\n */\nexport function getOrCreateInjectable<T>(\n    di: LInjector, token: Type<T>, flags?: InjectFlags, defaultValue?: T): T {\n  const bloomHash = bloomHashBit(token);\n\n  // If the token has a bloom hash, then it is a directive that is public to the injection system\n  // (diPublic). If there is no hash, fall back to the module injector.\n  if (bloomHash === null) {\n    const moduleInjector = di.injector;\n    if (!moduleInjector) {\n      if (defaultValue != null) {\n        return defaultValue;\n      }\n      throw createInjectionError('NotFound', token);\n    }\n    moduleInjector.get(token);\n  } else {\n    let injector: LInjector|null = di;\n\n    while (injector) {\n      // Get the closest potential matching injector (upwards in the injector tree) that\n      // *potentially* has the token.\n      injector = bloomFindPossibleInjector(injector, bloomHash);\n\n      // If no injector is found, we *know* that there is no ancestor injector that contains the\n      // token, so we abort.\n      if (!injector) {\n        break;\n      }\n\n      // At this point, we have an injector which *may* contain the token, so we step through the\n      // directives associated with the injector's corresponding node to get the directive instance.\n      const node = injector.node;\n\n      // The size of the node's directive's list is stored in certain bits of the node's flags,\n      // so exact it with a mask and shift it back such that the bits reflect the real value.\n      const flags = node.tNode !.flags;\n      const size = (flags & TNodeFlags.SIZE_MASK) >> TNodeFlags.SIZE_SHIFT;\n\n      if (size !== 0) {\n        // The start index of the directives list is also part of the node's flags, but there is\n        // nothing to the \"left\" of it so it doesn't need a mask.\n        const start = flags >> TNodeFlags.INDX_SHIFT;\n\n        const defs = node.view.tView.directives !;\n        for (let i = start, ii = start + size; i < ii; i++) {\n          // Get the definition for the directive at this index and, if it is injectable (diPublic),\n          // and matches the given token, return the directive instance.\n          const directiveDef = defs[i] as DirectiveDef<any>;\n          if (directiveDef.diPublic && directiveDef.type == token) {\n            return getDirectiveInstance(node.view.directives ![i]);\n          }\n        }\n      }\n\n      // If we *didn't* find the directive for the token and we are searching the current node's\n      // injector, it's possible the directive is on this node and hasn't been created yet.\n      let instance: T|null;\n      if (injector === di && (instance = searchMatchesQueuedForCreation<T>(node, token))) {\n        return instance;\n      }\n\n      // The def wasn't found anywhere on this node, so it might be a false positive.\n      // Traverse up the tree and continue searching.\n      injector = injector.parent;\n    }\n  }\n\n  // No directive was found for the given token.\n  // TODO: implement optional, check-self, and check-parent.\n  throw createInjectionError('Not found', token);\n}\n\nfunction searchMatchesQueuedForCreation<T>(node: LNode, token: any): T|null {\n  const matches = node.view.tView.currentMatches;\n  if (matches) {\n    for (let i = 0; i < matches.length; i += 2) {\n      const def = matches[i] as DirectiveDef<any>;\n      if (def.type === token) {\n        return resolveDirective(def, i + 1, matches, node.view.tView);\n      }\n    }\n  }\n  return null;\n}\n\n/**\n * Given a directive type, this function returns the bit in an injector's bloom filter\n * that should be used to determine whether or not the directive is present.\n *\n * When the directive was added to the bloom filter, it was given a unique ID that can be\n * retrieved on the class. Since there are only BLOOM_SIZE slots per bloom filter, the directive's\n * ID must be modulo-ed by BLOOM_SIZE to get the correct bloom bit (directives share slots after\n * BLOOM_SIZE is reached).\n *\n * @param type The directive type\n * @returns The bloom bit to check for the directive\n */\nfunction bloomHashBit(type: Type<any>): number|null {\n  let id: number|undefined = (type as any)[NG_ELEMENT_ID];\n  return typeof id === 'number' ? id % BLOOM_SIZE : null;\n}\n\n/**\n * Finds the closest injector that might have a certain directive.\n *\n * Each directive corresponds to a bit in an injector's bloom filter. Given the bloom bit to\n * check and a starting injector, this function traverses up injectors until it finds an\n * injector that contains a 1 for that bit in its bloom filter. A 1 indicates that the\n * injector may have that directive. It only *may* have the directive because directives begin\n * to share bloom filter bits after the BLOOM_SIZE is reached, and it could correspond to a\n * different directive sharing the bit.\n *\n * Note: We can skip checking further injectors up the tree if an injector's cbf structure\n * has a 0 for that bloom bit. Since cbf contains the merged value of all the parent\n * injectors, a 0 in the bloom bit indicates that the parents definitely do not contain\n * the directive and do not need to be checked.\n *\n * @param injector The starting node injector to check\n * @param  bloomBit The bit to check in each injector's bloom filter\n * @returns An injector that might have the directive\n */\nexport function bloomFindPossibleInjector(startInjector: LInjector, bloomBit: number): LInjector|\n    null {\n  // Create a mask that targets the specific bit associated with the directive we're looking for.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomBit;\n\n  // Traverse up the injector tree until we find a potential match or until we know there *isn't* a\n  // match.\n  let injector: LInjector|null = startInjector;\n  while (injector) {\n    // Our bloom filter size is 256 bits, which is eight 32-bit bloom filter buckets:\n    // bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc.\n    // Get the bloom filter value from the appropriate bucket based on the directive's bloomBit.\n    let value: number;\n    if (bloomBit < 128) {\n      value = bloomBit < 64 ? (bloomBit < 32 ? injector.bf0 : injector.bf1) :\n                              (bloomBit < 96 ? injector.bf2 : injector.bf3);\n    } else {\n      value = bloomBit < 192 ? (bloomBit < 160 ? injector.bf4 : injector.bf5) :\n                               (bloomBit < 224 ? injector.bf6 : injector.bf7);\n    }\n\n    // If the bloom filter value has the bit corresponding to the directive's bloomBit flipped on,\n    // this injector is a potential match.\n    if ((value & mask) === mask) {\n      return injector;\n    }\n\n    // If the current injector does not have the directive, check the bloom filters for the ancestor\n    // injectors (cbf0 - cbf7). These filters capture *all* ancestor injectors.\n    if (bloomBit < 128) {\n      value = bloomBit < 64 ? (bloomBit < 32 ? injector.cbf0 : injector.cbf1) :\n                              (bloomBit < 96 ? injector.cbf2 : injector.cbf3);\n    } else {\n      value = bloomBit < 192 ? (bloomBit < 160 ? injector.cbf4 : injector.cbf5) :\n                               (bloomBit < 224 ? injector.cbf6 : injector.cbf7);\n    }\n\n    // If the ancestor bloom filter value has the bit corresponding to the directive, traverse up to\n    // find the specific injector. If the ancestor bloom filter does not have the bit, we can abort.\n    injector = (value & mask) ? injector.parent : null;\n  }\n  return null;\n}\n\nexport class ReadFromInjectorFn<T> {\n  constructor(readonly read: (injector: LInjector, node: LNode, directiveIndex?: number) => T) {}\n}\n\n/**\n * Creates an ElementRef for a given node injector and stores it on the injector.\n * Or, if the ElementRef already exists, retrieves the existing ElementRef.\n *\n * @param di The node injector where we should store a created ElementRef\n * @returns The ElementRef instance to use\n */\nexport function getOrCreateElementRef(di: LInjector): viewEngine_ElementRef {\n  return di.elementRef || (di.elementRef = new ElementRef(\n                               di.node.type === LNodeType.Container ? null : di.node.native));\n}\n\nexport const QUERY_READ_TEMPLATE_REF = <QueryReadType<viewEngine_TemplateRef<any>>>(\n    new ReadFromInjectorFn<viewEngine_TemplateRef<any>>(\n        (injector: LInjector) => getOrCreateTemplateRef(injector)) as any);\n\nexport const QUERY_READ_CONTAINER_REF = <QueryReadType<viewEngine_ViewContainerRef>>(\n    new ReadFromInjectorFn<viewEngine_ViewContainerRef>(\n        (injector: LInjector) => getOrCreateContainerRef(injector)) as any);\n\nexport const QUERY_READ_ELEMENT_REF =\n    <QueryReadType<viewEngine_ElementRef>>(new ReadFromInjectorFn<viewEngine_ElementRef>(\n        (injector: LInjector) => getOrCreateElementRef(injector)) as any);\n\nexport const QUERY_READ_FROM_NODE =\n    (new ReadFromInjectorFn<any>((injector: LInjector, node: LNode, directiveIdx: number) => {\n      ngDevMode && assertNodeOfPossibleTypes(node, LNodeType.Container, LNodeType.Element);\n      if (directiveIdx > -1) {\n        return node.view.directives ![directiveIdx];\n      } else if (node.type === LNodeType.Element) {\n        return getOrCreateElementRef(injector);\n      } else if (node.type === LNodeType.Container) {\n        return getOrCreateTemplateRef(injector);\n      }\n      throw new Error('fail');\n    }) as any as QueryReadType<any>);\n\n/** A ref to a node's native element. */\nclass ElementRef implements viewEngine_ElementRef {\n  readonly nativeElement: any;\n  constructor(nativeElement: any) { this.nativeElement = nativeElement; }\n}\n\n/**\n * Creates a ViewContainerRef and stores it on the injector. Or, if the ViewContainerRef\n * already exists, retrieves the existing ViewContainerRef.\n *\n * @returns The ViewContainerRef instance to use\n */\nexport function getOrCreateContainerRef(di: LInjector): viewEngine_ViewContainerRef {\n  if (!di.viewContainerRef) {\n    const vcRefHost = di.node;\n\n    ngDevMode && assertNodeOfPossibleTypes(vcRefHost, LNodeType.Container, LNodeType.Element);\n\n    const lContainer = createLContainer(vcRefHost.parent !, vcRefHost.view);\n    const lContainerNode: LContainerNode = createLNodeObject(\n        LNodeType.Container, vcRefHost.view, vcRefHost.parent !, undefined, lContainer, null);\n\n    vcRefHost.dynamicLContainerNode = lContainerNode;\n\n    addToViewTree(vcRefHost.view, lContainer);\n\n    di.viewContainerRef = new ViewContainerRef(lContainerNode);\n  }\n\n  return di.viewContainerRef;\n}\n\n/**\n * A ref to a container that enables adding and removing views from that container\n * imperatively.\n */\nclass ViewContainerRef implements viewEngine_ViewContainerRef {\n  private _viewRefs: viewEngine_ViewRef[] = [];\n  element: viewEngine_ElementRef;\n  injector: Injector;\n  parentInjector: Injector;\n\n  constructor(private _lContainerNode: LContainerNode) {}\n\n  clear(): void {\n    const lContainer = this._lContainerNode.data;\n    while (lContainer.views.length) {\n      this.remove(0);\n    }\n  }\n  get(index: number): viewEngine_ViewRef|null { return this._viewRefs[index] || null; }\n  get length(): number {\n    const lContainer = this._lContainerNode.data;\n    return lContainer.views.length;\n  }\n  createEmbeddedView<C>(templateRef: viewEngine_TemplateRef<C>, context?: C, index?: number):\n      viewEngine_EmbeddedViewRef<C> {\n    const viewRef = templateRef.createEmbeddedView(context || <any>{});\n    this.insert(viewRef, index);\n    return viewRef;\n  }\n  createComponent<C>(\n      componentFactory: viewEngine_ComponentFactory<C>, index?: number|undefined,\n      injector?: Injector|undefined, projectableNodes?: any[][]|undefined,\n      ngModule?: viewEngine_NgModuleRef<any>|undefined): viewEngine_ComponentRef<C> {\n    throw notImplemented();\n  }\n  insert(viewRef: viewEngine_ViewRef, index?: number): viewEngine_ViewRef {\n    const lViewNode = (viewRef as EmbeddedViewRef<any>)._lViewNode;\n    const adjustedIdx = this._adjustAndAssertIndex(index);\n\n    insertView(this._lContainerNode, lViewNode, adjustedIdx);\n    // invalidate cache of next sibling RNode (we do similar operation in the containerRefreshEnd\n    // instruction)\n    this._lContainerNode.native = undefined;\n\n    this._viewRefs.splice(adjustedIdx, 0, viewRef);\n\n    (lViewNode as{parent: LNode}).parent = this._lContainerNode;\n\n    // If the view is dynamic (has a template), it needs to be counted both at the container\n    // level and at the node above the container.\n    if (lViewNode.data.template !== null) {\n      // Increment the container view count.\n      this._lContainerNode.data.dynamicViewCount++;\n\n      // Look for the parent node and increment its dynamic view count.\n      if (this._lContainerNode.parent !== null && this._lContainerNode.parent.data !== null) {\n        ngDevMode && assertNodeOfPossibleTypes(\n                         this._lContainerNode.parent, LNodeType.View, LNodeType.Element);\n        this._lContainerNode.parent.data.dynamicViewCount++;\n      }\n    }\n    return viewRef;\n  }\n  move(viewRef: viewEngine_ViewRef, currentIndex: number): viewEngine_ViewRef {\n    throw notImplemented();\n  }\n  indexOf(viewRef: viewEngine_ViewRef): number { throw notImplemented(); }\n  remove(index?: number): void {\n    const adjustedIdx = this._adjustAndAssertIndex(index);\n    removeView(this._lContainerNode, adjustedIdx);\n    this._viewRefs.splice(adjustedIdx, 1);\n  }\n  detach(index?: number|undefined): viewEngine_ViewRef|null { throw notImplemented(); }\n\n  private _adjustAndAssertIndex(index?: number|undefined) {\n    if (index == null) {\n      index = this._lContainerNode.data.views.length;\n    } else {\n      // +1 because it's legal to insert at the end.\n      ngDevMode && assertLessThan(index, this._lContainerNode.data.views.length + 1, 'index');\n    }\n    return index;\n  }\n}\n\n/**\n * Creates a TemplateRef and stores it on the injector. Or, if the TemplateRef already\n * exists, retrieves the existing TemplateRef.\n *\n * @param di The node injector where we should store a created TemplateRef\n * @returns The TemplateRef instance to use\n */\nexport function getOrCreateTemplateRef<T>(di: LInjector): viewEngine_TemplateRef<T> {\n  ngDevMode && assertNodeType(di.node, LNodeType.Container);\n  const data = (di.node as LContainerNode).data;\n  return di.templateRef || (di.templateRef = new TemplateRef<any>(\n                                getOrCreateElementRef(di), data.template !, getRenderer()));\n}\n\nclass TemplateRef<T> implements viewEngine_TemplateRef<T> {\n  readonly elementRef: viewEngine_ElementRef;\n  private _template: ComponentTemplate<T>;\n\n  constructor(\n      elementRef: viewEngine_ElementRef, template: ComponentTemplate<T>,\n      private _renderer: Renderer3) {\n    this.elementRef = elementRef;\n    this._template = template;\n  }\n\n  createEmbeddedView(context: T): viewEngine_EmbeddedViewRef<T> {\n    const viewNode = renderEmbeddedTemplate(null, this._template, context, this._renderer);\n    return addDestroyable(new EmbeddedViewRef(viewNode, this._template, context));\n  }\n}\n"]}
720
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"di.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/di.ts"],"names":[],"mappings":";;;;;;;;;;;AAWA,OAAO,EAAwB,MAAM,EAAE,kBAAkB,EAAC,MAAM,gBAAgB,CAAC;AASjF,OAAO,EAAC,iBAAiB,EAAE,cAAc,EAAE,aAAa,EAAC,MAAM,UAAU,CAAC;AAC1E,OAAO,EAAC,aAAa,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,WAAW,EAAE,WAAW,EAAE,sBAAsB,EAAE,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AAO7N,OAAO,EAAC,yBAAyB,EAAE,cAAc,EAAC,MAAM,eAAe,CAAC;AACxE,OAAO,EAAC,UAAU,EAAE,UAAU,EAAC,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAC,cAAc,EAAY,MAAM,QAAQ,CAAC;AACjD,OAAO,EAAC,eAAe,EAAW,cAAc,EAAE,aAAa,EAAC,MAAM,YAAY,CAAC;;;;;;AASnF,uBAAM,aAAa,GAAG,mBAAmB,CAAC;;;;;;AAO1C,uBAAM,UAAU,GAAG,GAAG,CAAC;;;;AAGvB,qBAAI,eAAe,GAAG,CAAC,CAAC;;;;;;;;;AASxB,MAAM,mBAAmB,QAAmB,EAAE,IAAe;IAC3D,qBAAI,EAAE,GAAqB,mBAAC,IAAW,EAAC,CAAC,aAAa,CAAC,CAAC;;;IAIxD,EAAE,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC;QACf,EAAE,GAAG,mBAAC,IAAW,EAAC,CAAC,aAAa,CAAC,GAAG,eAAe,EAAE,CAAC;KACvD;;;;;IAMD,uBAAM,QAAQ,GAAG,EAAE,GAAG,UAAU,CAAC;;;;IAKjC,uBAAM,IAAI,GAAG,CAAC,IAAI,QAAQ,CAAC;;;IAI3B,EAAE,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC;;QAEnB,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;YACnE,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC;KACnF;IAAC,IAAI,CAAC,CAAC;QACN,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;YACpE,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC;KACrF;CACF;;;;AAED,MAAM;IACJ,SAAS,IAAI,sBAAsB,EAAE,CAAC;IACtC,MAAM,CAAC,8BAA8B,mBAAC,uBAAuB,EAAmC,EAAC,CAAC;CACnG;;;;;;;AAQD,MAAM,yCAAyC,IAAmC;IAChF,uBAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;IACvC,uBAAM,cAAc,GAAG,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC;IAC/D,EAAE,CAAC,CAAC,YAAY,IAAI,cAAc,CAAC,CAAC,CAAC;QACnC,MAAM,oBAAC,YAAY,GAAG;KACvB;IACD,MAAM,CAAC,IAAI,CAAC,YAAY,GAAG;QACzB,MAAM,EAAE,cAAc;QACtB,IAAI,EAAE,IAAI;QACV,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,GAAG,EAAE,CAAC;QACN,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,IAAI,EAAE,cAAc,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,GAAG,cAAc,CAAC,GAAG;QAC3E,WAAW,EAAE,IAAI;QACjB,gBAAgB,EAAE,IAAI;QACtB,UAAU,EAAE,IAAI;QAChB,iBAAiB,EAAE,IAAI;KACxB,CAAC;CACH;;;;;;;;AASD,MAAM,6BAA6B,EAAa,EAAE,GAAsB;IACtE,QAAQ,CAAC,EAAE,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;CACxB;;;;;;;AAOD,MAAM,mBAAmB,GAAsB;IAC7C,kBAAkB,CAAC,uBAAuB,EAAE,EAAE,GAAG,CAAC,CAAC;CACpD;;;;;;;AA6BD,MAAM,0BAA6B,KAAc,EAAE,KAAK,kBAAsB;IAC5E,MAAM,CAAC,qBAAqB,CAAI,uBAAuB,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;CAC1E;;;;;;;AAQD,MAAM;IACJ,MAAM,CAAC,qBAAqB,CAAC,uBAAuB,EAAE,CAAC,CAAC;CACzD;;;;;;;;AAQD,MAAM;IACJ,MAAM,CAAC,sBAAsB,CAAI,uBAAuB,EAAE,CAAC,CAAC;CAC7D;;;;;;;AAQD,MAAM;IACJ,MAAM,CAAC,uBAAuB,CAAC,uBAAuB,EAAE,CAAC,CAAC;CAC3D;;;;;AAGD,MAAM;IACJ,MAAM,CAAC,4BAA4B,CAAC,uBAAuB,EAAE,EAAE,IAAI,CAAC,CAAC;CACtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiCD,MAAM,0BAA0B,QAAgB;IAC9C,SAAS,IAAI,sBAAsB,EAAE,CAAC;IACtC,uBAAM,QAAQ,qBAAG,uBAAuB,EAAkB,CAAA,CAAC;IAC3D,SAAS,IAAI,cAAc,CAAC,QAAQ,kBAAoB,CAAC;IACzD,uBAAM,QAAQ,sBAAG,QAAQ,CAAC,KAAK,EAAE,CAAC;IAClC,SAAS,IAAI,aAAa,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IACxD,uBAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;IAC7B,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACV,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5C,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC;gBACzB,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACrB;SACF;KACF;IACD,MAAM,CAAC,SAAS,CAAC;CAClB;;;;;;;;;AAQD,MAAM,uCACF,EAAa,EAAE,OAAY;IAC7B,EAAE,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC;QAAC,MAAM,CAAC,EAAE,CAAC,iBAAiB,CAAC;IAEtD,uBAAM,WAAW,GAAG,EAAE,CAAC,IAAI,CAAC;IAC5B,EAAE,CAAC,CAAC,WAAW,oBAAC,WAAW,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,EAAE,CAAC,iBAAiB,GAAG,aAAa,mBAAC,WAAW,CAAC,IAAa,GAAE,OAAO,CAAC,CAAC;KACjF;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,IAAI,oBAAsB,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,EAAE,CAAC,iBAAiB,GAAG,6BAA6B,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACpF;IACD,MAAM,oBAAC,IAAI,GAAG;CACf;;;;;;AAGD,uCAAuC,WAAqC;IAE1E,uBAAM,QAAQ,GAAG,2BAA2B,CAAC,WAAW,CAAC,CAAC;IAC1D,uBAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;IAC3C,uBAAM,WAAW,GAAG,YAAY,IAAI,YAAY,CAAC,iBAAiB,CAAC;IAEnE,MAAM,CAAC,WAAW,CAAC,CAAC;QAChB,WAAW,CAAC,CAAC;QACb,aAAa,mBACT,QAAQ,CAAC,IAAa,sBACtB,QAAQ,CAAC,IAAI;aACR,UAAU,sBAAG,QAAQ,CAAC,KAAK,GAAG,KAAK,0CAA4C,CAAC;CAC9F;;;;;;;;AAOD,qCAAqC,IAA8B;IACjE,OAAO,IAAI,CAAC,IAAI,iBAAmB,EAAE,CAAC;QACpC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;KACvB;IACD,MAAM,mBAAC,IAAoB,EAAC;CAC7B;;;;;;;;;;;;;;;;;;;AAmBD,MAAM,gCAAmC,EAAa,EAAE,KAAc,EAAE,KAAmB;IAEzF,uBAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;;;IAItC,EAAE,CAAC,CAAC,SAAS,KAAK,IAAI,CAAC,CAAC,CAAC;QACvB,uBAAM,cAAc,GAAG,uBAAuB,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/D,uBAAM,cAAc,GAAG,kBAAkB,CAAC,cAAc,CAAC,CAAC;QAC1D,IAAI,CAAC;YACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;SAC7B;gBAAS,CAAC;YACT,kBAAkB,CAAC,cAAc,CAAC,CAAC;SACpC;KACF;IAAC,IAAI,CAAC,CAAC;QACN,qBAAI,QAAQ,GAAmB,EAAE,CAAC;QAElC,OAAO,QAAQ,EAAE,CAAC;;;YAGhB,QAAQ,GAAG,yBAAyB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;;;YAI1D,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACd,KAAK,CAAC;aACP;;;YAID,uBAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC3B,uBAAM,KAAK,sBAAG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACjC,uBAAM,KAAK,GAAG,KAAK,gCAAgC,CAAC;YAEpD,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC;gBAChB,uBAAM,KAAK,GAAG,KAAK,wCAA0C,CAAC;gBAC9D,uBAAM,GAAG,GAAG,KAAK,GAAG,KAAK,CAAC;gBAC1B,uBAAM,IAAI,sBAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;gBAE1C,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;;;oBAGjC,uBAAM,YAAY,qBAAG,IAAI,CAAC,CAAC,CAAsB,CAAA,CAAC;oBAClD,EAAE,CAAC,CAAC,YAAY,CAAC,IAAI,KAAK,KAAK,IAAI,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;wBACzD,MAAM,CAAC,oBAAoB,oBAAC,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;qBACxD;iBACF;aACF;;;YAID,qBAAI,QAAgB,CAAC;YACrB,EAAE,CAAC,CAAC,QAAQ,KAAK,EAAE,IAAI,CAAC,QAAQ,GAAG,8BAA8B,CAAI,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnF,MAAM,CAAC,QAAQ,CAAC;aACjB;;;YAID,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;SAC5B;KACF;;;IAID,MAAM,IAAI,KAAK,CAAC,WAAW,CAAC,CAAC;CAC9B;;;;;;;AAED,wCAA2C,IAAW,EAAE,KAAU;IAChE,uBAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC;IAC/C,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QACZ,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;YAC3C,uBAAM,GAAG,qBAAG,OAAO,CAAC,CAAC,CAAsB,CAAA,CAAC;YAC5C,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC;gBACvB,MAAM,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC/D;SACF;KACF;IACD,MAAM,CAAC,IAAI,CAAC;CACb;;;;;;;;;;;;;AAcD,sBAAsB,IAAe;IACnC,qBAAI,EAAE,GAAqB,mBAAC,IAAW,EAAC,CAAC,aAAa,CAAC,CAAC;IACxD,MAAM,CAAC,OAAO,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;CACxD;;;;;;;;;;;;;;;;;;;;AAqBD,MAAM,oCAAoC,aAAwB,EAAE,QAAgB;;;;IAKlF,uBAAM,IAAI,GAAG,CAAC,IAAI,QAAQ,CAAC;;;IAI3B,qBAAI,QAAQ,GAAmB,aAAa,CAAC;IAC7C,OAAO,QAAQ,EAAE,CAAC;;;;QAIhB,qBAAI,KAAa,CAAC;QAClB,EAAE,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC;YACnB,KAAK,GAAG,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/C,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;SACvE;QAAC,IAAI,CAAC,CAAC;YACN,KAAK,GAAG,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;gBAChD,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;SACzE;;;QAID,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;YAC5B,MAAM,CAAC,QAAQ,CAAC;SACjB;;;QAID,EAAE,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC;YACnB,KAAK,GAAG,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;gBACjD,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SACzE;QAAC,IAAI,CAAC,CAAC;YACN,KAAK,GAAG,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;gBAClD,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC3E;;;QAID,QAAQ,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;KACpD;IACD,MAAM,CAAC,IAAI,CAAC;CACb;;;;AAED,MAAM;;;;IACJ,YAAqB,IAAsE;QAAtE,SAAI,GAAJ,IAAI,CAAkE;KAAI;CAChG;;;;;;;;;;;;AASD,MAAM,gCAAgC,EAAa;IACjD,MAAM,CAAC,EAAE,CAAC,UAAU,IAAI,CAAC,EAAE,CAAC,UAAU,GAAG,IAAI,UAAU,CAC1B,EAAE,CAAC,IAAI,CAAC,IAAI,sBAAwB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;CAC7F;AAED,MAAM,CAAC,uBAAM,uBAAuB,qBAA+C,mBAC/E,IAAI,kBAAkB,CAClB,CAAC,QAAmB,EAAE,EAAE,CAAC,sBAAsB,CAAC,QAAQ,CAAC,CAAQ,EAAC,CAAA,CAAC;AAE3E,MAAM,CAAC,uBAAM,wBAAwB,qBAA+C,mBAChF,IAAI,kBAAkB,CAClB,CAAC,QAAmB,EAAE,EAAE,CAAC,uBAAuB,CAAC,QAAQ,CAAC,CAAQ,EAAC,CAAA,CAAC;AAE5E,MAAM,CAAC,uBAAM,sBAAsB,qBACO,mBAAC,IAAI,kBAAkB,CACzD,CAAC,QAAmB,EAAE,EAAE,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAQ,EAAC,CAAA,CAAC;AAE1E,MAAM,CAAC,uBAAM,oBAAoB,GAC7B,oBAAC,IAAI,kBAAkB,CAAM,CAAC,QAAmB,EAAE,IAAW,EAAE,YAAoB,EAAE,EAAE;IACtF,SAAS,IAAI,yBAAyB,CAAC,IAAI,qCAAyC,CAAC;IACrF,EAAE,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,oBAAC,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,YAAY,EAAE;KAC7C;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,oBAAsB,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;KACxC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,sBAAwB,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,sBAAsB,CAAC,QAAQ,CAAC,CAAC;KACzC;IACD,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC;CACzB,CAAQ,GAAuB,CAAC;;;;AAGrC;;;;IAEE,YAAY,aAAkB,IAAI,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC,EAAE;CACxE;;;;;;;;;;;;AAQD,MAAM,kCAAkC,EAAa;IACnD,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;QACzB,uBAAM,SAAS,GAAG,EAAE,CAAC,IAAI,CAAC;QAE1B,SAAS,IAAI,yBAAyB,CAAC,SAAS,qCAAyC,CAAC;QAE1F,uBAAM,UAAU,GAAG,gBAAgB,oBAAC,SAAS,CAAC,MAAM,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC;QACxE,uBAAM,cAAc,GAAmB,iBAAiB,oBAC/B,SAAS,CAAC,IAAI,qBAAE,SAAS,CAAC,MAAM,IAAI,SAAS,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;QAE1F,SAAS,CAAC,qBAAqB,GAAG,cAAc,CAAC;QAEjD,aAAa,CAAC,SAAS,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAE1C,EAAE,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,cAAc,CAAC,CAAC;KAC5D;IAED,MAAM,CAAC,EAAE,CAAC,gBAAgB,CAAC;CAC5B;;;;;AAMD;;;;IAME,YAAoB,eAA+B;QAA/B,oBAAe,GAAf,eAAe,CAAgB;yBALT,EAAE;KAKW;;;;IAEvD,KAAK;QACH,uBAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;QAC7C,OAAO,UAAU,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YAC/B,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;SAChB;KACF;;;;;IAED,GAAG,CAAC,KAAa,IAA6B,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,EAAE;;;;IAErF,IAAI,MAAM;QACR,uBAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;QAC7C,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC;KAChC;;;;;;;;IAED,kBAAkB,CAAI,WAAsC,EAAE,OAAW,EAAE,KAAc;QAEvF,uBAAM,OAAO,GAAG,WAAW,CAAC,kBAAkB,CAAC,OAAO,sBAAS,EAAE,CAAA,CAAC,CAAC;QACnE,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAC5B,MAAM,CAAC,OAAO,CAAC;KAChB;;;;;;;;;;IAED,eAAe,CACX,gBAAgD,EAAE,KAAwB,EAC1E,QAA6B,EAAE,gBAAoC,EACnE,QAAgD;QAClD,MAAM,cAAc,EAAE,CAAC;KACxB;;;;;;IAED,MAAM,CAAC,OAA2B,EAAE,KAAc;QAChD,uBAAM,SAAS,GAAG,mBAAC,OAA+B,EAAC,CAAC,UAAU,CAAC;QAC/D,uBAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAE7C,UAAU,CAAC,IAAI,CAAC,eAAe,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;;;QAGzD,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,SAAS,CAAC;QAExC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QAE/C,mBAAC,SAA2B,EAAC,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC;;;QAI5D,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC;;YAErC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;;YAG7C,EAAE,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,IAAI,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC;gBACtF,SAAS,IAAI,yBAAyB,CACrB,IAAI,CAAC,eAAe,CAAC,MAAM,gCAAoC,CAAC;gBACjF,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACrD;SACF;QACD,MAAM,CAAC,OAAO,CAAC;KAChB;;;;;;IAED,IAAI,CAAC,OAA2B,EAAE,QAAgB;QAChD,uBAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,OAAO,CAAC;KAChB;;;;;IAED,OAAO,CAAC,OAA2B,IAAY,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE;;;;;IAExF,MAAM,CAAC,KAAc;QACnB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;;;;KAIpB;;;;;IAED,MAAM,CAAC,KAAc;QACnB,uBAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,UAAU,CAAC,IAAI,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;KACzD;;;;;;IAEO,YAAY,CAAC,KAAc,EAAE,QAAgB,CAAC;QACpD,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC;SACvD;QACD,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;YACd,iBAAiB,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,wBAAwB,CAAC,CAAC;;YAEvD,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,KAAK,EAAE,OAAO,CAAC,CAAC;SACpF;QACD,MAAM,CAAC,KAAK,CAAC;;CAEhB;;;;;;;;;;;;;;;;;;;;;AASD,MAAM,iCAAoC,EAAa;IACrD,SAAS,IAAI,cAAc,CAAC,EAAE,CAAC,IAAI,oBAAsB,CAAC;IAC1D,uBAAM,IAAI,GAAG,mBAAC,EAAE,CAAC,IAAsB,EAAC,CAAC,IAAI,CAAC;IAC9C,uBAAM,KAAK,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IACjC,MAAM,CAAC,EAAE,CAAC,WAAW,IAAI,CAAC,EAAE,CAAC,WAAW,GAAG,IAAI,WAAW,CAC5B,qBAAqB,CAAC,EAAE,CAAC,qBAAE,IAAI,CAAC,QAAQ,IAAI,WAAW,EAAE,EACzD,KAAK,CAAC,iBAAiB,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC;CAC7E;;;;AAED;;;;;;;;IAIE,YACI,UAAiC,EAAE,QAA8B,EACzD,WAA8B,WAAkC,EAChE;QADA,cAAS,GAAT,SAAS;QAAqB,gBAAW,GAAX,WAAW,CAAuB;QAChE,WAAM,GAAN,MAAM;QAChB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;KAC3B;;;;;IAED,kBAAkB,CAAC,OAAU;QAC3B,uBAAM,QAAQ,GAAG,sBAAsB,CACnC,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAClF,MAAM,CAAC,cAAc,CAAC,IAAI,eAAe,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC;KAC/E;CACF","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\n// We are temporarily importing the existing viewEngine_from core so we can be sure we are\n// correctly implementing its interfaces for backwards compatibility.\nimport {ChangeDetectorRef as viewEngine_ChangeDetectorRef} from '../change_detection/change_detector_ref';\nimport {InjectFlags, Injector, inject, setCurrentInjector} from '../di/injector';\nimport {ComponentFactory as viewEngine_ComponentFactory, ComponentRef as viewEngine_ComponentRef} from '../linker/component_factory';\nimport {ElementRef as viewEngine_ElementRef} from '../linker/element_ref';\nimport {NgModuleRef as viewEngine_NgModuleRef} from '../linker/ng_module_factory';\nimport {TemplateRef as viewEngine_TemplateRef} from '../linker/template_ref';\nimport {ViewContainerRef as viewEngine_ViewContainerRef} from '../linker/view_container_ref';\nimport {EmbeddedViewRef as viewEngine_EmbeddedViewRef, ViewRef as viewEngine_ViewRef} from '../linker/view_ref';\nimport {Type} from '../type';\n\nimport {assertGreaterThan, assertLessThan, assertNotNull} from './assert';\nimport {addToViewTree, assertPreviousIsParent, createLContainer, createLNodeObject, getDirectiveInstance, getPreviousOrParentNode, getRenderer, isComponent, renderEmbeddedTemplate, resolveDirective} from './instructions';\nimport {ComponentTemplate, DirectiveDef, DirectiveDefList, PipeDefList} from './interfaces/definition';\nimport {LInjector} from './interfaces/injector';\nimport {LContainerNode, LElementNode, LNode, LNodeType, LViewNode, TNodeFlags} from './interfaces/node';\nimport {QueryReadType} from './interfaces/query';\nimport {Renderer3} from './interfaces/renderer';\nimport {LView} from './interfaces/view';\nimport {assertNodeOfPossibleTypes, assertNodeType} from './node_assert';\nimport {insertView, removeView} from './node_manipulation';\nimport {notImplemented, stringify} from './util';\nimport {EmbeddedViewRef, ViewRef, addDestroyable, createViewRef} from './view_ref';\n\n\n\n/**\n * If a directive is diPublic, bloomAdd sets a property on the instance with this constant as\n * the key and the directive's unique ID as the value. This allows us to map directives to their\n * bloom filter bit for DI.\n */\nconst NG_ELEMENT_ID = '__NG_ELEMENT_ID__';\n\n/**\n * The number of slots in each bloom filter (used by DI). The larger this number, the fewer\n * directives that will share slots, and thus, the fewer false positives when checking for\n * the existence of a directive.\n */\nconst BLOOM_SIZE = 256;\n\n/** Counter used to generate unique IDs for directives. */\nlet nextNgElementId = 0;\n\n/**\n * Registers this directive as present in its node's injector by flipping the directive's\n * corresponding bit in the injector's bloom filter.\n *\n * @param injector The node injector in which the directive should be registered\n * @param type The directive to register\n */\nexport function bloomAdd(injector: LInjector, type: Type<any>): void {\n  let id: number|undefined = (type as any)[NG_ELEMENT_ID];\n\n  // Set a unique ID on the directive type, so if something tries to inject the directive,\n  // we can easily retrieve the ID and hash it into the bloom bit that should be checked.\n  if (id == null) {\n    id = (type as any)[NG_ELEMENT_ID] = nextNgElementId++;\n  }\n\n  // We only have BLOOM_SIZE (256) slots in our bloom filter (8 buckets * 32 bits each),\n  // so all unique IDs must be modulo-ed into a number from 0 - 255 to fit into the filter.\n  // This means that after 255, some directives will share slots, leading to some false positives\n  // when checking for a directive's presence.\n  const bloomBit = id % BLOOM_SIZE;\n\n  // Create a mask that targets the specific bit associated with the directive.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomBit;\n\n  // Use the raw bloomBit number to determine which bloom filter bucket we should check\n  // e.g: bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc\n  if (bloomBit < 128) {\n    // Then use the mask to flip on the bit (0-31) associated with the directive in that bucket\n    bloomBit < 64 ? (bloomBit < 32 ? (injector.bf0 |= mask) : (injector.bf1 |= mask)) :\n                    (bloomBit < 96 ? (injector.bf2 |= mask) : (injector.bf3 |= mask));\n  } else {\n    bloomBit < 192 ? (bloomBit < 160 ? (injector.bf4 |= mask) : (injector.bf5 |= mask)) :\n                     (bloomBit < 224 ? (injector.bf6 |= mask) : (injector.bf7 |= mask));\n  }\n}\n\nexport function getOrCreateNodeInjector(): LInjector {\n  ngDevMode && assertPreviousIsParent();\n  return getOrCreateNodeInjectorForNode(getPreviousOrParentNode() as LElementNode | LContainerNode);\n}\n\n/**\n * Creates (or gets an existing) injector for a given element or container.\n *\n * @param node for which an injector should be retrieved / created.\n * @returns Node injector\n */\nexport function getOrCreateNodeInjectorForNode(node: LElementNode | LContainerNode): LInjector {\n  const nodeInjector = node.nodeInjector;\n  const parentInjector = node.parent && node.parent.nodeInjector;\n  if (nodeInjector != parentInjector) {\n    return nodeInjector !;\n  }\n  return node.nodeInjector = {\n    parent: parentInjector,\n    node: node,\n    bf0: 0,\n    bf1: 0,\n    bf2: 0,\n    bf3: 0,\n    bf4: 0,\n    bf5: 0,\n    bf6: 0,\n    bf7: 0,\n    cbf0: parentInjector == null ? 0 : parentInjector.cbf0 | parentInjector.bf0,\n    cbf1: parentInjector == null ? 0 : parentInjector.cbf1 | parentInjector.bf1,\n    cbf2: parentInjector == null ? 0 : parentInjector.cbf2 | parentInjector.bf2,\n    cbf3: parentInjector == null ? 0 : parentInjector.cbf3 | parentInjector.bf3,\n    cbf4: parentInjector == null ? 0 : parentInjector.cbf4 | parentInjector.bf4,\n    cbf5: parentInjector == null ? 0 : parentInjector.cbf5 | parentInjector.bf5,\n    cbf6: parentInjector == null ? 0 : parentInjector.cbf6 | parentInjector.bf6,\n    cbf7: parentInjector == null ? 0 : parentInjector.cbf7 | parentInjector.bf7,\n    templateRef: null,\n    viewContainerRef: null,\n    elementRef: null,\n    changeDetectorRef: null\n  };\n}\n\n\n/**\n * Makes a directive public to the DI system by adding it to an injector's bloom filter.\n *\n * @param di The node injector in which a directive will be added\n * @param def The definition of the directive to be made public\n */\nexport function diPublicInInjector(di: LInjector, def: DirectiveDef<any>): void {\n  bloomAdd(di, def.type);\n}\n\n/**\n * Makes a directive public to the DI system by adding it to an injector's bloom filter.\n *\n * @param def The definition of the directive to be made public\n */\nexport function diPublic(def: DirectiveDef<any>): void {\n  diPublicInInjector(getOrCreateNodeInjector(), def);\n}\n\n/**\n * Searches for an instance of the given type up the injector tree and returns\n * that instance if found.\n *\n * If not found, it will propagate up to the next parent injector until the token\n * is found or the top is reached.\n *\n * Usage example (in factory function):\n *\n * class SomeDirective {\n *   constructor(directive: DirectiveA) {}\n *\n *   static ngDirectiveDef = defineDirective({\n *     type: SomeDirective,\n *     factory: () => new SomeDirective(directiveInject(DirectiveA))\n *   });\n * }\n *\n * NOTE: use `directiveInject` with `@Directive`, `@Component`, and `@Pipe`. For\n * all other injection use `inject` which does not walk the DOM render tree.\n *\n * @param token The directive type to search for\n * @param flags Injection flags (e.g. CheckParent)\n * @returns The instance found\n */\nexport function directiveInject<T>(token: Type<T>): T;\nexport function directiveInject<T>(token: Type<T>, flags?: InjectFlags): T|null;\nexport function directiveInject<T>(token: Type<T>, flags = InjectFlags.Default): T|null {\n  return getOrCreateInjectable<T>(getOrCreateNodeInjector(), token, flags);\n}\n\n/**\n * Creates an ElementRef and stores it on the injector.\n * Or, if the ElementRef already exists, retrieves the existing ElementRef.\n *\n * @returns The ElementRef instance to use\n */\nexport function injectElementRef(): viewEngine_ElementRef {\n  return getOrCreateElementRef(getOrCreateNodeInjector());\n}\n\n/**\n * Creates a TemplateRef and stores it on the injector. Or, if the TemplateRef already\n * exists, retrieves the existing TemplateRef.\n *\n * @returns The TemplateRef instance to use\n */\nexport function injectTemplateRef<T>(): viewEngine_TemplateRef<T> {\n  return getOrCreateTemplateRef<T>(getOrCreateNodeInjector());\n}\n\n/**\n * Creates a ViewContainerRef and stores it on the injector. Or, if the ViewContainerRef\n * already exists, retrieves the existing ViewContainerRef.\n *\n * @returns The ViewContainerRef instance to use\n */\nexport function injectViewContainerRef(): viewEngine_ViewContainerRef {\n  return getOrCreateContainerRef(getOrCreateNodeInjector());\n}\n\n/** Returns a ChangeDetectorRef (a.k.a. a ViewRef) */\nexport function injectChangeDetectorRef(): viewEngine_ChangeDetectorRef {\n  return getOrCreateChangeDetectorRef(getOrCreateNodeInjector(), null);\n}\n\n/**\n * Inject static attribute value into directive constructor.\n *\n * This method is used with `factory` functions which are generated as part of\n * `defineDirective` or `defineComponent`. The method retrieves the static value\n * of an attribute. (Dynamic attributes are not supported since they are not resolved\n *  at the time of injection and can change over time.)\n *\n * # Example\n * Given:\n * ```\n * @Component(...)\n * class MyComponent {\n *   constructor(@Attribute('title') title: string) { ... }\n * }\n * ```\n * When instantiated with\n * ```\n * <my-component title=\"Hello\"></my-component>\n * ```\n *\n * Then factory method generated is:\n * ```\n * MyComponent.ngComponentDef = defineComponent({\n *   factory: () => new MyComponent(injectAttribute('title'))\n *   ...\n * })\n * ```\n *\n * @experimental\n */\nexport function injectAttribute(attrName: string): string|undefined {\n  ngDevMode && assertPreviousIsParent();\n  const lElement = getPreviousOrParentNode() as LElementNode;\n  ngDevMode && assertNodeType(lElement, LNodeType.Element);\n  const tElement = lElement.tNode !;\n  ngDevMode && assertNotNull(tElement, 'expecting tNode');\n  const attrs = tElement.attrs;\n  if (attrs) {\n    for (let i = 0; i < attrs.length; i = i + 2) {\n      if (attrs[i] == attrName) {\n        return attrs[i + 1];\n      }\n    }\n  }\n  return undefined;\n}\n\n/**\n * Creates a ViewRef and stores it on the injector as ChangeDetectorRef (public alias).\n * Or, if it already exists, retrieves the existing instance.\n *\n * @returns The ChangeDetectorRef to use\n */\nexport function getOrCreateChangeDetectorRef(\n    di: LInjector, context: any): viewEngine_ChangeDetectorRef {\n  if (di.changeDetectorRef) return di.changeDetectorRef;\n\n  const currentNode = di.node;\n  if (isComponent(currentNode.tNode !)) {\n    return di.changeDetectorRef = createViewRef(currentNode.data as LView, context);\n  } else if (currentNode.type === LNodeType.Element) {\n    return di.changeDetectorRef = getOrCreateHostChangeDetector(currentNode.view.node);\n  }\n  return null !;\n}\n\n/** Gets or creates ChangeDetectorRef for the closest host component */\nfunction getOrCreateHostChangeDetector(currentNode: LViewNode | LElementNode):\n    viewEngine_ChangeDetectorRef {\n  const hostNode = getClosestComponentAncestor(currentNode);\n  const hostInjector = hostNode.nodeInjector;\n  const existingRef = hostInjector && hostInjector.changeDetectorRef;\n\n  return existingRef ?\n      existingRef :\n      createViewRef(\n          hostNode.data as LView,\n          hostNode.view\n              .directives ![hostNode.tNode !.flags >> TNodeFlags.DirectiveStartingIndexShift]);\n}\n\n/**\n * If the node is an embedded view, traverses up the view tree to return the closest\n * ancestor view that is attached to a component. If it's already a component node,\n * returns itself.\n */\nfunction getClosestComponentAncestor(node: LViewNode | LElementNode): LElementNode {\n  while (node.type === LNodeType.View) {\n    node = node.view.node;\n  }\n  return node as LElementNode;\n}\n\n/**\n * Searches for an instance of the given directive type up the injector tree and returns\n * that instance if found.\n *\n * Specifically, it gets the bloom filter bit associated with the directive (see bloomHashBit),\n * checks that bit against the bloom filter structure to identify an injector that might have\n * the directive (see bloomFindPossibleInjector), then searches the directives on that injector\n * for a match.\n *\n * If not found, it will propagate up to the next parent injector until the token\n * is found or the top is reached.\n *\n * @param di Node injector where the search should start\n * @param token The directive type to search for\n * @param flags Injection flags (e.g. CheckParent)\n * @returns The instance found\n */\nexport function getOrCreateInjectable<T>(di: LInjector, token: Type<T>, flags?: InjectFlags): T|\n    null {\n  const bloomHash = bloomHashBit(token);\n\n  // If the token has a bloom hash, then it is a directive that is public to the injection system\n  // (diPublic). If there is no hash, fall back to the module injector.\n  if (bloomHash === null) {\n    const moduleInjector = getPreviousOrParentNode().view.injector;\n    const formerInjector = setCurrentInjector(moduleInjector);\n    try {\n      return inject(token, flags);\n    } finally {\n      setCurrentInjector(formerInjector);\n    }\n  } else {\n    let injector: LInjector|null = di;\n\n    while (injector) {\n      // Get the closest potential matching injector (upwards in the injector tree) that\n      // *potentially* has the token.\n      injector = bloomFindPossibleInjector(injector, bloomHash);\n\n      // If no injector is found, we *know* that there is no ancestor injector that contains the\n      // token, so we abort.\n      if (!injector) {\n        break;\n      }\n\n      // At this point, we have an injector which *may* contain the token, so we step through the\n      // directives associated with the injector's corresponding node to get the directive instance.\n      const node = injector.node;\n      const flags = node.tNode !.flags;\n      const count = flags & TNodeFlags.DirectiveCountMask;\n\n      if (count !== 0) {\n        const start = flags >> TNodeFlags.DirectiveStartingIndexShift;\n        const end = start + count;\n        const defs = node.view.tView.directives !;\n\n        for (let i = start; i < end; i++) {\n          // Get the definition for the directive at this index and, if it is injectable (diPublic),\n          // and matches the given token, return the directive instance.\n          const directiveDef = defs[i] as DirectiveDef<any>;\n          if (directiveDef.type === token && directiveDef.diPublic) {\n            return getDirectiveInstance(node.view.directives ![i]);\n          }\n        }\n      }\n\n      // If we *didn't* find the directive for the token and we are searching the current node's\n      // injector, it's possible the directive is on this node and hasn't been created yet.\n      let instance: T|null;\n      if (injector === di && (instance = searchMatchesQueuedForCreation<T>(node, token))) {\n        return instance;\n      }\n\n      // The def wasn't found anywhere on this node, so it might be a false positive.\n      // Traverse up the tree and continue searching.\n      injector = injector.parent;\n    }\n  }\n\n  // No directive was found for the given token.\n  // TODO: implement optional, check-self, and check-parent.\n  throw new Error('Implement');\n}\n\nfunction searchMatchesQueuedForCreation<T>(node: LNode, token: any): T|null {\n  const matches = node.view.tView.currentMatches;\n  if (matches) {\n    for (let i = 0; i < matches.length; i += 2) {\n      const def = matches[i] as DirectiveDef<any>;\n      if (def.type === token) {\n        return resolveDirective(def, i + 1, matches, node.view.tView);\n      }\n    }\n  }\n  return null;\n}\n\n/**\n * Given a directive type, this function returns the bit in an injector's bloom filter\n * that should be used to determine whether or not the directive is present.\n *\n * When the directive was added to the bloom filter, it was given a unique ID that can be\n * retrieved on the class. Since there are only BLOOM_SIZE slots per bloom filter, the directive's\n * ID must be modulo-ed by BLOOM_SIZE to get the correct bloom bit (directives share slots after\n * BLOOM_SIZE is reached).\n *\n * @param type The directive type\n * @returns The bloom bit to check for the directive\n */\nfunction bloomHashBit(type: Type<any>): number|null {\n  let id: number|undefined = (type as any)[NG_ELEMENT_ID];\n  return typeof id === 'number' ? id % BLOOM_SIZE : null;\n}\n\n/**\n * Finds the closest injector that might have a certain directive.\n *\n * Each directive corresponds to a bit in an injector's bloom filter. Given the bloom bit to\n * check and a starting injector, this function traverses up injectors until it finds an\n * injector that contains a 1 for that bit in its bloom filter. A 1 indicates that the\n * injector may have that directive. It only *may* have the directive because directives begin\n * to share bloom filter bits after the BLOOM_SIZE is reached, and it could correspond to a\n * different directive sharing the bit.\n *\n * Note: We can skip checking further injectors up the tree if an injector's cbf structure\n * has a 0 for that bloom bit. Since cbf contains the merged value of all the parent\n * injectors, a 0 in the bloom bit indicates that the parents definitely do not contain\n * the directive and do not need to be checked.\n *\n * @param injector The starting node injector to check\n * @param  bloomBit The bit to check in each injector's bloom filter\n * @returns An injector that might have the directive\n */\nexport function bloomFindPossibleInjector(startInjector: LInjector, bloomBit: number): LInjector|\n    null {\n  // Create a mask that targets the specific bit associated with the directive we're looking for.\n  // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n  // to bit positions 0 - 31 in a 32 bit integer.\n  const mask = 1 << bloomBit;\n\n  // Traverse up the injector tree until we find a potential match or until we know there *isn't* a\n  // match.\n  let injector: LInjector|null = startInjector;\n  while (injector) {\n    // Our bloom filter size is 256 bits, which is eight 32-bit bloom filter buckets:\n    // bf0 = [0 - 31], bf1 = [32 - 63], bf2 = [64 - 95], bf3 = [96 - 127], etc.\n    // Get the bloom filter value from the appropriate bucket based on the directive's bloomBit.\n    let value: number;\n    if (bloomBit < 128) {\n      value = bloomBit < 64 ? (bloomBit < 32 ? injector.bf0 : injector.bf1) :\n                              (bloomBit < 96 ? injector.bf2 : injector.bf3);\n    } else {\n      value = bloomBit < 192 ? (bloomBit < 160 ? injector.bf4 : injector.bf5) :\n                               (bloomBit < 224 ? injector.bf6 : injector.bf7);\n    }\n\n    // If the bloom filter value has the bit corresponding to the directive's bloomBit flipped on,\n    // this injector is a potential match.\n    if ((value & mask) === mask) {\n      return injector;\n    }\n\n    // If the current injector does not have the directive, check the bloom filters for the ancestor\n    // injectors (cbf0 - cbf7). These filters capture *all* ancestor injectors.\n    if (bloomBit < 128) {\n      value = bloomBit < 64 ? (bloomBit < 32 ? injector.cbf0 : injector.cbf1) :\n                              (bloomBit < 96 ? injector.cbf2 : injector.cbf3);\n    } else {\n      value = bloomBit < 192 ? (bloomBit < 160 ? injector.cbf4 : injector.cbf5) :\n                               (bloomBit < 224 ? injector.cbf6 : injector.cbf7);\n    }\n\n    // If the ancestor bloom filter value has the bit corresponding to the directive, traverse up to\n    // find the specific injector. If the ancestor bloom filter does not have the bit, we can abort.\n    injector = (value & mask) ? injector.parent : null;\n  }\n  return null;\n}\n\nexport class ReadFromInjectorFn<T> {\n  constructor(readonly read: (injector: LInjector, node: LNode, directiveIndex?: number) => T) {}\n}\n\n/**\n * Creates an ElementRef for a given node injector and stores it on the injector.\n * Or, if the ElementRef already exists, retrieves the existing ElementRef.\n *\n * @param di The node injector where we should store a created ElementRef\n * @returns The ElementRef instance to use\n */\nexport function getOrCreateElementRef(di: LInjector): viewEngine_ElementRef {\n  return di.elementRef || (di.elementRef = new ElementRef(\n                               di.node.type === LNodeType.Container ? null : di.node.native));\n}\n\nexport const QUERY_READ_TEMPLATE_REF = <QueryReadType<viewEngine_TemplateRef<any>>>(\n    new ReadFromInjectorFn<viewEngine_TemplateRef<any>>(\n        (injector: LInjector) => getOrCreateTemplateRef(injector)) as any);\n\nexport const QUERY_READ_CONTAINER_REF = <QueryReadType<viewEngine_ViewContainerRef>>(\n    new ReadFromInjectorFn<viewEngine_ViewContainerRef>(\n        (injector: LInjector) => getOrCreateContainerRef(injector)) as any);\n\nexport const QUERY_READ_ELEMENT_REF =\n    <QueryReadType<viewEngine_ElementRef>>(new ReadFromInjectorFn<viewEngine_ElementRef>(\n        (injector: LInjector) => getOrCreateElementRef(injector)) as any);\n\nexport const QUERY_READ_FROM_NODE =\n    (new ReadFromInjectorFn<any>((injector: LInjector, node: LNode, directiveIdx: number) => {\n      ngDevMode && assertNodeOfPossibleTypes(node, LNodeType.Container, LNodeType.Element);\n      if (directiveIdx > -1) {\n        return node.view.directives ![directiveIdx];\n      } else if (node.type === LNodeType.Element) {\n        return getOrCreateElementRef(injector);\n      } else if (node.type === LNodeType.Container) {\n        return getOrCreateTemplateRef(injector);\n      }\n      throw new Error('fail');\n    }) as any as QueryReadType<any>);\n\n/** A ref to a node's native element. */\nclass ElementRef implements viewEngine_ElementRef {\n  readonly nativeElement: any;\n  constructor(nativeElement: any) { this.nativeElement = nativeElement; }\n}\n\n/**\n * Creates a ViewContainerRef and stores it on the injector. Or, if the ViewContainerRef\n * already exists, retrieves the existing ViewContainerRef.\n *\n * @returns The ViewContainerRef instance to use\n */\nexport function getOrCreateContainerRef(di: LInjector): viewEngine_ViewContainerRef {\n  if (!di.viewContainerRef) {\n    const vcRefHost = di.node;\n\n    ngDevMode && assertNodeOfPossibleTypes(vcRefHost, LNodeType.Container, LNodeType.Element);\n\n    const lContainer = createLContainer(vcRefHost.parent !, vcRefHost.view);\n    const lContainerNode: LContainerNode = createLNodeObject(\n        LNodeType.Container, vcRefHost.view, vcRefHost.parent !, undefined, lContainer, null);\n\n    vcRefHost.dynamicLContainerNode = lContainerNode;\n\n    addToViewTree(vcRefHost.view, lContainer);\n\n    di.viewContainerRef = new ViewContainerRef(lContainerNode);\n  }\n\n  return di.viewContainerRef;\n}\n\n/**\n * A ref to a container that enables adding and removing views from that container\n * imperatively.\n */\nclass ViewContainerRef implements viewEngine_ViewContainerRef {\n  private _viewRefs: viewEngine_ViewRef[] = [];\n  element: viewEngine_ElementRef;\n  injector: Injector;\n  parentInjector: Injector;\n\n  constructor(private _lContainerNode: LContainerNode) {}\n\n  clear(): void {\n    const lContainer = this._lContainerNode.data;\n    while (lContainer.views.length) {\n      this.remove(0);\n    }\n  }\n\n  get(index: number): viewEngine_ViewRef|null { return this._viewRefs[index] || null; }\n\n  get length(): number {\n    const lContainer = this._lContainerNode.data;\n    return lContainer.views.length;\n  }\n\n  createEmbeddedView<C>(templateRef: viewEngine_TemplateRef<C>, context?: C, index?: number):\n      viewEngine_EmbeddedViewRef<C> {\n    const viewRef = templateRef.createEmbeddedView(context || <any>{});\n    this.insert(viewRef, index);\n    return viewRef;\n  }\n\n  createComponent<C>(\n      componentFactory: viewEngine_ComponentFactory<C>, index?: number|undefined,\n      injector?: Injector|undefined, projectableNodes?: any[][]|undefined,\n      ngModule?: viewEngine_NgModuleRef<any>|undefined): viewEngine_ComponentRef<C> {\n    throw notImplemented();\n  }\n\n  insert(viewRef: viewEngine_ViewRef, index?: number): viewEngine_ViewRef {\n    const lViewNode = (viewRef as EmbeddedViewRef<any>)._lViewNode;\n    const adjustedIdx = this._adjustIndex(index);\n\n    insertView(this._lContainerNode, lViewNode, adjustedIdx);\n    // invalidate cache of next sibling RNode (we do similar operation in the containerRefreshEnd\n    // instruction)\n    this._lContainerNode.native = undefined;\n\n    this._viewRefs.splice(adjustedIdx, 0, viewRef);\n\n    (lViewNode as{parent: LNode}).parent = this._lContainerNode;\n\n    // If the view is dynamic (has a template), it needs to be counted both at the container\n    // level and at the node above the container.\n    if (lViewNode.data.template !== null) {\n      // Increment the container view count.\n      this._lContainerNode.data.dynamicViewCount++;\n\n      // Look for the parent node and increment its dynamic view count.\n      if (this._lContainerNode.parent !== null && this._lContainerNode.parent.data !== null) {\n        ngDevMode && assertNodeOfPossibleTypes(\n                         this._lContainerNode.parent, LNodeType.View, LNodeType.Element);\n        this._lContainerNode.parent.data.dynamicViewCount++;\n      }\n    }\n    return viewRef;\n  }\n\n  move(viewRef: viewEngine_ViewRef, newIndex: number): viewEngine_ViewRef {\n    const index = this.indexOf(viewRef);\n    this.detach(index);\n    this.insert(viewRef, this._adjustIndex(newIndex));\n    return viewRef;\n  }\n\n  indexOf(viewRef: viewEngine_ViewRef): number { return this._viewRefs.indexOf(viewRef); }\n\n  remove(index?: number): void {\n    this.detach(index);\n    // TODO(ml): proper destroy of the ViewRef, i.e. recursively destroy the LviewNode and its\n    // children, delete DOM nodes and QueryList, trigger hooks (onDestroy), destroy the renderer,\n    // detach projected nodes\n  }\n\n  detach(index?: number): viewEngine_ViewRef|null {\n    const adjustedIdx = this._adjustIndex(index, -1);\n    removeView(this._lContainerNode, adjustedIdx);\n    return this._viewRefs.splice(adjustedIdx, 1)[0] || null;\n  }\n\n  private _adjustIndex(index?: number, shift: number = 0) {\n    if (index == null) {\n      return this._lContainerNode.data.views.length + shift;\n    }\n    if (ngDevMode) {\n      assertGreaterThan(index, -1, 'index must be positive');\n      // +1 because it's legal to insert at the end.\n      assertLessThan(index, this._lContainerNode.data.views.length + 1 + shift, 'index');\n    }\n    return index;\n  }\n}\n\n/**\n * Creates a TemplateRef and stores it on the injector. Or, if the TemplateRef already\n * exists, retrieves the existing TemplateRef.\n *\n * @param di The node injector where we should store a created TemplateRef\n * @returns The TemplateRef instance to use\n */\nexport function getOrCreateTemplateRef<T>(di: LInjector): viewEngine_TemplateRef<T> {\n  ngDevMode && assertNodeType(di.node, LNodeType.Container);\n  const data = (di.node as LContainerNode).data;\n  const tView = di.node.view.tView;\n  return di.templateRef || (di.templateRef = new TemplateRef<any>(\n                                getOrCreateElementRef(di), data.template !, getRenderer(),\n                                tView.directiveRegistry, tView.pipeRegistry));\n}\n\nclass TemplateRef<T> implements viewEngine_TemplateRef<T> {\n  readonly elementRef: viewEngine_ElementRef;\n  private _template: ComponentTemplate<T>;\n\n  constructor(\n      elementRef: viewEngine_ElementRef, template: ComponentTemplate<T>,\n      private _renderer: Renderer3, private _directives: DirectiveDefList|null,\n      private _pipes: PipeDefList|null) {\n    this.elementRef = elementRef;\n    this._template = template;\n  }\n\n  createEmbeddedView(context: T): viewEngine_EmbeddedViewRef<T> {\n    const viewNode = renderEmbeddedTemplate(\n        null, this._template, context, this._renderer, this._directives, this._pipes);\n    return addDestroyable(new EmbeddedViewRef(viewNode, this._template, context));\n  }\n}\n"]}