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
69f6630a
Commit
69f6630a
authored
Mar 17, 2016
by
Devon Carew
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2758 from devoncarew/listen_update
update listen to work w/ ios devices
parents
80423ae9
882f849c
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
31 deletions
+40
-31
listen.dart
packages/flutter_tools/lib/src/commands/listen.dart
+40
-31
No files found.
packages/flutter_tools/lib/src/commands/listen.dart
View file @
69f6630a
...
@@ -5,31 +5,28 @@
...
@@ -5,31 +5,28 @@
import
'dart:async'
;
import
'dart:async'
;
import
'dart:io'
;
import
'dart:io'
;
import
'../base/os.dart'
;
import
'../base/process.dart'
;
import
'../base/process.dart'
;
import
'../globals.dart'
;
import
'../globals.dart'
;
import
'run.dart'
;
import
'run.dart'
;
class
ListenCommand
extends
RunCommandBase
{
class
ListenCommand
extends
RunCommandBase
{
ListenCommand
({
this
.
singleRun
:
false
});
@override
@override
final
String
name
=
'listen'
;
final
String
name
=
'listen'
;
@override
@override
final
String
description
=
final
String
description
=
'Listen for changes to files and reload the running app.'
;
'Listen for changes to files and reload the running app (Android only).'
;
@override
@override
final
String
usageFooter
=
final
String
usageFooter
=
'By default, only listens to "./" and "./lib/". To listen to additional directories, list them on
\n
'
'By default, only listens to "./" and "./lib/". To listen to additional directories, list them on
\n
'
'the command line.'
;
'the command line.'
;
/// Only run once.
Used for testing.
/// Only run once. Used for testing.
final
bool
singleRun
;
final
bool
singleRun
;
ListenCommand
({
this
.
singleRun
:
false
});
@override
bool
get
androidOnly
=>
true
;
@override
@override
bool
get
requiresDevice
=>
true
;
bool
get
requiresDevice
=>
true
;
...
@@ -38,16 +35,30 @@ class ListenCommand extends RunCommandBase {
...
@@ -38,16 +35,30 @@ class ListenCommand extends RunCommandBase {
await
downloadApplicationPackages
();
await
downloadApplicationPackages
();
await
downloadToolchain
();
await
downloadToolchain
();
List
<
String
>
watchCommand
=
_constructWatchCommand
(
()
sync
*
{
Iterable
<
String
>
directories
=
()
sync
*
{
yield
*
argResults
.
rest
;
yield
*
argResults
.
rest
;
yield
'.'
;
yield
'.'
;
yield
'lib'
;
yield
'lib'
;
}());
}();
List
<
String
>
watchCommand
=
_constructWatchCommand
(
directories
);
if
(
watchCommand
==
null
)
return
1
;
printStatus
(
'Listening for changes in '
'
${directories.map((String name) => "'$name${Platform.pathSeparator}
'").join(', ')}'
'.');
int result = 0;
int result = 0;
bool firstTime = true;
bool firstTime = true;
do {
do {
printStatus
(
'Updating running Flutter apps...'
);
printStatus('');
// TODO(devoncarew): We could print out here what changes we detected that caused a re-run.
if (!firstTime)
printStatus('Re-running app...');
result = await startApp(
result = await startApp(
deviceForCommand,
deviceForCommand,
applicationPackages,
applicationPackages,
...
@@ -62,45 +73,43 @@ class ListenCommand extends RunCommandBase {
...
@@ -62,45 +73,43 @@ class ListenCommand extends RunCommandBase {
);
);
firstTime = false;
firstTime = false;
} while (!singleRun && result == 0 && _watchDirectory(watchCommand));
} while (!singleRun && result == 0 && _watchDirectory(watchCommand));
return 0;
return 0;
}
}
List<String> _constructWatchCommand(Iterable<String> directories) {
List<String> _constructWatchCommand(Iterable<String> directories) {
if (Platform.isMacOS) {
if (Platform.isMacOS) {
try
{
if (os.which('fswatch') == null) {
runCheckedSync
(<
String
>[
'which'
,
'fswatch'
]);
}
catch
(
e
)
{
printError('"
listen
" command is only useful if you have installed '
printError('"
listen
" command is only useful if you have installed '
'fswatch on Mac. Run "brew install fswatch" to install it with '
'fswatch on Mac. Run "
brew
install
fswatch
" to install it with homebrew.');
'homebrew.'
);
return null;
return null;
} else {
return <String>['fswatch', '-r', '-v', '-1']..addAll(directories);
}
}
return
<
String
>[
'fswatch'
,
'-r'
,
'-v'
,
'-1'
]..
addAll
(
directories
);
} else if (Platform.isLinux) {
} else if (Platform.isLinux) {
try
{
if (os.which('inotifywait') == null) {
runCheckedSync
(<
String
>[
'which'
,
'inotifywait'
]);
}
catch
(
e
)
{
printError('"
listen
" command is only useful if you have installed '
printError('"
listen
" command is only useful if you have installed '
'inotifywait on Linux.
Run "apt-get install inotify-tools" or '
'inotifywait on Linux.
Run "
apt
-
get
install
inotify
-
tools
" or '
'equivalent to install it.'
);
'equivalent to install it.');
return null;
return null;
} else {
return <String>[
'inotifywait',
'-r',
'-e',
// Only listen for events that matter, to avoid triggering constantly
// from the editor watching files.
'modify,close_write,move,create,delete',
]..addAll(directories);
}
}
return
<
String
>[
'inotifywait'
,
'-r'
,
'-e'
,
// Only listen for events that matter, to avoid triggering constantly
// from the editor watching files.
'modify,close_write,move,create,delete'
,
]..
addAll
(
directories
);
} else {
} else {
printError('"
listen
" command is only available on Mac and Linux.');
printError('"
listen
" command is only available on Mac and Linux.');
}
}
return null;
return null;
}
}
bool _watchDirectory(List<String> watchCommand) {
bool _watchDirectory(List<String> watchCommand) {
printStatus
(
'Attempting to listen to these directories:
${watchCommand.join(", ")}
'
);
assert(watchCommand != null);
assert(watchCommand != null);
try {
try {
runCheckedSync(watchCommand);
runCheckedSync(watchCommand);
...
...
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