blob: 6d85a1a02c46aa251588d83eb071e4eb6b32af4a [file] [log] [blame]
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'dart:typed_data';
import 'package:package_config/package_config.dart';
import '../base/common.dart';
import '../base/file_system.dart';
import '../base/logger.dart';
/// Load the package configuration from [file] or throws a [ToolExit]
/// if the operation would fail.
///
/// If [throwOnError] is false, in the event of an error an empty package
/// config is returned.
Future<PackageConfig> loadPackageConfigWithLogging(File file, {
required Logger logger,
bool throwOnError = true,
}) async {
final FileSystem fileSystem = file.fileSystem;
bool didError = false;
final PackageConfig result = await loadPackageConfigUri(
file.absolute.uri,
loader: (Uri uri) async {
final File configFile = fileSystem.file(uri);
if (!configFile.existsSync()) {
return null;
}
return Future<Uint8List>.value(configFile.readAsBytesSync());
},
onError: (dynamic error) {
if (!throwOnError) {
return;
}
logger.printTrace(error.toString());
String message = '${file.path} does not exist.';
final String pubspecPath = fileSystem.path.absolute(fileSystem.path.dirname(file.path), 'pubspec.yaml');
if (fileSystem.isFileSync(pubspecPath)) {
message += '\nDid you run "flutter pub get" in this directory?';
} else {
message += '\nDid you run this command from the same directory as your pubspec.yaml file?';
}
logger.printError(message);
didError = true;
}
);
if (didError) {
throwToolExit('');
}
return result;
}