Chromium Code Reviews| Index: lib/compiler/implementation/enqueue.dart |
| diff --git a/lib/compiler/implementation/enqueue.dart b/lib/compiler/implementation/enqueue.dart |
| index 4a4b3530618480f43f0728e3cd928b74278471b5..7b0a8cf24ab612236de745546adf1a6bd0b6701e 100644 |
| --- a/lib/compiler/implementation/enqueue.dart |
| +++ b/lib/compiler/implementation/enqueue.dart |
| @@ -19,35 +19,6 @@ class EnqueueTask extends CompilerTask { |
| } |
| } |
| -class RecompilationQueue { |
| - final Function itemCompilationContextCreator; |
| - final Queue<WorkItem> queue; |
| - final Set<Element> queueElements; |
| - int processed = 0; |
| - |
| - RecompilationQueue(ItemCompilationContext itemCompilationContextCreator()) |
| - : this.itemCompilationContextCreator = itemCompilationContextCreator, |
| - queue = new Queue<WorkItem>(), |
| - queueElements = new Set<Element>(); |
| - |
| - void add(Element element, TreeElements elements) { |
| - if (queueElements.contains(element)) return; |
| - queueElements.add(element); |
| - queue.add(new WorkItem(element, elements, itemCompilationContextCreator())); |
| - } |
| - |
| - int get length => queue.length; |
| - |
| - bool isEmpty() => queue.isEmpty(); |
| - |
| - WorkItem next() { |
| - WorkItem item = queue.removeLast(); |
| - queueElements.remove(item.element); |
| - processed++; |
| - return item; |
| - } |
| -} |
| - |
| class Enqueuer { |
| final Compiler compiler; // TODO(ahe): Remove this dependency. |
| final Function itemCompilationContextCreator; |
| @@ -56,7 +27,6 @@ class Enqueuer { |
| final Universe universe; |
| final Queue<WorkItem> queue; |
| final Map<Element, TreeElements> resolvedElements; |
| - final RecompilationQueue recompilationCandidates; |
| bool queueIsClosed = false; |
| EnqueueTask task; |
| @@ -68,9 +38,7 @@ class Enqueuer { |
| seenClasses = new Set<ClassElement>(), |
| universe = new Universe(), |
| queue = new Queue<WorkItem>(), |
| - resolvedElements = new Map<Element, TreeElements>(), |
| - recompilationCandidates = |
| - new RecompilationQueue(itemCompilationContextCreator); |
| + resolvedElements = new Map<Element, TreeElements>(); |
| bool get isResolutionQueue => compiler.enqueuer.resolution === this; |
| @@ -89,7 +57,6 @@ class Enqueuer { |
| void addToWorkList(Element element, [TreeElements elements]) { |
| if (element.isForeign()) return; |
| - if (compiler.phase == Compiler.PHASE_RECOMPILING) return; |
| if (queueIsClosed) { |
| if (isResolutionQueue && getCachedElements(element) !== null) return; |
| compiler.internalErrorOnElement(element, "Work list is closed."); |
| @@ -127,14 +94,6 @@ class Enqueuer { |
| addToWorkList(element); |
| } |
| - void registerRecompilationCandidate(Element element, |
| - [TreeElements elements]) { |
| - if (queueIsClosed) { |
| - compiler.internalErrorOnElement(element, "Work list is closed."); |
| - } |
| - recompilationCandidates.add(element, elements); |
| - } |
| - |
| void registerInstantiatedClass(ClassElement cls) { |
| if (cls.isInterface()) { |
| compiler.internalErrorOnElement( |
| @@ -298,6 +257,11 @@ class Enqueuer { |
| } |
| return false; |
| }); |
| + // TODO(sgjesse): Add subscription to the enqueuer to deliver this |
| + // information to the JavaScript backend instead of this hardcoded hack. |
| + if (compiler.backend is js_backend.JavaScriptBackend) { |
| + compiler.backend.addedDynamicSetter(selector); |
|
ngeoffray
2012/09/20 14:43:01
I don't understand why you have to do that here. I
Søren Gjesse
2012/09/21 13:49:44
Having it here ensures that we get just one call w
|
| + } |
| } |
| void registerStaticUse(Element element) { |