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

Unified Diff: analyzer/lib/src/generated/incremental_resolution_validator.dart

Issue 1400473008: Roll Observatory packages and add a roll script (Closed) Base URL: git@github.com:dart-lang/observatory_pub_packages.git@master
Patch Set: Created 5 years, 2 months 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: analyzer/lib/src/generated/incremental_resolution_validator.dart
diff --git a/analyzer/lib/src/generated/incremental_resolution_validator.dart b/analyzer/lib/src/generated/incremental_resolution_validator.dart
deleted file mode 100644
index bab107ed465b44ab30351afc7a53249b36028f50..0000000000000000000000000000000000000000
--- a/analyzer/lib/src/generated/incremental_resolution_validator.dart
+++ /dev/null
@@ -1,938 +0,0 @@
-// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
-// for details. All rights reserved. Use of this source code is governed by a
-// BSD-style license that can be found in the LICENSE file.
-
-library engine.incremental_resolution_validator;
-
-import 'package:analyzer/src/generated/ast.dart';
-import 'package:analyzer/src/generated/element.dart';
-
-/**
- * Validates that the [actual] and the [expected] units have the same structure
- * and resolution. Throws [IncrementalResolutionMismatch] otherwise.
- */
-void assertSameResolution(CompilationUnit actual, CompilationUnit expected,
- {bool validateTypes: false}) {
- _SameResolutionValidator validator =
- new _SameResolutionValidator(validateTypes, expected);
- actual.accept(validator);
-}
-
-/**
- * This exception is thrown when a mismatch between actual and expected AST
- * or resolution is found.
- */
-class IncrementalResolutionMismatch {
- final String message;
- IncrementalResolutionMismatch(this.message);
-}
-
-class _SameResolutionValidator implements AstVisitor {
- final bool validateTypes;
- AstNode other;
-
- _SameResolutionValidator(this.validateTypes, this.other);
-
- @override
- visitAdjacentStrings(AdjacentStrings node) {}
-
- @override
- visitAnnotation(Annotation node) {
- Annotation other = this.other;
- _visitNode(node.name, other.name);
- _visitNode(node.constructorName, other.constructorName);
- _visitNode(node.arguments, other.arguments);
- _verifyElement(node.element, other.element);
- }
-
- @override
- visitArgumentList(ArgumentList node) {
- ArgumentList other = this.other;
- _visitList(node.arguments, other.arguments);
- }
-
- @override
- visitAsExpression(AsExpression node) {
- AsExpression other = this.other;
- _visitExpression(node, other);
- _visitNode(node.expression, other.expression);
- _visitNode(node.type, other.type);
- }
-
- @override
- visitAssertStatement(AssertStatement node) {
- AssertStatement other = this.other;
- _visitNode(node.condition, other.condition);
- }
-
- @override
- visitAssignmentExpression(AssignmentExpression node) {
- AssignmentExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitNode(node.leftHandSide, other.leftHandSide);
- _visitNode(node.rightHandSide, other.rightHandSide);
- }
-
- @override
- visitAwaitExpression(AwaitExpression node) {
- AwaitExpression other = this.other;
- _visitExpression(node, other);
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitBinaryExpression(BinaryExpression node) {
- BinaryExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitNode(node.leftOperand, other.leftOperand);
- _visitNode(node.rightOperand, other.rightOperand);
- }
-
- @override
- visitBlock(Block node) {
- Block other = this.other;
- _visitList(node.statements, other.statements);
- }
-
- @override
- visitBlockFunctionBody(BlockFunctionBody node) {
- BlockFunctionBody other = this.other;
- _visitNode(node.block, other.block);
- }
-
- @override
- visitBooleanLiteral(BooleanLiteral node) {
- BooleanLiteral other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitBreakStatement(BreakStatement node) {
- BreakStatement other = this.other;
- _visitNode(node.label, other.label);
- }
-
- @override
- visitCascadeExpression(CascadeExpression node) {
- CascadeExpression other = this.other;
- _visitExpression(node, other);
- _visitNode(node.target, other.target);
- _visitList(node.cascadeSections, other.cascadeSections);
- }
-
- @override
- visitCatchClause(CatchClause node) {
- CatchClause other = this.other;
- _visitNode(node.exceptionType, other.exceptionType);
- _visitNode(node.exceptionParameter, other.exceptionParameter);
- _visitNode(node.stackTraceParameter, other.stackTraceParameter);
- _visitNode(node.body, other.body);
- }
-
- @override
- visitClassDeclaration(ClassDeclaration node) {
- ClassDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.name, other.name);
- _visitNode(node.typeParameters, other.typeParameters);
- _visitNode(node.extendsClause, other.extendsClause);
- _visitNode(node.implementsClause, other.implementsClause);
- _visitNode(node.withClause, other.withClause);
- _visitList(node.members, other.members);
- }
-
- @override
- visitClassTypeAlias(ClassTypeAlias node) {
- ClassTypeAlias other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.name, other.name);
- _visitNode(node.typeParameters, other.typeParameters);
- _visitNode(node.superclass, other.superclass);
- _visitNode(node.withClause, other.withClause);
- }
-
- @override
- visitComment(Comment node) {
- Comment other = this.other;
- _visitList(node.references, other.references);
- }
-
- @override
- visitCommentReference(CommentReference node) {
- CommentReference other = this.other;
- _visitNode(node.identifier, other.identifier);
- }
-
- @override
- visitCompilationUnit(CompilationUnit node) {
- CompilationUnit other = this.other;
- _verifyElement(node.element, other.element);
- _visitList(node.directives, other.directives);
- _visitList(node.declarations, other.declarations);
- }
-
- @override
- visitConditionalExpression(ConditionalExpression node) {
- ConditionalExpression other = this.other;
- _visitExpression(node, other);
- _visitNode(node.condition, other.condition);
- _visitNode(node.thenExpression, other.thenExpression);
- _visitNode(node.elseExpression, other.elseExpression);
- }
-
- @override
- visitConstructorDeclaration(ConstructorDeclaration node) {
- ConstructorDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.returnType, other.returnType);
- _visitNode(node.name, other.name);
- _visitNode(node.parameters, other.parameters);
- _visitNode(node.redirectedConstructor, other.redirectedConstructor);
- _visitList(node.initializers, other.initializers);
- }
-
- @override
- visitConstructorFieldInitializer(ConstructorFieldInitializer node) {
- ConstructorFieldInitializer other = this.other;
- _visitNode(node.fieldName, other.fieldName);
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitConstructorName(ConstructorName node) {
- ConstructorName other = this.other;
- _verifyElement(node.staticElement, other.staticElement);
- _visitNode(node.type, other.type);
- _visitNode(node.name, other.name);
- }
-
- @override
- visitContinueStatement(ContinueStatement node) {
- ContinueStatement other = this.other;
- _visitNode(node.label, other.label);
- }
-
- @override
- visitDeclaredIdentifier(DeclaredIdentifier node) {
- DeclaredIdentifier other = this.other;
- _visitNode(node.type, other.type);
- _visitNode(node.identifier, other.identifier);
- }
-
- @override
- visitDefaultFormalParameter(DefaultFormalParameter node) {
- DefaultFormalParameter other = this.other;
- _visitNode(node.parameter, other.parameter);
- _visitNode(node.defaultValue, other.defaultValue);
- }
-
- @override
- visitDoStatement(DoStatement node) {
- DoStatement other = this.other;
- _visitNode(node.condition, other.condition);
- _visitNode(node.body, other.body);
- }
-
- @override
- visitDoubleLiteral(DoubleLiteral node) {
- DoubleLiteral other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitEmptyFunctionBody(EmptyFunctionBody node) {}
-
- @override
- visitEmptyStatement(EmptyStatement node) {}
-
- @override
- visitEnumConstantDeclaration(EnumConstantDeclaration node) {
- EnumConstantDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.name, other.name);
- }
-
- @override
- visitEnumDeclaration(EnumDeclaration node) {
- EnumDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.name, other.name);
- _visitList(node.constants, other.constants);
- }
-
- @override
- visitExportDirective(ExportDirective node) {
- ExportDirective other = this.other;
- _visitDirective(node, other);
- }
-
- @override
- visitExpressionFunctionBody(ExpressionFunctionBody node) {
- ExpressionFunctionBody other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitExpressionStatement(ExpressionStatement node) {
- ExpressionStatement other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitExtendsClause(ExtendsClause node) {
- ExtendsClause other = this.other;
- _visitNode(node.superclass, other.superclass);
- }
-
- @override
- visitFieldDeclaration(FieldDeclaration node) {
- FieldDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.fields, other.fields);
- }
-
- @override
- visitFieldFormalParameter(FieldFormalParameter node) {
- FieldFormalParameter other = this.other;
- _visitNormalFormalParameter(node, other);
- _visitNode(node.type, other.type);
- _visitNode(node.parameters, other.parameters);
- }
-
- @override
- visitForEachStatement(ForEachStatement node) {
- ForEachStatement other = this.other;
- _visitNode(node.identifier, other.identifier);
- _visitNode(node.loopVariable, other.loopVariable);
- _visitNode(node.iterable, other.iterable);
- }
-
- @override
- visitFormalParameterList(FormalParameterList node) {
- FormalParameterList other = this.other;
- _visitList(node.parameters, other.parameters);
- }
-
- @override
- visitForStatement(ForStatement node) {
- ForStatement other = this.other;
- _visitNode(node.variables, other.variables);
- _visitNode(node.initialization, other.initialization);
- _visitNode(node.condition, other.condition);
- _visitList(node.updaters, other.updaters);
- _visitNode(node.body, other.body);
- }
-
- @override
- visitFunctionDeclaration(FunctionDeclaration node) {
- FunctionDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.returnType, other.returnType);
- _visitNode(node.name, other.name);
- _visitNode(node.functionExpression, other.functionExpression);
- }
-
- @override
- visitFunctionDeclarationStatement(FunctionDeclarationStatement node) {
- FunctionDeclarationStatement other = this.other;
- _visitNode(node.functionDeclaration, other.functionDeclaration);
- }
-
- @override
- visitFunctionExpression(FunctionExpression node) {
- FunctionExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.element, other.element);
- _visitNode(node.parameters, other.parameters);
- _visitNode(node.body, other.body);
- }
-
- @override
- visitFunctionExpressionInvocation(FunctionExpressionInvocation node) {
- FunctionExpressionInvocation other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitNode(node.function, other.function);
- _visitNode(node.argumentList, other.argumentList);
- }
-
- @override
- visitFunctionTypeAlias(FunctionTypeAlias node) {
- FunctionTypeAlias other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.returnType, other.returnType);
- _visitNode(node.name, other.name);
- _visitNode(node.typeParameters, other.typeParameters);
- _visitNode(node.parameters, other.parameters);
- }
-
- @override
- visitFunctionTypedFormalParameter(FunctionTypedFormalParameter node) {
- FunctionTypedFormalParameter other = this.other;
- _visitNormalFormalParameter(node, other);
- _visitNode(node.returnType, other.returnType);
- _visitNode(node.parameters, other.parameters);
- }
-
- @override
- visitHideCombinator(HideCombinator node) {
- HideCombinator other = this.other;
- _visitList(node.hiddenNames, other.hiddenNames);
- }
-
- @override
- visitIfStatement(IfStatement node) {
- IfStatement other = this.other;
- _visitNode(node.condition, other.condition);
- _visitNode(node.thenStatement, other.thenStatement);
- _visitNode(node.elseStatement, other.elseStatement);
- }
-
- @override
- visitImplementsClause(ImplementsClause node) {
- ImplementsClause other = this.other;
- _visitList(node.interfaces, other.interfaces);
- }
-
- @override
- visitImportDirective(ImportDirective node) {
- ImportDirective other = this.other;
- _visitDirective(node, other);
- _visitNode(node.prefix, other.prefix);
- _verifyElement(node.uriElement, other.uriElement);
- }
-
- @override
- visitIndexExpression(IndexExpression node) {
- IndexExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitNode(node.target, other.target);
- _visitNode(node.index, other.index);
- }
-
- @override
- visitInstanceCreationExpression(InstanceCreationExpression node) {
- InstanceCreationExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _visitNode(node.constructorName, other.constructorName);
- _visitNode(node.argumentList, other.argumentList);
- }
-
- @override
- visitIntegerLiteral(IntegerLiteral node) {
- IntegerLiteral other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitInterpolationExpression(InterpolationExpression node) {
- InterpolationExpression other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitInterpolationString(InterpolationString node) {}
-
- @override
- visitIsExpression(IsExpression node) {
- IsExpression other = this.other;
- _visitExpression(node, other);
- _visitNode(node.expression, other.expression);
- _visitNode(node.type, other.type);
- }
-
- @override
- visitLabel(Label node) {
- Label other = this.other;
- _visitNode(node.label, other.label);
- }
-
- @override
- visitLabeledStatement(LabeledStatement node) {
- LabeledStatement other = this.other;
- _visitList(node.labels, other.labels);
- _visitNode(node.statement, other.statement);
- }
-
- @override
- visitLibraryDirective(LibraryDirective node) {
- LibraryDirective other = this.other;
- _visitDirective(node, other);
- _visitNode(node.name, other.name);
- }
-
- @override
- visitLibraryIdentifier(LibraryIdentifier node) {
- LibraryIdentifier other = this.other;
- _visitList(node.components, other.components);
- }
-
- @override
- visitListLiteral(ListLiteral node) {
- ListLiteral other = this.other;
- _visitExpression(node, other);
- _visitList(node.elements, other.elements);
- }
-
- @override
- visitMapLiteral(MapLiteral node) {
- MapLiteral other = this.other;
- _visitExpression(node, other);
- _visitList(node.entries, other.entries);
- }
-
- @override
- visitMapLiteralEntry(MapLiteralEntry node) {
- MapLiteralEntry other = this.other;
- _visitNode(node.key, other.key);
- _visitNode(node.value, other.value);
- }
-
- @override
- visitMethodDeclaration(MethodDeclaration node) {
- MethodDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.name, other.name);
- _visitNode(node.parameters, other.parameters);
- _visitNode(node.body, other.body);
- }
-
- @override
- visitMethodInvocation(MethodInvocation node) {
- MethodInvocation other = this.other;
- _visitNode(node.target, other.target);
- _visitNode(node.methodName, other.methodName);
- _visitNode(node.argumentList, other.argumentList);
- }
-
- @override
- visitNamedExpression(NamedExpression node) {
- NamedExpression other = this.other;
- _visitNode(node.name, other.name);
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitNativeClause(NativeClause node) {}
-
- @override
- visitNativeFunctionBody(NativeFunctionBody node) {}
-
- @override
- visitNullLiteral(NullLiteral node) {
- NullLiteral other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitParenthesizedExpression(ParenthesizedExpression node) {
- ParenthesizedExpression other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitPartDirective(PartDirective node) {
- PartDirective other = this.other;
- _visitDirective(node, other);
- }
-
- @override
- visitPartOfDirective(PartOfDirective node) {
- PartOfDirective other = this.other;
- _visitDirective(node, other);
- _visitNode(node.libraryName, other.libraryName);
- }
-
- @override
- visitPostfixExpression(PostfixExpression node) {
- PostfixExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitNode(node.operand, other.operand);
- }
-
- @override
- visitPrefixedIdentifier(PrefixedIdentifier node) {
- PrefixedIdentifier other = this.other;
- _visitExpression(node, other);
- _visitNode(node.prefix, other.prefix);
- _visitNode(node.identifier, other.identifier);
- }
-
- @override
- visitPrefixExpression(PrefixExpression node) {
- PrefixExpression other = this.other;
- _visitExpression(node, other);
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitNode(node.operand, other.operand);
- }
-
- @override
- visitPropertyAccess(PropertyAccess node) {
- PropertyAccess other = this.other;
- _visitExpression(node, other);
- _visitNode(node.target, other.target);
- _visitNode(node.propertyName, other.propertyName);
- }
-
- @override
- visitRedirectingConstructorInvocation(RedirectingConstructorInvocation node) {
- RedirectingConstructorInvocation other = this.other;
- _verifyElement(node.staticElement, other.staticElement);
- _visitNode(node.constructorName, other.constructorName);
- _visitNode(node.argumentList, other.argumentList);
- }
-
- @override
- visitRethrowExpression(RethrowExpression node) {
- RethrowExpression other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitReturnStatement(ReturnStatement node) {
- ReturnStatement other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitScriptTag(ScriptTag node) {}
-
- @override
- visitShowCombinator(ShowCombinator node) {
- ShowCombinator other = this.other;
- _visitList(node.shownNames, other.shownNames);
- }
-
- @override
- visitSimpleFormalParameter(SimpleFormalParameter node) {
- SimpleFormalParameter other = this.other;
- _visitNormalFormalParameter(node, other);
- _visitNode(node.type, other.type);
- }
-
- @override
- visitSimpleIdentifier(SimpleIdentifier node) {
- SimpleIdentifier other = this.other;
- _verifyElement(node.staticElement, other.staticElement);
- _verifyElement(node.propagatedElement, other.propagatedElement);
- _visitExpression(node, other);
- }
-
- @override
- visitSimpleStringLiteral(SimpleStringLiteral node) {}
-
- @override
- visitStringInterpolation(StringInterpolation node) {
- StringInterpolation other = this.other;
- _visitList(node.elements, other.elements);
- }
-
- @override
- visitSuperConstructorInvocation(SuperConstructorInvocation node) {
- SuperConstructorInvocation other = this.other;
- _verifyElement(node.staticElement, other.staticElement);
- _visitNode(node.constructorName, other.constructorName);
- _visitNode(node.argumentList, other.argumentList);
- }
-
- @override
- visitSuperExpression(SuperExpression node) {
- SuperExpression other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitSwitchCase(SwitchCase node) {
- SwitchCase other = this.other;
- _visitList(node.labels, other.labels);
- _visitNode(node.expression, other.expression);
- _visitList(node.statements, other.statements);
- }
-
- @override
- visitSwitchDefault(SwitchDefault node) {
- SwitchDefault other = this.other;
- _visitList(node.statements, other.statements);
- }
-
- @override
- visitSwitchStatement(SwitchStatement node) {
- SwitchStatement other = this.other;
- _visitNode(node.expression, other.expression);
- _visitList(node.members, other.members);
- }
-
- @override
- visitSymbolLiteral(SymbolLiteral node) {}
-
- @override
- visitThisExpression(ThisExpression node) {
- ThisExpression other = this.other;
- _visitExpression(node, other);
- }
-
- @override
- visitThrowExpression(ThrowExpression node) {
- ThrowExpression other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- @override
- visitTopLevelVariableDeclaration(TopLevelVariableDeclaration node) {
- TopLevelVariableDeclaration other = this.other;
- _visitNode(node.variables, other.variables);
- }
-
- @override
- visitTryStatement(TryStatement node) {
- TryStatement other = this.other;
- _visitNode(node.body, other.body);
- _visitList(node.catchClauses, other.catchClauses);
- _visitNode(node.finallyBlock, other.finallyBlock);
- }
-
- @override
- visitTypeArgumentList(TypeArgumentList node) {
- TypeArgumentList other = this.other;
- _visitList(node.arguments, other.arguments);
- }
-
- @override
- visitTypeName(TypeName node) {
- TypeName other = this.other;
- _verifyType(node.type, other.type);
- _visitNode(node.name, node.name);
- _visitNode(node.typeArguments, other.typeArguments);
- }
-
- @override
- visitTypeParameter(TypeParameter node) {
- TypeParameter other = this.other;
- _visitNode(node.name, other.name);
- _visitNode(node.bound, other.bound);
- }
-
- @override
- visitTypeParameterList(TypeParameterList node) {
- TypeParameterList other = this.other;
- _visitList(node.typeParameters, other.typeParameters);
- }
-
- @override
- visitVariableDeclaration(VariableDeclaration node) {
- VariableDeclaration other = this.other;
- _visitDeclaration(node, other);
- _visitNode(node.name, other.name);
- _visitNode(node.initializer, other.initializer);
- }
-
- @override
- visitVariableDeclarationList(VariableDeclarationList node) {
- VariableDeclarationList other = this.other;
- _visitNode(node.type, other.type);
- _visitList(node.variables, other.variables);
- }
-
- @override
- visitVariableDeclarationStatement(VariableDeclarationStatement node) {
- VariableDeclarationStatement other = this.other;
- _visitNode(node.variables, other.variables);
- }
-
- @override
- visitWhileStatement(WhileStatement node) {
- WhileStatement other = this.other;
- _visitNode(node.condition, other.condition);
- _visitNode(node.body, other.body);
- }
-
- @override
- visitWithClause(WithClause node) {
- WithClause other = this.other;
- _visitList(node.mixinTypes, other.mixinTypes);
- }
-
- @override
- visitYieldStatement(YieldStatement node) {
- YieldStatement other = this.other;
- _visitNode(node.expression, other.expression);
- }
-
- void _assertNode(AstNode a, AstNode b) {
- _expectEquals(a.offset, b.offset);
- _expectEquals(a.length, b.length);
- }
-
- void _expectEquals(actual, expected) {
- if (actual != expected) {
- String message = '';
- message += 'Expected: $expected\n';
- message += ' Actual: $actual\n';
- _fail(message);
- }
- }
-
- void _expectIsNull(obj) {
- if (obj != null) {
- String message = '';
- message += 'Expected: null\n';
- message += ' Actual: $obj\n';
- _fail(message);
- }
- }
-
- void _expectLength(List actualList, int expected) {
- String message = '';
- message += 'Expected length: $expected\n';
- if (actualList == null) {
- message += 'but null found.';
- _fail(message);
- }
- int actual = actualList.length;
- if (actual != expected) {
- message += 'but $actual found\n';
- message += 'in $actualList';
- _fail(message);
- }
- }
-
- void _fail(String message) {
- throw new IncrementalResolutionMismatch(message);
- }
-
- void _verifyElement(Element a, Element b) {
- if (a is Member && b is Member) {
- a = (a as Member).baseElement;
- b = (b as Member).baseElement;
- }
- String locationA = _getElementLocationWithoutUri(a);
- String locationB = _getElementLocationWithoutUri(b);
- if (locationA != locationB) {
- int offset = other.offset;
- _fail('[$offset]\nExpected: $b ($locationB)\n Actual: $a ($locationA)');
- }
- if (a == null && b == null) {
- return;
- }
- if (a.nameOffset != b.nameOffset) {
- _fail('Expected: ${b.nameOffset}\n Actual: ${a.nameOffset}');
- }
- }
-
- void _verifyType(DartType a, DartType b) {
- if (!validateTypes) {
- return;
- }
- if (a != b) {
- int offset = other.offset;
- _fail('[$offset]\nExpected: $b\n Actual: $a');
- }
- }
-
- void _visitAnnotatedNode(AnnotatedNode node, AnnotatedNode other) {
- _visitNode(node.documentationComment, other.documentationComment);
- _visitList(node.metadata, other.metadata);
- }
-
- _visitDeclaration(Declaration node, Declaration other) {
- _verifyElement(node.element, other.element);
- _visitAnnotatedNode(node, other);
- }
-
- _visitDirective(Directive node, Directive other) {
- _verifyElement(node.element, other.element);
- _visitAnnotatedNode(node, other);
- }
-
- void _visitExpression(Expression a, Expression b) {
-// print('[${a.offset}] |$a| vs. [${b.offset}] |$b|');
- _verifyType(a.staticType, b.staticType);
- _verifyType(a.propagatedType, b.propagatedType);
- _verifyElement(a.staticParameterElement, b.staticParameterElement);
- _verifyElement(a.propagatedParameterElement, b.propagatedParameterElement);
- _assertNode(a, b);
- }
-
- void _visitList(NodeList nodeList, NodeList otherList) {
- int length = nodeList.length;
- _expectLength(otherList, length);
- for (int i = 0; i < length; i++) {
- _visitNode(nodeList[i], otherList[i]);
- }
- }
-
- void _visitNode(AstNode node, AstNode other) {
- if (node == null) {
- _expectIsNull(other);
- } else {
- this.other = other;
- _assertNode(node, other);
- node.accept(this);
- }
- }
-
- void _visitNormalFormalParameter(
- NormalFormalParameter node, NormalFormalParameter other) {
- _verifyElement(node.element, other.element);
- _visitNode(node.documentationComment, other.documentationComment);
- _visitList(node.metadata, other.metadata);
- _visitNode(node.identifier, other.identifier);
- }
-
- /**
- * Returns an URI scheme independent version of the [element] location.
- */
- static String _getElementLocationWithoutUri(Element element) {
- if (element == null) {
- return '<null>';
- }
- if (element is UriReferencedElementImpl) {
- return '<ignored>';
- }
- ElementLocation location = element.location;
- List<String> components = location.components;
- String uriPrefix = '';
- Element unit = element is CompilationUnitElement
- ? element
- : element.getAncestor((e) => e is CompilationUnitElement);
- if (unit != null) {
- String libComponent = components[0];
- String unitComponent = components[1];
- components = components.sublist(2);
- uriPrefix = _getShortElementLocationUri(libComponent) +
- ':' +
- _getShortElementLocationUri(unitComponent);
- } else {
- String libComponent = components[0];
- components = components.sublist(1);
- uriPrefix = _getShortElementLocationUri(libComponent);
- }
- return uriPrefix + ':' + components.join(':');
- }
-
- /**
- * Returns a "short" version of the given [uri].
- *
- * For example:
- * /User/me/project/lib/my_lib.dart -> my_lib.dart
- * package:project/my_lib.dart -> my_lib.dart
- */
- static String _getShortElementLocationUri(String uri) {
- int index = uri.lastIndexOf('/');
- if (index == -1) {
- return uri;
- }
- return uri.substring(index + 1);
- }
-}
« no previous file with comments | « analyzer/lib/src/generated/incremental_logger.dart ('k') | analyzer/lib/src/generated/incremental_resolver.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698