blob: 9963a8f42b6158ec9bea49f21cdef719c78bd844 [file] [log] [blame]
// Copyright (c) 2019, 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:analyzer/dart/element/element2.dart';
import 'package:dartdoc/src/element_type.dart';
import 'package:dartdoc/src/model/comment_referable.dart';
import 'package:dartdoc/src/model/kind.dart';
import 'package:dartdoc/src/model/model.dart';
/// A [ModelElement] for a [TopLevelFunctionElement] that isn't part of a type definition.
class ModelFunction extends ModelFunctionTyped with Categorization {
ModelFunction(TopLevelFunctionElement super.element, super.library,
super.packageGraph);
bool get isStatic => element.isStatic;
@override
String get name => element.name3 ?? '';
@override
TopLevelFunctionElement get element =>
super.element as TopLevelFunctionElement;
bool get isAsynchronous => element.firstFragment.isAsynchronous;
}
/// A [ModelElement] for a [FunctionTypedElement2] that is part of an
/// explicit typedef.
class ModelFunctionTypedef extends ModelFunctionTyped {
ModelFunctionTypedef(super.element, super.library, super.packageGraph);
@override
String get name => element.enclosingElement2!.name3!;
}
class ModelFunctionTyped extends ModelElement with TypeParameters {
@override
final FunctionTypedElement2 element;
@override
late final List<TypeParameter> typeParameters = [
for (var p in element.typeParameters2)
getModelFor(p, library) as TypeParameter,
];
ModelFunctionTyped(this.element, super.library, super.packageGraph);
@override
Library get enclosingElement => library;
@override
// Prevent a collision with the library file.
String get fileName => name == 'index' ? '$name-function.html' : '$name.html';
@override
String get aboveSidebarPath => canonicalLibraryOrThrow.sidebarPath;
@override
String? get belowSidebarPath => null;
@override
String? get href {
if (!identical(canonicalModelElement, this)) {
return canonicalModelElement?.href;
}
return '${package.baseHref}$filePath';
}
@override
Kind get kind => Kind.function;
// Food for mustache. TODO(jcollins-g): what about enclosing elements?
bool get isInherited => false;
@override
late final Map<String, CommentReferable> referenceChildren = {
...parameters.explicitOnCollisionWith(this),
...typeParameters.explicitOnCollisionWith(this),
};
@override
Iterable<CommentReferable> get referenceParents => [library];
late final Callable modelType =
getTypeFor(element.type, library) as Callable;
// For use in templates.
bool get isProvidedByExtension => false;
// For use in templates.
Extension get enclosingExtension => throw UnsupportedError(
'Top-level variables are not provided by extensions');
}