blob: d0448d217a6dd50e5a5cb583732863412da8f3f2 [file] [log] [blame]
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import '../base/io.dart';
import '../build_info.dart';
import '../desktop_device.dart';
import '../device.dart';
import '../globals.dart' as globals;
import '../macos/application_package.dart';
import '../project.dart';
import 'build_macos.dart';
import 'macos_workflow.dart';
/// A device that represents a desktop MacOS target.
class MacOSDevice extends DesktopDevice {
MacOSDevice() : super(
'macOS',
platformType: PlatformType.macos,
ephemeral: false,
);
@override
bool isSupported() => true;
@override
String get name => 'macOS';
@override
Future<TargetPlatform> get targetPlatform async => TargetPlatform.darwin_x64;
@override
bool isSupportedForProject(FlutterProject flutterProject) {
return flutterProject.macos.existsSync();
}
@override
Future<void> buildForDevice(
covariant MacOSApp package, {
String mainPath,
BuildInfo buildInfo,
}) async {
await buildMacOS(
flutterProject: FlutterProject.current(),
buildInfo: buildInfo,
targetOverride: mainPath,
);
}
@override
String executablePathForDevice(covariant MacOSApp package, BuildMode buildMode) {
return package.executable(buildMode);
}
@override
void onAttached(covariant MacOSApp package, BuildMode buildMode, Process process) {
// Bring app to foreground. Ideally this would be done post-launch rather
// than post-attach, since this won't run for release builds, but there's
// no general-purpose way of knowing when a process is far enoug along in
// the launch process for 'open' to foreground it.
globals.processManager.run(<String>[
'open', package.applicationBundle(buildMode),
]).then((ProcessResult result) {
if (result.exitCode != 0) {
print('Failed to foreground app; open returned ${result.exitCode}');
}
});
}
}
class MacOSDevices extends PollingDeviceDiscovery {
MacOSDevices() : super('macOS devices');
@override
bool get supportsPlatform => globals.platform.isMacOS;
@override
bool get canListAnything => macOSWorkflow.canListDevices;
@override
Future<List<Device>> pollingGetDevices() async {
if (!canListAnything) {
return const <Device>[];
}
return <Device>[
MacOSDevice(),
];
}
@override
Future<List<String>> getDiagnostics() async => const <String>[];
}