| 
									
										
										
										
											2018-07-03 20:04:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @license | 
					
						
							|  |  |  |  * Copyright Google Inc. All Rights Reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Use of this source code is governed by an MIT-style license that can be | 
					
						
							|  |  |  |  * found in the LICENSE file at https://angular.io/license
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |  * Expresses a single CSS Selector. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Beginning of array | 
					
						
							|  |  |  |  * - First index: element name | 
					
						
							|  |  |  |  * - Subsequent odd indices: attr keys | 
					
						
							|  |  |  |  * - Subsequent even indices: attr values | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * After SelectorFlags.CLASS flag | 
					
						
							|  |  |  |  * - Class name values | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * SelectorFlags.NOT flag | 
					
						
							|  |  |  |  * - Changes the mode to NOT | 
					
						
							|  |  |  |  * - Can be combined with other flags to set the element / attr / class mode | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * e.g. SelectorFlags.NOT | SelectorFlags.ELEMENT | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Example: | 
					
						
							|  |  |  |  * Original: `div.foo.bar[attr1=val1][attr2]` | 
					
						
							|  |  |  |  * Parsed: ['div', 'attr1', 'val1', 'attr2', '', SelectorFlags.CLASS, 'foo', 'bar'] | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Original: 'div[attr1]:not(.foo[attr2]) | 
					
						
							|  |  |  |  * Parsed: [ | 
					
						
							|  |  |  |  *  'div', 'attr1', '', | 
					
						
							|  |  |  |  *  SelectorFlags.NOT | SelectorFlags.ATTRIBUTE 'attr2', '', SelectorFlags.CLASS, 'foo' | 
					
						
							|  |  |  |  * ] | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See more examples in node_selector_matcher_spec.ts | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  | export type CssSelector = (string | SelectorFlags)[]; | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |  * A list of CssSelectors. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * A directive or component can have multiple selectors. This type is used for | 
					
						
							|  |  |  |  * directive defs so any of the selectors in the list will match that directive. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Original: 'form, [ngForm]' | 
					
						
							|  |  |  |  * Parsed: [['form'], ['', 'ngForm', '']] | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  | export type CssSelectorList = CssSelector[]; | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  | /** Flags used to build up CssSelectors */ | 
					
						
							|  |  |  | export const enum SelectorFlags { | 
					
						
							|  |  |  |   /** Indicates this is the beginning of a new negative selector */ | 
					
						
							|  |  |  |   NOT = 0b0001, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Mode for matching attributes */ | 
					
						
							|  |  |  |   ATTRIBUTE = 0b0010, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Mode for matching tag names */ | 
					
						
							|  |  |  |   ELEMENT = 0b0100, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Mode for matching class names */ | 
					
						
							|  |  |  |   CLASS = 0b1000, | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-28 15:00:58 +01:00
										 |  |  | export const NG_PROJECT_AS_ATTR_NAME = 'ngProjectAs'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | // Note: This hack is necessary so we don't erroneously get a circular dependency
 | 
					
						
							|  |  |  | // failure based on types.
 | 
					
						
							|  |  |  | export const unusedValueExportToPlacateAjd = 1; |