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 part of dart2js; | 5 part of dart2js; |
6 | 6 |
7 /** | 7 /** |
8 * The [ConstantHandler] keeps track of compile-time constants, | 8 * The [ConstantHandler] keeps track of compile-time constants, |
9 * initializations of global and static fields, and default values of | 9 * initializations of global and static fields, and default values of |
10 * optional parameters. | 10 * optional parameters. |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
55 compiledConstants.add(constant); | 55 compiledConstants.add(constant); |
56 } | 56 } |
57 | 57 |
58 void registerInstantiatedClass(ClassElement element, TreeElements elements) { | 58 void registerInstantiatedClass(ClassElement element, TreeElements elements) { |
59 if (isMetadata) return; | 59 if (isMetadata) return; |
60 compiler.enqueuer.codegen.registerInstantiatedClass(element, elements); | 60 compiler.enqueuer.codegen.registerInstantiatedClass(element, elements); |
61 } | 61 } |
62 | 62 |
63 void registerStaticUse(Element element) { | 63 void registerStaticUse(Element element) { |
64 if (isMetadata) return; | 64 if (isMetadata) return; |
| 65 compiler.analyzeElement(element.declaration); |
65 compiler.enqueuer.codegen.registerStaticUse(element); | 66 compiler.enqueuer.codegen.registerStaticUse(element); |
66 } | 67 } |
67 | 68 |
68 void registerGetOfStaticFunction(FunctionElement element) { | 69 void registerGetOfStaticFunction(FunctionElement element) { |
69 if (isMetadata) return; | 70 if (isMetadata) return; |
| 71 compiler.analyzeElement(element.declaration); |
70 compiler.enqueuer.codegen.registerGetOfStaticFunction(element); | 72 compiler.enqueuer.codegen.registerGetOfStaticFunction(element); |
71 } | 73 } |
72 | 74 |
73 void registerStringInstance(TreeElements elements) { | 75 void registerStringInstance(TreeElements elements) { |
74 registerInstantiatedClass(compiler.stringClass, elements); | 76 registerInstantiatedClass(compiler.stringClass, elements); |
75 } | 77 } |
76 | 78 |
77 void registerCreateRuntimeTypeFunction() { | 79 void registerCreateRuntimeTypeFunction() { |
78 if (createRuntimeTypeFunction != null) return; | 80 if (createRuntimeTypeFunction != null) return; |
79 SourceString helperName = const SourceString('createRuntimeType'); | 81 SourceString helperName = const SourceString('createRuntimeType'); |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
117 * Returns the a compile-time constant if the variable could be compiled | 119 * Returns the a compile-time constant if the variable could be compiled |
118 * eagerly. Otherwise returns `null`. | 120 * eagerly. Otherwise returns `null`. |
119 */ | 121 */ |
120 Constant compileVariable(VariableElement element, {bool isConst: false}) { | 122 Constant compileVariable(VariableElement element, {bool isConst: false}) { |
121 return measure(() { | 123 return measure(() { |
122 if (initialVariableValues.containsKey(element)) { | 124 if (initialVariableValues.containsKey(element)) { |
123 Constant result = initialVariableValues[element]; | 125 Constant result = initialVariableValues[element]; |
124 return result; | 126 return result; |
125 } | 127 } |
126 return compiler.withCurrentElement(element, () { | 128 return compiler.withCurrentElement(element, () { |
127 TreeElements definitions = compiler.analyzeElement(element); | 129 TreeElements definitions = compiler.analyzeElement(element.declaration); |
128 Constant constant = compileVariableWithDefinitions( | 130 Constant constant = compileVariableWithDefinitions( |
129 element, definitions, isConst: isConst); | 131 element, definitions, isConst: isConst); |
130 return constant; | 132 return constant; |
131 }); | 133 }); |
132 }); | 134 }); |
133 } | 135 } |
134 | 136 |
135 /** | 137 /** |
136 * Returns the a compile-time constant if the variable could be compiled | 138 * Returns the a compile-time constant if the variable could be compiled |
137 * eagerly. If the variable needs to be initialized lazily returns `null`. | 139 * eagerly. If the variable needs to be initialized lazily returns `null`. |
(...skipping 500 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
638 return compiledArguments; | 640 return compiledArguments; |
639 } | 641 } |
640 | 642 |
641 Constant visitNewExpression(NewExpression node) { | 643 Constant visitNewExpression(NewExpression node) { |
642 if (!node.isConst()) { | 644 if (!node.isConst()) { |
643 return signalNotCompileTimeConstant(node); | 645 return signalNotCompileTimeConstant(node); |
644 } | 646 } |
645 | 647 |
646 Send send = node.send; | 648 Send send = node.send; |
647 FunctionElement constructor = elements[send]; | 649 FunctionElement constructor = elements[send]; |
| 650 // TODO(ahe): This is nasty: we must eagerly analyze the |
| 651 // constructor to ensure the redirectionTarget has been computed |
| 652 // correctly. Find a way to avoid this. |
| 653 compiler.analyzeElement(constructor.declaration); |
648 constructor = constructor.redirectionTarget; | 654 constructor = constructor.redirectionTarget; |
649 ClassElement classElement = constructor.getEnclosingClass(); | 655 ClassElement classElement = constructor.getEnclosingClass(); |
650 // The constructor must be an implementation to ensure that field | 656 // The constructor must be an implementation to ensure that field |
651 // initializers are handled correctly. | 657 // initializers are handled correctly. |
652 constructor = constructor.implementation; | 658 constructor = constructor.implementation; |
653 assert(invariant(node, constructor.isImplementation)); | 659 assert(invariant(node, constructor.isImplementation)); |
654 | 660 |
655 Selector selector = elements.getSelector(send); | 661 Selector selector = elements.getSelector(send); |
656 List<Constant> arguments = evaluateArgumentsToConstructor( | 662 List<Constant> arguments = evaluateArgumentsToConstructor( |
657 node, selector, send.arguments, constructor); | 663 node, selector, send.arguments, constructor); |
(...skipping 223 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
881 if (fieldValue == null) { | 887 if (fieldValue == null) { |
882 // Use the default value. | 888 // Use the default value. |
883 fieldValue = handler.compileConstant(field); | 889 fieldValue = handler.compileConstant(field); |
884 } | 890 } |
885 jsNewArguments.add(fieldValue); | 891 jsNewArguments.add(fieldValue); |
886 }, | 892 }, |
887 includeSuperAndInjectedMembers: true); | 893 includeSuperAndInjectedMembers: true); |
888 return jsNewArguments; | 894 return jsNewArguments; |
889 } | 895 } |
890 } | 896 } |
OLD | NEW |