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

[native_x] Deprecate dryRun #1757

Merged
merged 1 commit into from
Nov 27, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
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
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ void main(List<String> arguments) async {
final targetFile = File.fromUri(config.outputDirectoryShared
.resolve(sourceName.replaceFirst('data', 'data_transformed')));

// ignore: deprecated_member_use
if (!config.dryRun) {
// TODO(dacoharkes): Timestamps are not enough for correct caching.
if (!await targetFile.exists() ||
Expand All @@ -52,6 +53,7 @@ void main(List<String> arguments) async {
);
}

// ignore: deprecated_member_use
if (!config.dryRun) {
print('Transformed $transformedFiles files.');
print('Reused $cachedFiles cached files.');
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ void main(List<String> arguments) async {
final assetUri = config.outputDirectory.resolve(
OS.current.dylibFileName('foo'),
);
// ignore: deprecated_member_use
if (!config.dryRun) {
await File.fromUri(assetUri).writeAsBytes([1, 2, 3]);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ void main(List<String> arguments) async {
final assetUri = config.outputDirectory.resolve(
OS.current.dylibFileName('foo'),
);
// ignore: deprecated_member_use
if (!config.dryRun) {
await File.fromUri(assetUri).writeAsBytes([1, 2, 3]);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ Future<void> main(List<String> args) async {
final packageName = config.packageName;
final assetPath = config.outputDirectory.resolve(assetName);
final assetSourcePath = config.packageRoot.resolveUri(packageAssetPath);
// ignore: deprecated_member_use
if (!config.dryRun) {
// Insert code that downloads or builds the asset to `assetPath`.
await File.fromUri(assetSourcePath).copy(assetPath.toFilePath());
Expand All @@ -39,6 +40,7 @@ Future<void> main(List<String> args) async {
linkMode: DynamicLoadingBundled(),
os: config.targetOS,
architecture:
// ignore: deprecated_member_use
config.dryRun ? null : config.codeConfig.targetArchitecture,
),
);
Expand Down
16 changes: 7 additions & 9 deletions pkgs/native_assets_cli/lib/src/code_assets/code_asset.dart
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,6 @@ final class CodeAsset {
final OS os;

/// The architecture this asset can run on.
///
/// Not available during a [BuildConfig.dryRun].
final Architecture? architecture;

/// The link mode for this native code.
Expand All @@ -72,14 +70,14 @@ final class CodeAsset {

/// The file to be bundled with the Dart or Flutter application.
///
/// If the [linkMode] is [DynamicLoadingBundled], the file name must be
/// provided in the [BuildOutput] for [BuildConfig.dryRun]. Supplying a file
/// name instead of an absolute path is enough for [BuildConfig.dryRun]. The
/// file does not have to exist on disk during a dry run.
/// If the [linkMode] is [DynamicLoadingBundled], the file must be provided
/// and exist.
///
/// If the [linkMode] is [DynamicLoadingSystem], the file must be provided,
/// and not exist.
///
/// If the [linkMode] is [DynamicLoadingSystem], [LookupInProcess], or
/// [LookupInExecutable] the file must be omitted in the [BuildOutput] for
/// [BuildConfig.dryRun].
/// If the [linkMode] is [LookupInProcess], or [LookupInExecutable] the file
/// must be omitted in the [BuildOutput].
final Uri? file;

/// Constructs a native code asset.
Expand Down
1 change: 1 addition & 0 deletions pkgs/native_assets_cli/lib/src/code_assets/config.dart
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ class CodeConfig {
CodeConfig(HookConfig config)
: linkModePreference = LinkModePreference.fromString(
config.json.string(_linkModePreferenceKey)),
// ignore: deprecated_member_use_from_same_package
_targetArchitecture = (config is BuildConfig && config.dryRun)
? null
: Architecture.fromString(config.json.string(_targetArchitectureKey,
Expand Down
6 changes: 0 additions & 6 deletions pkgs/native_assets_cli/lib/src/code_assets/link_mode.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@
// 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 '../config.dart';

import 'code_asset.dart';

/// The link mode for a [CodeAsset].
Expand Down Expand Up @@ -75,10 +73,6 @@ abstract final class DynamicLoading extends LinkMode {
/// An asset with this dynamic loading method must provide a
/// [CodeAsset.file]. The Dart and Flutter SDK will bundle this code in
/// the final application.
///
/// During a [BuildConfig.dryRun], the [CodeAsset.file] can be a file name
/// instead of a the full path. The file does not have to exist during a dry
/// run.
final class DynamicLoadingBundled extends DynamicLoading {
DynamicLoadingBundled._() : super._();

Expand Down
18 changes: 15 additions & 3 deletions pkgs/native_assets_cli/lib/src/code_assets/validation.dart
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,12 @@ import 'link_mode.dart';
Future<ValidationErrors> validateCodeAssetBuildConfig(
BuildConfig config) async =>
_validateCodeConfig(
'BuildConfig', config.targetOS, config.dryRun, config.codeConfig);
'BuildConfig',
config.targetOS,
// ignore: deprecated_member_use_from_same_package
config.dryRun,
config.codeConfig,
);

Future<ValidationErrors> validateCodeAssetLinkConfig(LinkConfig config) async =>
_validateCodeConfig(
Expand Down Expand Up @@ -71,8 +76,15 @@ Future<ValidationErrors> validateCodeAssetBuildOutput(
BuildConfig config,
BuildOutput output,
) =>
_validateCodeAssetBuildOrLinkOutput(config, config.codeConfig,
output.encodedAssets, config.dryRun, output, true);
_validateCodeAssetBuildOrLinkOutput(
config,
config.codeConfig,
output.encodedAssets,
// ignore: deprecated_member_use_from_same_package
config.dryRun,
output,
true,
);

Future<ValidationErrors> validateCodeAssetLinkOutput(
LinkConfig config,
Expand Down
4 changes: 4 additions & 0 deletions pkgs/native_assets_cli/lib/src/config.dart
Original file line number Diff line number Diff line change
Expand Up @@ -166,17 +166,21 @@ const _packageRootConfigKey = 'package_root';
const _supportedAssetTypesKey = 'supported_asset_types';

final class BuildConfig extends HookConfig {
// TODO(dcharkes): Remove after 3.7.0 stable is released and bump the SDK
// constraint in the pubspec. Ditto for all uses in related packages.
/// Whether this run is a dry-run, which doesn't build anything.
///
/// A dry-run only reports information about which assets a build would
/// create, but doesn't actually create files.
@Deprecated('Flutter will no longer invoke dry run as of 3.27.')
final bool dryRun;

final bool linkingEnabled;

final Map<String, Metadata> metadata;

BuildConfig(super.json)
// ignore: deprecated_member_use_from_same_package
: dryRun = json.getOptional<bool>(_dryRunConfigKey) ?? false,
linkingEnabled = json.get<bool>(_linkingEnabledKey),
metadata = {
Expand Down
3 changes: 0 additions & 3 deletions pkgs/native_assets_cli/lib/src/data_assets/data_asset.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
// 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 '../config.dart';
import '../encoded_asset.dart';
import '../json_utils.dart';
import '../utils/map.dart';
Expand All @@ -18,8 +17,6 @@ import '../utils/map.dart';
final class DataAsset {
/// The file to be bundled with the Dart or Flutter application.
///
/// The file can be omitted in the [BuildOutput] for [BuildConfig.dryRun].
///
/// The file can also be omitted for asset types which refer to an asset
/// already present on the target system or an asset already present in Dart
/// or Flutter.
Expand Down
7 changes: 6 additions & 1 deletion pkgs/native_assets_cli/lib/src/data_assets/validation.dart
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,12 @@ Future<ValidationErrors> validateDataAssetBuildOutput(
BuildOutput output,
) =>
_validateDataAssetBuildOrLinkOutput(
config, output.encodedAssets, config.dryRun, true);
config,
output.encodedAssets,
// ignore: deprecated_member_use_from_same_package
config.dryRun,
true,
);

Future<ValidationErrors> validateDataAssetLinkOutput(
LinkConfig config,
Expand Down
3 changes: 3 additions & 0 deletions pkgs/native_toolchain_c/lib/src/cbuilder/cbuilder.dart
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,7 @@ class CBuilder extends CTool implements Builder {
// ignore: deprecated_member_use_from_same_package
for (final source in this.dartBuildFiles) packageRoot.resolve(source),
];
// ignore: deprecated_member_use
if (!config.dryRun) {
final task = RunCBuilder(
config: config,
Expand Down Expand Up @@ -175,11 +176,13 @@ class CBuilder extends CTool implements Builder {
linkMode: linkMode,
os: config.targetOS,
architecture:
// ignore: deprecated_member_use
config.dryRun ? null : config.codeConfig.targetArchitecture,
),
linkInPackage: linkInPackage,
);
}
// ignore: deprecated_member_use
if (!config.dryRun) {
final includeFiles = await Stream.fromIterable(includes)
.asyncExpand(
Expand Down