Skip to content

Extract deprecated usages of analyzer #2561

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion lib/dartdoc.dart
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ class DartdocFileWriter implements FileWriter {

var file = resourceProvider
.getFile(resourceProvider.pathContext.join(outputDir, outFile));
var parent = file.parent;
var parent = file.parent2;
if (!parent.exists) {
parent.create();
}
Expand Down
54 changes: 24 additions & 30 deletions lib/src/dartdoc_options.dart
Original file line number Diff line number Diff line change
Expand Up @@ -1094,26 +1094,23 @@ abstract class _DartdocFileOption<T> implements DartdocOption<T> {

/// Searches all dartdoc_options files through parent directories, starting at
/// [dir], for the option and returns one once found.
_OptionValueWithContext<Object> _valueAtFromFilesFirstFound(Folder dir) {
_OptionValueWithContext<Object> _valueAtFromFilesFirstFound(Folder folder) {
_OptionValueWithContext<Object> value;
while (true) {
for (var dir in folder.withAncestors) {
value = _valueAtFromFile(dir);
if (value != null || dir.parent == null) break;
dir = dir.parent;
if (value != null) break;
}
return value;
}

/// Searches all dartdoc_options files for the option, and returns the value
/// in the top-most parent directory `dartdoc_options.yaml` file it is
/// mentioned in.
_OptionValueWithContext<Object> _valueAtFromFilesLastFound(Folder dir) {
_OptionValueWithContext<Object> _valueAtFromFilesLastFound(Folder folder) {
_OptionValueWithContext<Object> value;
while (true) {
for (var dir in folder.withAncestors) {
var tmpValue = _valueAtFromFile(dir);
if (tmpValue != null) value = tmpValue;
dir = dir.parent;
if (dir == null) break;
}
return value;
}
Expand Down Expand Up @@ -1179,35 +1176,32 @@ abstract class _DartdocFileOption<T> implements DartdocOption<T> {
definingFile: 'dartdoc_options.yaml');
}

_YamlFileData _yamlAtDirectory(Folder dir) {
var canonicalPaths = <String>[
resourceProvider.pathContext.canonicalize(dir.path)
];
if (!_yamlAtCanonicalPathCache.containsKey(canonicalPaths.first)) {
var yamlData = _YamlFileData({}, _directoryCurrentPath);
_YamlFileData _yamlAtDirectory(Folder folder) {
var canonicalPaths = <String>[];
var yamlData = _YamlFileData({}, _directoryCurrentPath);

for (var dir in folder.withAncestors) {
var canonicalPath =
resourceProvider.pathContext.canonicalize(folder.path);
if (_yamlAtCanonicalPathCache.containsKey(canonicalPath)) {
yamlData = _yamlAtCanonicalPathCache[canonicalPath];
break;
}
canonicalPaths.add(canonicalPath);
if (dir.exists) {
File dartdocOptionsFile;

while (true) {
dartdocOptionsFile = resourceProvider.getFile(resourceProvider
.pathContext
.join(dir.path, 'dartdoc_options.yaml'));
if (dartdocOptionsFile.exists || dir.parent == null) {
break;
}
dir = dir.parent;
canonicalPaths
.add(resourceProvider.pathContext.canonicalize(dir.path));
}
var dartdocOptionsFile = resourceProvider.getFile(resourceProvider
.pathContext
.join(dir.path, 'dartdoc_options.yaml'));
if (dartdocOptionsFile.exists) {
yamlData = _YamlFileData(
loadYaml(dartdocOptionsFile.readAsStringSync()),
resourceProvider.pathContext.canonicalize(dir.path));
break;
}
}
canonicalPaths.forEach((p) => _yamlAtCanonicalPathCache[p] = yamlData);
}
return _yamlAtCanonicalPathCache[canonicalPaths.first];
canonicalPaths.forEach((p) => _yamlAtCanonicalPathCache[p] = yamlData);
return yamlData;
}
}

Expand Down Expand Up @@ -1402,7 +1396,7 @@ class DartdocOptionContext extends DartdocOptionContextBase
} else {
context = resourceProvider.getFolder(resourceProvider.pathContext
.canonicalize(
resource is File ? resource.parent.path : resource.path));
resource is File ? resource.parent2.path : resource.path));
}
}

Expand Down
14 changes: 5 additions & 9 deletions lib/src/element_type.dart
Original file line number Diff line number Diff line change
Expand Up @@ -34,11 +34,7 @@ abstract class ElementType extends Privacy {
} else {
var element = ModelElement.fromElement(f.element, packageGraph);
assert(f is ParameterizedType || f is TypeParameterType);
// TODO(jcollins-g): Remove reference to f.element.enclosingElement after
// analyzer 0.41.
var isGenericTypeAlias =
f.element.enclosingElement is FunctionTypeAliasElement ||
f.element is FunctionTypeAliasElement;
var isGenericTypeAlias = f.aliasElement != null;
if (f is FunctionType) {
assert(f is ParameterizedType);
if (isGenericTypeAlias) {
Expand Down Expand Up @@ -366,13 +362,13 @@ abstract class CallableElementTypeMixin implements ParameterizedElementType {
Iterable<DartType> dartTypeArguments;
if (returnedFrom is FunctionTypeElementType) {
if (type.typeFormals.isEmpty) {
dartTypeArguments = type.typeArguments;
dartTypeArguments = type.aliasArguments;
} else {
dartTypeArguments = type.typeFormals.map(_legacyTypeParameterType);
}
} else {
if (type.typeFormals.isEmpty) {
dartTypeArguments = type.typeArguments;
dartTypeArguments = type.aliasArguments;
} else if (returnedFrom != null &&
returnedFrom.type.element is GenericFunctionTypeElement) {
_typeArguments = (returnedFrom as DefinedElementType).typeArguments;
Expand Down Expand Up @@ -447,8 +443,8 @@ class CallableGenericTypeAliasElementType extends ParameterizedElementType
ModelElement _returnElement;
@override
ModelElement get returnElement {
_returnElement ??=
ModelElement.fromElement(type.element.enclosingElement, packageGraph);
_returnElement ??= ModelElement.fromElement(
type.aliasElement.enclosingElement, packageGraph);
return _returnElement;
}

Expand Down
48 changes: 27 additions & 21 deletions lib/src/model/model_element.dart
Original file line number Diff line number Diff line change
Expand Up @@ -330,7 +330,7 @@ abstract class ModelElement extends Canonicalization
if (e is FunctionElement) {
return ModelFunction(e, library, packageGraph);
} else if (e is GenericFunctionTypeElement) {
assert(e.enclosingElement is FunctionTypeAliasElement);
assert(e.enclosingElement is TypeAliasElement);
assert(e.enclosingElement.name != '');
return ModelFunctionTypedef(e, library, packageGraph);
}
Expand Down Expand Up @@ -547,8 +547,11 @@ abstract class ModelElement extends Canonicalization
return allFeatures.join(', ');
}

// True if this is a function, or if it is an type alias to a function.
bool get isCallable =>
element is FunctionTypedElement || element is FunctionTypeAliasElement;
element is FunctionTypedElement ||
(element is TypeAliasElement &&
(element as TypeAliasElement).aliasedElement is FunctionTypedElement);

ModelElement buildCanonicalModelElement() {
Container preferredClass;
Expand Down Expand Up @@ -1079,28 +1082,31 @@ abstract class ModelElement extends Canonicalization
if (_parameters == null) {
List<ParameterElement> params;

if (element is ExecutableElement) {
if (_originalMember != null) {
assert(_originalMember is ExecutableMember);
params = (_originalMember as ExecutableMember).parameters;
} else {
params = (element as ExecutableElement).parameters;
if (element is TypeAliasElement) {
_parameters = ModelElement.fromElement(
(element as TypeAliasElement).aliasedElement, packageGraph)
.parameters;
} else {
if (element is ExecutableElement) {
if (_originalMember != null) {
assert(_originalMember is ExecutableMember);
params = (_originalMember as ExecutableMember).parameters;
} else {
params = (element as ExecutableElement).parameters;
}
}
}
if (params == null && element is FunctionTypedElement) {
if (_originalMember != null) {
params = (_originalMember as dynamic).parameters;
} else {
params = (element as FunctionTypedElement).parameters;
if (params == null && element is FunctionTypedElement) {
if (_originalMember != null) {
params = (_originalMember as dynamic).parameters;
} else {
params = (element as FunctionTypedElement).parameters;
}
}
_parameters = UnmodifiableListView(params
.map(
(p) => ModelElement.from(p, library, packageGraph) as Parameter)
.toList(growable: false));
}
if (params == null && element is FunctionTypeAliasElement) {
params = (element as FunctionTypeAliasElement).function.parameters;
}

_parameters = UnmodifiableListView(params
.map((p) => ModelElement.from(p, library, packageGraph) as Parameter)
.toList(growable: false));
}
return _parameters;
}
Expand Down
2 changes: 1 addition & 1 deletion lib/src/model/package_graph.dart
Original file line number Diff line number Diff line change
Expand Up @@ -972,7 +972,7 @@ class PackageGraph {
// might not be where the element was defined, which is what's important
// for nodoc's semantics. Looking up the defining element just to pull
// a context is again, slow.
List<String> globs = config.optionSet['nodoc'].valueAt(file.parent);
List<String> globs = config.optionSet['nodoc'].valueAt(file.parent2);
_configSetsNodocFor[fullName] = matchGlobs(globs, fullName);
}
return _configSetsNodocFor[fullName];
Expand Down
2 changes: 1 addition & 1 deletion lib/src/model/typedef.dart
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ class FunctionTypedef extends Typedef {

@override
List<TypeParameterElement> get genericTypeParameters {
var aliasedTypeElement = aliasedType.element;
var aliasedTypeElement = aliasedType.aliasElement;
if (aliasedTypeElement is FunctionTypedElement) {
return aliasedTypeElement.typeParameters;
}
Expand Down
2 changes: 1 addition & 1 deletion lib/src/mustachio/renderer_base.dart
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ class Template {
partialResolver = (String path) async {
var partialPath = pathContext.isAbsolute(path)
? path
: pathContext.join(file.parent.path, path);
: pathContext.join(file.parent2.path, path);
var partialFile =
file.provider.getFile(pathContext.normalize(partialPath));
return partialFile;
Expand Down
51 changes: 23 additions & 28 deletions lib/src/package_meta.dart
Original file line number Diff line number Diff line change
Expand Up @@ -42,8 +42,8 @@ final PackageMetaProvider pubPackageMetaProvider = PackageMetaProvider(
PhysicalResourceProvider.INSTANCE
.getFile(PhysicalResourceProvider.INSTANCE.pathContext
.absolute(Platform.resolvedExecutable))
.parent
.parent);
.parent2
.parent2);

/// Sets the supported way of constructing [PackageMeta] objects.
///
Expand Down Expand Up @@ -177,23 +177,21 @@ abstract class PubPackageMeta extends PackageMeta {

static final _sdkDirParent = <String, Folder>{};

/// If [dir] is inside a Dart SDK, returns the directory of the SDK, and `null`
/// If [folder] is inside a Dart SDK, returns the directory of the SDK, and `null`
/// otherwise.
static Folder sdkDirParent(Folder dir, ResourceProvider resourceProvider) {
static Folder sdkDirParent(Folder folder, ResourceProvider resourceProvider) {
var pathContext = resourceProvider.pathContext;
var dirPathCanonical = pathContext.canonicalize(dir.path);
var dirPathCanonical = pathContext.canonicalize(folder.path);
if (!_sdkDirParent.containsKey(dirPathCanonical)) {
_sdkDirParent[dirPathCanonical] = null;
while (dir.exists) {
for (var dir in folder.withAncestors) {
if (_sdkDirFilePaths.every((List<String> l) {
return l.any((f) =>
resourceProvider.getFile(pathContext.join(dir.path, f)).exists);
})) {
_sdkDirParent[dirPathCanonical] = dir;
break;
}
dir = dir.parent;
if (dir == null) break;
}
}
return _sdkDirParent[dirPathCanonical];
Expand All @@ -210,54 +208,50 @@ abstract class PubPackageMeta extends PackageMeta {
resourceProvider
.getFile(resourceProvider.pathContext
.canonicalize(libraryElement.source.fullName))
.parent,
.parent2,
resourceProvider);
}

static PubPackageMeta fromFilename(
String filename, ResourceProvider resourceProvider) {
return PubPackageMeta.fromDir(
resourceProvider.getFile(filename).parent, resourceProvider);
resourceProvider.getFile(filename).parent2, resourceProvider);
}

/// This factory is guaranteed to return the same object for any given
/// [dir.absolute.path]. Multiple [dir.absolute.path]s will resolve to the
/// same object if they are part of the same package. Returns null
/// if the directory is not part of a known package.
static PubPackageMeta fromDir(Folder dir, ResourceProvider resourceProvider) {
static PubPackageMeta fromDir(
Folder folder, ResourceProvider resourceProvider) {
var pathContext = resourceProvider.pathContext;
var original = resourceProvider.getFolder(pathContext.absolute(dir.path));
dir = original;
var original =
resourceProvider.getFolder(pathContext.absolute(folder.path));
folder = original;
if (!original.exists) {
throw PackageMetaFailure(
'fatal error: unable to locate the input directory at ${original.path}.');
}

if (!_packageMetaCache.containsKey(dir.path)) {
if (!_packageMetaCache.containsKey(folder.path)) {
PackageMeta packageMeta;
// There are pubspec.yaml files inside the SDK. Ignore them.
var parentSdkDir = sdkDirParent(dir, resourceProvider);
var parentSdkDir = sdkDirParent(folder, resourceProvider);
if (parentSdkDir != null) {
packageMeta = _SdkMeta(parentSdkDir, resourceProvider);
} else {
while (dir.exists) {
for (var dir in folder.withAncestors) {
var pubspec = resourceProvider
.getFile(pathContext.join(dir.path, 'pubspec.yaml'));
if (pubspec.exists) {
packageMeta = _FilePackageMeta(dir, resourceProvider);
break;
}
// Allow a package to be at root (possible in a Windows setting with
// drive letter mappings).
if (dir.parent == null) break;
// TODO(srawlins): or just... `.parent`?
dir =
resourceProvider.getFolder(pathContext.absolute(dir.parent.path));
}
}
_packageMetaCache[pathContext.absolute(dir.path)] = packageMeta;
_packageMetaCache[pathContext.absolute(folder.path)] = packageMeta;
}
return _packageMetaCache[pathContext.absolute(dir.path)];
return _packageMetaCache[pathContext.absolute(folder.path)];
}

@override
Expand Down Expand Up @@ -317,10 +311,11 @@ class _FilePackageMeta extends PubPackageMeta {
// a pub library to do this.
// People could have a pub cache at root with Windows drive mappings.
if (pathContext.split(pathContext.canonicalize(dir.path)).length >= 3) {
var pubCacheRoot = dir.parent.parent.parent?.path;
if (pubCacheRoot != null) {
var hosted = pathContext.canonicalize(dir.parent.parent.path);
var hostname = pathContext.canonicalize(dir.parent.path);
var pubCacheRoot = dir.parent2.parent2.parent2.path;
// Check for directory structure too close to root.
if (pubCacheRoot != dir.parent2.parent2.path) {
var hosted = pathContext.canonicalize(dir.parent2.parent2.path);
var hostname = pathContext.canonicalize(dir.parent2.path);
if (pathContext.basename(hosted) == 'hosted' &&
resourceProvider
.getFolder(pathContext.join(pubCacheRoot, '_temp'))
Expand Down
Loading