Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(65)

Unified Diff: compiler/java/com/google/dart/compiler/parser/DartParser.java

Issue 8948001: Updates dartc to recognize 'default' keyword on interface and updated factory method syntax (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Feedback from mmendez Created 9 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: compiler/java/com/google/dart/compiler/parser/DartParser.java
diff --git a/compiler/java/com/google/dart/compiler/parser/DartParser.java b/compiler/java/com/google/dart/compiler/parser/DartParser.java
index 85e54bf233d968aeb3ba567714bd926568e0b44c..fc5e8f0a0f4064ab2b420d836ad52cd5f90315a5 100644
--- a/compiler/java/com/google/dart/compiler/parser/DartParser.java
+++ b/compiler/java/com/google/dart/compiler/parser/DartParser.java
@@ -58,7 +58,7 @@ import com.google.dart.compiler.ast.DartNewExpression;
import com.google.dart.compiler.ast.DartNode;
import com.google.dart.compiler.ast.DartNullLiteral;
import com.google.dart.compiler.ast.DartParameter;
-import com.google.dart.compiler.ast.DartParameterizedNode;
+import com.google.dart.compiler.ast.DartParameterizedTypeNode;
import com.google.dart.compiler.ast.DartParenthesizedExpression;
import com.google.dart.compiler.ast.DartPropertyAccess;
import com.google.dart.compiler.ast.DartRedirectConstructorInvocation;
@@ -125,7 +125,7 @@ public class DartParser extends CompletionHooksParserBase {
private static final String ASSERT_KEYWORD = "assert";
private static final String CLASS_KEYWORD = "class";
private static final String EXTENDS_KEYWORD = "extends";
- private static final String FACTORY_KEYWORD = "factory";
+ private static final String FACTORY_KEYWORD = "factory"; // TODO(zundel): remove
private static final String GETTER_KEYWORD = "get";
private static final String IMPLEMENTS_KEYWORD = "implements";
private static final String INTERFACE_KEYWORD = "interface";
@@ -579,9 +579,13 @@ public class DartParser extends CompletionHooksParserBase {
}
// Deal with factory clause for interfaces.
- DartTypeNode factory = null;
- if (isParsingInterface && optionalPseudoKeyword(FACTORY_KEYWORD)) {
- factory = parseTypeAnnotation();
+ DartParameterizedTypeNode defaultClass = null;
+ if (isParsingInterface &&
+ (optionalDeprecatedFactory() || optional(Token.DEFAULT))) {
+ DartExpression qualified = parseQualified();
+ List<DartTypeParameter> defaultTypeParameters = parseTypeParametersOpt();
+ defaultClass = doneWithoutConsuming(new DartParameterizedTypeNode(qualified,
+ defaultTypeParameters));
}
// Deal with native clause for classes.
@@ -610,7 +614,7 @@ public class DartParser extends CompletionHooksParserBase {
}
if (isParsingInterface) {
- return done(new DartClass(name, superType, interfaces, members, typeParameters, factory));
+ return done(new DartClass(name, superType, interfaces, members, typeParameters, defaultClass));
} else {
return done(new DartClass(name,
nativeName,
@@ -622,6 +626,15 @@ public class DartParser extends CompletionHooksParserBase {
}
}
+ private boolean optionalDeprecatedFactory() {
+ if (optionalPseudoKeyword(FACTORY_KEYWORD)) {
+ // Uncommenting this makes tests fail until corelib is cleaned up
+ // reportError(position(), ParserErrorCode.DEPRECATED_USE_OF_FACTORY_KEYWORD);
+ return true;
+ }
+ return false;
+ }
+
private List<DartTypeNode> parseTypeAnnotationList() {
List<DartTypeNode> result = new ArrayList<DartTypeNode>();
do {
@@ -959,11 +972,10 @@ public class DartParser extends CompletionHooksParserBase {
*
* : get
* | set
- *
- * | identifier typeArguments? ( // Case 1
- * | identifier DOT identifier typearguments? ( // Case 2
- * | identifier typeArguments? DOT identifier ( // Case 3
- * | identifier DOT identifier typeArguments? DOT identifier ( // Case 4
+ * | operator
+ * | identifier ( // Case 1
+ * | identifier DOT identifier ( // Case 2
+ * | identifier DOT identifier DOT identifier ( // Case 3
*
* @return <code>true</code> if the signature of a method has been found. No tokens are consumed.
*/
@@ -981,25 +993,13 @@ public class DartParser extends CompletionHooksParserBase {
consume(Token.IDENTIFIER);
if (peek(0).equals(Token.PERIOD) && peek(1).equals(Token.IDENTIFIER)) {
- // Case 2 class.id<typearguments?>
- // Case 4, a constructor of the form library.class<typearguments?>.id
consume(Token.PERIOD);
consume(Token.IDENTIFIER);
- parseTypeArgumentsOpt();
- if (peek(0).equals(Token.PERIOD) && peek(1).equals(Token.IDENTIFIER)
- && peek(2).equals(Token.LPAREN)) {
- return true;
- }
- } else {
- // Case 1, id<typearguments?>
- // Case 3, class.<typearguments?>.id
- parseTypeArgumentsOpt();
- }
- if (peek(0).equals(Token.PERIOD) && peek(1).equals(Token.IDENTIFIER)) {
- // Case 3, a constructor of the form class<typearguments?>.id
- consume(Token.PERIOD);
- consume(Token.IDENTIFIER);
+ if (peek(0).equals(Token.PERIOD) && peek(1).equals(Token.IDENTIFIER)) {
+ consume(Token.PERIOD);
+ consume(Token.IDENTIFIER);
+ }
}
// next token should be LPAREN
@@ -1019,10 +1019,6 @@ public class DartParser extends CompletionHooksParserBase {
private DartMethodDefinition parseFactory(Modifiers modifiers) {
beginMethodName();
DartExpression name = parseQualified();
- List<DartTypeParameter> typeParameters = parseTypeParametersOpt();
- if (!typeParameters.isEmpty()) {
- name = doneWithoutConsuming(new DartParameterizedNode(name, typeParameters));
- }
if (optional(Token.PERIOD)) {
name = doneWithoutConsuming(new DartPropertyAccess(name, parseIdentifier()));
}
@@ -1036,7 +1032,7 @@ public class DartParser extends CompletionHooksParserBase {
function = new DartFunction(formals, parseFunctionStatementBody(true), null);
}
doneWithoutConsuming(function);
- return DartMethodDefinition.create(name, function, modifiers, null, typeParameters);
+ return DartMethodDefinition.create(name, function, modifiers, null);
}
private DartIdentifier parseVoidIdentifier() {
@@ -1106,8 +1102,6 @@ public class DartParser extends CompletionHooksParserBase {
} else {
// Normal method or property.
name = parseIdentifier();
- // TODO(zundel): something constructive with the type arguments
- parseTypeArgumentsOpt();
}
// Check for named constructor.
@@ -1172,7 +1166,7 @@ public class DartParser extends CompletionHooksParserBase {
}
DartFunction function = doneWithoutConsuming(new DartFunction(parameters, body, returnType));
- return DartMethodDefinition.create(name, function, modifiers, initializers, null);
+ return DartMethodDefinition.create(name, function, modifiers, initializers);
}
private DartBlock parseNativeBlock(Modifiers modifiers) {

Powered by Google App Engine
This is Rietveld 408576698