Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
4dffc851
Unverified
Commit
4dffc851
authored
Oct 13, 2020
by
Jenn Magder
Committed by
GitHub
Oct 13, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Detect ARM macOS arch with sysctl hw.optional.arm64 (#67970)
parent
0343555a
Changes
5
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
287 additions
and
53 deletions
+287
-53
application_package.dart
packages/flutter_tools/lib/src/application_package.dart
+1
-1
os.dart
packages/flutter_tools/lib/src/base/os.dart
+58
-12
build_info.dart
packages/flutter_tools/lib/src/build_info.dart
+4
-0
os_test.dart
packages/flutter_tools/test/general.shard/base/os_test.dart
+220
-40
context.dart
packages/flutter_tools/test/src/context.dart
+4
-0
No files found.
packages/flutter_tools/lib/src/application_package.dart
View file @
4dffc851
...
@@ -328,7 +328,7 @@ abstract class IOSApp extends ApplicationPackage {
...
@@ -328,7 +328,7 @@ abstract class IOSApp extends ApplicationPackage {
}
}
static
Future
<
IOSApp
>
fromIosProject
(
IosProject
project
,
BuildInfo
buildInfo
)
{
static
Future
<
IOSApp
>
fromIosProject
(
IosProject
project
,
BuildInfo
buildInfo
)
{
if
(
getCurrentHostPlatform
()
!=
HostPlatform
.
darwin_x64
)
{
if
(
!
globals
.
platform
.
isMacOS
)
{
return
null
;
return
null
;
}
}
if
(!
project
.
exists
)
{
if
(!
project
.
exists
)
{
...
...
packages/flutter_tools/lib/src/base/os.dart
View file @
4dffc851
...
@@ -7,6 +7,7 @@ import 'package:file/file.dart';
...
@@ -7,6 +7,7 @@ import 'package:file/file.dart';
import
'package:meta/meta.dart'
;
import
'package:meta/meta.dart'
;
import
'package:process/process.dart'
;
import
'package:process/process.dart'
;
import
'../build_info.dart'
;
import
'../globals.dart'
as
globals
;
import
'../globals.dart'
as
globals
;
import
'common.dart'
;
import
'common.dart'
;
import
'file_system.dart'
;
import
'file_system.dart'
;
...
@@ -29,6 +30,13 @@ abstract class OperatingSystemUtils {
...
@@ -29,6 +30,13 @@ abstract class OperatingSystemUtils {
platform:
platform
,
platform:
platform
,
processManager:
processManager
,
processManager:
processManager
,
);
);
}
else
if
(
platform
.
isMacOS
)
{
return
_MacOSUtils
(
fileSystem:
fileSystem
,
logger:
logger
,
platform:
platform
,
processManager:
processManager
,
);
}
else
{
}
else
{
return
_PosixUtils
(
return
_PosixUtils
(
fileSystem:
fileSystem
,
fileSystem:
fileSystem
,
...
@@ -112,6 +120,8 @@ abstract class OperatingSystemUtils {
...
@@ -112,6 +120,8 @@ abstract class OperatingSystemUtils {
return
osNames
.
containsKey
(
osName
)
?
osNames
[
osName
]
:
osName
;
return
osNames
.
containsKey
(
osName
)
?
osNames
[
osName
]
:
osName
;
}
}
HostPlatform
get
hostPlatform
;
List
<
File
>
_which
(
String
execName
,
{
bool
all
=
false
});
List
<
File
>
_which
(
String
execName
,
{
bool
all
=
false
});
/// Returns the separator between items in the PATH environment variable.
/// Returns the separator between items in the PATH environment variable.
...
@@ -246,30 +256,63 @@ class _PosixUtils extends OperatingSystemUtils {
...
@@ -246,30 +256,63 @@ class _PosixUtils extends OperatingSystemUtils {
return
_fileSystem
.
file
(
path
);
return
_fileSystem
.
file
(
path
);
}
}
@override
String
get
pathVarSeparator
=>
':'
;
@override
HostPlatform
hostPlatform
=
HostPlatform
.
linux_x64
;
}
class
_MacOSUtils
extends
_PosixUtils
{
_MacOSUtils
({
@required
FileSystem
fileSystem
,
@required
Logger
logger
,
@required
Platform
platform
,
@required
ProcessManager
processManager
,
})
:
super
(
fileSystem:
fileSystem
,
logger:
logger
,
platform:
platform
,
processManager:
processManager
,
);
String
_name
;
String
_name
;
@override
@override
String
get
name
{
String
get
name
{
if
(
_name
==
null
)
{
if
(
_name
==
null
)
{
if
(
_platform
.
isMacOS
)
{
final
List
<
RunResult
>
results
=
<
RunResult
>[
final
List
<
RunResult
>
results
=
<
RunResult
>[
_processUtils
.
runSync
(<
String
>[
'sw_vers'
,
'-productName'
]),
_processUtils
.
runSync
(<
String
>[
'sw_vers'
,
'-productName'
]),
_processUtils
.
runSync
(<
String
>[
'sw_vers'
,
'-productVersion'
]),
_processUtils
.
runSync
(<
String
>[
'sw_vers'
,
'-productVersion'
]),
_processUtils
.
runSync
(<
String
>[
'sw_vers'
,
'-buildVersion'
]),
_processUtils
.
runSync
(<
String
>[
'sw_vers'
,
'-buildVersion'
]),
];
_processUtils
.
runSync
(<
String
>[
'uname'
,
'-m'
]),
if
(
results
.
every
((
RunResult
result
)
=>
result
.
exitCode
==
0
))
{
];
_name
=
if
(
results
.
every
((
RunResult
result
)
=>
result
.
exitCode
==
0
))
{
'
${results[0].stdout.trim()}
${results[1].stdout.trim()}
${results[2].stdout.trim()}
${getNameForHostPlatform(hostPlatform)}
'
;
_name
=
'
${results[0].stdout.trim()}
${results[1].stdout
.trim()}
${results[2].stdout.trim()}
${results[3].stdout.trim()}
'
;
}
}
}
_name
??=
super
.
name
;
_name
??=
super
.
name
;
}
}
return
_name
;
return
_name
;
}
}
HostPlatform
_hostPlatform
;
// On ARM returns arm64, even when this process is running in Rosetta.
@override
@override
String
get
pathVarSeparator
=>
':'
;
HostPlatform
get
hostPlatform
{
if
(
_hostPlatform
==
null
)
{
final
RunResult
arm64Check
=
_processUtils
.
runSync
(<
String
>[
'sysctl'
,
'hw.optional.arm64'
]);
// hw.optional.arm64 is unavailable on < macOS 11 and exits with 1, assume x86 on failure.
// On arm64 stdout is "sysctl hw.optional.arm64: 1"
if
(
arm64Check
.
exitCode
==
0
&&
arm64Check
.
stdout
.
trim
().
endsWith
(
'1'
))
{
_hostPlatform
=
HostPlatform
.
darwin_arm
;
}
else
{
_hostPlatform
=
HostPlatform
.
darwin_x64
;
}
}
return
_hostPlatform
;
}
}
}
class
_WindowsUtils
extends
OperatingSystemUtils
{
class
_WindowsUtils
extends
OperatingSystemUtils
{
...
@@ -285,6 +328,9 @@ class _WindowsUtils extends OperatingSystemUtils {
...
@@ -285,6 +328,9 @@ class _WindowsUtils extends OperatingSystemUtils {
processManager:
processManager
,
processManager:
processManager
,
);
);
@override
HostPlatform
hostPlatform
=
HostPlatform
.
windows_x64
;
@override
@override
void
makeExecutable
(
File
file
)
{}
void
makeExecutable
(
File
file
)
{}
...
...
packages/flutter_tools/lib/src/build_info.dart
View file @
4dffc851
...
@@ -398,6 +398,7 @@ bool isEmulatorBuildMode(BuildMode mode) {
...
@@ -398,6 +398,7 @@ bool isEmulatorBuildMode(BuildMode mode) {
enum
HostPlatform
{
enum
HostPlatform
{
darwin_x64
,
darwin_x64
,
darwin_arm
,
linux_x64
,
linux_x64
,
windows_x64
,
windows_x64
,
}
}
...
@@ -406,6 +407,8 @@ String getNameForHostPlatform(HostPlatform platform) {
...
@@ -406,6 +407,8 @@ String getNameForHostPlatform(HostPlatform platform) {
switch
(
platform
)
{
switch
(
platform
)
{
case
HostPlatform
.
darwin_x64
:
case
HostPlatform
.
darwin_x64
:
return
'darwin-x64'
;
return
'darwin-x64'
;
case
HostPlatform
.
darwin_arm
:
return
'darwin-arm'
;
case
HostPlatform
.
linux_x64
:
case
HostPlatform
.
linux_x64
:
return
'linux-x64'
;
return
'linux-x64'
;
case
HostPlatform
.
windows_x64
:
case
HostPlatform
.
windows_x64
:
...
@@ -418,6 +421,7 @@ String getNameForHostPlatform(HostPlatform platform) {
...
@@ -418,6 +421,7 @@ String getNameForHostPlatform(HostPlatform platform) {
enum
TargetPlatform
{
enum
TargetPlatform
{
android
,
android
,
ios
,
ios
,
// darwin_arm64 not yet supported, macOS desktop targets run in Rosetta as x86.
darwin_x64
,
darwin_x64
,
linux_x64
,
linux_x64
,
windows_x64
,
windows_x64
,
...
...
packages/flutter_tools/test/general.shard/base/os_test.dart
View file @
4dffc851
This diff is collapsed.
Click to expand it.
packages/flutter_tools/test/src/context.dart
View file @
4dffc851
...
@@ -17,6 +17,7 @@ import 'package:flutter_tools/src/base/signals.dart';
...
@@ -17,6 +17,7 @@ import 'package:flutter_tools/src/base/signals.dart';
import
'package:flutter_tools/src/base/template.dart'
;
import
'package:flutter_tools/src/base/template.dart'
;
import
'package:flutter_tools/src/base/terminal.dart'
;
import
'package:flutter_tools/src/base/terminal.dart'
;
import
'package:flutter_tools/src/base/time.dart'
;
import
'package:flutter_tools/src/base/time.dart'
;
import
'package:flutter_tools/src/build_info.dart'
;
import
'package:flutter_tools/src/isolated/mustache_template.dart'
;
import
'package:flutter_tools/src/isolated/mustache_template.dart'
;
import
'package:flutter_tools/src/cache.dart'
;
import
'package:flutter_tools/src/cache.dart'
;
import
'package:flutter_tools/src/context_runner.dart'
;
import
'package:flutter_tools/src/context_runner.dart'
;
...
@@ -294,6 +295,9 @@ class FakeOperatingSystemUtils implements OperatingSystemUtils {
...
@@ -294,6 +295,9 @@ class FakeOperatingSystemUtils implements OperatingSystemUtils {
@override
@override
ProcessResult
makeExecutable
(
File
file
)
=>
null
;
ProcessResult
makeExecutable
(
File
file
)
=>
null
;
@override
HostPlatform
hostPlatform
=
HostPlatform
.
linux_x64
;
@override
@override
void
chmod
(
FileSystemEntity
entity
,
String
mode
)
{
}
void
chmod
(
FileSystemEntity
entity
,
String
mode
)
{
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment