blob: c347f4152381d3269061c090c9bc3c97b5fb74d6 [file] [log] [blame]
// Copyright (c) 2024, 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.
part of 'fragment.dart';
class PrimaryConstructorFragment implements Fragment, FunctionFragment {
final String name;
final Uri fileUri;
final int startOffset;
final int? nameOffset;
final int formalsOffset;
final Modifiers modifiers;
final OmittedTypeBuilder returnType;
final List<NominalParameterBuilder>? typeParameters;
final LookupScope typeParameterScope;
final List<FormalParameterBuilder>? formals;
final bool forAbstractClassOrMixin;
Token? _beginInitializers;
AbstractSourceConstructorBuilder? _builder;
PrimaryConstructorFragment(
{required this.name,
required this.fileUri,
required this.startOffset,
required this.nameOffset,
required this.formalsOffset,
required this.modifiers,
required this.returnType,
required this.typeParameters,
required this.typeParameterScope,
required this.formals,
required this.forAbstractClassOrMixin,
required Token? beginInitializers})
: _beginInitializers = beginInitializers;
int get fileOffset => nameOffset ?? formalsOffset;
Token? get beginInitializers {
Token? result = _beginInitializers;
// Ensure that we don't hold onto the token.
_beginInitializers = null;
return result;
}
@override
AbstractSourceConstructorBuilder get builder {
assert(_builder != null, "Builder has not been computed for $this.");
return _builder!;
}
void set builder(AbstractSourceConstructorBuilder value) {
assert(_builder == null, "Builder has already been computed for $this.");
_builder = value;
}
@override
FunctionBodyBuildingContext createFunctionBodyBuildingContext() {
return new _PrimaryConstructorBodyBuildingContext(this);
}
@override
String toString() => '$runtimeType($name,$fileUri,$formalsOffset)';
}
class _PrimaryConstructorBodyBuildingContext
implements FunctionBodyBuildingContext {
PrimaryConstructorFragment _fragment;
_PrimaryConstructorBodyBuildingContext(this._fragment);
@override
// Coverage-ignore(suite): Not run.
// TODO(johnniwinther): This matches what is passed when parsing, but seems
// odd given that it used to allow 'covariant' modifiers, which shouldn't be
// allowed on constructors.
MemberKind get memberKind => MemberKind.NonStaticMethod;
@override
bool get shouldBuild => !_fragment.modifiers.isConst;
@override
LocalScope computeFormalParameterScope(LookupScope typeParameterScope) {
return _fragment.builder.computeFormalParameterScope(typeParameterScope);
}
@override
LookupScope get typeParameterScope {
return _fragment.typeParameterScope;
}
@override
BodyBuilderContext createBodyBuilderContext() {
return _fragment.builder.createBodyBuilderContext();
}
@override
InferenceDataForTesting? get inferenceDataForTesting => _fragment
.builder
.dataForTesting
// Coverage-ignore(suite): Not run.
?.inferenceData;
@override
List<TypeParameter>? get thisTypeParameters =>
_fragment.builder.thisTypeParameters;
@override
VariableDeclaration? get thisVariable => _fragment.builder.thisVariable;
}