NHacker Next
  • new
  • past
  • show
  • ask
  • show
  • jobs
  • submit
The missing standard library for multithreading in JavaScript (github.com)
bastawhiz 3 hours ago [-]
I like this, but unfortunately it doesn't solve one annoying problem: lexical scope doesn't work and it will fail in an unexpected way.

If you reference something lexically, your code fails at runtime. Want to use an import? You have to use import() inside the closure you pass to spawn(). Typescript doesn't know this. Your language server doesn't know this. Access a variable that shadows a built in global? Now you're accessing the built in global.

The only way this could even be addressed is by having a full on parser. Even then you can't guarantee things will work.

I think the only "fix" is for JS to introduce a new syntax to have a function that can't access lexical scope, returning a value that either extends a subclass of Function or has a cheeky symbol set on it. At least then, it'll fail at compile time.

kretaceous 34 minutes ago [-]
A linter rule provided by the library could be helpful here. I know it's just a workaround but probably easier than going for a solution that does compile time checks.
austin-cheney 29 minutes ago [-]
This should be the expected behavior when multithreading. It is the expected behavior when executing a child process, such as node’s child_process.fork.
christophilus 2 hours ago [-]
I’d love a way to be able to specify that sort of thing. I wrote a little server-side JSX rendering layer, and event handlers were serialized to strings, and so they had similar restrictions.
christophilus 2 hours ago [-]
This looks great. If it works as well as the readme suggests, this’ll let me reach for Bun in some of the scenarios where I currently reach for Go. Typescript has become my favorite language, but the lack of efficient multithreading is sometimes a deal breaker.
kretaceous 30 minutes ago [-]
Exactly my thoughts. The only incompatibility with Bun is the unavailability of the `using` keyword:

> If you are using Bun (which doesn't natively support using and uses a transpiler which is incompatible with this library)...

I skimmed the issues but I couldn't find any issues on Bun regarding this except for: https://github.com/oven-sh/bun/discussions/4325

wrs 3 hours ago [-]
This seems very much worth a look!

(I suspect, to paraphrase Greenspun's rule, any sufficiently complicated app using Web Workers contains an ad hoc, informally-specified, bug-ridden, slow implementation of half of this library...)

Zedriv 3 hours ago [-]
This is cool! Hope we can get multi-threaded wasm some time soon.
petesergeant 1 hours ago [-]
Documentation here is exceptionally well written for a JS project, although move() doing different things depending on the type of data you pass to it feels like a foot-gun, and also how is it blocking access to arrays you pass to it?
Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact
Rendered at 03:13:46 GMT+0000 (Coordinated Universal Time) with Vercel.