Commit 0bf68cc5 authored by Chinmay Garde's avatar Chinmay Garde

Merge pull request #3140 from chinmaygarde/master

Add a `--no-codesign` option to `ios build` to disable code signing.
parent dea7c347
...@@ -15,7 +15,9 @@ import 'package:path/path.dart' as path; ...@@ -15,7 +15,9 @@ import 'package:path/path.dart' as path;
class BuildIOSCommand extends FlutterCommand { class BuildIOSCommand extends FlutterCommand {
BuildIOSCommand() { BuildIOSCommand() {
argParser.addFlag('simulator', help: 'Build for the iOS simulator instead of the device'); argParser.addFlag('simulator', help: 'Build for the iOS simulator instead of the device.');
argParser.addFlag('codesign', negatable: true, defaultsTo: true,
help: 'Codesign the application bundle (only available on device builds).');
} }
@override @override
...@@ -39,6 +41,12 @@ class BuildIOSCommand extends FlutterCommand { ...@@ -39,6 +41,12 @@ class BuildIOSCommand extends FlutterCommand {
} }
bool forSimulator = argResults['simulator']; bool forSimulator = argResults['simulator'];
bool shouldCodesign = argResults['codesign'];
if (!forSimulator && !shouldCodesign) {
printStatus('Warning: Building for device with codesigning disabled.');
printStatus('You will have to manually codesign before deploying to device.');
}
String logTarget = forSimulator ? "simulator" : "device"; String logTarget = forSimulator ? "simulator" : "device";
...@@ -50,7 +58,7 @@ class BuildIOSCommand extends FlutterCommand { ...@@ -50,7 +58,7 @@ class BuildIOSCommand extends FlutterCommand {
await buildDir.create(); await buildDir.create();
bool result = await buildIOSXcodeProject(app, bool result = await buildIOSXcodeProject(app,
buildForDevice: !forSimulator, buildDirectory: buildDir); buildForDevice: !forSimulator, buildDirectory: buildDir, codesign: shouldCodesign);
if (!result) { if (!result) {
printError('Encountered error while building for $logTarget.'); printError('Encountered error while building for $logTarget.');
......
...@@ -97,7 +97,7 @@ bool _xcodeVersionCheckValid(int major, int minor) { ...@@ -97,7 +97,7 @@ bool _xcodeVersionCheckValid(int major, int minor) {
} }
Future<bool> buildIOSXcodeProject(ApplicationPackage app, Future<bool> buildIOSXcodeProject(ApplicationPackage app,
{ bool buildForDevice, Directory buildDirectory }) async { { bool buildForDevice, Directory buildDirectory, bool codesign: true }) async {
String flutterProjectPath = Directory.current.path; String flutterProjectPath = Directory.current.path;
if (xcodeProjectRequiresUpdate()) { if (xcodeProjectRequiresUpdate()) {
...@@ -125,6 +125,8 @@ Future<bool> buildIOSXcodeProject(ApplicationPackage app, ...@@ -125,6 +125,8 @@ Future<bool> buildIOSXcodeProject(ApplicationPackage app,
'/usr/bin/env', '/usr/bin/env',
'xcrun', 'xcrun',
'xcodebuild', 'xcodebuild',
'clean',
'build',
'-target', 'Runner', '-target', 'Runner',
'-configuration', 'Release', '-configuration', 'Release',
'ONLY_ACTIVE_ARCH=YES', 'ONLY_ACTIVE_ARCH=YES',
...@@ -141,6 +143,15 @@ Future<bool> buildIOSXcodeProject(ApplicationPackage app, ...@@ -141,6 +143,15 @@ Future<bool> buildIOSXcodeProject(ApplicationPackage app,
if (buildForDevice) { if (buildForDevice) {
commands.addAll(<String>['-sdk', 'iphoneos', '-arch', 'arm64']); commands.addAll(<String>['-sdk', 'iphoneos', '-arch', 'arm64']);
if (!codesign) {
commands.addAll(
<String>[
'CODE_SIGNING_ALLOWED=NO',
'CODE_SIGNING_REQUIRED=NO',
'CODE_SIGNING_IDENTITY=""'
]
);
}
} else { } else {
commands.addAll(<String>['-sdk', 'iphonesimulator', '-arch', 'x86_64']); commands.addAll(<String>['-sdk', 'iphonesimulator', '-arch', 'x86_64']);
} }
......
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