thecodrr/fdir

Remove callback API in next major

vjpr opened this issue · 1 comments

vjpr commented

Code could be simplified by removing the callback API. There are native promise apis for most functions now.

Not sure how performance is effected though - this would be the primary concern.

import { readdir } from 'fs/promises';

try {
  const files = await readdir(path);
  for (const file of files)
    console.log(file);
} catch (err) {
  console.error(err);
}

Would pave the way for supporting modern API interfaces such as Node Streams, Web Streams, AsyncInterators. AbortController could also be used for early-exit scenarios.

Promise API is 3 to 4 times slower. I have tested this extensively. Callback API fits the JS "parallelism" very well.

Would pave the way for supporting modern API interfaces such as Node Streams, Web Streams, AsyncInterators. AbortController could also be used for early-exit scenarios.

Most of these things are unnecessary. Async Iterators make sense but streaming is pointless; not to mention that it is trivial to convert iterators to Streams. AbortController would add unnecessary overhead of checking on every iteration if cancellation is requested — something you can easily do with an Iterator and a for-loop.