Hacker Newsnew | past | comments | ask | show | jobs | submitlogin

"Turning into" is the wrong phrasing. It's enabling Lisp.

And also Python, Go, Rust, Haskell...



pretty hard to enable lisp without eval or garbage collection


You might find these interesting:

- https://github.com/WebAssembly/gc

- https://github.com/WebAssembly/reference-types

- https://github.com/WebAssembly/funclets

As for the eval thing, you surely can compile and execute code on the fly. Such features would be enabled by the aforementioned proposals, but should be possible today as well (through shared memory).


you mean you can compile code into a separate module, right? Which could then access the original module only via marshaled calls through the javascript layer? I guess anything can be compiled into anything but I wouldn't prefer to target lisp to such an environment.


Yes, what you are saying, but that can be optimized very well after the proposals come through.


My Intel CPU also doesn't have garbage collection or eval opcodes and yet it runs Lisp...


your intel CPU allows you to iterate through the stack and jump to a location in the heap though (as long as you don't mark the page NX). These features are used by most gc and jit implementations respectively. wasm requires all functions to be specified at module creation time and gives no access to the stack.


There are plenty of GC algorithms to chose from, and several examples how to implement them in WebAssembly already.

https://github.com/appcypher/awesome-wasm-langs/blob/master/...

No need to get everything served on a plate.


Those have suboptimal GC implementations because of the lack of primitives to do better. Some just straight up use reference counting and leak anything with circular references.


So what?

Yes some have buggy implementations, others could do better, yet they exist.

I rather have a half working bicycle that takes me to town than none at all.


What is a "half working bicycle that takes me to town". Like by definition it fulfills it purpose.

A garbage collector that breaks down on circular references is crazy town for real work. Like there's even AI Lab Koan about that specifically. http://catb.org/jargon/html/koans.html

A better example would be a bicycle without the front wheel. Yeah, if you're real good and real careful you can probably treat it as a unicycle and get to where you're going, but you'd be real pissed if someone sold it to you as a working bicycle, no?


Not all GC enabled languages that currently target WebAssembly are buggy as you make it to be.

PNaCL also did not have direct GC support, yet it got released with working OCaml support.


Did anyone actually use that OCaml support? Like a single production application?


Maybe yes, maybe no.

Enjoying moving goalposts?


It's not moving goalposts. If nobody is using it, not even the developers who put in the effort to make it work, it's a pretty good sign it's not a production ready solution.

Like "technically works enough for a demo" isn't what I'd call full support.


The whole point of this thread was that implementing a GC is possible with what WebAssembly provides today, no need to wait for an API that might never come.

Yes there are bugs in some implementations and others could have been better done, it happens.

Discussing technicalities of who is using what in production is moving goalposts.

Not a big fan of having lost PNaCL in favour of WebAssembly craziness, but that is what we have to work with, GC might come in 5 years time or even never, who knows.

What I know is that despite the flaws, many developers are eager to implement something with what we have now and kudos to them for trying it out.

“They did not know it was impossible so they did it” ― Mark Twain


Like, a no-op GC is a valid implementation as long as your code doesn't allocate too much in the first place. If you ran into that would you consider their implementation buggy and just give them time? Similarly reference counting based GCs _can't_ do anything other than leaking object graphs with circular references, fundamentally. It's not a buggy implementation, it's a fundamental limitation of the technique.

Also, I looked into it. PNaCl couldn't run OCaml, only NaCl. PNaCl (and wasm) doesn't really let you scan stacks, but NaCl does, so they had to drop a real GC with the semantics you'd expect on the transition to PNaCl.

"They did know it was impossible, so they didn't bother" ~ monocasa

And once again, explaining why your examples aren't valid and refuting them isn't "moving goalposts".


Sure it is, because you keep focusing on the few buggy implementations, instead of those that actually work.

There are plenty of leaking object graphs with circular references implementations in native CPUs, and yet people do use them, starting with C++ standard library collection types or Objective-C ARC.

So your point on refuting whatever I present instead of appreciating the work of the implementations that actually work is kind of moving goalposts.

Because apparently people bother with native CPU implementations, even with those bugs, so why should WebAssembly be any different?!?

You don't want to bother, fine go watch tv, play football, whatever is your fancy.

Me, I will be supporting anyone that with the WebAssembly we get to play with, decides to implement their favourite language.

https://docs.assemblyscript.org/details/runtime#collecting-g...

https://docs.microsoft.com/en-us/aspnet/core/blazor/hosting-...

https://fsbolero.io/

https://swiftwasm.org/

https://tinygo.org/lang-support/

Like they say back home "Those that don't have dogs hunt with cats".




Consider applying for YC's Winter 2026 batch! Applications are open till Nov 10

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: