Skip to content

Commit

Permalink
fixes genai build.dart script (#63)
Browse files Browse the repository at this point in the history
  • Loading branch information
craiglabenz authored Jun 6, 2024
1 parent 5ee4fb1 commit dba7fef
Show file tree
Hide file tree
Showing 4 changed files with 130 additions and 126 deletions.
122 changes: 0 additions & 122 deletions packages/mediapipe-task-genai/build.dart

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -470,7 +470,7 @@
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CLANG_ENABLE_MODULES = YES;
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
DEVELOPMENT_TEAM = 35JKZ342M3;
DEVELOPMENT_TEAM = S8QB4VV633;
ENABLE_BITCODE = NO;
INFOPLIST_FILE = Runner/Info.plist;
LD_RUNPATH_SEARCH_PATHS = (
Expand Down Expand Up @@ -653,7 +653,7 @@
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CLANG_ENABLE_MODULES = YES;
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
DEVELOPMENT_TEAM = 35JKZ342M3;
DEVELOPMENT_TEAM = S8QB4VV633;
ENABLE_BITCODE = NO;
INFOPLIST_FILE = Runner/Info.plist;
LD_RUNPATH_SEARCH_PATHS = (
Expand All @@ -676,7 +676,7 @@
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CLANG_ENABLE_MODULES = YES;
CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)";
DEVELOPMENT_TEAM = 35JKZ342M3;
DEVELOPMENT_TEAM = S8QB4VV633;
ENABLE_BITCODE = NO;
INFOPLIST_FILE = Runner/Info.plist;
LD_RUNPATH_SEARCH_PATHS = (
Expand Down
126 changes: 126 additions & 0 deletions packages/mediapipe-task-genai/hook/build.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,126 @@
import 'dart:io';
import 'package:native_assets_cli/native_assets_cli.dart';
import 'package:http/http.dart' as http;
import 'package:path/path.dart' as path;

import '../sdk_downloads.dart';

late File logFile;

final logs = <(DateTime, String)>[];
void log(String msg) {
logs.add((DateTime.now(), msg));
if (!logFile.parent.existsSync()) {
logFile.parent.createSync();
}

if (logFile.existsSync()) {
logFile.deleteSync();
}
logFile.createSync();
logFile.writeAsStringSync(logs
.map<String>((rec) => '[${rec.$1.toIso8601String()}] ${rec.$2}')
.toList()
.join('\n\n'));
}

Future<void> main(List<String> args) async {
await build(args, (buildConfig, buildOutput) async {
logFile = File(
path.joinAll([
Directory.current.path, // root dir of app using `mediapipe-task-xyz`
'build/${buildConfig.dryRun ? "dryrun" : "live-run"}-build-log.txt',
]),
);

log(args.join(' '));
final String targetOs = buildConfig.targetOS.toString();

log('dir.current: ${Directory.current.absolute.path}');

// Throw if target runtime is unsupported.
if (!sdkDownloadUrls.containsKey(targetOs)) {
throw Exception('Unsupported target OS: $targetOs. '
'Supported values are: ${sdkDownloadUrls.keys.toSet()}');
}

buildOutput.addDependencies([
buildConfig.packageRoot.resolve('build.dart'),
buildConfig.packageRoot.resolve('sdk_downloads.dart'),
]);

final modelName = 'libllm_inference_engine';
final Iterable<String> archKeys;
if (buildConfig.dryRun) {
archKeys = sdkDownloadUrls[targetOs]![modelName]!.keys;
} else {
archKeys = [buildConfig.targetArchitecture.toString()];
}
for (String arch in archKeys) {
arch = getArchAlias(arch);
log('arch: $arch');
log('sdkDownloadUrls[$targetOs]: ${sdkDownloadUrls[targetOs]}');
log('sdkDownloadUrls[$targetOs][$modelName]: ${sdkDownloadUrls[targetOs]![modelName]}');
log('sdkDownloadUrls[$targetOs][$modelName][$arch]: ${sdkDownloadUrls[targetOs]![modelName]![arch]}');

if (!sdkDownloadUrls[targetOs]!['libllm_inference_engine']!
.containsKey(arch)) {
continue;
}
final assetUrl =
sdkDownloadUrls[targetOs]!['libllm_inference_engine']![arch]!;

// Take last chunk and drop file extension, e.g.,
// "path/to/file.dylib" -> "file"
final fileName = assetUrl.split('/').last.split('.').first;

final downloadFileLocation = buildConfig.outputDirectory.resolve(
buildConfig.targetOS.dylibFileName(fileName),
);
buildOutput.addAsset(
NativeCodeAsset(
package: 'mediapipe_genai',
name:
'src/io/third_party/mediapipe/generated/mediapipe_genai_bindings.dart',
linkMode: DynamicLoadingBundled(),
os: buildConfig.targetOS,
architecture: buildConfig.targetArchitecture,
file: downloadFileLocation,
),
);
if (!buildConfig.dryRun) {
log('downloadFileLocation: $downloadFileLocation');
downloadAsset(assetUrl, downloadFileLocation);
}
}
});
}

Future<void> downloadAsset(String assetUrl, Uri destinationFile) async {
final downloadUri = Uri.parse(assetUrl);
final downloadedFile = File(destinationFile.toFilePath());
log('Saving file to ${downloadedFile.absolute.path}');

final downloadResponse = await http.get(downloadUri);
log('Download response: ${downloadResponse.statusCode}');

if (downloadResponse.statusCode == 200) {
if (downloadedFile.existsSync()) {
downloadedFile.deleteSync();
}
downloadedFile.createSync();
log('Saved file to ${downloadedFile.absolute.path}\n');
downloadedFile.writeAsBytes(downloadResponse.bodyBytes);
} else {
log('${downloadResponse.statusCode} :: ${downloadResponse.body}');
throw Exception(
'${downloadResponse.statusCode} :: ${downloadResponse.body}');
}
}

/// Translates native-assets architecture names into MediaPipe architecture names
String getArchAlias(String arch) =>
<String, String>{
'arm': 'arm64',
}[arch] ??
arch;
2 changes: 1 addition & 1 deletion packages/mediapipe-task-text/hook/build.dart
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,6 @@ Future<void> main(List<String> args) async {
final downloadFileLocation = buildConfig.outputDirectory.resolve(
buildConfig.targetOS.dylibFileName('text'),
);
log('downloadFileLocation: $downloadFileLocation');
buildOutput.addAsset(
NativeCodeAsset(
package: 'mediapipe_text',
Expand All @@ -66,6 +65,7 @@ Future<void> main(List<String> args) async {
),
);
if (!buildConfig.dryRun) {
log('downloadFileLocation: $downloadFileLocation');
final arch = buildConfig.targetArchitecture.toString();
final assetUrl = sdkDownloadUrls[targetOS]!['libtext']![arch]!;
downloadAsset(assetUrl, downloadFileLocation);
Expand Down

1 comment on commit dba7fef

@charlieforward9
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@craiglabenz Taking another whack at this.

I am trying to run the genai example on my machine and am running into problems:

Target dart_build failed: Error: Building native assets failed. See the logs for more details.

Failed to package /Users/crich/development/github/flutter-mediapipe/packages/mediapipe-task-genai/example.

"/Users/crich/development/github/flutter-mediapipe/packages/mediapipe-task-genai/hook/build.dart" file not found.

When I copy the build.dart file from this commit, it cannot find sdk_downloads.dart

Seems like the genai package needs a few extra kinks smoothed out. Going to get familiar with the text package instead prior to contributing to vision.

Please sign in to comment.