blob: 635fe97ade9eb132e0890e8af12f87cd29c64f7d [file] [log] [blame]
// Copyright (c) 2017, 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/analysis/session.dart';
import 'package:analyzer/dart/ast/ast.dart';
import 'package:analyzer/dart/element/element.dart';
import 'package:analyzer/error/error.dart';
import 'package:analyzer/src/generated/resolver.dart';
import 'package:analyzer/src/generated/source.dart';
/**
* The result of performing some kind of analysis on a single file. Every result
* that implements this interface will also implement a sub-interface.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class AnalysisResult {
/**
* The absolute and normalized path of the file that was analyzed.
*/
String get path;
/**
* Return the session used to compute this result.
*/
AnalysisSession get session;
/**
* The state of the results.
*/
ResultState get state;
/**
* The absolute URI of the file that was analyzed.
*/
Uri get uri;
}
/**
* An analysis result that includes the errors computed during analysis.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class AnalysisResultWithErrors implements FileResult {
/**
* The analysis errors that were computed during analysis.
*/
List<AnalysisError> get errors;
}
/**
* The result of computing all of the errors contained in a single file, both
* syntactic and semantic.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class ErrorsResult implements AnalysisResultWithErrors {}
/**
* The result of computing some cheap information for a single file, when full
* parsed file is not required, so [ParseResult] is not necessary.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class FileResult implements AnalysisResult {
/**
* Whether the file is a part.
*/
bool get isPart;
/**
* Information about lines in the content.
*/
LineInfo get lineInfo;
}
/**
* The result of parsing of a single file. The errors returned include only
* those discovered during scanning and parsing.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class ParseResult implements AnalysisResultWithErrors {
/**
* The content of the file that was scanned and parsed.
*/
String get content;
/**
* The parsed, unresolved compilation unit for the [content].
*/
CompilationUnit get unit;
}
/**
* The result of building a resolved AST for a single file. The errors returned
* include both syntactic and semantic errors.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class ResolveResult implements AnalysisResultWithErrors {
/**
* The content of the file that was scanned, parsed and resolved.
*/
String get content;
/**
* The element representing the library containing the compilation [unit].
*/
LibraryElement get libraryElement;
/**
* The type provider used when resolving the compilation [unit].
*/
TypeProvider get typeProvider;
/**
* The fully resolved compilation unit for the [content].
*/
CompilationUnit get unit;
}
/**
* An indication of whether an analysis result is valid, and if not why.
*/
enum ResultState {
/**
* An indication that analysis could not be performed because the path
* represents a file of a type that cannot be analyzed.
*/
INVALID_FILE_TYPE,
/**
* An indication that analysis could not be performed because the path does
* not represent a file. It might represent something else, such as a
* directory, or it might not represent anything.
*/
NOT_A_FILE,
/**
* An indication that analysis completed normally and the results are valid.
*/
VALID
}
/**
* The result of building the element model for a single file.
*
* Clients may not extend, implement or mix-in this class.
*/
abstract class UnitElementResult implements AnalysisResult {
/**
* The element of the file.
*/
CompilationUnitElement get element;
/**
* The signature of the library containing the [element]. This is the same
* signature returned by the method [AnalysisSession.getUnitElementSignature]
* when given the path to the compilation unit represented by the [element].
*
* The signature is based on the APIs of the files of the library (including
* the file itself), and the transitive closure of files imported and exported
* by the library. If the signature of a file has not changed, then there have
* been no changes that would cause any files that depend on it to need to be
* re-analyzed.
*/
String get signature;
}