Ignore:
Timestamp:
Sep 23, 2017, 8:05:53 AM (8 years ago)
Author:
[email protected]
Message:

[ESNext] Async iteration - Implement Async Generator - optimization
https://bugs.webkit.org/show_bug.cgi?id=175891

Reviewed by Yusuke Suzuki.

Add small optimization for async generators:

  1. merging async generator queue to async generator itself

generator.@first / generator.@last is enough, by doing so,

we remove one unnecessary object alloc.

  1. merging request with queue.
  • builtins/AsyncGeneratorPrototype.js:

(globalPrivate.asyncGeneratorQueueIsEmpty):
(globalPrivate.asyncGeneratorQueueCreateItem):
(globalPrivate.asyncGeneratorQueueEnqueue):
(globalPrivate.asyncGeneratorQueueDequeue):
(globalPrivate.asyncGeneratorDequeue):
(globalPrivate.isSuspendYieldState):
(globalPrivate.asyncGeneratorEnqueue):

  • builtins/BuiltinNames.h:
  • bytecompiler/BytecodeGenerator.cpp:

(JSC::BytecodeGenerator::emitPutAsyncGeneratorFields):

  • bytecompiler/BytecodeGenerator.h:
  • bytecompiler/NodesCodegen.cpp:

(JSC::FunctionNode::emitBytecode):

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/Source/JavaScriptCore/builtins/BuiltinNames.h

    r221417 r222425  
    127127    macro(asyncGeneratorSuspendReason) \
    128128    macro(asyncGeneratorQueue) \
     129    macro(asyncGeneratorQueueFirst) \
     130    macro(asyncGeneratorQueueLast) \
     131    macro(asyncGeneratorQueueItemNext) \
     132    macro(asyncGeneratorQueueItemPrevious) \
    129133    macro(promiseCapability) \
    130134    macro(generatorResumeMode) \
Note: See TracChangeset for help on using the changeset viewer.