| 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 library dart2js.enqueue; | 5 library dart2js.enqueue; |
| 6 | 6 |
| 7 import 'dart:collection' show | 7 import 'dart:collection' show |
| 8 Queue; | 8 Queue; |
| 9 | 9 |
| 10 import 'common/names.dart' show | 10 import 'common/names.dart' show |
| 11 Identifiers; | 11 Identifiers; |
| 12 import 'common/resolution.dart' show | 12 import 'common/resolution.dart' show |
| 13 Resolution; | 13 Resolution; |
| 14 import 'common/work.dart' show | 14 import 'common/work.dart' show |
| 15 ItemCompilationContext, | 15 ItemCompilationContext, |
| 16 WorkItem; | 16 WorkItem; |
| 17 import 'common/tasks.dart' show | 17 import 'common/tasks.dart' show |
| 18 CompilerTask, | 18 CompilerTask, |
| 19 DeferredAction, | 19 DeferredAction, |
| 20 DeferredTask; | 20 DeferredTask; |
| 21 import 'common/codegen.dart' show | 21 import 'common/codegen.dart' show |
| 22 CodegenWorkItem; | 22 CodegenWorkItem; |
| 23 import 'common/resolution.dart' show | 23 import 'common/resolution.dart' show |
| 24 ResolutionWorkItem; | 24 ResolutionWorkItem; |
| 25 import 'compiler.dart' show | 25 import 'compiler.dart' show |
| 26 Compiler; | 26 Compiler; |
| 27 import 'dart_types.dart' show | 27 import 'dart_types.dart' show |
| 28 DartType, | 28 DartType, |
| 29 InterfaceType; | 29 InterfaceType; |
| 30 import 'diagnostics/diagnostic_listener.dart' show |
| 31 DiagnosticReporter; |
| 30 import 'diagnostics/invariant.dart' show | 32 import 'diagnostics/invariant.dart' show |
| 31 invariant; | 33 invariant; |
| 32 import 'diagnostics/spannable.dart' show | 34 import 'diagnostics/spannable.dart' show |
| 33 SpannableAssertionFailure; | 35 SpannableAssertionFailure; |
| 34 import 'elements/elements.dart' show | 36 import 'elements/elements.dart' show |
| 35 AnalyzableElement, | 37 AnalyzableElement, |
| 36 AstElement, | 38 AstElement, |
| 37 ClassElement, | 39 ClassElement, |
| 38 ConstructorElement, | 40 ConstructorElement, |
| 39 Element, | 41 Element, |
| (...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 147 Resolution get resolution => compiler.resolution; | 149 Resolution get resolution => compiler.resolution; |
| 148 | 150 |
| 149 Queue<WorkItem> get queue; | 151 Queue<WorkItem> get queue; |
| 150 bool get queueIsEmpty => queue.isEmpty; | 152 bool get queueIsEmpty => queue.isEmpty; |
| 151 | 153 |
| 152 /// Returns [:true:] if this enqueuer is the resolution enqueuer. | 154 /// Returns [:true:] if this enqueuer is the resolution enqueuer. |
| 153 bool get isResolutionQueue => false; | 155 bool get isResolutionQueue => false; |
| 154 | 156 |
| 155 QueueFilter get filter => compiler.enqueuerFilter; | 157 QueueFilter get filter => compiler.enqueuerFilter; |
| 156 | 158 |
| 159 DiagnosticReporter get reporter => compiler.reporter; |
| 160 |
| 157 /// Returns [:true:] if [member] has been processed by this enqueuer. | 161 /// Returns [:true:] if [member] has been processed by this enqueuer. |
| 158 bool isProcessed(Element member); | 162 bool isProcessed(Element member); |
| 159 | 163 |
| 160 /** | 164 /** |
| 161 * Documentation wanted -- johnniwinther | 165 * Documentation wanted -- johnniwinther |
| 162 * | 166 * |
| 163 * Invariant: [element] must be a declaration element. | 167 * Invariant: [element] must be a declaration element. |
| 164 */ | 168 */ |
| 165 void addToWorkList(Element element) { | 169 void addToWorkList(Element element) { |
| 166 assert(invariant(element, element.isDeclaration)); | 170 assert(invariant(element, element.isDeclaration)); |
| (...skipping 352 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 519 void enqueueReflectiveElements(Iterable<ClassElement> recents) { | 523 void enqueueReflectiveElements(Iterable<ClassElement> recents) { |
| 520 if (!hasEnqueuedReflectiveElements) { | 524 if (!hasEnqueuedReflectiveElements) { |
| 521 logEnqueueReflectiveAction("!START enqueueAll"); | 525 logEnqueueReflectiveAction("!START enqueueAll"); |
| 522 // First round of enqueuing, visit everything that is visible to | 526 // First round of enqueuing, visit everything that is visible to |
| 523 // also pick up static top levels, etc. | 527 // also pick up static top levels, etc. |
| 524 // Also, during the first round, consider all classes that have been seen | 528 // Also, during the first round, consider all classes that have been seen |
| 525 // as recently seen, as we do not know how many rounds of resolution might | 529 // as recently seen, as we do not know how many rounds of resolution might |
| 526 // have run before tree shaking is disabled and thus everything is | 530 // have run before tree shaking is disabled and thus everything is |
| 527 // enqueued. | 531 // enqueued. |
| 528 recents = _processedClasses.toSet(); | 532 recents = _processedClasses.toSet(); |
| 529 compiler.log('Enqueuing everything'); | 533 reporter.log('Enqueuing everything'); |
| 530 for (LibraryElement lib in compiler.libraryLoader.libraries) { | 534 for (LibraryElement lib in compiler.libraryLoader.libraries) { |
| 531 enqueueReflectiveElementsInLibrary(lib, recents); | 535 enqueueReflectiveElementsInLibrary(lib, recents); |
| 532 } | 536 } |
| 533 enqueueReflectiveSpecialClasses(); | 537 enqueueReflectiveSpecialClasses(); |
| 534 hasEnqueuedReflectiveElements = true; | 538 hasEnqueuedReflectiveElements = true; |
| 535 hasEnqueuedReflectiveStaticFields = true; | 539 hasEnqueuedReflectiveStaticFields = true; |
| 536 logEnqueueReflectiveAction("!DONE enqueueAll"); | 540 logEnqueueReflectiveAction("!DONE enqueueAll"); |
| 537 } else if (recents.isNotEmpty) { | 541 } else if (recents.isNotEmpty) { |
| 538 // Keep looking at new classes until fixpoint is reached. | 542 // Keep looking at new classes until fixpoint is reached. |
| 539 logEnqueueReflectiveAction("!START enqueueRecents"); | 543 logEnqueueReflectiveAction("!START enqueueRecents"); |
| (...skipping 356 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 896 } | 900 } |
| 897 | 901 |
| 898 bool onQueueEmpty(Iterable<ClassElement> recentClasses) { | 902 bool onQueueEmpty(Iterable<ClassElement> recentClasses) { |
| 899 emptyDeferredTaskQueue(); | 903 emptyDeferredTaskQueue(); |
| 900 return super.onQueueEmpty(recentClasses); | 904 return super.onQueueEmpty(recentClasses); |
| 901 } | 905 } |
| 902 | 906 |
| 903 void emptyDeferredTaskQueue() { | 907 void emptyDeferredTaskQueue() { |
| 904 while (!deferredTaskQueue.isEmpty) { | 908 while (!deferredTaskQueue.isEmpty) { |
| 905 DeferredTask task = deferredTaskQueue.removeFirst(); | 909 DeferredTask task = deferredTaskQueue.removeFirst(); |
| 906 compiler.withCurrentElement(task.element, task.action); | 910 reporter.withCurrentElement(task.element, task.action); |
| 907 } | 911 } |
| 908 } | 912 } |
| 909 | 913 |
| 910 void _logSpecificSummary(log(message)) { | 914 void _logSpecificSummary(log(message)) { |
| 911 log('Resolved ${resolvedElements.length} elements.'); | 915 log('Resolved ${resolvedElements.length} elements.'); |
| 912 } | 916 } |
| 913 | 917 |
| 914 void forgetElement(Element element) { | 918 void forgetElement(Element element) { |
| 915 super.forgetElement(element); | 919 super.forgetElement(element); |
| 916 resolvedElements.remove(element); | 920 resolvedElements.remove(element); |
| (...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1065 @override | 1069 @override |
| 1066 void processStaticUse(Enqueuer enqueuer, Element element) { | 1070 void processStaticUse(Enqueuer enqueuer, Element element) { |
| 1067 enqueuer.registerStaticUseInternal(element); | 1071 enqueuer.registerStaticUseInternal(element); |
| 1068 } | 1072 } |
| 1069 | 1073 |
| 1070 @override | 1074 @override |
| 1071 void processSelector(Enqueuer enqueuer, UniverseSelector selector) { | 1075 void processSelector(Enqueuer enqueuer, UniverseSelector selector) { |
| 1072 enqueuer.handleUnseenSelectorInternal(selector); | 1076 enqueuer.handleUnseenSelectorInternal(selector); |
| 1073 } | 1077 } |
| 1074 } | 1078 } |
| OLD | NEW |