frontpage.
newsnewestaskshowjobs

Made with ♥ by @iamnishanth

Open Source @Github

fp.

Slack has raised our charges by $195k per year

https://skyfall.dev/posts/slack
596•JustSkyfall•4h ago•304 comments

European ant is the first known animal to clone members of another species

https://www.livescience.com/animals/ants/almost-like-science-fiction-european-ant-is-the-first-kn...
27•zdw•56m ago•0 comments

Meta Ray-Ban Display

https://www.meta.com/blog/meta-ray-ban-display-ai-glasses-connect-2025/
309•martpie•5h ago•415 comments

WASM 3.0 Completed

https://webassembly.org/news/2025-09-17-wasm-3.0/
798•todsacerdoti•12h ago•318 comments

Show HN: The text disappears when you screenshot it

https://unscreenshottable.vercel.app/?text=Hello
115•zikero•4h ago•43 comments

Orange Pi RV2 $40 RISC-V SBC: Friendly Gateway to IoT and AI Projects

https://riscv.org/ecosystem-news/2025/09/orange-pi-rv2-40-risc-v-sbc-friendly-gateway-to-iot-and-...
20•warrenm•2d ago•9 comments

Apple Photos app corrupts images

https://tenderlovemaking.com/2025/09/17/apple-photos-app-corrupts-images/
1059•pattyj•19h ago•382 comments

A postmortem of three recent issues

https://www.anthropic.com/engineering/a-postmortem-of-three-recent-issues
254•moatmoat•9h ago•84 comments

One Token to rule them all – Obtaining Global Admin in every Entra ID tenant

https://dirkjanm.io/obtaining-global-admin-in-every-entra-id-tenant-with-actor-tokens/
147•colinprince•7h ago•20 comments

Towards a Physics Foundation Model

https://arxiv.org/abs/2509.13805
29•NeoInHacker•3h ago•9 comments

Boring is good

https://jenson.org/boring/
131•zdw•2d ago•27 comments

Hypervisor 101 in Rust

https://tandasat.github.io/Hypervisor-101-in-Rust/
71•pykello•5h ago•3 comments

Stepping Down as Libxml2 Maintainer

https://discourse.gnome.org/t/stepping-down-as-libxml2-maintainer/31398
53•zdw•6h ago•12 comments

YouTube addresses lower view counts which seem to be caused by ad blockers

https://9to5google.com/2025/09/16/youtube-lower-view-counts-ad-blockers/
321•iamflimflam1•15h ago•606 comments

Condor Technology to Fly "Cuzco" RISC-V CPU into the Datacenter

https://www.nextplatform.com/2025/09/15/condor-technology-to-fly-cuzco-risc-v-cpu-into-the-datace...
10•rbanffy•2d ago•3 comments

A QBasic Text Adventure Still Expanding in 2025

https://the-ventureweaver.itch.io/
27•ATiredGoat•3h ago•10 comments

Ton Roosendaal to step down as Blender chairman and CEO

https://www.cgchannel.com/2025/09/ton-roosendaal-to-step-down-as-blender-chairman-and-ceo/
283•cma•13h ago•53 comments

Optimizing ClickHouse for Intel's 280 core processors

https://clickhouse.com/blog/optimizing-clickhouse-intel-high-core-count-cpu
175•ashvardanian•11h ago•40 comments

Tinycolor supply chain attack post-mortem

https://sigh.dev/posts/ctrl-tinycolor-post-mortem/
149•STRiDEX•13h ago•55 comments

What's New in C# 14: Null-Conditional Assignments

https://blog.ivankahl.com/csharp-14-null-conditional-assignments/
106•ivankahl•2d ago•82 comments

Drought in Iraq reveals tombs created 2,300 years ago

https://www.smithsonianmag.com/smart-news/severe-droughts-in-iraq-reveals-dozens-of-ancient-tombs...
125•pseudolus•13h ago•20 comments

DeepMind and OpenAI win gold at ICPC

https://codeforces.com/blog/entry/146536
205•notemap•12h ago•199 comments

U.S. investors, Trump close in on TikTok deal with China

https://www.wsj.com/tech/details-emerge-on-u-s-china-tiktok-deal-594e009f
388•Mgtyalx•1d ago•532 comments

Ask HN: What's a good 3D Printer for sub $1000?

176•lucideng•2d ago•215 comments

Alibaba's new AI chip: Key specifications comparable to H20

https://news.futunn.com/en/post/62202518/alibaba-s-new-ai-chip-unveiled-key-specifications-compar...
275•dworks•20h ago•277 comments

Gluon: a GPU programming language based on the same compiler stack as Triton

https://github.com/triton-lang/triton/blob/main/python/tutorials/gluon/01-intro.py
70•matt_d•10h ago•19 comments

Understanding Deflate

https://jjrscott.com/to-deflate-or-not/
53•ingve•3d ago•6 comments

Launch HN: RunRL (YC X25) – Reinforcement learning as a service

https://runrl.com
59•ag8•14h ago•16 comments

Tau² benchmark: How a prompt rewrite boosted GPT-5-mini by 22%

https://quesma.com/blog/tau2-benchmark-improving-results-smaller-models/
179•blndrt•17h ago•54 comments

Determination of the fifth Busy Beaver value

https://arxiv.org/abs/2509.12337
268•marvinborner•19h ago•107 comments
Open in hackernews

Don't Use ISO/IEC 14977:1996 Extended Backus-Naur Form (EBNF) (2023)

https://dwheeler.com/essays/dont-use-iso-14977-ebnf.html
51•gslin•4mo ago

Comments

dwheeler•4mo ago
I'm the author. Ask me anything!
teddyh•4mo ago
Is there any documented version of EBNF suitable for general use?
ggm•4mo ago
IETF uses ABNF https://datatracker.ietf.org/doc/html/rfc5234

Commentaries say its different, but the differences might not matter?

ucarion•4mo ago
Is the main objection to RFC5234 its weird syntax for repetition (*THING, [THING], 5THING)?
dwheeler•4mo ago
More or less. It's a perfectly workable approach, but it's the reverse of what practically everyone else does, as well as the reverse of regex notation. Common notations should be common.
90s_dev•4mo ago
What's your favorite programming language and why is it C?
dwheeler•4mo ago
I like lots of programming languages, I don't really have 1 favorite. I like the relative simplicity of C, and I have long familiarity with it, but its lack of memory safety and endless undefined behavior make it more difficult to safely use than necessary.
arh68•4mo ago
Great article. Informative, qualified. I had not realized how splintered the [E]BNF syntax is, like in the way I already knew timestamps are (3339 vs 8601 vs mm/dd/yyyy &c &c).

Q: what's your ideal way to write Unicode characters clearly? In the W3C/XML spec they'll have stuff like [#x200C-#x200D] but I have no idea what those are, without like a dictionary on hand. Points for specificity, but it doesn't scream "readable".

Your point about standards-not-publicly-available is unfortunately similar to, well, laws. In some areas, "the laws" themselves are not public (!) though perhaps it's a digression better to not get into

pedantically, s/unabiguously/unambiguously/g

dwheeler•4mo ago
In many cases I think the character itself is clearest. Thankfully most tools can handle Unicode today. That's not always unambiguous, so sometimes an annotation may be helpful, and if the spec is freely available you can copy amd paste from it.
alfiedotwtf•4mo ago
So if not EBNF for defining grammars, what should people be using ie what would be your preferred that would be powerfully enough and general purpose?

I’ve never seen PCRE used for grammars and not sure if it would be powerfully enough for all cases, but personally I think it would be pretty cool since I find it easier to read than EBNF and it’s so widely used people can slot a specification right into code and it should just work

dwheeler•4mo ago
One of those alternative specifications is in the W3C Extensible Markup Language (XML) 1.0 (Fifth Edition). As I note, "The W3C specification is much more similar to typical regex syntax making it much easier for today's software developers to understand), avoids the key problems of 14977:1996, and is already clearly described." It's freely available from w3c. You don't need to use XML to use it.
alfiedotwtf•3mo ago
Oops, sorry. When you said that I thought there was going to be an actual specification of the grammar specification itself rather than the application in use. Ok cool, got it thanks :)
HarHarVeryFunny•4mo ago
> One of the most common operations in a grammar, by far, is concatenation (aka sequencing). ISO/IEC 14977:1996 requires that a comma be used for every concatenation, so any sequence of N symbols will have N-1 commas.

It seems they were trying really hard to make EBNF NOT look like the grammar it is representing.

> ISO/IEC 14977:1996 represents “one or more” as { symbol }- which means “0 or more symbols, and then subtract the empty set

It's almost as if they were looking for a special syntax to express "1 or more".

Bizarre ... just bizarre.

mannyv•4mo ago
(4) -> I would say that the lack of regex use is a plus. Yes I use them all the time. For anything complicated I'll just ask ChatGPT to make it. And of course, are regexs all the same across everything?

(5) -> Once you get it you get it.

Every language specification is odd in its own special way. In any case I haven't really seen BNF/EBNF used in the last few years, so this is probably a moot discussion.

alfiedotwtf•4mo ago
How are the grammars you see on a regular basis specified if not by BNF?
mdaniel•4mo ago
I'm not the person you asked but I believe there are two broad classes of answers: hand rolled parsers and PEG grammars

e.g. https://github.com/llvm/llvm-project/blob/llvmorg-20.1.5/cla... and https://github.com/python/cpython/blob/v3.13.3/Grammar/pytho...

alfiedotwtf•3mo ago
Hand rolled and PEG are nice implementation wise, but to think about the grammar itself and needing to debug it not so much.

Maybe it's a personal thing, but I'd rather something textual that generated a parser than have to hand roll rec decent etc.

Mofpofjis•4mo ago
The complaints about ISO Prolog, and about ISO standards generally not being available publicly / at no cost, resonate a lot with me. If you compare eg. the POSIX and the ISO C development workflows, and their respective end results, there's a world of difference.

"ISO" (International Standards Organization), where you have "national member bodies", should absolutely be a thing of the past for programming languages (or for anything related to computing). My country's national body's own homepage has a huge tirade, aiming to "dispel myths", such as the "myth" that "standards should be available free of charge". Meanwhile, lots of std orgs have published computing standards with various degrees of openness already.

ISO is a relic when it comes to computing. (So are other standards bodies that choose to remain proprietary; like those behind PCI, SCSI, ... Computing is ubiquitous and these bodies should be forced open by law, for the public interest.)

convolvatron•4mo ago
doesn’t have to be a legal enforcement if vendors just don’t work with bodies that insist on this counterproductive notion of standards as a profit center.

unfortunately i think there us some degree of collusion here. it’s easier to get your existing proprietary standards ratified if there are fewer players in the room and the palms that need to be greased are clearly marked

OneDeuxTriSeiGo•4mo ago
It's not exactly clear cut. Standards are unfortunately in general quite expensive to produce and maintain.

Software oriented standards are certainly cheaper than metallurgy, machining, manufacturing, building construction, environmental, health & safety, and the other big classes of standards however they still have quite a cost.

Historically the ISO standards development process for software standards (like the C or C++ standards) happened only in small part asynchronously and historically required large, extended-duration committee meetings where all the details were hashed out in person. This process only really started to change during COVID but even then it's still a very in-person synch-heavy process and that's not exactly cheap to run.

And with most standards, the FDIS (final draft international standard) revisions are made public. They can be found online even if they can be annoying to dig up. For 99% of cases the FDIS revision is more than sufficient and is identical to the published standard minus a typo or grammar mistake here and there.

As the average SW dev or engineer of course you don't need to fork over the cost for the published standard but any large company will probably purchase a catalog of standards rather than deal with the overhead of dealing with FDIS (and any legal risk from not following the "true" standard).

It is also worth noting that pretty much every university library (and many public non-university libraries) has some contract or service that provides access to copies of the standard to members free of cost.

convolvatron•4mo ago
I used to work in standards. my organization supported my salary, my travel, and paid membership fees. yes, the standards body did rent the hotel ballroom, and run a website. but otherwise the task of making the sausage was all volunteer.
Mofpofjis•3mo ago
Evidence to the contrary (anecdotal, admittedly):

- https://github.com/EbookFoundation/free-programming-books/is... -- "The most recent freely available draft of C17/C18 used to be c17_updated_proposed_fdis.pdf, but it's no longer available directly and you need to use Wayback Machine to download it."

- I used to work for a multinational software company whose bread-and-butter was C. The company had indeed purchased a catalog of standards, but that catalog didn't include ISO C. When I formally proposed just that, they rejected it (and kind of made me feel uncomfortable about my proposal, to boot).

fanf2•4mo ago
Yeah

For the horrible tedious details, see the “Policy for the distribution of ISO publications and the protection of ISO’s copyright” aka ISO POCOSA 2012.

https://archive.org/details/iso-pocosa

unixhero•4mo ago
Scsi was great
sevensor•4mo ago
It really was.
TheAceOfHearts•4mo ago
Maybe someday someone will find the courage to do a full dump of every ISO standard into LibGen or SciHub.
pjmlp•4mo ago
POSIX is hardly much more open than ISO, it also has its issues, and contributing to OpenGroup is hardly like doing a pull request.

So is Khronos also a relic? After all if the standards are made available, the contributions are "you have to be this tall to play" kind of entry.

I do agree that ISO should improve itself to modern times, though.

kazinator•3mo ago
The Open Group hosts hosts a searchable, hyper-linked form of the specification.

Here is the 2024 update:

https://pubs.opengroup.org/onlinepubs/9799919799/

If you go to the Main Index there is a link to a Downloads page where you can get a tarball of this stuff in some shape or form for local use.

Vast difference between this and the paywalls put up by ISO and their member organizations, and their free PDFs that have only tables of contents.

pjmlp•3mo ago
Now try to contribute to OpenGroup.

You mean free pdfs like C and C++ drafts?

https://www.open-std.org/jtc1/sc22/wg14/www/docs/n3220.pdf

https://isocpp.org/files/papers/N4860.pdf

Maybe like Ada,

http://ada-auth.org/standards/ada2y.html

Or Fortran,

https://j3-fortran.org/doc/year/23/23-007r1.pdf

Apparently there is a little more than a table of contents, when people actually know where to look.

kazinator•3mo ago
It shouldn't be easy to contribute to POSIX. That shit needs some serious gatekeeping. It's not a side-project whose goal is self-actualization for all participants. The requirements get foisted on everyone and last decades.
Mofpofjis•3mo ago
I agree with you about the seriousness and heft of POSIX (and I definitely know your name from comp.lang.c[.moderated], so I respect your opinion); however, there is no arbitrary gate-keeping around POSIX. If anyone is willing to put in the time and effort, they're welcome to join. This couldn't be more different from other standards orgs where you can only join as a (voting, or observing) representative of an employer that pays an exorbitant yearly membership fee.
Mofpofjis•3mo ago
> Now try to contribute to OpenGroup.

Funnily enough, I had ended up contributing to POSIX without trying to. I just participated in mailing list discussions and in the public bug tracker (reporting issues, commenting on tickets etc), for which I only needed to register a no-strings-attached account -- the absolute minimum for participating in any bug tracker. Unexpectedly, I got named in the "Participants" section of the standard. My head is still spinning.

Here are some links for you:

- SUSv2: https://pubs.opengroup.org/onlinepubs/007908775/idx/index.ht...

- SUSv3, 2004 Edition: https://pubs.opengroup.org/onlinepubs/000095399/nfindex.html

- SUSv4, 2024 Edition: https://pubs.opengroup.org/onlinepubs/9799919799/

You can find links to earlier editions of SUSv3 and SUSv4 here: https://en.wikipedia.org/wiki/Single_UNIX_Specification#Exte...

Austin CSRG landing page: https://www.opengroup.org/austin/

Join the group: https://www.opengroup.org/austin/lists.html

Bug tracker: https://austingroupbugs.net/view_all_bug_page.php

I don't know where the SUSv1 PDFs are, I have local copies; but in 2025, they're at best of historical interest.

tialaramex•4mo ago
Technically ISO is not an abbreviation, their name is just shortened to ISO from the Greek word meaning equal.

The programming language standards in particular are the work of "ISO/IEC JTC 1/SC 22 Programming languages, their environments and system software interfaces" which is a sub-committee of the Joint Technical Committee between ISO and the IEC. It's sub-sub-committees all the way down.

I believe ISO processes are ill-suited to this type of work, and that on the whole those languages which still have SC22 working groups would benefit from finding a better home than ISO. The best SDO today (if you can reasonably call the IETF an "organisation" which it says it is not) is the IETF but the IETF doesn't want anything to do with programming languages, so, maybe they could find a home at ECMA where Javascript lives or they could go build their own SDO for purpose.

Mofpofjis•3mo ago
> they could find a home at ECMA where Javascript lives or they could go build their own SDO for purpose

One option is https://www.oasis-open.org/

userbinator•4mo ago
IMHO ABNF is just as annoying to read, especially its insistence on '/' instead of '|' for alternation (when | has universally become the "OR" symbol in other languages) and "%x" for hex prefixes. My preference for syntax descriptions is [ ] for "optional", ",,," or "+" for "1 or more", "*" for "0 or more", and "{min,max}" or "{n}" for repetition ranges, which closely mirrors regex syntax; I'm not sure if this has been standardised or even has a name, but I've seen it far more often than ABNF/EBNF.
Pet_Ant•4mo ago
First thing I noticed was

> rule = definition; comment CR LF

...so it uses CR/LF as a line terminator as opposed to just LF like POSIX does so you are gonna have text editors and other tools just breaking the format on save.

kstenerud•4mo ago
These are some of the many reasons why I developed the Dogma metalanguage.

https://dogma-lang.org/

https://github.com/kstenerud/dogma/blob/master/v1/dogma_v1.0...

That, and also I needed a language that could describe binary data.

mdaniel•4mo ago
Do I correctly understand that you don't currently have a parser generator for .dogma files? I tried clicking around in a few of the adjacent repos without much luck

Anyway, my go-to tire kicking for any such binary file description format is parsing .pdf files, since they are ferociously hard, and include backreferences

kstenerud•4mo ago
I haven't gotten around to writing a parser generator yet. I only wanted this for documentation purposes, and haven't had the spare time to take it further yet.

There are definitely going to be horribly convoluted formats that it can't describe without help (which is where custom functions come in). But it's been able to describe most formats I've thrown at it, so that's good enough for Dogma v1.

I was able to get it to describe minidump without function help...

PJBaker•4mo ago
> every single language document uses its own notation, which is more often than not, a dialect of the (Extended) Backus-Naur Form

I came across this recently while writing an article that references Lua, Go and Python (3.8) syntax. Each of them uses a slightly different form of EBNF.

To make them more easily comparable, I wanted to convert all three to the same format. Looking for something fairly standard (not entirely ad-hoc but also not as formal as ISO/IEC EBNF or RFC 5234 ABNF), I came across Wirth Syntax Notation [0] [1]:

    syntax = { production } .
    production = identifier "=" expression "." .
    expression = term { "|" term } .
    term = factor { factor } .
    factor = identifier | literal | "(" expression ")" | "[" expression "]" | "{" expression "}" .
    literal = "\"" character {character} "\"" .
It turns out that the Go specification already uses WSN [2]. I converted Lua and Python, and then could work with all three language grammars in a consistent, machine-readable notation.

[0] https://en.wikipedia.org/wiki/Wirth_syntax_notation

[1] https://dl.acm.org/doi/10.1145/359863.359883

[2] https://go.dev/ref/spec#Notation

egberts1•4mo ago
Here is a list of all variants of EBNFs:

https://github.com/egberts/vim-syntax-ebnf

And a EBNF format detector:

https://github.com/egberts/filetype-ebnf-grammars

And a master list of all variants of EBNF:

http://www.cs.man.ac.uk/~pjj/bnf/ebnf.html

egberts1•4mo ago
Still use EBNF, so some of my tools, citations, and sources are:

Here is a list of all variants of EBNFs as well as Vim syntax highlighter for EBNF variants:

https://github.com/egberts/vim-syntax-ebnf

And a EBNF format detector:

https://github.com/egberts/filetype-ebnf-grammars

And a master list of all variants of EBNF:

http://www.cs.man.ac.uk/~pjj/bnf/ebnf.html