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
b72d67a8
Commit
b72d67a8
authored
Sep 15, 2015
by
Ian Fischer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Private setup methods for AndroidDevice.
parent
5678c124
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
149 additions
and
1 deletion
+149
-1
sky_tools.dart
packages/flutter_tools/bin/sky_tools.dart
+6
-0
device.dart
packages/flutter_tools/lib/src/device.dart
+121
-1
process_wrapper.dart
packages/flutter_tools/lib/src/process_wrapper.dart
+22
-0
No files found.
packages/flutter_tools/bin/sky_tools.dart
View file @
b72d67a8
...
@@ -14,6 +14,12 @@ void main(List<String> args) {
...
@@ -14,6 +14,12 @@ void main(List<String> args) {
Logger
.
root
.
level
=
Level
.
WARNING
;
Logger
.
root
.
level
=
Level
.
WARNING
;
Logger
.
root
.
onRecord
.
listen
((
LogRecord
rec
)
{
Logger
.
root
.
onRecord
.
listen
((
LogRecord
rec
)
{
print
(
'
${rec.level.name}
:
${rec.message}
'
);
print
(
'
${rec.level.name}
:
${rec.message}
'
);
if
(
rec
.
error
!=
null
)
{
print
(
rec
.
error
);
}
if
(
rec
.
stackTrace
!=
null
)
{
print
(
rec
.
stackTrace
);
}
});
});
Map
<
String
,
CommandHandler
>
handlers
=
{};
Map
<
String
,
CommandHandler
>
handlers
=
{};
...
...
packages/flutter_tools/lib/src/device.dart
View file @
b72d67a8
...
@@ -4,6 +4,15 @@
...
@@ -4,6 +4,15 @@
library
sky_tools
.
device
;
library
sky_tools
.
device
;
import
'dart:io'
;
import
'package:logging/logging.dart'
;
import
'package:path/path.dart'
as
path
;
import
'process_wrapper.dart'
;
final
Logger
_logging
=
new
Logger
(
'sky_tools.device'
);
abstract
class
_Device
{
abstract
class
_Device
{
final
String
id
;
final
String
id
;
static
Map
<
String
,
_Device
>
_deviceCache
=
{};
static
Map
<
String
,
_Device
>
_deviceCache
=
{};
...
@@ -41,14 +50,28 @@ abstract class _Device {
...
@@ -41,14 +50,28 @@ abstract class _Device {
}
}
class
AndroidDevice
extends
_Device
{
class
AndroidDevice
extends
_Device
{
static
const
String
_ADB_PATH
=
'adb'
;
static
const
String
className
=
'AndroidDevice'
;
static
const
String
className
=
'AndroidDevice'
;
static
final
String
defaultDeviceID
=
'default'
;
static
final
String
defaultDeviceID
=
'default'
;
String
_adbPath
;
String
get
adbPath
=>
_adbPath
;
factory
AndroidDevice
([
String
id
=
null
])
{
factory
AndroidDevice
([
String
id
=
null
])
{
return
new
_Device
(
className
,
id
);
return
new
_Device
(
className
,
id
);
}
}
AndroidDevice
.
_
(
id
)
:
super
.
_
(
id
);
AndroidDevice
.
_
(
id
)
:
super
.
_
(
id
)
{
_updatePaths
();
// Checking for lollipop only needs to be done if we are starting an
// app, but it has an important side effect, which is to discard any
// progress messages if the adb server is restarted.
if
(!
_checkForAdb
()
||
!
_checkForLollipopOrLater
())
{
_logging
.
severe
(
'Unable to run on Android.'
);
}
}
@override
@override
bool
installApp
(
String
path
)
{
bool
installApp
(
String
path
)
{
...
@@ -64,4 +87,101 @@ class AndroidDevice extends _Device {
...
@@ -64,4 +87,101 @@ class AndroidDevice extends _Device {
bool
isConnected
()
{
bool
isConnected
()
{
return
true
;
return
true
;
}
}
void
_updatePaths
()
{
if
(
Platform
.
environment
.
containsKey
(
'ANDROID_HOME'
))
{
String
androidHomeDir
=
Platform
.
environment
[
'ANDROID_HOME'
];
String
adbPath1
=
path
.
join
(
androidHomeDir
,
'sdk'
,
'platform-tools'
,
'adb'
);
String
adbPath2
=
path
.
join
(
androidHomeDir
,
'platform-tools'
,
'adb'
);
if
(
FileSystemEntity
.
isFileSync
(
adbPath1
))
{
_adbPath
=
adbPath1
;
}
else
if
(
FileSystemEntity
.
isFileSync
(
adbPath2
))
{
_adbPath
=
adbPath2
;
}
else
{
_logging
.
info
(
'"adb" not found at
\n
"
$adbPath1
" or
\n
"
$adbPath2
"
\n
'
+
'using default path "
$_ADB_PATH
"'
);
_adbPath
=
_ADB_PATH
;
}
}
else
{
_adbPath
=
_ADB_PATH
;
}
}
bool
_isValidAdbVersion
(
String
adbVersion
)
{
// Sample output: 'Android Debug Bridge version 1.0.31'
Match
versionFields
=
new
RegExp
(
r'(\d+)\.(\d+)\.(\d+)'
).
firstMatch
(
adbVersion
);
if
(
versionFields
!=
null
)
{
int
majorVersion
=
int
.
parse
(
versionFields
[
1
]);
int
minorVersion
=
int
.
parse
(
versionFields
[
2
]);
int
patchVersion
=
int
.
parse
(
versionFields
[
3
]);
if
(
majorVersion
>
1
)
{
return
true
;
}
if
(
majorVersion
==
1
&&
minorVersion
>
0
)
{
return
true
;
}
if
(
majorVersion
==
1
&&
minorVersion
==
0
&&
patchVersion
>=
32
)
{
return
true
;
}
return
false
;
}
_logging
.
warning
(
'Unrecognized adb version string
$adbVersion
. Skipping version check.'
);
return
true
;
}
bool
_checkForAdb
()
{
try
{
String
adbVersion
=
runCheckedSync
([
adbPath
,
'version'
]);
if
(
_isValidAdbVersion
(
adbVersion
))
{
return
true
;
}
String
locatedAdbPath
=
runCheckedSync
([
'which'
,
'adb'
]);
_logging
.
severe
(
'"
$locatedAdbPath
" is too old. '
'Please install version 1.0.32 or later.
\n
'
'Try setting ANDROID_HOME to the path to your Android SDK install. '
'Android builds are unavailable.'
);
}
catch
(
e
,
stack
)
{
_logging
.
severe
(
'"adb" not found in
\
$PATH
. '
'Please install the Android SDK or set ANDROID_HOME '
'to the path of your Android SDK install.'
);
_logging
.
info
(
e
);
_logging
.
info
(
stack
);
}
return
false
;
}
bool
_checkForLollipopOrLater
()
{
try
{
// If the server is automatically restarted, then we get irrelevant
// output lines like this, which we want to ignore:
// adb server is out of date. killing..
// * daemon started successfully *
runCheckedSync
([
adbPath
,
'start-server'
]);
// Sample output: '22'
String
sdkVersion
=
runCheckedSync
([
adbPath
,
'shell'
,
'getprop'
,
'ro.build.version.sdk'
])
.
trimRight
();
int
sdkVersionParsed
=
int
.
parse
(
sdkVersion
,
onError:
(
String
source
)
=>
null
);
if
(
sdkVersionParsed
==
null
)
{
_logging
.
severe
(
'Unexpected response from getprop: "
$sdkVersion
"'
);
return
false
;
}
if
(
sdkVersionParsed
<
22
)
{
_logging
.
severe
(
'Version "
$sdkVersion
" of the Android SDK is too old. '
'Please install Lollipop (version 22) or later.'
);
return
false
;
}
return
true
;
}
catch
(
e
,
stack
)
{
_logging
.
severe
(
'Unexpected failure from adb: '
,
e
,
stack
);
}
return
false
;
}
}
}
packages/flutter_tools/lib/src/process_wrapper.dart
0 → 100644
View file @
b72d67a8
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
library
sky_tools
.
process_wrapper
;
import
'dart:io'
;
import
'package:logging/logging.dart'
;
final
Logger
_logging
=
new
Logger
(
'sky_tools.process_wrapper'
);
String
runCheckedSync
(
List
<
String
>
cmd
)
{
_logging
.
info
(
cmd
.
join
(
' '
));
ProcessResult
results
=
Process
.
runSync
(
cmd
[
0
],
cmd
.
getRange
(
1
,
cmd
.
length
).
toList
());
if
(
results
.
exitCode
!=
0
)
{
throw
'Error code '
+
results
.
exitCode
.
toString
()
+
' returned when attempting to run command: '
+
cmd
.
join
(
' '
);
}
return
results
.
stdout
;
}
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