Download and unzip native assets during build
This commit is contained in:
@@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user