Skip to content
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

generator: Support the latest package dependencies #328

Merged
merged 4 commits into from
Dec 18, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
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
33 changes: 27 additions & 6 deletions web_generator/bin/update_bindings.dart
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import 'package:analyzer/dart/element/type.dart';
import 'package:args/args.dart';
import 'package:io/ansi.dart' as ansi;
import 'package:io/io.dart';
import 'package:package_config/package_config.dart';
import 'package:path/path.dart' as p;

void main(List<String> arguments) async {
Expand Down Expand Up @@ -48,13 +49,16 @@ $_usage''');
await _generateJsTypeSupertypes();

if (argResult['compile'] as bool) {
final webPkgLangVersion = await _webPackageLanguageVersion(_webPackagePath);
// Compile Dart to Javascript.
await _runProc(
Platform.executable,
[
'compile',
'js',
'--enable-asserts',
'--server-mode',
'-DlanguageVersion=$webPkgLangVersion',
'dart_main.dart',
'-o',
'dart_main.js',
Expand All @@ -64,8 +68,7 @@ $_usage''');
}

// Determine the set of previously generated files.
final domDir =
Directory(Platform.script.resolve('../../web/lib/src/dom').path);
final domDir = Directory(p.join(_webPackagePath, 'lib/src/dom'));
final existingFiles =
domDir.listSync(recursive: true).whereType<File>().where((file) {
if (!file.path.endsWith('.dart')) return false;
Expand All @@ -83,7 +86,7 @@ $_usage''');
'node',
[
'main.mjs',
'--output-directory=${Platform.script.resolve('../../web/lib/src').path}',
'--output-directory=${p.join(_webPackagePath, 'lib/src')}',
if (generateAll) '--generate-all',
],
workingDirectory: _bindingsGeneratorPath,
Expand Down Expand Up @@ -128,6 +131,25 @@ $_startComment
}
}

Future<String> _webPackageLanguageVersion(String pkgPath) async {
srujzs marked this conversation as resolved.
Show resolved Hide resolved
final packageConfig = await findPackageConfig(Directory(pkgPath));
if (packageConfig == null) {
throw StateError('No package config for "$pkgPath"');
}
final package =
packageConfig.packageOf(Uri.file(p.join(pkgPath, 'pubspec.yaml')));
if (package == null) {
throw StateError('No package at "$pkgPath"');
}
final languageVersion = package.languageVersion;
if (languageVersion == null) {
throw StateError('No language version "$pkgPath"');
}
return '$languageVersion.0';
}

final _webPackagePath = Platform.script.resolve('../../web').path;

String _packageLockVersion(String package) {
final packageLockData = jsonDecode(
File(p.join(_bindingsGeneratorPath, 'package-lock.json'))
Expand Down Expand Up @@ -174,9 +196,8 @@ Future<void> _runProc(
// used by the translator to handle IDL types.
Future<void> _generateJsTypeSupertypes() async {
// Use a file that uses `dart:js_interop` for analysis.
final contextCollection = AnalysisContextCollection(includedPaths: [
p.fromUri(Platform.script.resolve('../../web/lib/src/dom.dart'))
]);
final contextCollection = AnalysisContextCollection(
includedPaths: [p.join(_webPackagePath, 'lib/src/dom.dart')]);
final dartJsInterop = (await contextCollection.contexts.single.currentSession
.getLibraryByUri('dart:js_interop') as LibraryElementResult)
.element;
Expand Down
24 changes: 17 additions & 7 deletions web_generator/lib/src/dart_main.dart
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import 'dart:js_interop';
import 'package:args/args.dart';
import 'package:code_builder/code_builder.dart' as code;
import 'package:dart_style/dart_style.dart';
import 'package:pub_semver/pub_semver.dart';

import 'filesystem_api.dart';
import 'generate_bindings.dart';
Expand All @@ -19,15 +20,24 @@ import 'util.dart';
// probably involve parsing the TC39 spec.

void main(List<String> args) async {
var languageVersionString = const String.fromEnvironment('languageVersion');
if (languageVersionString == '') {
kevmoo marked this conversation as resolved.
Show resolved Hide resolved
languageVersionString = DartFormatter.latestLanguageVersion.toString();
}
final ArgResults argResult;
argResult = _parser.parse(args);
await _generateAndWriteBindings(
outputDirectory: argResult['output-directory'] as String,
generateAll: argResult['generate-all'] as bool);
outputDirectory: argResult['output-directory'] as String,
generateAll: argResult['generate-all'] as bool,
languageVersion: Version.parse(languageVersionString),
);
}

Future<void> _generateAndWriteBindings(
{required String outputDirectory, required bool generateAll}) async {
Future<void> _generateAndWriteBindings({
required String outputDirectory,
required bool generateAll,
required Version languageVersion,
}) async {
const librarySubDir = 'dom';

ensureDirectoryExists('$outputDirectory/$librarySubDir');
Expand All @@ -38,20 +48,20 @@ Future<void> _generateAndWriteBindings(
final libraryPath = entry.key;
final library = entry.value;

final contents = _emitLibrary(library).toJS;
final contents = _emitLibrary(library, languageVersion).toJS;
fs.writeFileSync('$outputDirectory/$libraryPath'.toJS, contents);
}
}

String _emitLibrary(code.Library library) {
String _emitLibrary(code.Library library, Version languageVersion) {
final emitter = code.DartEmitter(
allocator: code.Allocator(),
orderDirectives: true,
useNullSafetySyntax: true,
);

final source = library.accept(emitter);
return DartFormatter(languageVersion: DartFormatter.latestLanguageVersion)
return DartFormatter(languageVersion: languageVersion)
.format(source.toString());
}

Expand Down
8 changes: 5 additions & 3 deletions web_generator/pubspec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,19 @@ description: Generator scripts for package:web.
repository: https://github.com/dart-lang/web

environment:
sdk: ^3.6.0-0
sdk: ^3.6.0

dependencies:
analyzer: ^6.3.0
analyzer: ^7.0.0
args: ^2.4.0
build_runner: ^2.4.6
build_web_compilers: ^4.0.8
code_builder: ^4.10.0
collection: ^1.18.0
dart_flutter_team_lints: ^3.0.0
dart_style: ^2.3.7
dart_style: ^3.0.0
io: ^1.0.4
package_config: ^2.1.1
path: ^1.8.3
pub_semver: ^2.1.5
test: ^1.24.4
Loading