OLD | NEW |
---|---|
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 class EnqueueTask extends CompilerTask { | 5 class EnqueueTask extends CompilerTask { |
6 final Enqueuer codegen; | 6 final Enqueuer codegen; |
7 final Enqueuer resolution; | 7 final Enqueuer resolution; |
8 | 8 |
9 String get name => 'Enqueue'; | 9 String get name => 'Enqueue'; |
10 | 10 |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
96 queue.add(new WorkItem(element, elements, itemCompilationContextCreator())); | 96 queue.add(new WorkItem(element, elements, itemCompilationContextCreator())); |
97 | 97 |
98 // Enable runtime type support if we discover a getter called runtimeType. | 98 // Enable runtime type support if we discover a getter called runtimeType. |
99 // We have to enable runtime type before hitting the codegen, so | 99 // We have to enable runtime type before hitting the codegen, so |
100 // that constructors know whether they need to generate code for | 100 // that constructors know whether they need to generate code for |
101 // runtime type. | 101 // runtime type. |
102 if (element.isGetter() && element.name == Compiler.RUNTIME_TYPE) { | 102 if (element.isGetter() && element.name == Compiler.RUNTIME_TYPE) { |
103 compiler.enabledRuntimeType = true; | 103 compiler.enabledRuntimeType = true; |
104 } else if (element == compiler.functionApplyMethod) { | 104 } else if (element == compiler.functionApplyMethod) { |
105 compiler.enabledFunctionApply = true; | 105 compiler.enabledFunctionApply = true; |
106 } else if (element == compiler.invokeOnMethod) { | |
107 compiler.enabledInvokeOn = true; | |
106 } | 108 } |
107 | 109 |
108 // Enable isolate support if we start using something from the | 110 // Enable isolate support if we start using something from the |
109 // isolate library. | 111 // isolate library. |
110 LibraryElement library = element.getLibrary(); | 112 LibraryElement library = element.getLibrary(); |
111 if (!compiler.hasIsolateSupport() | 113 if (!compiler.hasIsolateSupport() |
112 && library.uri.toString() == 'dart:isolate') { | 114 && library.uri.toString() == 'dart:isolate') { |
113 compiler.enableIsolateSupport(library); | 115 compiler.enableIsolateSupport(library); |
114 } | 116 } |
115 } | 117 } |
(...skipping 124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
240 }); | 242 }); |
241 } | 243 } |
242 | 244 |
243 void registerNewSelector(SourceString name, | 245 void registerNewSelector(SourceString name, |
244 Selector selector, | 246 Selector selector, |
245 Map<SourceString, Set<Selector>> selectorsMap) { | 247 Map<SourceString, Set<Selector>> selectorsMap) { |
246 if (name != selector.name) { | 248 if (name != selector.name) { |
247 String message = "$name != ${selector.name} (${selector.kind})"; | 249 String message = "$name != ${selector.name} (${selector.kind})"; |
248 compiler.internalError("Wrong selector name: $message."); | 250 compiler.internalError("Wrong selector name: $message."); |
249 } | 251 } |
252 /*if (!compiler.enabledInvokeOn && name == Compiler.INVOKE_ON) { | |
ngeoffray
2012/10/26 08:34:55
Remove comment.
Johnni Winther
2012/10/26 10:18:01
Done.
| |
253 if (selector.applies(compiler.invokeOnMethod, compiler)) { | |
254 compiler.enabledInvokeOn = true; | |
255 } | |
256 }*/ | |
250 Set<Selector> selectors = | 257 Set<Selector> selectors = |
251 selectorsMap.putIfAbsent(name, () => new Set<Selector>()); | 258 selectorsMap.putIfAbsent(name, () => new Set<Selector>()); |
252 if (!selectors.contains(selector)) { | 259 if (!selectors.contains(selector)) { |
253 selectors.add(selector); | 260 selectors.add(selector); |
254 handleUnseenSelector(name, selector); | 261 handleUnseenSelector(name, selector); |
255 } | 262 } |
256 } | 263 } |
257 | 264 |
258 void registerInvocation(SourceString methodName, Selector selector) { | 265 void registerInvocation(SourceString methodName, Selector selector) { |
259 task.measure(() { | 266 task.measure(() { |
(...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
362 | 369 |
363 String toString() => 'Enqueuer($name)'; | 370 String toString() => 'Enqueuer($name)'; |
364 | 371 |
365 registerUsedSelector(Selector selector) { | 372 registerUsedSelector(Selector selector) { |
366 Element interceptor = compiler.backend.getInterceptor(selector); | 373 Element interceptor = compiler.backend.getInterceptor(selector); |
367 if (interceptor != null) { | 374 if (interceptor != null) { |
368 registerStaticUse(interceptor); | 375 registerStaticUse(interceptor); |
369 } | 376 } |
370 } | 377 } |
371 } | 378 } |
OLD | NEW |