 Chromium Code Reviews
 Chromium Code Reviews Issue 1062723002:
  Implement the new '?.' operator in analyzer.  (Closed) 
  Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
    
  
    Issue 1062723002:
  Implement the new '?.' operator in analyzer.  (Closed) 
  Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart| Index: pkg/analyzer/lib/src/generated/element_resolver.dart | 
| diff --git a/pkg/analyzer/lib/src/generated/element_resolver.dart b/pkg/analyzer/lib/src/generated/element_resolver.dart | 
| index 94894c0a16ba9bb1676a8daa1c40c9d4015e54d6..68b7cddcdb551f34ce238448786cfecf8da1ece4 100644 | 
| --- a/pkg/analyzer/lib/src/generated/element_resolver.dart | 
| +++ b/pkg/analyzer/lib/src/generated/element_resolver.dart | 
| @@ -594,9 +594,11 @@ class ElementResolver extends SimpleAstVisitor<Object> { | 
| // | 
| // If this method invocation is of the form 'C.m' where 'C' is a class, | 
| // then we don't call resolveInvokedElement(..) which walks up the class | 
| 
Brian Wilkerson
2015/04/05 19:55:45
".." --> "..."
 
Paul Berry
2015/04/05 20:49:43
Done.
 | 
| - // hierarchy, instead we just look for the member in the type only. | 
| + // hierarchy, instead we just look for the member in the type only. This | 
| + // does not apply to conditional method invocation (i.e. 'C?.m(...)'). | 
| // | 
| - ClassElementImpl typeReference = getTypeReference(target); | 
| + bool isConditional = node.operator.type == sc.TokenType.QUESTION_PERIOD; | 
| + ClassElementImpl typeReference = getTypeReference(target, isConditional); | 
| if (typeReference != null) { | 
| staticElement = | 
| propagatedElement = _resolveElement(typeReference, methodName); | 
| @@ -855,7 +857,7 @@ class ElementResolver extends SimpleAstVisitor<Object> { | 
| // Otherwise, the prefix is really an expression that happens to be a simple | 
| // identifier and this is really equivalent to a property access node. | 
| // | 
| - _resolvePropertyAccess(prefix, identifier); | 
| + _resolvePropertyAccess(prefix, identifier, false); | 
| return null; | 
| } | 
| @@ -911,7 +913,8 @@ class ElementResolver extends SimpleAstVisitor<Object> { | 
| return null; | 
| } | 
| SimpleIdentifier propertyName = node.propertyName; | 
| - _resolvePropertyAccess(target, propertyName); | 
| + _resolvePropertyAccess(target, propertyName, | 
| + node.operator.type == sc.TokenType.QUESTION_PERIOD); | 
| return null; | 
| } | 
| @@ -2443,7 +2446,7 @@ class ElementResolver extends SimpleAstVisitor<Object> { | 
| } | 
| void _resolvePropertyAccess( | 
| - Expression target, SimpleIdentifier propertyName) { | 
| + Expression target, SimpleIdentifier propertyName, bool isConditional) { | 
| DartType staticType = _getStaticType(target); | 
| DartType propagatedType = _getPropagatedType(target); | 
| Element staticElement = null; | 
| @@ -2451,9 +2454,10 @@ class ElementResolver extends SimpleAstVisitor<Object> { | 
| // | 
| // If this property access is of the form 'C.m' where 'C' is a class, | 
| // then we don't call resolveProperty(..) which walks up the class | 
| 
Brian Wilkerson
2015/04/05 19:55:45
".." --> "..."
 
Paul Berry
2015/04/05 20:49:43
Done.
 | 
| - // hierarchy, instead we just look for the member in the type only. | 
| + // hierarchy, instead we just look for the member in the type only. This | 
| + // does not apply to conditional property accesses (i.e. 'C?.m'). | 
| // | 
| - ClassElementImpl typeReference = getTypeReference(target); | 
| + ClassElementImpl typeReference = getTypeReference(target, isConditional); | 
| if (typeReference != null) { | 
| // TODO(brianwilkerson) Why are we setting the propagated element here? | 
| // It looks wrong. | 
| @@ -2701,10 +2705,12 @@ class ElementResolver extends SimpleAstVisitor<Object> { | 
| /** | 
| * Checks whether the given [expression] is a reference to a class. If it is | 
| * then the element representing the class is returned, otherwise `null` is | 
| - * returned. | 
| + * returned. [isConditional] indicates whether [expression] is to the left | 
| + * of a '?.' opertator. | 
| */ | 
| - static ClassElementImpl getTypeReference(Expression expression) { | 
| - if (expression is Identifier) { | 
| + static ClassElementImpl getTypeReference( | 
| + Expression expression, bool isConditional) { | 
| + if (!isConditional && expression is Identifier) { | 
| Element staticElement = expression.staticElement; | 
| if (staticElement is ClassElementImpl) { | 
| return staticElement; |