| Index: runtime/vm/parser.cc
|
| diff --git a/runtime/vm/parser.cc b/runtime/vm/parser.cc
|
| index bc6740cd67e8c6f34b7b1142f08060463ce24a6e..94485a81fdc4710dde3e44833c0021ab016c8aab 100644
|
| --- a/runtime/vm/parser.cc
|
| +++ b/runtime/vm/parser.cc
|
| @@ -3578,16 +3578,20 @@ SequenceNode* Parser::ParseFunc(const Function& func, bool check_semicolon) {
|
| ASSERT(!func.is_generated_body());
|
| // The code of an async function is synthesized. Disable debugging.
|
| func.set_is_debuggable(false);
|
| - // In order to collect causal asynchronous stacks efficiently we rely on
|
| - // this function not being inlined.
|
| - func.set_is_inlinable(!FLAG_causal_async_stacks);
|
| + if (FLAG_causal_async_stacks) {
|
| + // In order to collect causal asynchronous stacks efficiently we rely on
|
| + // this function not being inlined.
|
| + func.set_is_inlinable(false);
|
| + }
|
| generated_body_closure = OpenAsyncFunction(func.token_pos());
|
| } else if (func.IsAsyncClosure()) {
|
| // The closure containing the body of an async function is debuggable.
|
| ASSERT(func.is_debuggable());
|
| - // In order to collect causal asynchronous stacks efficiently we rely on
|
| - // this function not being inlined.
|
| - func.set_is_inlinable(!FLAG_causal_async_stacks);
|
| + if (FLAG_causal_async_stacks) {
|
| + // In order to collect causal asynchronous stacks efficiently we rely on
|
| + // this function not being inlined.
|
| + func.set_is_inlinable(false);
|
| + }
|
| OpenAsyncClosure();
|
| } else if (func.IsSyncGenerator()) {
|
| // The code of a sync generator is synthesized. Disable debugging.
|
| @@ -3599,16 +3603,20 @@ SequenceNode* Parser::ParseFunc(const Function& func, bool check_semicolon) {
|
| async_temp_scope_ = current_block_->scope;
|
| } else if (func.IsAsyncGenerator()) {
|
| func.set_is_debuggable(false);
|
| - // In order to collect causal asynchronous stacks efficiently we rely on
|
| - // this function not being inlined.
|
| - func.set_is_inlinable(!FLAG_causal_async_stacks);
|
| + if (FLAG_causal_async_stacks) {
|
| + // In order to collect causal asynchronous stacks efficiently we rely on
|
| + // this function not being inlined.
|
| + func.set_is_inlinable(false);
|
| + }
|
| generated_body_closure = OpenAsyncGeneratorFunction(func.token_pos());
|
| } else if (func.IsAsyncGenClosure()) {
|
| // The closure containing the body of an async* function is debuggable.
|
| ASSERT(func.is_debuggable());
|
| - // In order to collect causal asynchronous stacks efficiently we rely on
|
| - // this function not being inlined.
|
| - func.set_is_inlinable(!FLAG_causal_async_stacks);
|
| + if (FLAG_causal_async_stacks) {
|
| + // In order to collect causal asynchronous stacks efficiently we rely on
|
| + // this function not being inlined.
|
| + func.set_is_inlinable(false);
|
| + }
|
| OpenAsyncGeneratorClosure();
|
| }
|
|
|
|
|