|  | // 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/error/error.dart'; | 
|  | import 'package:analyzer/error/listener.dart'; | 
|  | import 'package:analyzer/file_system/file_system.dart'; | 
|  | import 'package:analyzer/src/generated/source.dart'; | 
|  | import 'package:analyzer/src/pubspec/validators/dependency_validator.dart'; | 
|  | import 'package:analyzer/src/pubspec/validators/field_validator.dart'; | 
|  | import 'package:analyzer/src/pubspec/validators/flutter_validator.dart'; | 
|  | import 'package:analyzer/src/pubspec/validators/name_validator.dart'; | 
|  | import 'package:analyzer/src/pubspec/validators/platforms_validator.dart'; | 
|  | import 'package:analyzer/src/pubspec/validators/screenshot_validator.dart'; | 
|  | import 'package:yaml/yaml.dart'; | 
|  |  | 
|  | /// List of [PubspecValidator] implementations. | 
|  | const _pubspecValidators = <PubspecValidator>[ | 
|  | dependencyValidator, | 
|  | fieldValidator, | 
|  | flutterValidator, | 
|  | nameValidator, | 
|  | screenshotsValidator, | 
|  | platformsValidator, | 
|  | ]; | 
|  |  | 
|  | /// Validate pubspec with given [contents]. | 
|  | /// | 
|  | /// The [source] argument must be the source of the file being validated. | 
|  | /// The [provider] argument must provide access to the file-system. | 
|  | List<AnalysisError> validatePubspec({ | 
|  | // TODO(brianwilkerson) This method needs to take a `YamlDocument` rather | 
|  | //  than the contents of the document so that it can validate an empty file. | 
|  | required Map<dynamic, YamlNode> contents, | 
|  | required Source source, | 
|  | required ResourceProvider provider, | 
|  | }) { | 
|  | final recorder = RecordingErrorListener(); | 
|  | final ctx = PubspecValidationContext._( | 
|  | contents: contents, | 
|  | source: source, | 
|  | reporter: ErrorReporter( | 
|  | recorder, | 
|  | source, | 
|  | isNonNullableByDefault: false, | 
|  | ), | 
|  | provider: provider, | 
|  | ); | 
|  |  | 
|  | for (final validator in _pubspecValidators) { | 
|  | validator(ctx); | 
|  | } | 
|  |  | 
|  | return recorder.errors; | 
|  | } | 
|  |  | 
|  | /// A function that can validate a `pubspec.yaml`. | 
|  | typedef PubspecValidator = void Function(PubspecValidationContext ctx); | 
|  |  | 
|  | final class PubspecField { | 
|  | /// The name of the sub-field (under `flutter`) whose value is a list of | 
|  | /// assets available to Flutter apps at runtime. | 
|  | static const String ASSETS_FIELD = 'assets'; | 
|  |  | 
|  | /// The name of the field whose value is a map of dependencies. | 
|  | static const String DEPENDENCIES_FIELD = 'dependencies'; | 
|  |  | 
|  | /// The name of the field whose value is a map of development dependencies. | 
|  | static const String DEV_DEPENDENCIES_FIELD = 'dev_dependencies'; | 
|  |  | 
|  | /// The name of the field whose value is a specification of Flutter-specific | 
|  | /// configuration data. | 
|  | static const String FLUTTER_FIELD = 'flutter'; | 
|  |  | 
|  | /// The name of the field whose value is a git dependency. | 
|  | static const String GIT_FIELD = 'git'; | 
|  |  | 
|  | /// The name of the field whose value is the name of the package. | 
|  | static const String NAME_FIELD = 'name'; | 
|  |  | 
|  | /// The name of the field whose value is a path to a package dependency. | 
|  | static const String PATH_FIELD = 'path'; | 
|  |  | 
|  | /// The name of the field whose value is the where to publish the package. | 
|  | static const String PUBLISH_TO_FIELD = 'publish_to'; | 
|  |  | 
|  | /// The name of the field whose value is a list of screenshots to publish. | 
|  | static const String SCREENSHOTS_FIELD = 'screenshots'; | 
|  |  | 
|  | /// The name of the field that declares platforms. | 
|  | static const String PLATFORMS_FIELD = 'platforms'; | 
|  |  | 
|  | /// The name of the field whose value is the version of the package. | 
|  | static const String VERSION_FIELD = 'version'; | 
|  | } | 
|  |  | 
|  | /// Context given to function that implement [PubspecValidator]. | 
|  | final class PubspecValidationContext { | 
|  | /// Yaml document being validated | 
|  | final Map<dynamic, YamlNode> contents; | 
|  |  | 
|  | /// The source representing the file being validated. | 
|  | final Source source; | 
|  |  | 
|  | /// The reporter to which errors should be reported. | 
|  | final ErrorReporter reporter; | 
|  |  | 
|  | /// The resource provider used to access the file system. | 
|  | final ResourceProvider provider; | 
|  |  | 
|  | PubspecValidationContext._({ | 
|  | required this.contents, | 
|  | required this.source, | 
|  | required this.reporter, | 
|  | required this.provider, | 
|  | }); | 
|  |  | 
|  | String? asString(dynamic node) { | 
|  | if (node is String) { | 
|  | return node; | 
|  | } | 
|  | if (node is YamlScalar && node.value is String) { | 
|  | return node.value as String; | 
|  | } | 
|  | return null; | 
|  | } | 
|  |  | 
|  | /// Report an error for the given node. | 
|  | void reportErrorForNode( | 
|  | YamlNode node, | 
|  | ErrorCode errorCode, [ | 
|  | List<Object>? arguments, | 
|  | ]) { | 
|  | final span = node.span; | 
|  | reporter.reportErrorForOffset( | 
|  | errorCode, | 
|  | span.start.offset, | 
|  | span.length, | 
|  | arguments, | 
|  | ); | 
|  | } | 
|  | } |