Are there any examples of 'perfect' software?
I'm talking about programs that can't be improved no matter what. They do exactly what they're supposed to and will never be changed.
It'll probably have to be something small, like cd or pwd, but does such a program exist?
Honestly, it all starts going to shite after "hello world."
Shouldn't it be "Hello world."?
No. "Hello, world!" or you're doing it wrong.
What does perfect hello world even mean? It can be realized in many ways and none is the best way.
Computers can't even greet you in the real world. Its like some kind of sick joke.
"Dance, clanker! Dance!"
Hahahahah
The flight software for the Apollo moonshots.
It was fault tolerant but I wouldn't say it was perfect. There were plenty of "known issues", and the fix in production was basically, "don't do that".
It's on Github and has several PRs.
You may be interested by this https://en.wikipedia.org/wiki/Formal_verification.
Automotive engine control computers.
They just work, for decades and millions of miles.
There was a moment in time where maybe it was qmail:
https://en.wikipedia.org/wiki/Qmail
More on how it was accomplished:
https://blog.acolyer.org/2018/01/17/some-thoughts-on-security-after-ten-years-of-qmail-1-0/
Djbdns was excellent too, and ezmlm,.in fact all DJB's software was quality for its single purpose. The world moved on though, and you had to have your basic Internet servers just...do more
No; since every user defines the perfect program differently. Which should be the default behaviour(s)?
Software is always an ongoing conversation.
I wanted to say VLC because to me, it's the gold standard of fully working open-source software that just destroys the commercial competitors.
But it's not perfect only because society changes. New video formats forces VLC and open-source devs to adapt. Bigger video and new tech specs require VLC to update. If it wasn't for all those external needs, VLC would be perfect.
Did I also mentioned the many times rich companies wanted to buy VLC and they laughed?
Personally I prefer MPV but yeah both just wrap around FFMPEG
It’s worth noting that most commercial multimedia software is also more or less a wrapper around ffmpeg
TempleOS
The dev of left-pad made it perfect by removing it.
Of course: https://github.com/kelseyhightower/nocode
Ha. I still have an open PR on that.
Perfect code right here:
Is there a perfect building?
Probably not, since they exist in an environment — which is constantly changing — and are used by people — whose needs are constantly changing.
The same is true of software. Yes, programs consist of math which has objective qualities. But in order to execute in the physical world, they have to make certain assumptions which can always be invalidated.
Consider fast inverse sqrt: maybe perfect, for the time, for specific uses, on specific hardware? Probably not perfect for today.
Notepad.exe, pre-windows 11. Now it's something else entirely but still uses the name :(
Nah it was eternally annoying that it didn't support Unix line endings. Also there are clearly a ton of basic features that people want from lightweight text editors.
Notepad did what it needed to do, but it could be improved in a lot of ways
I kinda love snipping tool.
TeX. Best documented source, and last bug found was 12 years ago.
The 2021 release of Tex included several bug-fixes, so not quite 12 years:
https://tug.org/texmfbug/tuneup21bugs.html
See also the following list of potential bugs, that may be included in the planned 2029 release of Tex:
https://tug.org/texmfbug/newbug.html
That said, Tex is still an impressive piece of software
Thanks for the update, I somehow missed that.
To be honest, they didn’t make it easy to find
7zip?
7zip has had few CVEs and vulnerabilities
TeX?
Development is considered to be complete, and the version numbering is just adding a digit of pi. Last change was 5 years ago.
This was going to be my point. The idea that as the software slowly makes new releases the version number more and more closely approximates Pi
Yeah you probably can't do to much more to
pwdoryesor whatever (yeah I know about the silly optimisations). I think once you get much beyond that there are always more features you can add. Even for something likecd, people have made fancier versions with fuzzy matching and so on.LaTeX
Error: Too many unprocessed floats.
ugh, no way. It might do a fine job with typesetting, but the user experience is utterly awful and that's very unlikely to change because of design choices over 40+ years. If you don't think so, give typst a real try.
Semantic round brackets make typst impossible to use for me. If it had curlies instead it would be great.
Not sure about LaTeX, but TeX is widely considered to be almost "perfect" code.
TeX will be perfect after Knuth dies and the version number is incremented to π.
wget.
I don't think such thing as perfect software exist, only abandoned software. If the environment changes, then the software needs changes too.
Or a new software.
Or a rewrite in Rust.
I would have said Windows notepad but they screwed the pooch on that one and changed it.
notepad++
They recently experienced an self-update hijack. Plenty of room for improvement.
That was a server side compromise, but the update function could have detected it with more security features so you're still right.
Actually had a security vulnerability recently.
https://www.pcworld.com/article/3058647/windows-notepad-is-now-complex-enough-to-have-a-serious-security-flaw.html
Ski Free
For software to be perfect, can not be improved no matter what, you'd have to define a very specific and narrow scope and evaluate against that.
Environments change, text and data encoding and content changes, forms and protocol of input and output changes, opportunities and wishes to integrate or extend change.
pwdseems simple enough.cdI would already say no, with opportunities to remember folders, support globbing, fuzzy matching, history, virtual filesystems. Many of those depend on the environment you're in. Typically, shells handle globbing. There's alternativecdtools that do fuzzy matching and history, and virtual filesystems are usually abstracted away. But things change. And I would certainly like an interactive and fuzzy cd.Now, if you define it's scope, you can say: "All that other stuff is out of scope. It's perfect within it's defined target scope." But I don't know if that's what you're looking for? It certainly doesn't mean it can't be improved no matter what.
If you just need the functionality then fzf does (among other things) exactly that. Interactive fuzzy cd. If you use the shell bindings you can do
cd foo/bar/**<tab>to get a recursive fuzzy matching or you can do alt+c to immediately find any subdirectory and directly cd into it upon pressing enter. You can also use Ctrl+T to find and insert a path into the prompt.Thanks for the suggestion. As a first step, I set it up in Nushell with a
ctrl+tshortcut:Maybe I will look into more. :) I've known about
fzfbut I guess never gotten around to fully evaluating and integrating it.Nushell supports fuzzy completions, globbing, and "menus" (TUI) natively. Still, the TUI aspect and possibly other forms of integrations seem like they could be worthwhile or useful as extensions.
WinRAR free version
While WinRAR is pretty great, it has also had several severe security vulnerabilities over the years, including one last year:
https://en.wikipedia.org/wiki/WinRAR#Security
Which isn’t quite what you’d expect from “perfect” software
Pretty subjective but if you're looking for do one thing and do it well I'd go with some of the GNU core utils like you mentioned, vlc & ffmpeg for AV media, and sl for being a silly way to handle ls typos
A program that just prints "Hello World" to the screen and quits.
…that supports Unicode? Which encodings? Or only ASCII? Unicode continues to change.
I wouldn't be very confident that it won't change or offer reasonable opportunities for improvement.
[deleted]
Your sentence abruptly ends in a backtick - did you mean to include something more? Maybe “
wc”?Ed. It's the standard text editor.
https://www.gnu.org/fun/jokes/ed-msg.html
Nope.
I've thought about this before, and it gave me an interesting thought process: AI can't ever be good at doing a large project.
It has a hard limit. Not only is it not as good as us, the best it can ever do is as good as us, and we're not even good at it. That's all it can be trained on! Our garbage code lol
Windows event viewer... You open it, go to the toilet, to the shower, take a coffee, ... and only 2 more minutes later, it shows you the entries...
It's so perfect, they never had to improve it in decades.
/s
Logic gates?
Logic gates are hardware, not software
Depends on your definition of "perfect" and "improved". Is it perfect because it does one fundamental thing really well? Is it improved by adding new features?
I think what you're meaning is, is there a program that is ubiquitous (or at least works anywhere), will basically remain used forever because it does a fundamental job that will always need to be done, and it does that job in the most straightforward way possible that can't be made any algorithmically simpler, faster, etc. Probably plenty, honestly. Bitwise operations, arithmetic, fetch/store, etc. Though ubiquity/working anywhere gets rarer the higher you go from hardware. Even your suggestion of cd, for example, has to interface with an OS's file system, of which there are several common types. What it's doing is simple in concept, but will always be dependent on other programs for the file system.
Pretty certain cd and pwd have changed over the years. The kernel hasn't remained the same so the commands that use it wont and now we have faster methods to do various things like getting file data the commands that depend on it will change. Less quickly than something that is still gaining features but bit rot is a very real effect since every single part of software is in constant flux.
mcmaster.com is pretty close...
Do you exclude inventory management from that "will never change" so that that's only about software?
I imagine there will be new products to be listed.
Winamp! It probably had some bugs or security issues but functional it was perfect imo.
I would say git, tex, sqlite, Clojure, Steel banks common lisp are some of the candidates.
Perfect doesn't meen "not any bugs fixes or features needed" to me. I can't really define what it means to me...
Does IRC count ?
Didn't IRC have major insecurity issues?
I can't remember why IRC died.
It never died
The original one? Because there's numerous extensions to it. I wouldn't be confident it won't evolve further.
emacs can only be improved no matter what but it should count
As a vim user, I agree that it can only be improved.
Pkzip version 2.04g
Ehhh, for curl there is a few features they're working on (like better websocket support), and I'm sure there's lots of optimizations that could be made, given how complex a project it is..
Some time ago I used haproxy, a software load balancer. I remember that I found an issue which was that it could start with an empty configuration or something similar. When I reached the owner repo it was stated that there were found nu bugs for years of heavy use.
Anything I've ever written....
..JK I suck ass
Some Quines maybe?
Ericsson's AXD 301 has achieved a NINE nines reliability (yes, you read that right, 99.9999999%)!
yes
Htop
Btop?
Many might disagree, but imo vim is the perfect text editor for a command line interface. It's just so simpel and does exactly what I need it to do without doing anything unnecessary
Vim has some pretty messy design... Starting at some of the action quirks and ending at vim9script
Never heard of vim9script, what is it. I must admit I don't use it for a lot of super complicated tasks just regular yaml and file editing. At for that it's perfect imo
Vim9-script is a bespoke DSL introduced in vim 9 which was to replace vimscript (the old config language) It was recieved as a bit wacky with its support for classes among other things.
neovim is a drop in replacement for vim that fixes the issues that bother me with vim
Might install that then in the future, if I remember it. Sudo apt-get install vim is just so ingrained in muscle memory
not sure why your getting downvoted
Nit: vim is a visual editor. It has a text interface, but it's not a command line interface.
An example of a command line text editor would be sed.
I know it isn't a cli but a text editor that you can use in a terminal, if there's any other difference i got wrong feel free to correct me