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
333e6115
Commit
333e6115
authored
Aug 31, 2015
by
Ian Fischer
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #969 from iansf/extract_install
Extract install from StartSky
parents
805ff313
0c089cb3
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
72 additions
and
41 deletions
+72
-41
sky_tool
packages/flutter/lib/sky_tool
+72
-41
No files found.
packages/flutter/lib/sky_tool
View file @
333e6115
...
...
@@ -146,11 +146,48 @@ def _url_for_path(port, root, path):
return
'http://localhost:
%
s/
%
s'
%
(
port
,
relative_path
)
class
InstallSky
(
object
):
def
add_subparser
(
self
,
subparsers
):
install_parser
=
subparsers
.
add_parser
(
'install'
,
help
=
'install SkyShell on Android and iOS devices and simulators'
)
install_parser
.
set_defaults
(
func
=
self
.
run
)
def
run
(
self
,
args
,
pids
):
android
=
AndroidDevice
()
# Install on connected Android device
if
android
.
is_connected
()
and
args
.
android_build_available
:
if
args
.
use_release
:
apk_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
android_release_build_path
,
'apks'
,
APK_NAME
)
else
:
apk_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
android_debug_build_path
,
'apks'
,
APK_NAME
)
android
.
install_apk
(
apk_path
)
# Install on connected iOS device
if
IOSDevice
.
is_connected
()
and
args
.
ios_build_available
:
if
args
.
use_release
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_release_build_path
,
IOS_APP_NAME
)
else
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_debug_build_path
,
IOS_APP_NAME
)
IOSDevice
.
install_app
(
app_path
)
# Install on iOS simulator if it's running
if
IOSSimulator
.
is_booted
()
and
args
.
ios_sim_build_available
:
if
args
.
use_release
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_sim_release_build_path
,
IOS_APP_NAME
)
else
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_sim_debug_build_path
,
IOS_APP_NAME
)
IOSSimulator
.
fork_install_app
(
app_path
)
# TODO(iansf): get rid of need for args
def
needs_install
(
self
,
args
):
return
AndroidDevice
()
.
needs_install
(
args
)
or
IOSDevice
.
needs_install
(
args
)
or
IOSSimulator
.
needs_install
(
args
)
class
StartSky
(
object
):
def
add_subparser
(
self
,
subparsers
):
start_parser
=
subparsers
.
add_parser
(
'start'
,
help
=
'launch
%
s on the device'
%
APK_NAME
)
start_parser
.
add_argument
(
'--install'
,
action
=
'store_true'
)
start_parser
.
add_argument
(
'--poke'
,
action
=
'store_true'
)
start_parser
.
add_argument
(
'--checked'
,
action
=
'store_true'
)
start_parser
.
add_argument
(
'project_or_path'
,
nargs
=
'?'
,
type
=
str
,
...
...
@@ -161,17 +198,15 @@ class StartSky(object):
if
not
args
.
poke
:
StopSky
()
.
run
(
args
,
pids
)
# Only install if the user did not specify a poke
installer
=
InstallSky
()
if
installer
.
needs_install
(
args
):
installer
.
run
(
args
,
pids
)
android
=
AndroidDevice
()
project_or_path
=
os
.
path
.
abspath
(
args
.
project_or_path
)
if
args
.
android_build_available
and
args
.
use_release
:
apk_path
=
os
.
path
.
join
(
os
.
path
.
normpath
(
args
.
sky_src_path
),
args
.
android_release_build_path
,
'apks'
,
APK_NAME
)
elif
args
.
android_build_available
:
apk_path
=
os
.
path
.
join
(
os
.
path
.
normpath
(
args
.
sky_src_path
),
args
.
android_debug_build_path
,
'apks'
,
APK_NAME
)
else
:
apk_path
=
os
.
path
.
join
(
APK_DIR
,
APK_NAME
)
if
os
.
path
.
isdir
(
project_or_path
):
sky_server_root
=
project_or_path
main_dart
=
os
.
path
.
join
(
project_or_path
,
'lib'
,
'main.dart'
)
...
...
@@ -192,38 +227,6 @@ class StartSky(object):
logging
.
error
(
'
%
s is not a valid packages path.'
%
package_root
)
return
2
if
not
android
.
is_package_installed
(
ANDROID_PACKAGE
):
logging
.
info
(
'
%
s is not on the device. Installing now...'
%
APK_NAME
)
args
.
install
=
True
elif
android
.
get_device_apk_sha1
(
apk_path
)
!=
android
.
get_source_sha1
(
apk_path
):
logging
.
info
(
'
%
s on the device is out of date. Installing now...'
%
APK_NAME
)
args
.
install
=
True
if
args
.
install
:
# Install on connected Android device
if
android
.
is_connected
()
and
args
.
android_build_available
:
if
args
.
use_release
:
apk_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
android_release_build_path
,
'apks'
,
APK_NAME
)
else
:
apk_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
android_debug_build_path
,
'apks'
,
APK_NAME
)
android
.
install_apk
(
apk_path
)
# Install on connected iOS device
if
IOSDevice
.
is_connected
()
and
args
.
ios_build_available
:
if
args
.
use_release
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_release_build_path
,
IOS_APP_NAME
)
else
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_debug_build_path
,
IOS_APP_NAME
)
IOSDevice
.
install_app
(
app_path
)
# Install on iOS simulator if it's running
if
IOSSimulator
.
is_booted
()
and
args
.
ios_sim_build_available
:
if
args
.
use_release
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_sim_release_build_path
,
IOS_APP_NAME
)
else
:
app_path
=
os
.
path
.
join
(
args
.
sky_src_path
,
args
.
ios_sim_debug_build_path
,
IOS_APP_NAME
)
IOSSimulator
.
fork_install_app
(
app_path
)
# TODO(iansf): fix this so that we don't have to pass sky_server_root, main_dart, pid, and args.
android
.
setup_servers
(
sky_server_root
,
main_dart
,
pids
,
args
)
...
...
@@ -361,9 +364,29 @@ class AndroidDevice(object):
def
get_source_sha1
(
self
,
apk_path
):
return
hashlib
.
sha1
(
open
(
apk_path
,
'rb'
)
.
read
())
.
hexdigest
()
# TODO(iansf): get rid of need for args
def
get_apk_path
(
self
,
args
):
if
args
.
android_build_available
and
args
.
use_release
:
return
os
.
path
.
join
(
os
.
path
.
normpath
(
args
.
sky_src_path
),
args
.
android_release_build_path
,
'apks'
,
APK_NAME
)
elif
args
.
android_build_available
:
return
os
.
path
.
join
(
os
.
path
.
normpath
(
args
.
sky_src_path
),
args
.
android_debug_build_path
,
'apks'
,
APK_NAME
)
else
:
return
os
.
path
.
join
(
APK_DIR
,
APK_NAME
)
def
is_connected
(
self
):
return
self
.
has_valid_android
def
needs_install
(
self
,
args
):
apk_path
=
self
.
get_apk_path
(
args
)
if
not
self
.
is_package_installed
(
ANDROID_PACKAGE
):
logging
.
info
(
'
%
s is not on the device. Installing now...'
%
APK_NAME
)
return
True
elif
self
.
get_device_apk_sha1
(
apk_path
)
!=
self
.
get_source_sha1
(
apk_path
):
logging
.
info
(
'
%
s on the device is out of date. Installing now...'
%
APK_NAME
)
return
True
return
False
def
install_apk
(
self
,
apk_path
):
if
not
os
.
path
.
exists
(
apk_path
):
logging
.
error
(
'"
%
s" does not exist.'
%
apk_path
)
...
...
@@ -480,6 +503,10 @@ class IOSDevice(object):
cls
.
_is_connected
=
False
return
cls
.
_is_connected
@
classmethod
def
needs_install
(
cls
,
args
):
return
cls
.
is_connected
()
@
classmethod
def
install_app
(
cls
,
ios_app_path
):
if
not
cls
.
has_ios_deploy
():
...
...
@@ -603,6 +630,10 @@ class IOSSimulator(object):
cls
.
_simulator_app_documents_dir
=
os
.
path
.
join
(
simulator_path
,
'data'
,
'Containers'
,
'Data'
,
'Application'
,
simulator_app_id
,
'Documents'
)
return
cls
.
_simulator_app_documents_dir
@
classmethod
def
needs_install
(
cls
,
args
):
return
cls
.
is_booted
()
@
classmethod
def
fork_install_app
(
cls
,
ios_app_path
):
cmd
=
[
...
...
@@ -987,7 +1018,7 @@ class SkyShellRunner(object):
subparsers
=
parser
.
add_subparsers
(
help
=
'sub-command help'
)
for
command
in
[
StartSky
(),
StopSky
(),
StartListening
(),
StartTracing
(),
StopTracing
(),
IOSSimulator
()]:
for
command
in
[
InstallSky
(),
StartSky
(),
StopSky
(),
StartListening
(),
StartTracing
(),
StopTracing
(),
IOSSimulator
()]:
command
.
add_subparser
(
subparsers
)
args
=
parser
.
parse_args
()
...
...
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