<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Hacker News: lerno</title><link>https://news.ycombinator.com/user?id=lerno</link><description>Hacker News RSS</description><docs>https://hnrss.org/</docs><generator>hnrss v2.1.1</generator><lastBuildDate>Tue, 28 Apr 2026 08:22:24 +0000</lastBuildDate><atom:link href="https://hnrss.org/user?id=lerno" rel="self" type="application/rss+xml"></atom:link><item><title><![CDATA[New comment by lerno in "Zig 0.16.0 Release Notes"]]></title><description><![CDATA[
<p>Odin started in 2017, had a fraction of the contributors and is soon 1.0, so that explanation isn’t cutting it.<p>If you instead look at the over 500 kloc of the Zig source compared to the 70 kloc of the Odin one, it’s a bit clearer why the delay happened: the goals of Zig kept expanding.<p>But not only that: ”juicy main” and Io is something that could have been in Zig from the early days and yet it isn’t. In the Io case it’s Zig pivoting from ”we have colorless async!” to no async, to Io.<p>In other words, Andrew is still experimenting with the language (and more is to come, like ranged integers). This is not the signs of a maturing language, it a language still very much in flux, trying to find its form.<p>The contrast to Odin is that for the last 2-3 years it has had minimal syntax tweaks, and is essentially in release candidate mode for the language.<p>Even if Zig didn’t need more changes, it would still need that stabilization period.<p>This tells us Zig is still rather far from 1.0.<p>I wonder what Andrew is thinking about all this.</p>
]]></description><pubDate>Mon, 20 Apr 2026 10:28:21 +0000</pubDate><link>https://news.ycombinator.com/item?id=47832376</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47832376</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47832376</guid></item><item><title><![CDATA[New comment by lerno in "Zig 0.16.0 Release Notes"]]></title><description><![CDATA[
<p>I think Andrew should seriously think about decoupling the toolchain from the language to put focus on reaching stability there. As it is, we have the compiler with surrounding toolchain, the standard library and the language. The two former can keep evolving even language is fixed.<p>Just being ambitious isn’t necessarily good. Look at Perl6.</p>
]]></description><pubDate>Mon, 20 Apr 2026 10:09:49 +0000</pubDate><link>https://news.ycombinator.com/item?id=47832268</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47832268</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47832268</guid></item><item><title><![CDATA[New comment by lerno in "C3 0.7.11: closing out the 0.7 series before 0.8"]]></title><description><![CDATA[
<p>C3 0.7.11 is the final release in the 0.7 series.<p>This version focuses on tightening semantics, improving type inference, and cleaning up edge cases rather than adding new features. Some parts of the standard library (like matrices) have also been reworked.<p>The goal is to stabilize behavior and reduce inconsistencies before starting the 0.8 cycle.<p>C3 is aiming to stay close to C in terms of control and predictability, while reducing complexity in everyday use.</p>
]]></description><pubDate>Tue, 07 Apr 2026 11:22:52 +0000</pubDate><link>https://news.ycombinator.com/item?id=47673496</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47673496</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47673496</guid></item><item><title><![CDATA[C3 0.7.11: closing out the 0.7 series before 0.8]]></title><description><![CDATA[
<p>Article URL: <a href="https://c3-lang.org/blog/c3-0-7-11-the-last-v0-7/">https://c3-lang.org/blog/c3-0-7-11-the-last-v0-7/</a></p>
<p>Comments URL: <a href="https://news.ycombinator.com/item?id=47673495">https://news.ycombinator.com/item?id=47673495</a></p>
<p>Points: 4</p>
<p># Comments: 1</p>
]]></description><pubDate>Tue, 07 Apr 2026 11:22:52 +0000</pubDate><link>https://c3-lang.org/blog/c3-0-7-11-the-last-v0-7/</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47673495</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47673495</guid></item><item><title><![CDATA[New comment by lerno in "Type resolution redesign, with language changes to taste"]]></title><description><![CDATA[
<p>I just have to add another reflection:<p>One thing that tends to be overlooked when discussing changes is the ecosystem effect of frequent changes.<p>A language that breaks frequently doesn't just impose upgrade work on apps, but also discourages the creation of long-lived libraries and tools. Anything that sits between the language and the user (linters, bindings, frameworks, teaching material, tutorials etc) has to to some degree "chase the language"<p>This means that the ecosystem will skew toward very actively maintained libraries and away from "write once then leave it alone" libs. And this the trade-off is reasonable during early language design, but it's worth acknowledging that it has real consequences for ecosystem growth.<p>One should note that other newer languages have put significant effort into minimizing this churn, precisely to allow the latter type of ecosystem to also form. So it's kind of an experiment, and it will be interesting to see which approach ends up producing the larger ecosystem over time.</p>
]]></description><pubDate>Wed, 11 Mar 2026 15:27:04 +0000</pubDate><link>https://news.ycombinator.com/item?id=47336869</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47336869</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47336869</guid></item><item><title><![CDATA[New comment by lerno in "Type resolution redesign, with language changes to taste"]]></title><description><![CDATA[
<p>> Not at all, if the team needs 30 more years they should take it.<p>Yes, I understand that is the opinion in the Zig community. As an outsider, it seems odd to me to pick a language that I constantly need to maintain.<p>>> However, the outlook for a Zig 1.0 is bleak from what I gather from Zig social forums: the most optimistic estimate I’ve heard is 2029 for 1.0.<p>> Funny you see it as bleak when most of the community sees it as the most excitinh thing in systems programming happening right now.<p>You misread that one. I was talking about the odds of seeing a 1.0 version of Zig soon.<p>> I think you comment is in bad faith, all the big zig projects say that the upgrade path is never a main concern, just read HN comments here or on other zig threads, people ask about this a lot and maintains always answer.<p>Maybe you didn't read what I wrote carefully enough. This is part of the protectiveness from the Zig community that prompted me to write in the first place.<p>WITHIN the Zig community it is deemed acceptable for Zig upgrades to break code. Consequently it becomes simple <i>survivor bias</i> that people who use Zig for larger projects don't think that this is a major concern BECAUSE IF THEY FELT IT WAS A CONCERN THEY WOULD NOT USE ZIG.<p>Whether programmers at large feel that this is a problem is an unknown still, since Zig has not yet reached to point of general adoption (when people use Zig because they have to, rather than because they want to).<p>However, it is INCORRECT to state that just because a language is not yet 1.0 it needs to break older code aggressively without deprecation paths. As an example, Odin removed the old `os` module and replaced it with the new "os2". This break was announced half a year in advance and lots of thought was put into reducing work for developers: <a href="https://odin-lang.org/news/moving-towards-a-new-core-os/" rel="nofollow">https://odin-lang.org/news/moving-towards-a-new-core-os/</a><p>In the case of C3, breaking changes only happen once a year with stdlib going through the general process of deprecating functions long before removing them.<p>I wanted to highlight how these are quite different approaches. For established languages, this is of course even more rigorous, but neither C3 nor Odin are 1.0, and still see this as valuable and their communities then end up expecting it.<p>So please understand that when you say "it's never a main[sic] concern", this is simple survivor bias.</p>
]]></description><pubDate>Wed, 11 Mar 2026 15:09:58 +0000</pubDate><link>https://news.ycombinator.com/item?id=47336650</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47336650</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47336650</guid></item><item><title><![CDATA[New comment by lerno in "Zig – Type Resolution Redesign and Language Changes"]]></title><description><![CDATA[
<p>I am using games, because they pop up more often (gamejams etc), but we can see the same if we'd look at utility apps. Do you want to broaden that to "Odin is more explicitly marked towards writing applications", but if so what would that say of Zig?</p>
]]></description><pubDate>Wed, 11 Mar 2026 14:43:59 +0000</pubDate><link>https://news.ycombinator.com/item?id=47336250</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47336250</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47336250</guid></item><item><title><![CDATA[New comment by lerno in "Type resolution redesign, with language changes to taste"]]></title><description><![CDATA[
<p>> However we value explicitness and allow the developer to do anything they need to do*<p>* except for having unused variables. Those are so dangerous the compiler will refuse the code every time.</p>
]]></description><pubDate>Wed, 11 Mar 2026 11:49:02 +0000</pubDate><link>https://news.ycombinator.com/item?id=47334400</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47334400</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47334400</guid></item><item><title><![CDATA[New comment by lerno in "Type resolution redesign, with language changes to taste"]]></title><description><![CDATA[
<p>It’s good to see that this is finally addressed. It’s been a well known broken part of the language semantics for years.<p>There are similar hidden quirks in the language that will need to be addressed at some point, such as integer promotion semantics.<p>To address the question about stability: the Zig community are already used to Zig breaking between 0.x versions. Unlike competitors such as Odin or my own C3, there is no expectation that Zig is trying to minimize upgrading problems.<p>This is a cultural thing, it would be no real problem to be clear about deprecations, but in the Zig community it’s simply not valued. In fact it’s a source of pride to be able to adapt as fast as possible to the new changes.<p>I like to talk about expectation management, and this is a great example of it.<p>In discussions, it is often falsely argued that ”Zig is not 1.0 so breaks are expected” in order to motivate the frequent breaks. However, there are degrees to how you handle breaks, and Zig is clearly in the ”we don’t care to reduce the work”-camp.<p>If someone is trying to get a more objective look at the Zig upgrade path, then it’s worth keeping in mind that the tradition in Zig is to offload all the work on the user.<p>The argument, which is frequently voiced, is that ”breaking things will make the language get better and so it’s good that there are language breaks”<p>It is certainly true that breaking changes are needed, but most people outside of the Zig community would expect it to be done with more care (deprecation paths etc)<p>Secondly, it should perhaps be a concern for Zig, now at 10 years old, to still produce solidly breaking code every half year.<p>10 years is the common point where languages go 1.0. However, the outlook for a Zig 1.0 is bleak from what I gather from Zig social forums: the most optimistic estimate I’ve heard is 2029 for 1.0.<p>This means that in the future, projects using Zig can still expect any libraries and applications to bitrot quickly if they are not constantly maintained.<p>Putting this in contrast with Odin (9 years old) which is essentially 1.0 already and has been stable for several years.<p>Maybe this also explains the difference in actual output. For example the number of games I know of written in Odin is somewhere between 5 to 10 times as many as Zig games. Now weighing in that Zig has maybe 5 or 10 times as many users, it means Odin users are somewhere between 20-100 times as likely to have written a playable game.<p>There are several explanations as to why this is: we could discuss whether the availability of SDL, Raylib etc is easier on Odin (then why is Zig less friendly?), maybe more Odin has better programmers (then why do better programmers choose Odin over Zig), maybe it’s just easier to write resource intensive applications with Odin than Zig (then what do we make of Zig’s claim of optimality?)<p>If we look past the excuses made for Zig (”it’s easy to fix breaks” ”it’s not 1.0”) and the hype (”Zig is much safer than C” ”Zig makes me so productive”) and compare with Odin in actual productivity, stability and compilation speed (neither C3 nor Odin requires 100s of GB of cache to compile in less than a second <i>using LLVM</i>) then Zig is not looking particularly good.<p>Even things like build.zig, often touted as a great thing, is making it really hard for a Zig beginner (”to build your first Hello World, first understand this build script in non-trivial Zig”). Then for IDEs, suddenly something like just reading the configuration of what is going to be used for building is hidden behind an opaque Zig script. These trade-offs are rarely talked about, as both criticism and hype is usually based on surface rather than depth.<p>Well, that’s long enough of a comment.<p>To round it off I’d like to end on a positive note: I find the Zig community nice and welcoming. So if you’re trying Zig out (and better do that, don’t let others’ opinions - including mine - prevent you from trying things out) do so.<p>If you want to evaluate Zig against competitors, I’d recommend comparing it to D, Odin, Jai and C3.</p>
]]></description><pubDate>Wed, 11 Mar 2026 11:20:31 +0000</pubDate><link>https://news.ycombinator.com/item?id=47334171</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47334171</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47334171</guid></item><item><title><![CDATA[New comment by lerno in "C3 0.7.10: constdef Takes Shape"]]></title><description><![CDATA[
<p>C3 0.7.10 introduces constdef, syntactically and semantically making a clear distinction between proper enums and "enums is collection of constants".<p>Other improvements in this release:<p>- Much improved MSVC cross compilation<p>- Quality-of-life fixes<p>- Custom LLVM builds to reduce external dependencies</p>
]]></description><pubDate>Thu, 26 Feb 2026 23:27:57 +0000</pubDate><link>https://news.ycombinator.com/item?id=47173750</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47173750</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47173750</guid></item><item><title><![CDATA[C3 0.7.10: constdef Takes Shape]]></title><description><![CDATA[
<p>Article URL: <a href="https://c3-lang.org/blog/c3-0-7-10-constdef-finally-takes-shape/">https://c3-lang.org/blog/c3-0-7-10-constdef-finally-takes-shape/</a></p>
<p>Comments URL: <a href="https://news.ycombinator.com/item?id=47173749">https://news.ycombinator.com/item?id=47173749</a></p>
<p>Points: 2</p>
<p># Comments: 1</p>
]]></description><pubDate>Thu, 26 Feb 2026 23:27:57 +0000</pubDate><link>https://c3-lang.org/blog/c3-0-7-10-constdef-finally-takes-shape/</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=47173749</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47173749</guid></item><item><title><![CDATA[New comment by lerno in "C3 0.7.9 with Updated Generics"]]></title><description><![CDATA[
<p>C3 is a language designed as an evolution of C, without retaining strict backwards compatibility, but excellent interop with C.<p>This version departs from its rather uncommon module-based generics, but doesn't go all the way to C++ style templates. Instead generics can be grouped for common constraint checking on template parameters and instantiation. As usual it also contains fixes and additions to the stdlib.<p>Some older posts on C3:<p>- <a href="https://news.ycombinator.com/item?id=46463921">https://news.ycombinator.com/item?id=46463921</a><p>- <a href="https://news.ycombinator.com/item?id=43569724">https://news.ycombinator.com/item?id=43569724</a><p>- <a href="https://news.ycombinator.com/item?id=24108980">https://news.ycombinator.com/item?id=24108980</a><p>- <a href="https://news.ycombinator.com/item?id=27876570">https://news.ycombinator.com/item?id=27876570</a><p>- <a href="https://news.ycombinator.com/item?id=32005678">https://news.ycombinator.com/item?id=32005678</a><p>Try out C3 in the browser:<p>- <a href="https://www.learn-c3.org" rel="nofollow">https://www.learn-c3.org</a><p>Here are some interviews on C3:<p>- <a href="https://www.youtube.com/watch?v=UC8VDRJqXfc" rel="nofollow">https://www.youtube.com/watch?v=UC8VDRJqXfc</a><p>- <a href="https://www.youtube.com/watch?v=9rS8MVZH-vA" rel="nofollow">https://www.youtube.com/watch?v=9rS8MVZH-vA</a><p>Here is a series doing various tasks in C3, slightly dated:<p>- <a href="https://ebn.codeberg.page/programming/c3/c3-file-io/" rel="nofollow">https://ebn.codeberg.page/programming/c3/c3-file-io/</a><p>Repository with link to various C3 resources and projects:<p>- <a href="https://github.com/c3lang/c3-showcase" rel="nofollow">https://github.com/c3lang/c3-showcase</a><p>Some projects:<p>- Gameboy emulator <a href="https://github.com/OdnetninI/Gameboy-Emulator/" rel="nofollow">https://github.com/OdnetninI/Gameboy-Emulator/</a><p>- RISCV Bare metal Hello World: <a href="https://www.youtube.com/watch?v=0iAJxx6Ok4E" rel="nofollow">https://www.youtube.com/watch?v=0iAJxx6Ok4E</a><p>- "Depths of Daemonheim" roguelike <a href="https://github.com/TechnicalFowl/7DRL-2025" rel="nofollow">https://github.com/TechnicalFowl/7DRL-2025</a></p>
]]></description><pubDate>Sat, 31 Jan 2026 04:27:06 +0000</pubDate><link>https://news.ycombinator.com/item?id=46833494</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46833494</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46833494</guid></item><item><title><![CDATA[C3 0.7.9 with Updated Generics]]></title><description><![CDATA[
<p>Article URL: <a href="https://c3-lang.org/blog/c3-0-7-9-new-generics-and-new-optional-syntax/">https://c3-lang.org/blog/c3-0-7-9-new-generics-and-new-optional-syntax/</a></p>
<p>Comments URL: <a href="https://news.ycombinator.com/item?id=46833493">https://news.ycombinator.com/item?id=46833493</a></p>
<p>Points: 5</p>
<p># Comments: 1</p>
]]></description><pubDate>Sat, 31 Jan 2026 04:27:06 +0000</pubDate><link>https://c3-lang.org/blog/c3-0-7-9-new-generics-and-new-optional-syntax/</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46833493</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46833493</guid></item><item><title><![CDATA[New comment by lerno in "Zen-C: Write like a high-level language, run like C"]]></title><description><![CDATA[
<p>I didn't see any similarities to C3, quite the opposite.</p>
]]></description><pubDate>Tue, 13 Jan 2026 15:11:06 +0000</pubDate><link>https://news.ycombinator.com/item?id=46602007</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46602007</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46602007</guid></item><item><title><![CDATA[New comment by lerno in "Zen-C: Write like a high-level language, run like C"]]></title><description><![CDATA[
<p>C2 (<a href="http://c2lang.org" rel="nofollow">http://c2lang.org</a>) similarly compiles to C, but arguably more readable C code from what I can see. The benefits are (1) easy access to pretty much any platform with little extra work (2) significantly less long term work compared to integrating with LLVM or similar (3) if it's readable enough, it might be submitted as "C code" in working environments which mandate C.</p>
]]></description><pubDate>Tue, 13 Jan 2026 15:07:42 +0000</pubDate><link>https://news.ycombinator.com/item?id=46601958</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46601958</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46601958</guid></item><item><title><![CDATA[New comment by lerno in "Zen-C: Write like a high-level language, run like C"]]></title><description><![CDATA[
<p>It would be interesting to hear the motivation for it.</p>
]]></description><pubDate>Tue, 13 Jan 2026 15:04:35 +0000</pubDate><link>https://news.ycombinator.com/item?id=46601911</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46601911</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46601911</guid></item><item><title><![CDATA[New comment by lerno in "The C3 Programming Language"]]></title><description><![CDATA[
<p>But it of course move semantics and destructors affect all things. If the goal is to call and <i>be callable</i> from C without special constructs, how would you make the C code respect the move semantics and destructors?</p>
]]></description><pubDate>Mon, 05 Jan 2026 11:21:56 +0000</pubDate><link>https://news.ycombinator.com/item?id=46497522</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46497522</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46497522</guid></item><item><title><![CDATA[New comment by lerno in "The C3 Programming Language"]]></title><description><![CDATA[
<p>They have different wins. I think labelled break/continue help because they are clearer in locally expressing what the point is. If you see `goto NEXT;` you can kind of guess the intention, but `continue OUTER;` doesn't require you to read the code at the label and check what's happening there. `defer catch` and `defer try` helps avoiding some booleans otherwise needed with just a basic defer. `defer` on its own otherwise sometimes needs booleans to track what should be closed. With goto those naturally go to different cleanup sections.<p>I keep revisiting goto though. I like it a lot for its simplicity.</p>
]]></description><pubDate>Mon, 05 Jan 2026 11:15:19 +0000</pubDate><link>https://news.ycombinator.com/item?id=46497468</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46497468</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46497468</guid></item><item><title><![CDATA[New comment by lerno in "The C3 Programming Language"]]></title><description><![CDATA[
<p>There is <a href="https://github.com/c3lang/c3c/issues/829" rel="nofollow">https://github.com/c3lang/c3c/issues/829</a></p>
]]></description><pubDate>Mon, 05 Jan 2026 11:05:54 +0000</pubDate><link>https://news.ycombinator.com/item?id=46497429</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46497429</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46497429</guid></item><item><title><![CDATA[New comment by lerno in "The C3 Programming Language"]]></title><description><![CDATA[
<p>That's the kind of thing I was thinking about. You can solve that with a switch in C3, but it's not as nice. However, this accounts for no more than 1% of all my goto uses (from a quick inspection), which is too little to build a feature from (discipline is needed to prevent a language from ballooning, it's hard to say no). I am looking for some use for it that can redeem its inclusion.</p>
]]></description><pubDate>Sun, 04 Jan 2026 23:15:40 +0000</pubDate><link>https://news.ycombinator.com/item?id=46493413</link><dc:creator>lerno</dc:creator><comments>https://news.ycombinator.com/item?id=46493413</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46493413</guid></item></channel></rss>