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 'dart:io';
import 'package:archive/archive.dart';
import 'package:logging/logging.dart'; import 'package:logging/logging.dart';
import 'package:native_assets_cli/native_assets_cli.dart'; import 'package:native_assets_cli/native_assets_cli.dart';
import 'package:native_toolchain_c/native_toolchain_c.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/"; var libDir = "${config.packageRoot.toFilePath()}/native/lib/$platform/";
if (platform == "macos") { if (platform == "macos") {
libDir += libDir += "${config.dryRun ? "debug" : config.buildMode == BuildMode.debug ? "debug" : "release"}";
"${config.dryRun ? "debug" : config.buildMode == BuildMode.debug ? "debug" : "release"}";
} else if (platform == "android") { } else if (platform == "android") {
// we don't recommend using Filament debug builds on Android, since there // we don't recommend using Filament debug builds on Android, since there
// are known driver issues, e.g.: // 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 packageName = config.packageName;
final sources = Directory("${config.packageRoot.toFilePath()}/native/src") final sources = Directory("${config.packageRoot.toFilePath()}/native/src")
@@ -80,15 +85,7 @@ void main(List<String> args) async {
var frameworks = []; var frameworks = [];
if (platform == "ios") { if (platform == "ios") {
frameworks.addAll([ frameworks.addAll(['Foundation', 'CoreGraphics', 'QuartzCore', 'GLKit', "Metal", 'CoreVideo', 'OpenGLES']);
'Foundation',
'CoreGraphics',
'QuartzCore',
'GLKit',
"Metal",
'CoreVideo',
'OpenGLES'
]);
} else if (platform == "macos") { } else if (platform == "macos") {
frameworks.addAll([ frameworks.addAll([
'Foundation', 'Foundation',
@@ -135,8 +132,7 @@ void main(List<String> args) async {
_ => throw FormatException('Invalid') _ => throw FormatException('Invalid')
}; };
var ndkRoot = File(config.cCompiler.compiler!.path).parent.parent.path; var ndkRoot = File(config.cCompiler.compiler!.path).parent.parent.path;
var stlPath = var stlPath = File("$ndkRoot/sysroot/usr/lib/${archExtension}/libc++_shared.so");
File("$ndkRoot/sysroot/usr/lib/${archExtension}/libc++_shared.so");
output.addAsset(NativeCodeAsset( output.addAsset(NativeCodeAsset(
package: "dart_filament", package: "dart_filament",
name: "libc++_shared.so", 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: tuple:
ffi: ffi:
animation_tools_dart: ^0.0.4 animation_tools_dart: ^0.0.4
archive: ^3.6.1
native_assets_cli: ^0.5.0
native_toolchain_c: ^0.4.0
dev_dependencies: dev_dependencies:
ffigen: ^11.0.0 ffigen: ^11.0.0
native_assets_cli: ^0.5.0
native_toolchain_c: ^0.4.0
test: test: