Unverified Commit 63e6a7ad authored by Stanislav Baranov's avatar Stanislav Baranov Committed by GitHub

Support for building dynamic patches in AOT mode. (#27672)

parent 7cdb30fb
...@@ -503,13 +503,21 @@ Future<void> _buildGradleProjectV2( ...@@ -503,13 +503,21 @@ Future<void> _buildGradleProjectV2(
final Archive update = Archive(); final Archive update = Archive();
for (ArchiveFile newFile in newApk) { for (ArchiveFile newFile in newApk) {
if (!newFile.isFile || !newFile.name.startsWith('assets/flutter_assets/')) if (!newFile.isFile)
continue;
// Ignore changes to signature manifests.
if (newFile.name.startsWith('META-INF/'))
continue; continue;
final ArchiveFile oldFile = oldApk.findFile(newFile.name); final ArchiveFile oldFile = oldApk.findFile(newFile.name);
if (oldFile != null && oldFile.crc32 == newFile.crc32) if (oldFile != null && oldFile.crc32 == newFile.crc32)
continue; continue;
// Only allow changes under assets/.
if (!newFile.name.startsWith('assets/'))
throwToolExit("Error: Dynamic patching doesn't support changes to ${newFile.name}.");
final String name = fs.path.relative(newFile.name, from: 'assets/'); final String name = fs.path.relative(newFile.name, from: 'assets/');
update.addFile(ArchiveFile(name, newFile.content.length, newFile.content)); update.addFile(ArchiveFile(name, newFile.content.length, newFile.content));
} }
...@@ -527,11 +535,21 @@ Future<void> _buildGradleProjectV2( ...@@ -527,11 +535,21 @@ Future<void> _buildGradleProjectV2(
printStatus('No changes detected, creating rollback patch.'); printStatus('No changes detected, creating rollback patch.');
} }
final ArchiveFile oldFile = oldApk.findFile('assets/flutter_assets/isolate_snapshot_data'); final List<String> checksumFiles = <String>[
if (oldFile == null) 'assets/isolate_snapshot_data',
throwToolExit('Error: Could not find baseline assets/flutter_assets/isolate_snapshot_data.'); 'assets/isolate_snapshot_instr',
'assets/flutter_assets/isolate_snapshot_data',
];
int baselineChecksum = 0;
for (String fn in checksumFiles) {
final ArchiveFile oldFile = oldApk.findFile(fn);
if (oldFile != null)
baselineChecksum = getCrc32(oldFile.content, baselineChecksum);
}
if (baselineChecksum == 0)
throwToolExit('Error: Could not find baseline VM snapshot.');
final int baselineChecksum = getCrc32(oldFile.content);
final Map<String, dynamic> manifest = <String, dynamic>{ final Map<String, dynamic> manifest = <String, dynamic>{
'baselineChecksum': baselineChecksum, 'baselineChecksum': baselineChecksum,
'buildNumber': package.versionCode, 'buildNumber': package.versionCode,
......
...@@ -440,6 +440,15 @@ class JITSnapshotter { ...@@ -440,6 +440,15 @@ class JITSnapshotter {
} }
} }
} }
{
final ArchiveFile af = baselinePkg.findFile(
fs.path.join('assets/flutter_assets/vm_snapshot_instr'));
if (af != null) {
printError('Error: Invalid baseline package ${baselineApk.path}.');
return 1;
}
}
} }
final String depfilePath = fs.path.join(outputDir.path, 'snapshot.d'); final String depfilePath = fs.path.join(outputDir.path, 'snapshot.d');
......
...@@ -229,9 +229,7 @@ class UserMessages { ...@@ -229,9 +229,7 @@ class UserMessages {
'https://github.com/flutter/flutter/blob/master/examples/flutter_gallery/pubspec.yaml\n'; 'https://github.com/flutter/flutter/blob/master/examples/flutter_gallery/pubspec.yaml\n';
String flutterTargetFileMissing(String path) => 'Target file "$path" not found.'; String flutterTargetFileMissing(String path) => 'Target file "$path" not found.';
String get flutterBasePatchFlagsExclusive => 'Error: Only one of --baseline, --patch is allowed.'; String get flutterBasePatchFlagsExclusive => 'Error: Only one of --baseline, --patch is allowed.';
String get flutterBaselineRequiresDynamic => 'Error: --baseline is allowed only when --dynamic is specified.';
String get flutterBaselineRequiresTraceFile => 'Error: --baseline requires --compilation-trace-file to be specified.'; String get flutterBaselineRequiresTraceFile => 'Error: --baseline requires --compilation-trace-file to be specified.';
String get flutterPatchRequiresDynamic => 'Error: --patch is allowed only when --dynamic is specified.';
String get flutterPatchRequiresTraceFile => 'Error: --patch requires --compilation-trace-file to be specified.'; String get flutterPatchRequiresTraceFile => 'Error: --patch requires --compilation-trace-file to be specified.';
// Messages used in FlutterCommandRunner // Messages used in FlutterCommandRunner
......
...@@ -647,8 +647,6 @@ abstract class FlutterCommand extends Command<void> { ...@@ -647,8 +647,6 @@ abstract class FlutterCommand extends Command<void> {
throw ToolExit(userMessages.flutterTargetFileMissing(targetPath)); throw ToolExit(userMessages.flutterTargetFileMissing(targetPath));
} }
final bool dynamicFlag = argParser.options.containsKey('dynamic')
? argResults['dynamic'] : false;
final String compilationTraceFilePath = argParser.options.containsKey('compilation-trace-file') final String compilationTraceFilePath = argParser.options.containsKey('compilation-trace-file')
? argResults['compilation-trace-file'] : null; ? argResults['compilation-trace-file'] : null;
final bool createBaseline = argParser.options.containsKey('baseline') final bool createBaseline = argParser.options.containsKey('baseline')
...@@ -658,12 +656,8 @@ abstract class FlutterCommand extends Command<void> { ...@@ -658,12 +656,8 @@ abstract class FlutterCommand extends Command<void> {
if (createBaseline && createPatch) if (createBaseline && createPatch)
throw ToolExit(userMessages.flutterBasePatchFlagsExclusive); throw ToolExit(userMessages.flutterBasePatchFlagsExclusive);
if (createBaseline && !dynamicFlag)
throw ToolExit(userMessages.flutterBaselineRequiresDynamic);
if (createBaseline && compilationTraceFilePath == null) if (createBaseline && compilationTraceFilePath == null)
throw ToolExit(userMessages.flutterBaselineRequiresTraceFile); throw ToolExit(userMessages.flutterBaselineRequiresTraceFile);
if (createPatch && !dynamicFlag)
throw ToolExit(userMessages.flutterPatchRequiresDynamic);
if (createPatch && compilationTraceFilePath == null) if (createPatch && compilationTraceFilePath == null)
throw ToolExit(userMessages.flutterPatchRequiresTraceFile); throw ToolExit(userMessages.flutterPatchRequiresTraceFile);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment