Skip to content

Commit

Permalink
fix: make relative paths in copied package_config.json absolute
Browse files Browse the repository at this point in the history
 so that they are still valid at their new place
  • Loading branch information
devmil committed Sep 26, 2023
1 parent 88b2147 commit ed2f92c
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 3 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# Changelog

## Version 0.16.2
- fixes relative path handling in package config (leading to unresolvable types)

## Version 0.16.1
- fixes issues with pubspec_overrides.yaml that got published with a pub package

Expand Down
38 changes: 35 additions & 3 deletions lib/src/cli/commands/command_mixin.dart
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import 'dart:convert';
import 'dart:io';

import 'package:dart_apitool/api_tool.dart';
Expand Down Expand Up @@ -79,6 +80,10 @@ OBSOLETE: Has no effect anymore.
File(_getPackageConfigPathForPackage(tempDir.path))
..createSync(recursive: true);
await sourcePackageConfig.copy(targetPackageConfig.path);
await _adaptPackageConfigToAbsolutePaths(
targetPackageConfigPath: targetPackageConfig.absolute.path,
sourcePackageConfigPath: sourcePackageConfig.absolute.path,
);
} else {
await stdoutSession.writeln('Cleaning up local copy of pub package');
// Check if we have a pub package that bundles a pubspec_overrides.yaml (as this most probably destroys pub get)
Expand Down Expand Up @@ -190,7 +195,34 @@ OBSOLETE: Has no effect anymore.
}
}
}
}

String _getPackageConfigPathForPackage(String packagePath) =>
p.join(packagePath, '.dart_tool', 'package_config.json');
Future _adaptPackageConfigToAbsolutePaths({
required String targetPackageConfigPath,
required String sourcePackageConfigPath,
}) async {
final sourcePackageConfigDirPath = p.dirname(sourcePackageConfigPath);
final targetPackageConfigContent =
jsonDecode(await File(targetPackageConfigPath).readAsString());
// iterate through the package_config.json content and look for relative paths
for (final packageConfig in targetPackageConfigContent['packages']) {
final rootUri = Uri.parse(packageConfig['rootUri']);
final packagePath = p.fromUri(rootUri);
if (p.isRelative(packagePath)) {
// we make the relative path absolute by using the origin of the source package config as a base
final normalizedPackagePath =
p.normalize(p.join(sourcePackageConfigDirPath, packagePath));
// and write the new absolute path back to the json structure
packageConfig['rootUri'] = p.toUri(normalizedPackagePath).toString();
}
}
final encoder = JsonEncoder.withIndent(' ');
// replace the package config with the new content
await File(targetPackageConfigPath).writeAsString(
encoder.convert(targetPackageConfigContent),
mode: FileMode.write,
);
}

String _getPackageConfigPathForPackage(String packagePath) =>
p.join(packagePath, '.dart_tool', 'package_config.json');
}

0 comments on commit ed2f92c

Please sign in to comment.