| // Copyright (c) 2025, 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. |
| |
| import 'package:kernel/ast.dart'; |
| import 'package:kernel/class_hierarchy.dart'; |
| import 'package:kernel/type_environment.dart'; |
| |
| import '../../base/local_scope.dart'; |
| import '../../base/messages.dart'; |
| import '../../base/scope.dart'; |
| import '../../builder/declaration_builders.dart'; |
| import '../../builder/formal_parameter_builder.dart'; |
| import '../../builder/metadata_builder.dart'; |
| import '../../builder/property_builder.dart'; |
| import '../../builder/type_builder.dart'; |
| import '../../kernel/body_builder_context.dart'; |
| import '../../kernel/hierarchy/class_member.dart'; |
| import '../../kernel/hierarchy/members_builder.dart'; |
| import '../../kernel/type_algorithms.dart'; |
| import '../../source/name_scheme.dart'; |
| import '../../source/source_class_builder.dart'; |
| import '../../source/source_library_builder.dart'; |
| import '../../source/source_loader.dart'; |
| import '../../source/source_member_builder.dart'; |
| import '../../source/source_property_builder.dart'; |
| import '../fragment.dart'; |
| import 'body_builder_context.dart'; |
| import 'encoding.dart'; |
| |
| /// Interface for a getter declaration aspect of a [SourcePropertyBuilder]. |
| abstract class GetterDeclaration { |
| Uri get fileUri; |
| |
| GetterQuality get getterQuality; |
| |
| List<MetadataBuilder>? get metadata; |
| |
| Member get readTarget; |
| |
| void buildGetterOutlineExpressions( |
| {required ClassHierarchy classHierarchy, |
| required SourceLibraryBuilder libraryBuilder, |
| required DeclarationBuilder? declarationBuilder, |
| required SourcePropertyBuilder propertyBuilder, |
| required Annotatable annotatable, |
| required Uri annotatableFileUri, |
| required bool isClassInstanceMember}); |
| |
| void buildGetterOutlineNode( |
| {required SourceLibraryBuilder libraryBuilder, |
| required NameScheme nameScheme, |
| required BuildNodesCallback f, |
| required PropertyReferences? references, |
| required List<TypeParameter>? classTypeParameters}); |
| |
| void checkGetterTypes(SourceLibraryBuilder libraryBuilder, |
| TypeEnvironment typeEnvironment, SourcePropertyBuilder? setterBuilder); |
| |
| void checkGetterVariance( |
| SourceClassBuilder sourceClassBuilder, TypeEnvironment typeEnvironment); |
| |
| int computeGetterDefaultTypes(ComputeDefaultTypeContext context); |
| |
| void createGetterEncoding( |
| ProblemReporting problemReporting, |
| SourcePropertyBuilder builder, |
| PropertyEncodingStrategy encodingStrategy, |
| List<NominalParameterBuilder> unboundNominalParameters); |
| |
| void ensureGetterTypes( |
| {required SourceLibraryBuilder libraryBuilder, |
| required DeclarationBuilder? declarationBuilder, |
| required ClassMembersBuilder membersBuilder, |
| required Set<ClassMember>? getterOverrideDependencies}); |
| |
| Iterable<Reference> getExportedGetterReferences( |
| PropertyReferences references); |
| |
| List<ClassMember> get localMembers; |
| } |
| |
| class GetterDeclarationImpl |
| implements GetterDeclaration, GetterFragmentDeclaration { |
| final GetterFragment _fragment; |
| late final GetterEncoding _encoding; |
| |
| GetterDeclarationImpl(this._fragment) { |
| _fragment.declaration = this; |
| } |
| |
| @override |
| AsyncMarker get asyncModifier => _fragment.asyncModifier; |
| |
| @override |
| // Coverage-ignore(suite): Not run. |
| Uri get fileUri => _fragment.fileUri; |
| |
| @override |
| List<FormalParameterBuilder>? get formals => _encoding.formals; |
| |
| @override |
| FunctionNode get function => _encoding.function; |
| |
| @override |
| GetterQuality get getterQuality => _fragment.modifiers.isAbstract |
| ? GetterQuality.Abstract |
| : _fragment.modifiers.isExternal |
| ? GetterQuality.External |
| : GetterQuality.Concrete; |
| |
| @override |
| bool get isExternal => _fragment.modifiers.isExternal; |
| |
| @override |
| // Coverage-ignore(suite): Not run. |
| List<MetadataBuilder>? get metadata => _fragment.metadata; |
| |
| @override |
| String get name => _fragment.name; |
| |
| @override |
| int get nameOffset => _fragment.nameOffset; |
| |
| @override |
| Procedure get readTarget => _encoding.readTarget; |
| |
| @override |
| TypeBuilder get returnType => _fragment.returnType; |
| |
| @override |
| List<TypeParameter>? get thisTypeParameters => _encoding.thisTypeParameters; |
| |
| @override |
| VariableDeclaration? get thisVariable => _encoding.thisVariable; |
| |
| @override |
| void becomeNative(SourceLoader loader) { |
| _encoding.becomeNative(loader); |
| } |
| |
| @override |
| void buildGetterOutlineExpressions( |
| {required ClassHierarchy classHierarchy, |
| required SourceLibraryBuilder libraryBuilder, |
| required DeclarationBuilder? declarationBuilder, |
| required SourcePropertyBuilder propertyBuilder, |
| required Annotatable annotatable, |
| required Uri annotatableFileUri, |
| required bool isClassInstanceMember}) { |
| _encoding.buildOutlineExpressions( |
| classHierarchy: classHierarchy, |
| libraryBuilder: libraryBuilder, |
| declarationBuilder: declarationBuilder, |
| bodyBuilderContext: createBodyBuilderContext(propertyBuilder), |
| annotatable: annotatable, |
| annotatableFileUri: annotatableFileUri, |
| isClassInstanceMember: isClassInstanceMember); |
| } |
| |
| @override |
| void buildGetterOutlineNode( |
| {required SourceLibraryBuilder libraryBuilder, |
| required NameScheme nameScheme, |
| required BuildNodesCallback f, |
| required PropertyReferences? references, |
| required List<TypeParameter>? classTypeParameters}) { |
| _encoding.buildOutlineNode( |
| libraryBuilder: libraryBuilder, |
| nameScheme: nameScheme, |
| f: f, |
| references: references, |
| isAbstractOrExternal: |
| _fragment.modifiers.isAbstract || _fragment.modifiers.isExternal, |
| classTypeParameters: classTypeParameters); |
| } |
| |
| @override |
| void checkGetterTypes(SourceLibraryBuilder libraryBuilder, |
| TypeEnvironment typeEnvironment, SourcePropertyBuilder? setterBuilder) { |
| _encoding.checkTypes(libraryBuilder, typeEnvironment, setterBuilder, |
| isAbstract: _fragment.modifiers.isAbstract, |
| isExternal: _fragment.modifiers.isExternal); |
| } |
| |
| @override |
| void checkGetterVariance( |
| SourceClassBuilder sourceClassBuilder, TypeEnvironment typeEnvironment) { |
| _encoding.checkVariance(sourceClassBuilder, typeEnvironment); |
| } |
| |
| @override |
| int computeGetterDefaultTypes(ComputeDefaultTypeContext context) { |
| return _encoding.computeDefaultTypes(context); |
| } |
| |
| @override |
| BodyBuilderContext createBodyBuilderContext( |
| SourcePropertyBuilder propertyBuilder) { |
| return new GetterFragmentBodyBuilderContext(propertyBuilder, this, |
| propertyBuilder.libraryBuilder, propertyBuilder.declarationBuilder, |
| isDeclarationInstanceMember: |
| propertyBuilder.isDeclarationInstanceMember); |
| } |
| |
| @override |
| void createGetterEncoding( |
| ProblemReporting problemReporting, |
| SourcePropertyBuilder builder, |
| PropertyEncodingStrategy encodingStrategy, |
| List<NominalParameterBuilder> unboundNominalParameters) { |
| _encoding = encodingStrategy.createGetterEncoding( |
| builder, _fragment, unboundNominalParameters); |
| _fragment.typeParameterNameSpace.addTypeParameters( |
| problemReporting, _encoding.clonedAndDeclaredTypeParameters, |
| ownerName: _fragment.name, allowNameConflict: true); |
| _fragment.returnType.registerInferredTypeListener(_encoding); |
| } |
| |
| @override |
| LocalScope createFormalParameterScope(LookupScope typeParameterScope) { |
| return _encoding.createFormalParameterScope(typeParameterScope); |
| } |
| |
| @override |
| void ensureGetterTypes( |
| {required SourceLibraryBuilder libraryBuilder, |
| required DeclarationBuilder? declarationBuilder, |
| required ClassMembersBuilder membersBuilder, |
| required Set<ClassMember>? getterOverrideDependencies}) { |
| if (getterOverrideDependencies != null) { |
| membersBuilder.inferGetterType(declarationBuilder as SourceClassBuilder, |
| _fragment.returnType, getterOverrideDependencies, |
| name: _fragment.name, |
| fileUri: _fragment.fileUri, |
| nameOffset: _fragment.nameOffset, |
| nameLength: _fragment.name.length); |
| } |
| _encoding.ensureTypes(libraryBuilder, membersBuilder.hierarchyBuilder); |
| } |
| |
| @override |
| Iterable<Reference> getExportedGetterReferences( |
| PropertyReferences references) => |
| [references.getterReference!]; |
| |
| @override |
| VariableDeclaration getFormalParameter(int index) { |
| return _encoding.getFormalParameter(index); |
| } |
| |
| @override |
| List<ClassMember> get localMembers => |
| [new GetterClassMember(_fragment.builder)]; |
| } |
| |
| /// Interface for using a [GetterFragment] to create a [BodyBuilderContext]. |
| abstract class GetterFragmentDeclaration { |
| AsyncMarker get asyncModifier; |
| |
| List<FormalParameterBuilder>? get formals; |
| |
| FunctionNode get function; |
| |
| bool get isExternal; |
| |
| String get name; |
| |
| int get nameOffset; |
| |
| TypeBuilder get returnType; |
| |
| List<TypeParameter>? get thisTypeParameters; |
| |
| VariableDeclaration? get thisVariable; |
| |
| void becomeNative(SourceLoader loader); |
| |
| BodyBuilderContext createBodyBuilderContext( |
| SourcePropertyBuilder propertyBuilder); |
| |
| LocalScope createFormalParameterScope(LookupScope typeParameterScope); |
| |
| VariableDeclaration getFormalParameter(int index); |
| } |