Download and unzip native assets during build

This commit is contained in:
Hannes Hultergård
2024-06-06 21:13:40 +02:00
parent c40814709d
commit 1831e31afb
2 changed files with 36 additions and 15 deletions

View File

@@ -1,4 +1,5 @@
import 'dart:io';
import 'package:archive/archive.dart';
import 'package:logging/logging.dart';
import 'package:native_assets_cli/native_assets_cli.dart';
import 'package:native_toolchain_c/native_toolchain_c.dart';
@@ -10,8 +11,7 @@ void main(List<String> args) async {
var libDir = "${config.packageRoot.toFilePath()}/native/lib/$platform/";
if (platform == "macos") {
libDir +=
"${config.dryRun ? "debug" : config.buildMode == BuildMode.debug ? "debug" : "release"}";
libDir += "${config.dryRun ? "debug" : config.buildMode == BuildMode.debug ? "debug" : "release"}";
} else if (platform == "android") {
// we don't recommend using Filament debug builds on Android, since there
// are known driver issues, e.g.:
@@ -35,6 +35,11 @@ void main(List<String> args) async {
}
}
// Assume that the libraries exist if the directory containing them exists.
if (!Directory(libDir).existsSync()) {
await _downloadLibraries(platform, libDir);
}
final packageName = config.packageName;
final sources = Directory("${config.packageRoot.toFilePath()}/native/src")
@@ -80,15 +85,7 @@ void main(List<String> args) async {
var frameworks = [];
if (platform == "ios") {
frameworks.addAll([
'Foundation',
'CoreGraphics',
'QuartzCore',
'GLKit',
"Metal",
'CoreVideo',
'OpenGLES'
]);
frameworks.addAll(['Foundation', 'CoreGraphics', 'QuartzCore', 'GLKit', "Metal", 'CoreVideo', 'OpenGLES']);
} else if (platform == "macos") {
frameworks.addAll([
'Foundation',
@@ -135,8 +132,7 @@ void main(List<String> args) async {
_ => throw FormatException('Invalid')
};
var ndkRoot = File(config.cCompiler.compiler!.path).parent.parent.path;
var stlPath =
File("$ndkRoot/sysroot/usr/lib/${archExtension}/libc++_shared.so");
var stlPath = File("$ndkRoot/sysroot/usr/lib/${archExtension}/libc++_shared.so");
output.addAsset(NativeCodeAsset(
package: "dart_filament",
name: "libc++_shared.so",
@@ -147,3 +143,27 @@ void main(List<String> args) async {
}
});
}
Future<void> _downloadLibraries(String platform, String outputDirectory) async {
final request = await HttpClient().getUrl(Uri.parse('http://localhost:8000/$platform-libraries.zip'));
final response = await request.close();
final libraryZip = File('${Directory.systemTemp.path}/$platform-libraries.zip');
await response.pipe(libraryZip.openWrite());
final archive = ZipDecoder().decodeBytes(await libraryZip.readAsBytes());
for (final file in archive) {
final filename = file.name;
if (file.isFile) {
final data = file.content as List<int>;
final f = File('$outputDirectory/$filename');
await f.create(recursive: true);
await f.writeAsBytes(data);
} else {
final d = Directory('$outputDirectory/$filename');
await d.create(recursive: true);
}
}
}

View File

@@ -12,11 +12,12 @@ dependencies:
tuple:
ffi:
animation_tools_dart: ^0.0.4
archive: ^3.6.1
native_assets_cli: ^0.5.0
native_toolchain_c: ^0.4.0
dev_dependencies:
ffigen: ^11.0.0
native_assets_cli: ^0.5.0
native_toolchain_c: ^0.4.0
test: