alt.hn

3/20/2026 at 10:06:51 PM

Show HN: We built a terminal-only Bluesky / AT Proto client written in Fortran

https://github.com/FormerLab/fortransky

by FormerLabFred

3/21/2026 at 7:17:20 AM

Love seeing niche Show HN projects like this. The choice of Fortran is wild but that's what makes it fun. As someone building small Mac utilities, I appreciate any project that proves you don't need a massive stack to ship something useful.

by lzhgusapp

3/21/2026 at 8:03:57 AM

Thanks for the feedback!

We got a spec for Assemblersky. Will be a weekend project. Cancel Easter :) And probably Midsummer too…

We got image composer and decoder plugged in in dev env, but will let this first open version breathe first. ASCII or early Apple algo

Fortran-fast feed builder probably in next open version. It crunches fast

Morning, 9 o’clock in Sweden, coffee and check-the-feed-on- Fortransky-time :)

by FormerLabFred

3/21/2026 at 3:11:13 PM

COBOLsky. It’s enterprise webscale.

by bombcar

3/20/2026 at 10:08:38 PM

out of curiosity, why fortran? no disrespect. I wrote a lot of scientific software in the earlier days of my career and I learned fortran to update ocean modeling software.

by cat-turner

3/20/2026 at 10:26:20 PM

You are not the first one to ask :)

We built Cobolsky. Will go public soon. Parallelly too curious on Fortran. The world is better with a Fortran-based social network client in it :)

When we are building the feed composer, in next version, Fortran will be great for the algorithm etc.

Keeping the ancient languages alive. I built some Cobol stuff many years ago. Back at it again. Rusty.

Both Cobolsky and Fortransky looks great on Swordfish90’s cool-retro-term, but we are building our own terminal for Fortransky too. There is a blog post with screenshots over at Patreon/formerlab

Can’t get enough Fortran

by FormerLabFred

3/20/2026 at 10:27:41 PM

> The world is better with a Fortran-based social network client in it

If you don't mind me asking, why is the world better with more Fortran-based software?

by embedding-shape

3/20/2026 at 10:39:05 PM

Our modern languages are built on it, and it’s incredibly fast,

so it deserves to be kept alive. We owe a great deal to the people who wrote it in the 1950s I guess

by FormerLabFred

3/20/2026 at 11:13:09 PM

This thread makes me happy

by mountainriver

3/21/2026 at 5:30:47 PM

I know right! I was pleasantly surprised. It has to be one of the greatest news I have heard in a while.

by johnisgood

3/20/2026 at 11:12:26 PM

> Our modern languages are built on it

It's part of the lineage, yeah, probably started with Algol though? Fast I guess is always nice, but I'm not sure that's enough to keep it alive solely for that, at least to me.

by embedding-shape

3/21/2026 at 7:01:49 AM

I think the best answer you're really going to get here is that it's cool and fun to learn and use old languages.

by mathieudombrock

3/21/2026 at 10:16:12 AM

I'd agree with all of those reasons! I do so myself as well, was just specifically curious about the "The world is better with a Fortran-based social network client in it" part. Don't get me wrong, I've spent too many nights learning "dead" languages too, but never with the idea that the world would be better if I published more code in these dead languages, it's just for my own gratification and learnings.

by embedding-shape

3/21/2026 at 1:26:49 AM

I came here to suggest COBOL as a better fit, then saw your comment a few levels up in this thread.

Out of curiosity, does your implementation use CODASYL?

(For people that don't pay much attention to historical software systems, most CODASYL implementations were similar to JSON document databases, so going that way isn't as crazy as it sounds.)

by hedora

3/21/2026 at 8:59:36 AM

Great comment! Thanks!

No CODASYL, the JSON parser is hand-rolled Fortran with a depth-tracking key scanner

CODASYL not a crazy direction for the feed composer

Got more depth to explore here, still early :)

by FormerLabFred

3/21/2026 at 8:01:58 AM

How do COBOL and Fortran compare for something like this ?

by Melatonic

3/21/2026 at 8:55:06 AM

COBOL is more painful, Fortran better.

Good you raised the topic, can write a blog post on it when we ship Cobolsky. Will be a proof of concept repo. Fortransky is the one

(If AT Proto did fixed-width records instead of JSON, COBOL would be formidable)

by FormerLabFred

3/21/2026 at 12:51:18 PM

Which version of the language is it? It looks like you used Fortran90 at least (modules are used), which is pretty old, but not totally ancient like Fortran77.

Anyway there are also 2018 and 2023 versions…

by bee_rider

3/21/2026 at 3:54:09 PM

I still make a living from Fortran77 work, though much of it is converting it to Matlab.

by fortran77

3/21/2026 at 5:07:15 PM

Building interfaces or full converting? Either way sounds like a dream job, haha.

by bee_rider

3/21/2026 at 5:17:10 PM

Thank you for choosing Fortran. Seriously, I mean it.

Someone else already said this, but it is awesome because it proves that you can write useful software using languages others consider ancient or dead and therefore "unusable".

Keep up the great work!

by johnisgood

3/20/2026 at 10:21:33 PM

> why fortran?

why not? the language is straightforward and loops are fast. It is portable and your code will work unchanged for the next 50 years. It may be a bit verbose, but that's not a big deal with today's tooling.

by enriquto

3/20/2026 at 10:27:25 PM

Fortran will survive the cockroaches even, when the world 404s

by FormerLabFred

3/20/2026 at 10:35:58 PM

Your code will work unchanged until you try to change compilers or your compiler adopts a J3 breaking change to the language.

by pklausler

3/21/2026 at 12:02:29 AM

> your compiler adopts a J3 breaking change to the language

Like all the 3 of them they added in the last 30 years, and that compiler vendors are not enforcing anyway because they don’t want to annoy their users?

Windows’ backward compatibility is a joke compared to Fortran.

by kergonath

3/21/2026 at 6:09:04 PM

Yea na, Fortran is pretty compiler dependent and there are a lot of compilers. Already old Fortran code used all sorts of now-dead proprietary compilers and can take a huge effort to get it to compile on modern compilers or even modern computers. Modern code might use Gfortran which sometimes makes breaking changes so that's not an option. Perhaps if everyone uses the latest shiny new Flang or whatever, then it'll finally last 50 years? Not likely, given the history.

by foxglacier

3/22/2026 at 2:04:30 PM

For a standardized language, Fortran isn’t very portable across compilers. GNU Fortran has done a great job supporting legacy features, and I hope that our work in flang-new has made it easy to port to, as well. I basically ignored the zealots who wanted flang-new to be a strict compiler by default. The hobbyist project LFortran is quite the opposite, and will yell at you by default for perfectly conforming variations in keyword spelling. For those who like that sort of thing, that’s exactly the sort of thing that they like.

by pklausler

3/21/2026 at 4:23:39 AM

Great, can we see some benchmarks?

by deadbabe

3/21/2026 at 9:04:43 AM

Cobolsky holds the record for most surprised looks per line of code :)

Fortransky benchmarks pending

the feed scorer will have real numbers worth reporting

Whenever time allows in future: Fortran vs Go vs Python

by FormerLabFred

3/20/2026 at 10:20:03 PM

maybe they weren't really concerned about portability or a decent standard?

by pklausler

3/20/2026 at 10:32:23 PM

It’s keyboard navigation only, and we got the Bluesky firehose raw straight into the Rust decoder. Or we switch mode to Jetstream with m+EnTER :)

You hit l+ENTER to like a post. If anyone replies from Bluesky, we hit n+ENTER and see the notifs. And so on

Fortransky is 70% Fortran, rest is Rust, C and a tiny Python helper

by FormerLabFred

3/21/2026 at 2:50:46 PM

It seems you’ve written an extensive blog post about this, but I don’t see a direct link anywhere!

https://www.patreon.com/posts/fortransky-we-in-153457794

by jrmg

3/21/2026 at 3:47:08 PM

To the repo? It’s in the blog post head, in section under first screenshot,

https://github.com/FormerLab/fortransky

by FormerLabFred

3/21/2026 at 3:48:49 PM

No, I mean the other direction.

The repo is what’s this HN post links to, and I don’t see a link to the blog post in it or in other comments here. The blog post is interesting!

by jrmg

3/21/2026 at 4:08:38 PM

Ok got you. Good point, added to repo README

by FormerLabFred

3/21/2026 at 12:41:31 PM

I’ve never seen fortran before. Wow, that looks more readable than a lot of modern languages.

by worldmerge

3/21/2026 at 1:51:15 PM

Modern versions of Fortran are reasonably pretty.

It’s a fairly nice language. You can probably get better performance out of C/C++ with unlimited effort. But, it is really nice for allowing computational scientists to get, like, 95% of the way there.

I think it actually suffers from the reputation as this ancient/super hardcore performance language. The name comes from “Formula Translating System,” which implies… it was written for people who speak human languages first!

by bee_rider

3/21/2026 at 3:48:52 PM

ive maintained a simulation software where the core is written in fortran. its using some intel math library that is expensive that i cannot recall, does immense calculations and makes faster binaries than c on every compiler we tried

by sitzkrieg

3/21/2026 at 6:27:14 PM

Have you tried using the restrict keyword everywhere you can in c?

In Fortran, arrays are not allowed to overlap which allows some optimisations. c has rules in the spec about how memory accesses must occur, and overlapping arrays being possible prevents some compiler optimisations. The restrict keyword is you promising that the memory at some pointer won't be accessed through another pointer.

You can compare two implementations in Fortran/c using godbolt to see how each of them compile.

by extraduder_ire

3/22/2026 at 1:55:10 PM

Dummy arguments may not alias anything else, including other dummy arguments, in conforming Fortran if either are modified, with some exceptions. But there are many ways in which arrays can overlap that don’t involve dummy arguments. GNU Fortran optimizes ASSOCIATE names as if they were free of aliasing, too, but that is a bug.

by pklausler

3/21/2026 at 5:00:22 PM

Interesting.

MKL is Intel’s famous numerical library (it includes things like BLAS “basic linear algebra subroutines” and fast Fourier transforms). It is availible for free, but IIRC they had some support plans maybe, maybe that’s what you are remembering?

It is closed source, but you can look at the source of the best open source competitor libflame/BLIS, and see that most of the performance comes from C and assembly.

It is difficult to beat “unlimited effort” C, but not many program really justify that treatment.

by bee_rider

3/21/2026 at 5:57:45 PM

MKL used to not be free. You had to buy it from a local reseller for a few hundred dollars per developer.

by foxglacier

3/21/2026 at 1:02:41 PM

Modern dialects of Fortran, sure.

Old school Fortran from before they added cleaner and more structured elements is terrifying.

by cmrdporcupine

3/21/2026 at 4:58:24 AM

Brilliant in every possible way. Fortran was first language I learnt at high school in its "PORTRAN" variant.

by zoom6628

3/21/2026 at 8:10:08 AM

:) We tried Abacus Fortran on the C64 back in the days and were allowed to stay indoors during breaks doing Basic stuff too on school computer.

One of the guys wrote 8xxROM some 10 years later.

Today known as U−Boot :)

by FormerLabFred

3/21/2026 at 7:49:35 PM

I'm curious if you used AI during development and how it handled Fortran

by vissnia

3/22/2026 at 7:07:36 AM

Great question!

This was quite straightforward to code ’manually’, but we got stuck for some hours when trying to send the first message. CPU topped, fans spinning, no message through. Analyzed, and after a while when we got same block the nth time, someone proposed Claude.

So Claude got the repo, prompted Claude:

”You got one job, why isn’t message through and why CPU usage high?”

He didn’t solve it. Probably could have if we kept Clauding.

But we found the problem. The issue was that the code was hitting the terminal 300 times trying to send the message :)

For clarity reasons Claude got the job to write the README, personally I don’t like that approach, but we got many other projects so time management basically.

We are building Cobolsky too.

Right now we are building the part to get images through using Apples old algo. Will be 576x720 using the Föoyd-Steinberg dither, 1984 Apple algorithm :)

by FormerLabFred

3/20/2026 at 11:09:02 PM

Are there any other AT protocol apps that aren’t derivatives of bluesky? By that I mean, not social media feed related, twitter clone.

by hk1337

3/20/2026 at 11:16:33 PM

Yep lots! Mine is a livestreaming service: https://stream.place

Also a great blogging platform: https://leaflet.pub

Here's a goal tracker: https://goals.garden

This one just dropped recently; it's 44 different atproto-related apps with a cyberpunk theme: https://www.aetheros.computer/

Lots others mentioned here: https://blueskydirectory.com/

by iameli

3/20/2026 at 11:30:57 PM

AT conference in a couple of days. In Vancouver. Bet they are all there and the rest of the AT bunch.

by FormerLabFred

3/20/2026 at 11:27:56 PM

Don’t know if people are building GitHub-like systems, offline-first app sync etc

Many devs reuse schema and write some twitter/bsky clone

Kind of search engine for my Blueaky likes

Gotta get off the timeline, germ has a messaging app, then there is Tangled and some more

We do Fortransky and Cobolsky now, got more ideas for the protocol than time :)

by FormerLabFred

3/20/2026 at 11:57:09 PM

https://tangled.org/ <--- GitHub on ATProto

that's all I'm aware of

(edit) Oops, just saw that you mentioned it, confused by your first line then. Tangled is awesome!

by linolevan

3/20/2026 at 11:39:36 PM

i am currently working on a dropbox alternative: https://dropb.at

by tjuene

3/21/2026 at 4:22:51 PM

Cool!

by FormerLabFred

3/21/2026 at 11:52:13 AM

How do you plan on differentiating it from just a trivial setup of an FTP account that's mounted locally with curlftpfs and has files in a SVN or CVS on the mounted filesystem?

by Hamuko

3/21/2026 at 1:56:14 PM

good point, i havent considered this at all. its basically dead on arrival

by tjuene

3/20/2026 at 11:27:35 PM

It's always nice to see production codebases in languages that you've never used but are interested in.

Tangential, but to the author, are there any FORTRAN codebases you feel are well designed?

by h4ch1

3/20/2026 at 11:34:27 PM

Good reminder to dig around. Will check. We picked up the Fortran manual and just went for it.

The original Manual exists as a PDF. Was it in a Stuttgart uni URL? Just a search away.

Late in Sweden, gotta Fortran tomorrow. Happy to continue discussion here tomorrow.

by FormerLabFred

3/21/2026 at 4:27:49 PM

Forecast: Fortransky on Tangled tomorrow Sunday

by FormerLabFred

3/21/2026 at 2:46:03 PM

There seems to be a bunch of Rust in there too?

by jrmg

3/21/2026 at 3:45:26 PM

It’s early version yes. It’s 70% Fortran, next version more Fortran and we will add x86-64 assembly decoder for AT Proto firehose frames

by FormerLabFred

3/21/2026 at 12:08:10 PM

'written in Fortran'.

Interesting choice. Why?

by vincentabolarin

3/21/2026 at 3:09:25 AM

y'all gotta throw this up on https://tangled.org ;)

by nerdypepper

3/21/2026 at 4:21:46 PM

On it!

by FormerLabFred

3/20/2026 at 10:34:15 PM

The world is a better place for this app. Wonderful!

by uberdru

3/20/2026 at 10:44:43 PM

:) I mean there are still some people alive out there who never saw a web UI when beginning dev. They get a bit nostalgic, missing their 286

It’s fun and it is appreciated by them, and the young ones who are curious

by FormerLabFred

3/21/2026 at 3:57:36 PM

Whenever I hear about this AT protocol I think about the text-based commands to control cellular modems. I can't be the only one, r-right guise... r-right?

by Uptrenda

3/21/2026 at 3:52:47 PM

Finally! Some relevant news here. I wondered where all the other Fortran people were hiding. I thought I knew all the other BlueSky Fortraners.

by fortran77

3/21/2026 at 5:34:09 AM

Oh this is cool

by Ashkaan

3/20/2026 at 10:23:52 PM

fortran > cobol

by blundergoat

3/20/2026 at 10:36:24 PM

fortran .GT. cobol

by pklausler

3/20/2026 at 10:46:47 PM

> forever

by FormerLabFred

3/21/2026 at 7:03:17 AM

thats COBOL :)

by arunakt

3/21/2026 at 5:17:45 AM

On ATProto: it’s funny how we never learn the lesson:

- VCs band together to fund something shiny.

- Devs love shiny, helping spread the something.

- VCs enschitify it to get their coins back.

by isodev

3/21/2026 at 4:22:23 PM

VC is Fortransky no-go zone

by FormerLabFred

3/21/2026 at 12:59:59 AM

[dead]

by dualblocksgame

3/21/2026 at 12:34:45 AM

[dead]

by DaleBiagio

3/21/2026 at 2:02:08 AM

[flagged]

by aimarketintel

3/21/2026 at 12:03:42 AM

[flagged]

by patapim

3/21/2026 at 12:55:14 AM

AI slop comment

by ccmcarey

3/21/2026 at 1:34:48 AM

HN is getting legitimately difficult to use with how much AI spam has been flooding the comment section recently

by dymk

3/21/2026 at 1:36:37 PM

Why not Rust ?

by grougnax

3/21/2026 at 5:40:50 AM

From my experience building browser automation tools, the biggest challenge with most Chromium-based solutions is that their TLS fingerprint is a dead giveaway. Firefox-based approaches tend to fare much better against JA3/JA4 fingerprinting.

The key insight is moving fingerprint spoofing from the JS level (which is itself detectable) down to the native C++ level. It's a fundamentally different approach.

by youhai

3/21/2026 at 9:07:25 AM

Multiple tabs open? :)

by FormerLabFred

3/21/2026 at 4:18:33 PM

Just spam.

by kgwxd