| // 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 '../../base/uri_offset.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 '../../source/type_parameter_factory.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; |
| |
| UriOffsetLength get uriOffset; |
| |
| 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, |
| TypeParameterFactory typeParameterFactory, |
| ); |
| |
| 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 RegularGetterDeclaration |
| implements GetterDeclaration, GetterFragmentDeclaration { |
| final GetterFragment _fragment; |
| late final GetterEncoding _encoding; |
| |
| RegularGetterDeclaration(this._fragment) { |
| _fragment.declaration = this; |
| } |
| |
| @override |
| UriOffsetLength get uriOffset => _fragment.uriOffset; |
| |
| @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, |
| TypeParameterFactory typeParameterFactory, |
| ) { |
| _fragment.builder = builder; |
| typeParameterFactory.createNominalParameterBuilders( |
| _fragment.declaredTypeParameters, |
| ); |
| |
| _encoding = encodingStrategy.createGetterEncoding( |
| builder, |
| _fragment, |
| typeParameterFactory, |
| ); |
| _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); |
| } |