Como posso usar geradores assíncronos em JavaScript?

Eu tenho uma API que vai retornar um cursor para buscar mais dados. Eu zombei assim:

function fetch(n) {
  return Promise.resolve({
    results: [n],
    next: next < 10 && n + 1,
  })
}

O que estou tentando fazer é descobrir como posso usar async / waitit junto com geradores para interagir com esta API.

Aqui está basicamente o que eu prototipei:

async function* api(url) {
  let result = await fetch(url)
  yield result
  while (result.next) {
    result = await fetch(result.next)
    yield result
  }
}

A ideia é que eu seja capaz de criar um gerador assíncrono e produzir com esse gerador para iterar através do cursor:

async function main() {
  const gen = api(0)
  const zero = await gen.next()
  console.log(zero.result)
  const one = await gen.next()
  console.log(one.result)
  const rest = await Promise.all([...gen])
  console.log(rest.map(r => r.result))
}

Considerando tudo, acho que essa é uma maneira muito legal de lidar com dados paginados e poder extrair todos os dados com[...gen] é bem legal.

O único problema é que não funciona! Apropriadamente você não pode usarasync comfunction*:

❯❯❯ node --version
v7.0.0
❯❯❯ node --harmony --harmony-async-await async-generator.js
/Users/chetcorcos/code/async-generator.js:11
async function* api(url) {
              ^
SyntaxError: Unexpected token *
    at Object.exports.runInThisContext (vm.js:76:16)
    at Module._compile (module.js:545:28)
    at Object.Module._extensions..js (module.js:582:10)
    at Module.load (module.js:490:32)
    at tryModuleLoad (module.js:449:12)
    at Function.Module._load (module.js:441:3)
    at Module.runMain (module.js:607:10)
    at run (bootstrap_node.js:382:7)
    at startup (bootstrap_node.js:137:9)
    at bootstrap_node.js:497:3

Mas realmente sinto que isso deveria ser possível. Existe uma biblioteca popular chamadaco com quem ando bisbilhotando, mas acho que não é isso que quero.

Alguma idéia de como obter esse conceito de "geradores assíncronos" para funcionar?

questionAnswers(2)

yourAnswerToTheQuestion