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
2daac920
Unverified
Commit
2daac920
authored
Mar 12, 2021
by
Jonah Williams
Committed by
GitHub
Mar 12, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[flutter_tools] simplify shutdown hooks (#77969)
parent
66768f8c
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
14 additions
and
77 deletions
+14
-77
application_package.dart
packages/flutter_tools/lib/src/application_package.dart
+0
-3
file_system.dart
packages/flutter_tools/lib/src/base/file_system.dart
+0
-1
process.dart
packages/flutter_tools/lib/src/base/process.dart
+12
-53
process_test.dart
...s/flutter_tools/test/general.shard/base/process_test.dart
+2
-20
No files found.
packages/flutter_tools/lib/src/application_package.dart
View file @
2daac920
...
@@ -347,9 +347,6 @@ abstract class IOSApp extends ApplicationPackage {
...
@@ -347,9 +347,6 @@ abstract class IOSApp extends ApplicationPackage {
}
else
{
}
else
{
// Try to unpack as an ipa.
// Try to unpack as an ipa.
final
Directory
tempDir
=
globals
.
fs
.
systemTempDirectory
.
createTempSync
(
'flutter_app.'
);
final
Directory
tempDir
=
globals
.
fs
.
systemTempDirectory
.
createTempSync
(
'flutter_app.'
);
shutdownHooks
.
addShutdownHook
(()
async
{
await
tempDir
.
delete
(
recursive:
true
);
},
ShutdownStage
.
STILL_RECORDING
);
globals
.
os
.
unzip
(
globals
.
fs
.
file
(
applicationBinary
),
tempDir
);
globals
.
os
.
unzip
(
globals
.
fs
.
file
(
applicationBinary
),
tempDir
);
final
Directory
payloadDir
=
globals
.
fs
.
directory
(
final
Directory
payloadDir
=
globals
.
fs
.
directory
(
globals
.
fs
.
path
.
join
(
tempDir
.
path
,
'Payload'
),
globals
.
fs
.
path
.
join
(
tempDir
.
path
,
'Payload'
),
...
...
packages/flutter_tools/lib/src/base/file_system.dart
View file @
2daac920
...
@@ -235,7 +235,6 @@ class LocalFileSystem extends local_fs.LocalFileSystem {
...
@@ -235,7 +235,6 @@ class LocalFileSystem extends local_fs.LocalFileSystem {
// exits normally.
// exits normally.
shutdownHooks
?.
addShutdownHook
(
shutdownHooks
?.
addShutdownHook
(
_tryToDeleteTemp
,
_tryToDeleteTemp
,
ShutdownStage
.
CLEANUP
,
);
);
}
}
return
_systemTemp
;
return
_systemTemp
;
...
...
packages/flutter_tools/lib/src/base/process.dart
View file @
2daac920
...
@@ -26,35 +26,6 @@ typedef ShutdownHook = FutureOr<dynamic> Function();
...
@@ -26,35 +26,6 @@ typedef ShutdownHook = FutureOr<dynamic> Function();
// See [here](https://github.com/flutter/flutter/pull/14535#discussion_r167041161)
// See [here](https://github.com/flutter/flutter/pull/14535#discussion_r167041161)
// for more details.
// for more details.
/// The stage in which a [ShutdownHook] will be run. All shutdown hooks within
/// a given stage will be started in parallel and will be guaranteed to run to
/// completion before shutdown hooks in the next stage are started.
class
ShutdownStage
implements
Comparable
<
ShutdownStage
>
{
const
ShutdownStage
.
_
(
this
.
priority
);
/// The stage priority. Smaller values will be run before larger values.
final
int
priority
;
/// The stage before the invocation recording (if one exists) is serialized
/// to disk. Tasks performed during this stage *will* be recorded.
static
const
ShutdownStage
STILL_RECORDING
=
ShutdownStage
.
_
(
1
);
/// The stage during which the invocation recording (if one exists) will be
/// serialized to disk. Invocations performed after this stage will not be
/// recorded.
static
const
ShutdownStage
SERIALIZE_RECORDING
=
ShutdownStage
.
_
(
2
);
/// The stage during which a serialized recording will be refined (e.g.
/// cleansed for tests, zipped up for bug reporting purposes, etc.).
static
const
ShutdownStage
POST_PROCESS_RECORDING
=
ShutdownStage
.
_
(
3
);
/// The stage during which temporary files and directories will be deleted.
static
const
ShutdownStage
CLEANUP
=
ShutdownStage
.
_
(
4
);
@override
int
compareTo
(
ShutdownStage
other
)
=>
priority
.
compareTo
(
other
.
priority
);
}
ShutdownHooks
get
shutdownHooks
=>
ShutdownHooks
.
instance
;
ShutdownHooks
get
shutdownHooks
=>
ShutdownHooks
.
instance
;
abstract
class
ShutdownHooks
{
abstract
class
ShutdownHooks
{
...
@@ -67,14 +38,9 @@ abstract class ShutdownHooks {
...
@@ -67,14 +38,9 @@ abstract class ShutdownHooks {
static
ShutdownHooks
get
instance
=>
context
.
get
<
ShutdownHooks
>();
static
ShutdownHooks
get
instance
=>
context
.
get
<
ShutdownHooks
>();
/// Registers a [ShutdownHook] to be executed before the VM exits.
/// Registers a [ShutdownHook] to be executed before the VM exits.
///
/// If [stage] is specified, the shutdown hook will be run during the specified
/// stage. By default, the shutdown hook will be run during the
/// [ShutdownStage.CLEANUP] stage.
void
addShutdownHook
(
void
addShutdownHook
(
ShutdownHook
shutdownHook
,
[
ShutdownHook
shutdownHook
ShutdownStage
stage
=
ShutdownStage
.
CLEANUP
,
);
]);
/// Runs all registered shutdown hooks and returns a future that completes when
/// Runs all registered shutdown hooks and returns a future that completes when
/// all such hooks have finished.
/// all such hooks have finished.
...
@@ -92,18 +58,16 @@ class _DefaultShutdownHooks implements ShutdownHooks {
...
@@ -92,18 +58,16 @@ class _DefaultShutdownHooks implements ShutdownHooks {
})
:
_logger
=
logger
;
})
:
_logger
=
logger
;
final
Logger
_logger
;
final
Logger
_logger
;
final
List
<
ShutdownHook
>
_shutdownHooks
=
<
ShutdownHook
>[];
final
Map
<
ShutdownStage
,
List
<
ShutdownHook
>>
_shutdownHooks
=
<
ShutdownStage
,
List
<
ShutdownHook
>>{};
bool
_shutdownHooksRunning
=
false
;
bool
_shutdownHooksRunning
=
false
;
@override
@override
void
addShutdownHook
(
void
addShutdownHook
(
ShutdownHook
shutdownHook
,
[
ShutdownHook
shutdownHook
ShutdownStage
stage
=
ShutdownStage
.
CLEANUP
,
)
{
])
{
assert
(!
_shutdownHooksRunning
);
assert
(!
_shutdownHooksRunning
);
_shutdownHooks
.
putIfAbsent
(
stage
,
()
=>
<
ShutdownHook
>[]).
add
(
shutdownHook
);
_shutdownHooks
.
add
(
shutdownHook
);
}
}
@override
@override
...
@@ -111,22 +75,17 @@ class _DefaultShutdownHooks implements ShutdownHooks {
...
@@ -111,22 +75,17 @@ class _DefaultShutdownHooks implements ShutdownHooks {
_logger
.
printTrace
(
'Running shutdown hooks'
);
_logger
.
printTrace
(
'Running shutdown hooks'
);
_shutdownHooksRunning
=
true
;
_shutdownHooksRunning
=
true
;
try
{
try
{
for
(
final
ShutdownStage
stage
in
_shutdownHooks
.
keys
.
toList
()..
sort
())
{
final
List
<
Future
<
dynamic
>>
futures
=
<
Future
<
dynamic
>>[];
_logger
.
printTrace
(
'Shutdown hook priority
${stage.priority}
'
);
for
(
final
ShutdownHook
shutdownHook
in
_shutdownHooks
)
{
final
List
<
ShutdownHook
>
hooks
=
_shutdownHooks
.
remove
(
stage
);
final
FutureOr
<
dynamic
>
result
=
shutdownHook
();
final
List
<
Future
<
dynamic
>>
futures
=
<
Future
<
dynamic
>>[];
if
(
result
is
Future
<
dynamic
>)
{
for
(
final
ShutdownHook
shutdownHook
in
hooks
)
{
futures
.
add
(
result
);
final
FutureOr
<
dynamic
>
result
=
shutdownHook
();
if
(
result
is
Future
<
dynamic
>)
{
futures
.
add
(
result
);
}
}
}
await
Future
.
wait
<
dynamic
>(
futures
);
}
}
await
Future
.
wait
<
dynamic
>(
futures
);
}
finally
{
}
finally
{
_shutdownHooksRunning
=
false
;
_shutdownHooksRunning
=
false
;
}
}
assert
(
_shutdownHooks
.
isEmpty
);
_logger
.
printTrace
(
'Shutdown hooks complete'
);
_logger
.
printTrace
(
'Shutdown hooks complete'
);
}
}
}
}
...
...
packages/flutter_tools/test/general.shard/base/process_test.dart
View file @
2daac920
...
@@ -48,35 +48,17 @@ void main() {
...
@@ -48,35 +48,17 @@ void main() {
group
(
'shutdownHooks'
,
()
{
group
(
'shutdownHooks'
,
()
{
testWithoutContext
(
'runInExpectedOrder'
,
()
async
{
testWithoutContext
(
'runInExpectedOrder'
,
()
async
{
int
i
=
1
;
int
i
=
1
;
int
serializeRecording1
;
int
serializeRecording2
;
int
postProcessRecording
;
int
cleanup
;
int
cleanup
;
final
ShutdownHooks
shutdownHooks
=
ShutdownHooks
(
logger:
BufferLogger
.
test
());
final
ShutdownHooks
shutdownHooks
=
ShutdownHooks
(
logger:
BufferLogger
.
test
());
shutdownHooks
.
addShutdownHook
(()
async
{
serializeRecording1
=
i
++;
},
ShutdownStage
.
SERIALIZE_RECORDING
);
shutdownHooks
.
addShutdownHook
(()
async
{
shutdownHooks
.
addShutdownHook
(()
async
{
cleanup
=
i
++;
cleanup
=
i
++;
},
ShutdownStage
.
CLEANUP
);
});
shutdownHooks
.
addShutdownHook
(()
async
{
postProcessRecording
=
i
++;
},
ShutdownStage
.
POST_PROCESS_RECORDING
);
shutdownHooks
.
addShutdownHook
(()
async
{
serializeRecording2
=
i
++;
},
ShutdownStage
.
SERIALIZE_RECORDING
);
await
shutdownHooks
.
runShutdownHooks
();
await
shutdownHooks
.
runShutdownHooks
();
expect
(
serializeRecording1
,
lessThanOrEqualTo
(
2
));
expect
(
cleanup
,
1
);
expect
(
serializeRecording2
,
lessThanOrEqualTo
(
2
));
expect
(
postProcessRecording
,
3
);
expect
(
cleanup
,
4
);
});
});
});
});
...
...
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