|  |  | @ -14,6 +14,8 @@ export default class Expression { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	contexts: Set<string>; |  |  |  | 	contexts: Set<string>; | 
			
		
	
		
		
			
				
					
					|  |  |  | 	indexes: Set<string>; |  |  |  | 	indexes: Set<string>; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	thisReferences: Array<{ start: number, end: number }>; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	constructor(compiler, parent, scope, info) { |  |  |  | 	constructor(compiler, parent, scope, info) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		// TODO revert to direct property access in prod?
 |  |  |  | 		// TODO revert to direct property access in prod?
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		Object.defineProperties(this, { |  |  |  | 		Object.defineProperties(this, { | 
			
		
	
	
		
		
			
				
					|  |  | @ -23,6 +25,7 @@ export default class Expression { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		}); |  |  |  | 		}); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		this.node = info; |  |  |  | 		this.node = info; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		this.thisReferences = []; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		this.snippet = `[✂${info.start}-${info.end}✂]`; |  |  |  | 		this.snippet = `[✂${info.start}-${info.end}✂]`; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -34,7 +37,9 @@ export default class Expression { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		const { code, helpers } = compiler; |  |  |  | 		const { code, helpers } = compiler; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		let { map, scope: currentScope } = createScopes(info); |  |  |  | 		let { map, scope: currentScope } = createScopes(info); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		const isEventHandler = parent.type === 'EventHandler'; |  |  |  | 		const isEventHandler = parent.type === 'EventHandler'; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		const { thisReferences } = this; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		walk(info, { |  |  |  | 		walk(info, { | 
			
		
	
		
		
			
				
					
					|  |  |  | 			enter(node: any, parent: any) { |  |  |  | 			enter(node: any, parent: any) { | 
			
		
	
	
		
		
			
				
					|  |  | @ -46,6 +51,10 @@ export default class Expression { | 
			
		
	
		
		
			
				
					
					|  |  |  | 					return; |  |  |  | 					return; | 
			
		
	
		
		
			
				
					
					|  |  |  | 				} |  |  |  | 				} | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 				if (node.type === 'ThisExpression') { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 					thisReferences.push(node); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 				} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 				if (isReference(node, parent)) { |  |  |  | 				if (isReference(node, parent)) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 					const { name } = flattenReference(node); |  |  |  | 					const { name } = flattenReference(node); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -85,4 +94,12 @@ export default class Expression { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		this.contexts = new Set(); // TODO...
 |  |  |  | 		this.contexts = new Set(); // TODO...
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		this.indexes = new Set(); // TODO...
 |  |  |  | 		this.indexes = new Set(); // TODO...
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	overwriteThis(name) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		this.thisReferences.forEach(ref => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			this.compiler.code.overwrite(ref.start, ref.end, name, { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 				storeName: true | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			}); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		}); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } |