| OLD | NEW |
| 1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2017, 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 /// This file declares a "shadow hierarchy" of concrete classes which extend | 5 /// This file declares a "shadow hierarchy" of concrete classes which extend |
| 6 /// the kernel class hierarchy, adding methods and fields needed by the | 6 /// the kernel class hierarchy, adding methods and fields needed by the |
| 7 /// BodyBuilder. | 7 /// BodyBuilder. |
| 8 /// | 8 /// |
| 9 /// Instances of these classes may be created using the factory methods in | 9 /// Instances of these classes may be created using the factory methods in |
| 10 /// `ast_factory.dart`. | 10 /// `ast_factory.dart`. |
| (...skipping 395 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 406 } | 406 } |
| 407 } | 407 } |
| 408 } | 408 } |
| 409 | 409 |
| 410 /// Concrete shadow object representing a conditional expression in kernel form. | 410 /// Concrete shadow object representing a conditional expression in kernel form. |
| 411 /// Shadow object for [ConditionalExpression]. | 411 /// Shadow object for [ConditionalExpression]. |
| 412 class KernelConditionalExpression extends ConditionalExpression | 412 class KernelConditionalExpression extends ConditionalExpression |
| 413 implements KernelExpression { | 413 implements KernelExpression { |
| 414 KernelConditionalExpression( | 414 KernelConditionalExpression( |
| 415 Expression condition, Expression then, Expression otherwise) | 415 Expression condition, Expression then, Expression otherwise) |
| 416 : super(condition, then, otherwise, const DynamicType()); | 416 : super(condition, then, otherwise, null); |
| 417 | 417 |
| 418 @override | 418 @override |
| 419 void _collectDependencies(KernelDependencyCollector collector) { | 419 void _collectDependencies(KernelDependencyCollector collector) { |
| 420 // Inference dependencies are the union of the inference dependencies of the | 420 // Inference dependencies are the union of the inference dependencies of the |
| 421 // two returned sub-expressions. | 421 // two returned sub-expressions. |
| 422 collector.collectDependencies(then); | 422 collector.collectDependencies(then); |
| 423 collector.collectDependencies(otherwise); | 423 collector.collectDependencies(otherwise); |
| 424 } | 424 } |
| 425 | 425 |
| 426 @override | 426 @override |
| 427 DartType _inferExpression( | 427 DartType _inferExpression( |
| 428 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { | 428 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { |
| 429 typeNeeded = | 429 typeNeeded = |
| 430 inferrer.listener.conditionalExpressionEnter(this, typeContext) || | 430 inferrer.listener.conditionalExpressionEnter(this, typeContext) || |
| 431 typeNeeded; | 431 typeNeeded; |
| 432 if (!inferrer.isTopLevel) { | 432 if (!inferrer.isTopLevel) { |
| 433 inferrer.inferExpression( | 433 inferrer.inferExpression( |
| 434 condition, inferrer.coreTypes.boolClass.rawType, false); | 434 condition, inferrer.coreTypes.boolClass.rawType, false); |
| 435 } | 435 } |
| 436 DartType thenType = inferrer.inferExpression(then, typeContext, true); | 436 DartType thenType = inferrer.inferExpression(then, typeContext, true); |
| 437 DartType otherwiseType = | 437 DartType otherwiseType = |
| 438 inferrer.inferExpression(otherwise, typeContext, true); | 438 inferrer.inferExpression(otherwise, typeContext, true); |
| 439 DartType type = inferrer.typeSchemaEnvironment | 439 DartType type = inferrer.typeSchemaEnvironment |
| 440 .getLeastUpperBound(thenType, otherwiseType); | 440 .getLeastUpperBound(thenType, otherwiseType); |
| 441 staticType = type; | 441 if (inferrer.strongMode) { |
| 442 staticType = type; |
| 443 } |
| 442 var inferredType = typeNeeded ? type : null; | 444 var inferredType = typeNeeded ? type : null; |
| 443 inferrer.listener.conditionalExpressionExit(this, inferredType); | 445 inferrer.listener.conditionalExpressionExit(this, inferredType); |
| 444 return inferredType; | 446 return inferredType; |
| 445 } | 447 } |
| 446 } | 448 } |
| 447 | 449 |
| 448 /// Shadow object for [ConstructorInvocation]. | 450 /// Shadow object for [ConstructorInvocation]. |
| 449 class KernelConstructorInvocation extends ConstructorInvocation | 451 class KernelConstructorInvocation extends ConstructorInvocation |
| 450 implements KernelExpression { | 452 implements KernelExpression { |
| 451 final Member _initialTarget; | 453 final Member _initialTarget; |
| (...skipping 480 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 932 collector.recordNotImmediatelyEvident(fileOffset); | 934 collector.recordNotImmediatelyEvident(fileOffset); |
| 933 } | 935 } |
| 934 | 936 |
| 935 @override | 937 @override |
| 936 DartType _inferExpression( | 938 DartType _inferExpression( |
| 937 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { | 939 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { |
| 938 typeNeeded = inferrer.listener.ifNullEnter(this, typeContext) || typeNeeded; | 940 typeNeeded = inferrer.listener.ifNullEnter(this, typeContext) || typeNeeded; |
| 939 // To infer `e0 ?? e1` in context K: | 941 // To infer `e0 ?? e1` in context K: |
| 940 // - Infer e0 in context K to get T0 | 942 // - Infer e0 in context K to get T0 |
| 941 var lhsType = inferrer.inferExpression(_lhs, typeContext, true); | 943 var lhsType = inferrer.inferExpression(_lhs, typeContext, true); |
| 942 variable.type = lhsType; | 944 if (inferrer.strongMode) { |
| 945 variable.type = lhsType; |
| 946 } |
| 943 // - Let J = T0 if K is `_` else K. | 947 // - Let J = T0 if K is `_` else K. |
| 944 var rhsContext = typeContext ?? lhsType; | 948 var rhsContext = typeContext ?? lhsType; |
| 945 // - Infer e1 in context J to get T1 | 949 // - Infer e1 in context J to get T1 |
| 946 var rhsType = | 950 var rhsType = |
| 947 inferrer.inferExpression(_rhs, rhsContext, typeContext == null); | 951 inferrer.inferExpression(_rhs, rhsContext, typeContext == null); |
| 948 // - Let T = greatest closure of K with respect to `?` if K is not `_`, else | 952 // - Let T = greatest closure of K with respect to `?` if K is not `_`, else |
| 949 // UP(t0, t1) | 953 // UP(t0, t1) |
| 950 // - Then the inferred type is T. | 954 // - Then the inferred type is T. |
| 951 var inferredType = typeContext == null | 955 var inferredType = typeContext == null |
| 952 ? inferrer.typeSchemaEnvironment.getLeastUpperBound(lhsType, rhsType) | 956 ? inferrer.typeSchemaEnvironment.getLeastUpperBound(lhsType, rhsType) |
| 953 : greatestClosure(inferrer.coreTypes, typeContext); | 957 : greatestClosure(inferrer.coreTypes, typeContext); |
| 954 body.staticType = inferredType; | 958 if (inferrer.strongMode) { |
| 959 body.staticType = inferredType; |
| 960 } |
| 955 inferrer.listener.ifNullExit(this, inferredType); | 961 inferrer.listener.ifNullExit(this, inferredType); |
| 956 return inferredType; | 962 return inferredType; |
| 957 } | 963 } |
| 958 } | 964 } |
| 959 | 965 |
| 960 /// Concrete shadow object representing an if statement in kernel form. | 966 /// Concrete shadow object representing an if statement in kernel form. |
| 961 class KernelIfStatement extends IfStatement implements KernelStatement { | 967 class KernelIfStatement extends IfStatement implements KernelStatement { |
| 962 KernelIfStatement(Expression condition, Statement then, Statement otherwise) | 968 KernelIfStatement(Expression condition, Statement then, Statement otherwise) |
| 963 : super(condition, then, otherwise); | 969 : super(condition, then, otherwise); |
| 964 | 970 |
| (...skipping 425 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1390 @override | 1396 @override |
| 1391 DartType _inferExpression( | 1397 DartType _inferExpression( |
| 1392 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { | 1398 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { |
| 1393 var inferredType = inferrer.inferMethodInvocation( | 1399 var inferredType = inferrer.inferMethodInvocation( |
| 1394 this, | 1400 this, |
| 1395 variable.initializer, | 1401 variable.initializer, |
| 1396 fileOffset, | 1402 fileOffset, |
| 1397 _desugaredInvocation, | 1403 _desugaredInvocation, |
| 1398 false, | 1404 false, |
| 1399 typeContext, | 1405 typeContext, |
| 1400 true, | 1406 typeNeeded || inferrer.strongMode, |
| 1401 receiverVariable: variable); | 1407 receiverVariable: variable); |
| 1402 body.staticType = inferredType; | 1408 if (inferrer.strongMode) { |
| 1409 body.staticType = inferredType; |
| 1410 } |
| 1403 return inferredType; | 1411 return inferredType; |
| 1404 } | 1412 } |
| 1405 } | 1413 } |
| 1406 | 1414 |
| 1407 /// Concrete shadow object representing a null-aware read from a property. | 1415 /// Concrete shadow object representing a null-aware read from a property. |
| 1408 /// | 1416 /// |
| 1409 /// A null-aware property get of the form `a?.b` is represented as the kernel | 1417 /// A null-aware property get of the form `a?.b` is represented as the kernel |
| 1410 /// expression: | 1418 /// expression: |
| 1411 /// | 1419 /// |
| 1412 /// let v = a in v == null ? null : v.b | 1420 /// let v = a in v == null ? null : v.b |
| 1413 class KernelNullAwarePropertyGet extends Let implements KernelExpression { | 1421 class KernelNullAwarePropertyGet extends Let implements KernelExpression { |
| 1414 KernelNullAwarePropertyGet( | 1422 KernelNullAwarePropertyGet( |
| 1415 VariableDeclaration variable, ConditionalExpression body) | 1423 VariableDeclaration variable, ConditionalExpression body) |
| 1416 : super(variable, body); | 1424 : super(variable, body); |
| 1417 | 1425 |
| 1418 @override | 1426 @override |
| 1419 ConditionalExpression get body => super.body; | 1427 ConditionalExpression get body => super.body; |
| 1420 | 1428 |
| 1421 PropertyGet get _desugaredGet => body.otherwise; | 1429 PropertyGet get _desugaredGet => body.otherwise; |
| 1422 | 1430 |
| 1423 @override | 1431 @override |
| 1424 void _collectDependencies(KernelDependencyCollector collector) { | 1432 void _collectDependencies(KernelDependencyCollector collector) { |
| 1425 // Null aware expressions are not immediately evident. | 1433 // Null aware expressions are not immediately evident. |
| 1426 collector.recordNotImmediatelyEvident(fileOffset); | 1434 collector.recordNotImmediatelyEvident(fileOffset); |
| 1427 } | 1435 } |
| 1428 | 1436 |
| 1429 @override | 1437 @override |
| 1430 DartType _inferExpression( | 1438 DartType _inferExpression( |
| 1431 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { | 1439 KernelTypeInferrer inferrer, DartType typeContext, bool typeNeeded) { |
| 1432 var inferredType = inferrer.inferPropertyGet(this, variable.initializer, | 1440 var inferredType = inferrer.inferPropertyGet( |
| 1433 fileOffset, _desugaredGet, typeContext, true, | 1441 this, |
| 1442 variable.initializer, |
| 1443 fileOffset, |
| 1444 _desugaredGet, |
| 1445 typeContext, |
| 1446 typeNeeded || inferrer.strongMode, |
| 1434 receiverVariable: variable); | 1447 receiverVariable: variable); |
| 1435 body.staticType = inferredType; | 1448 if (inferrer.strongMode) { |
| 1449 body.staticType = inferredType; |
| 1450 } |
| 1436 return inferredType; | 1451 return inferredType; |
| 1437 } | 1452 } |
| 1438 } | 1453 } |
| 1439 | 1454 |
| 1440 /// Concrete shadow object representing a null literal in kernel form. | 1455 /// Concrete shadow object representing a null literal in kernel form. |
| 1441 class KernelNullLiteral extends NullLiteral implements KernelExpression { | 1456 class KernelNullLiteral extends NullLiteral implements KernelExpression { |
| 1442 @override | 1457 @override |
| 1443 void _collectDependencies(KernelDependencyCollector collector) { | 1458 void _collectDependencies(KernelDependencyCollector collector) { |
| 1444 // No inference dependencies. | 1459 // No inference dependencies. |
| 1445 } | 1460 } |
| (...skipping 819 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2265 } | 2280 } |
| 2266 | 2281 |
| 2267 transformChildren(v) { | 2282 transformChildren(v) { |
| 2268 return internalError("Internal error: Unsupported operation."); | 2283 return internalError("Internal error: Unsupported operation."); |
| 2269 } | 2284 } |
| 2270 | 2285 |
| 2271 visitChildren(v) { | 2286 visitChildren(v) { |
| 2272 return internalError("Internal error: Unsupported operation."); | 2287 return internalError("Internal error: Unsupported operation."); |
| 2273 } | 2288 } |
| 2274 } | 2289 } |
| OLD | NEW |