blob: fe2329ffdf3ede7447286a75b5a25e852cb95a9e [file] [log] [blame]
// 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);
}