Skip to content

Commit

Permalink
[native_toolchain_c] Add workaround for minSdkVersion 19 and 20 (#181)
Browse files Browse the repository at this point in the history
Closes: #171

Uses the workaround that the Android Gradle plugin uses: #171 (comment).
  • Loading branch information
dcharkes authored Nov 1, 2023
1 parent ad02f7e commit aecb5c6
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 32 deletions.
12 changes: 11 additions & 1 deletion pkgs/native_toolchain_c/lib/src/cbuilder/run_cbuilder.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
// 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 'dart:math';

import 'package:logging/logging.dart';
import 'package:native_assets_cli/native_assets_cli.dart';

Expand Down Expand Up @@ -126,13 +128,21 @@ class RunCBuilder {
targetIosSdk = buildConfig.targetIOSSdk!;
}

// The Android Gradle plugin does not honor API level 19 and 20 when
// invoking clang. Mimic that behavior here.
// See https://github.com/dart-lang/native/issues/171.
late final int targetAndroidNdkApi;
if (target.os == OS.android) {
targetAndroidNdkApi = max(buildConfig.targetAndroidNdkApi!, 21);
}

await runProcess(
executable: compiler.uri,
arguments: [
if (target.os == OS.android) ...[
'--target='
'${androidNdkClangTargetFlags[target]!}'
'${buildConfig.targetAndroidNdkApi!}',
'$targetAndroidNdkApi',
'--sysroot=${androidSysroot(compiler).toFilePath()}',
],
if (target.os == OS.macOS)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,9 @@ void main() {
Target.androidX64: 'elf64-x86-64',
};

/// From https://docs.flutter.dev/reference/supported-platforms.
const flutterAndroidNdkVersionLowestBestEffort = 19;

/// From https://docs.flutter.dev/reference/supported-platforms.
const flutterAndroidNdkVersionLowestSupported = 21;

Expand All @@ -41,38 +44,45 @@ void main() {

for (final linkMode in LinkMode.values) {
for (final target in targets) {
test('CBuilder $linkMode library $target', () async {
final tempUri = await tempDirForTest();
final libUri = await buildLib(
tempUri,
target,
flutterAndroidNdkVersionLowestSupported,
linkMode,
);
if (Platform.isLinux) {
final result = await runProcess(
executable: Uri.file('readelf'),
arguments: ['-h', libUri.path],
logger: logger,
);
expect(result.exitCode, 0);
final machine = result.stdout
.split('\n')
.firstWhere((e) => e.contains('Machine:'));
expect(machine, contains(readElfMachine[target]));
} else if (Platform.isMacOS) {
final result = await runProcess(
executable: Uri.file('objdump'),
arguments: ['-T', libUri.path],
logger: logger,
for (final apiLevel in [
flutterAndroidNdkVersionLowestBestEffort,
flutterAndroidNdkVersionLowestSupported,
flutterAndroidNdkVersionHighestSupported,
]) {
test('CBuilder $linkMode library $target minSdkVersion $apiLevel',
() async {
final tempUri = await tempDirForTest();
final libUri = await buildLib(
tempUri,
target,
apiLevel,
linkMode,
);
expect(result.exitCode, 0);
final machine = result.stdout
.split('\n')
.firstWhere((e) => e.contains('file format'));
expect(machine, contains(objdumpFileFormat[target]));
}
});
if (Platform.isLinux) {
final result = await runProcess(
executable: Uri.file('readelf'),
arguments: ['-h', libUri.path],
logger: logger,
);
expect(result.exitCode, 0);
final machine = result.stdout
.split('\n')
.firstWhere((e) => e.contains('Machine:'));
expect(machine, contains(readElfMachine[target]));
} else if (Platform.isMacOS) {
final result = await runProcess(
executable: Uri.file('objdump'),
arguments: ['-T', libUri.path],
logger: logger,
);
expect(result.exitCode, 0);
final machine = result.stdout
.split('\n')
.firstWhere((e) => e.contains('file format'));
expect(machine, contains(objdumpFileFormat[target]));
}
});
}
}
}

Expand Down

0 comments on commit aecb5c6

Please sign in to comment.