OLD | NEW |
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, 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.semantics_visitor; | 5 part of dart2js.semantics_visitor; |
6 | 6 |
7 enum SendStructureKind { | 7 enum SendStructureKind { |
8 GET, | 8 GET, |
9 SET, | 9 SET, |
10 INVOKE, | 10 INVOKE, |
(...skipping 730 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
741 Node node = definitions.definitions.nodes.single; | 741 Node node = definitions.definitions.nodes.single; |
742 ParameterElement element = elements[node]; | 742 ParameterElement element = elements[node]; |
743 if (element == null) { | 743 if (element == null) { |
744 throw new SpannableAssertionFailure( | 744 throw new SpannableAssertionFailure( |
745 node, "No parameter structure for $node."); | 745 node, "No parameter structure for $node."); |
746 } | 746 } |
747 if (isRequired) { | 747 if (isRequired) { |
748 return new RequiredParameterStructure( | 748 return new RequiredParameterStructure( |
749 definitions, node, element, index); | 749 definitions, node, element, index); |
750 } else { | 750 } else { |
751 ConstantExpression defaultValue; | 751 // TODO(johnniwinther): Should we differentiate between implicit (null) |
752 if (element.initializer != null) { | 752 // and explicit values? What about optional parameters on redirecting |
753 defaultValue = elements.getConstant(element.initializer); | 753 // factories? |
754 } | |
755 if (isNamed) { | 754 if (isNamed) { |
756 return new NamedParameterStructure( | 755 return new NamedParameterStructure( |
757 definitions, node, element, defaultValue); | 756 definitions, node, element, element.constant); |
758 } else { | 757 } else { |
759 return new OptionalParameterStructure( | 758 return new OptionalParameterStructure( |
760 definitions, node, element, defaultValue, index); | 759 definitions, node, element, element.constant, index); |
761 } | 760 } |
762 } | 761 } |
763 } | 762 } |
764 | 763 |
765 void computeVariableStructures( | 764 void computeVariableStructures( |
766 VariableDefinitions definitions, | 765 VariableDefinitions definitions, |
767 void callback(Node node, VariableStructure structure)) { | 766 void callback(Node node, VariableStructure structure)) { |
768 for (Node node in definitions.definitions) { | 767 for (Node node in definitions.definitions) { |
769 callback(definitions, computeVariableStructure(node)); | 768 callback(definitions, computeVariableStructure(node)); |
770 } | 769 } |
(...skipping 14 matching lines...) Expand all Loading... |
785 return internalError(node, "Unexpected variable $element."); | 784 return internalError(node, "Unexpected variable $element."); |
786 } | 785 } |
787 if (element.isConst) { | 786 if (element.isConst) { |
788 ConstantExpression constant = elements.getConstant(element.initializer); | 787 ConstantExpression constant = elements.getConstant(element.initializer); |
789 return new ConstantVariableStructure(kind, node, element, constant); | 788 return new ConstantVariableStructure(kind, node, element, constant); |
790 } else { | 789 } else { |
791 return new NonConstantVariableStructure(kind, node, element); | 790 return new NonConstantVariableStructure(kind, node, element); |
792 } | 791 } |
793 } | 792 } |
794 } | 793 } |
OLD | NEW |