frontpage.
newsnewestaskshowjobs

Made with ♥ by @iamnishanth

Open Source @Github

Small business AI lagging, one channels Sherlock Holmes knocking out grunt work

https://www.cnbc.com/2025/06/24/small-business-ai-use.html
1•Bluestein•54s ago•0 comments

Ask HN: Alternatives to Headspace Sleepcasts?

1•dot1x•59s ago•0 comments

Why Factories Are Having Trouble Filling 400k Open Jobs

https://www.nytimes.com/2025/06/23/business/factory-jobs-workers-trump.html
2•geox•6m ago•0 comments

Logo Mashups (2020)

https://www.olivierbruel.com/2020/07/logomashups/
2•gaws•6m ago•0 comments

Trust takes time (2024)

https://ruben.verborgh.org/blog/2024/10/15/trust-takes-time/
2•smj-edison•6m ago•0 comments

Divorce Kings of the Caribbean

https://story-bureau.com/divorce-caribbean-style/
2•bryanrasmussen•8m ago•0 comments

Bezos 'forced to move Venice wedding party'

https://www.telegraph.co.uk/world-news/2025/06/23/protest-venice-huge-banner-jeff-bezos-wedding-tourism-tax/
2•Bluestein•10m ago•0 comments

The same solidjs codebase to build our AI coding tool for many platforms

https://www.usejolt.ai/blog/a-solid-approach-to-building-client-apps
3•carloskelly13•10m ago•0 comments

Making electronic dance music in 1990 with budget home computer [video]

https://www.youtube.com/watch?v=6OaBkvwx7Hw
2•tie-in•10m ago•0 comments

Korean students seek 'digital undertakers' amid US visa social media screening

https://www.koreaherald.com/article/10515737
2•djoldman•10m ago•0 comments

Structural and functional characterization of human sweet taste receptor

https://www.nature.com/articles/s41586-025-09302-6
2•Bluestein•12m ago•0 comments

The Résumé is dying, and AI is holding the smoking gun

https://arstechnica.com/ai/2025/06/the-resume-is-dying-and-ai-is-holding-the-smoking-gun/
3•pseudolus•14m ago•0 comments

A War Thunder Player Leaked Classified Military Info (Again)

https://www.gamespot.com/articles/a-war-thunder-player-leaked-classified-military-info-again/1100-6532669/
3•speckx•15m ago•0 comments

Scientists breed mushrooms to build versatile substitutes for comm materials

https://phys.org/news/2025-06-nature-toolkit-scientists-mushrooms-versatile.html
2•PaulHoule•15m ago•0 comments

Companies Are Suing Honest Reviewers and It's Going to Get Ugly [video]

https://www.youtube.com/watch?v=RNonfByE9xc
3•LorenDB•15m ago•0 comments

Early US Intel assessment suggests strikes on Iran did not destroy nuclear sites

https://www.cnn.com/2025/06/24/politics/intel-assessment-us-strikes-iran-nuclear-sites
5•jbegley•17m ago•0 comments

Show HN: Rotta-Rs, Deep Learning Framework in Rust Release 0.0.3

https://github.com/araxnoid-code/ROTTA-rs
3•araxnoid•17m ago•0 comments

Practical tips to optimize documentation for LLMs, AI agents, and chatbots

https://biel.ai/blog/optimizing-docs-for-ai-agents-complete-guide#12-the-human-element-ai-as-a-tool-not-an-end
2•dgarcia360•18m ago•0 comments

Forbidden secrets of ancient X11 scaling technology revealed

https://flak.tedunangst.com/post/forbidden-secrets-of-ancient-X11-scaling-technology-revealed
18•todsacerdoti•22m ago•3 comments

Subsecond: A runtime hotpatching engine for Rust hot-reloading

https://docs.rs/subsecond/0.7.0-alpha.1/subsecond/index.html
3•varbhat•23m ago•0 comments

Watermarking Autoregressive Image Generation

https://arxiv.org/abs/2506.16349
1•fzliu•24m ago•0 comments

Bridging Cinematic Principles and Generative AI for Automated Film Generation

https://arxiv.org/abs/2506.18899
4•jag729•26m ago•1 comments

Omakase Software

https://twitter.com/b___ence/status/1937219611000254524
2•srbhr•26m ago•0 comments

ts-wordle - An implementation of Wordle written in TypeScript types

https://github.com/alexbckr/ts-wordle
4•alexbckr11•26m ago•0 comments

A Remote Shell for Embedded IoT Devices

https://blog.golioth.io/a-remote-shell-for-embedded-iot-devices/
1•hasheddan•28m ago•0 comments

OpenAI Designed a Rival to Google Workspace, Microsoft Office

https://www.theinformation.com/articles/openai-quietly-designed-rival-google-workspace-microsoft-office
1•anorak27•30m ago•0 comments

Multi-vector retrieval as a fast second-stage reranker

https://www.pinecone.io/blog/cascading-retrieval-with-multi-vector-representations/
3•amallia•33m ago•1 comments

Amazon aims to reach 'millions' more small town customers

https://www.geekwire.com/2025/amazon-aims-to-reach-tens-of-millions-more-small-town-and-rural-customers-with-same-day-delivery/
1•eligrid•33m ago•0 comments

Show HN: A crypto and dividends dashboard I made for my baby CEO

https://mattiasassets.com
1•ang3l1n•35m ago•1 comments

Cloudflare Containers – Open Beta Launch Event Recording

https://containers.cloudflare.com/
8•StanAngeloff•37m ago•2 comments
Open in hackernews

Writing toy software is a joy

https://blog.jsbarretto.com/post/software-is-joy
333•bundie•4h ago

Comments

akkartik•3h ago
Ha, these "toys" are quite ambitious. Here are my joyful toys: https://akkartik.itch.io/carousel/devlog
Swizec•3h ago
Toy Software is a lot like working on your bike/car/boat/whatever.

Working on your bike is fun. Working on the bike you need to ride to work tomorrow is stressful.

I miss writing toy software. It’s fun. But inevitably I want to use said software and that’s where the trouble starts. You find all the bugs and none of the time to fix them.

unshavedyak•3h ago
I also have more "working software" interests than i have time and energy. Many of them have a ton of mundane boring details i've done a thousand times before. I'm actually a bit excited that i can work on what i want to work on.

With that said it's a challenge and a chore on its own to curate what "AI" writes. So it's definitely not all roses.

Disclaimer: I'm still early in the experimentation phase. We'll see if i hold these opinions in a few months.

jona777than•3h ago
I recently wrote my own invoicing application. I got wrapped up in the joy of adding the features I wanted. Many of these features come at a premium monthly fee for a big named product.

I needed to get an invoice out in a timely fashion. As much as I wanted to use my app, I found certain kinks I needed to work out (with styling, adding addresses, etc.) -- This was where I realized what you have articulated.

At some point, it becomes better to prioritize the "fun" in working on my bike, and the "usefulness" of the daily driver bike.

In doing so, perhaps the fun/usefulness of each converges over time.

pjc50•3h ago
I used to self-host my email. I don't any more, for exactly this reason. And of course this applies to every other "just do it yourself!" enthusiast appeal. I actually want to delegate it to someone who does it full time.
ryandrake•1h ago
Strange example, because self-hosted email has been pretty much setup-and-forget for me. I’ve been hosting my own email for several domains on a $5 VPS for over a decade and it’s largely just hummed along, without needing babysitting. Very rarely, some ISP’s spamblocker gets a little too squirrelly and I have a brief deliverability issue, but those are rare and easy to resolve.
bee_rider•2h ago
I dunno. Working on a bike you want to use to ride to work could be stressful if it is your only bike, you need it to get to work, and your manager will be really mad if you don’t show up to work one day. If there was any slip available it wouldn’t be so bad.

Actually, I really like this analogy because

1) We can’t really work on non-trivial fixes for our cars because they are too complex

2) We’ve totally structured our living situations around these over-complex beasts

3) Sometimes they do just break down at random, and it becomes a mini-crisis for everyone involved, which can’t really be resolved without missing a day of work to go to a professional

4) The bike is in exactly the same situation, except you can actually fix most bike problems yourself with a little kit

And yet, it is seen as a serious adult thing to have a car, instead of a bicycle.

Some thoughts:

Outside of, like, customer service, most places are throughput-oriented and it doesn’t even really matter all that much if somebody misses a day.

If we really cared about “uptime” of employees, we’d all be living in bicycle range of our jobs, and able to fix our bikes. Maybe there’d be a bus route as well.

Karrot_Kream•1h ago
As someone who's stuck to owning a single bike for over a decade (tho I will probably change this in the coming year) for both athletic rides and commuting, I'll say the "it is seen as a serious adult thing to have a car" can sometimes make having a single bike worse.

If my bike flats and I'm out of tubes and I have a busy day planned, I have to take it to a local bike shop but those generally close pretty early. If I miss the window to take it to an LBS then I'm SOL. With a car there's generally a developed enough ecosystem that I can get a roadside assistance type service to put a spare on the car until I can actually get my car into a shop.

This is a good analogy for SaaS vs using a tinkerer tool. A tinkerer tool often can be customized exactly to your needs. I can work on my bike at 10 PM in my garage after dinner as long as I have the parts. But sometimes your tinkerer tool is going to leave you working all night or you'll be SOL. But SaaS is generally a full-time job for other folks. Sure you pay money, but there's fewer situations you're SOL.

(Personally when my bike is inop and I need to head to work I use transit.)

socalgal2•18m ago
> If we really cared about “uptime” of employees, we’d all be living in bicycle range of our jobs

And then reality hits. You're married and your partner's job is on the other side of the city. You just bought and house and now you want to switch jobs but you'd be limited to only jobs in biking distance. eTc....

I bike to work (was 4 miles, now 2), but it's unrealistic to expect people to be in bicycle range of their jobs.

FirmwareBurner•2h ago
>Working on the bike you need to ride to work tomorrow is stressful.

How about working on your bike that other people also work on daily? That's work.

DustinBrett•1h ago
This is why I love building a personal website. It's like a live playground.
asicsp•3h ago
Dupe: https://news.ycombinator.com/item?id=44284291 (117 points | 8 days ago | 28 comments)

Seems like the link changed, and thus not caught by the dupe detector.

rubicon33•3h ago
> In 2025, the beauty and craft of writing software is being eroded. AI is threatening to replace us (or, at least, the most joyful aspects of our craft) and software development is being increasingly commodified, measured, packaged, and industrialised. Software development needs more simple joy, and I’ve found that creating toy programs is a great way to remember why I started working with computers again.

Sad but true. I especially feel that comment about losing the most “joyful” part.

danielbln•3h ago
I have more joy than ever working on toy software while using LLMs. My joy comes from building things, thinking architecture, components, creative solutions that create something new and exciting. Hand-setting lines of code is NOT what brings me joy personally, it's a means to an end. Dancing with agentic LLMs is so much fun to me. I can however understand that if the code part is what brings you joy, then we're probably not moving in a direction that pleases you. For those of us who like to build, first and foremost, it's heaven.
klabb3•3h ago
> AI is threatening to replace us (or, at least, the most joyful aspects of our craft)

I don’t like this either but every time I use LLMs it feels like we’re talking about completely different things. It moves waaay to fast and makes bad decisions at every turn, if I accepted them all it would be complexity deadlock within a week tops. Pooping out boilerplate sure but then you’re generally holding it wrong anyway (or there’s an opportunity to automate things). Plus even if you don’t have the time to automate it, sure, but then are you enjoying the act of shitting out your own boilerplate?

Out of the things I consider fun the LLM is at best a good rubber duck. It needs constant hand-holding, sometimes polluting the context window (and physical space) with a barrage of poorly written code. Code is bad, we’re trying to minimize it. No? At least that’s how I think: what’s the minimum* amount of code that can solve this problem?

*: minimum in a brain complexity sense, not char count. They correlate strongly though

thomascountz•3h ago

  GameBoy Advance game (difficulty = 3/10, time = 2 weeks)
Wow!

  Physics engine (difficulty = 5/10, time = 1 week)
What??

  Threaded Virtual Machine (difficulty = 6/10, time = 1 week)
I—

  POSIX shell (difficulty = 4/10, time = 3-5 days)
Ok... I can't believe this person :D

But regardless of the time estimates, I appreciate the idea!

Jtsummers•3h ago
I was going to make a similar comment. This list is fine, but the times are all over the place. If they removed those estimates it'd be a much better list. If a hash map takes 3-5 days for someone, they aren't making a threaded VM in 7 days.
tuveson•2h ago
I have to assume the author listed these times based on how long it would take for someone to follow along with the blogs that they linked to, which demonstrate stripped down simple versions of these things. Like the POSIX shell example just implements a few basic things, but leaves out a lot (and says so).
simonw•2h ago
This person is a game developer who works on an open source voxel RPG https://github.com/veloren/veloren - take their estimates with that in mind!
rybosome•3h ago
This is quite an impressive list, and many of the things ranking low in difficulty for the author would have been quite high for me. It's definitely inspiring, makes me want to dust off a toy of my own.

That said, I feel the conclusion on learning with LLMs deserves some more nuance. It really depends on how you use them.

This is a terrible prompt for learning:

> Implement this solution for me

This is an AMAZING prompt for learning:

> Please give me an overview of ELF. Focus on the highest level abstractions, more of the 'why' than the 'how'

Certainly one can argue that it takes something away, in that you did not have to conduct the research yourself whenever a question occurred. However, if you are engaging in honest intellectual work (i.e. really thinking), then having a Socratic teacher always ready to discuss your questions is a profound accelerant to the learning process.

roughly•3h ago
One of the best things that I’ve done for myself, career-wise, came during a 6-month sabbatical between jobs. I had a bunch of projects that I wanted to do, but I kept finding myself stymied by scope creep - when you don’t have any constraints, it’s hard to decide how big a project should be, and the projects would grow to these massive unfinishable beasts.

I decided to constrain myself to one week per project - whatever I could get done in a week was what I’d do for this project. The experience of going from zero to something useable in either a new language or a new framework or a new field in a week was enormously confidence-building - learning that I was actually pretty good at this whole programming thing and breaking through a bunch of walls I’d run into previously in my professional career gave me an incredible amount of trust in myself to be able to take on new challenges that really helped me when I was looking for a new job. At the same time, it reminded me what I loved about programming - in a week, I was able to build something that solved a problem I had or that someone I knew had, and I got to do so in a creative and intellectually challenging fashion.

If ever you find yourself in a position to take a couple months off between jobs, skip the leetcoding or whatever else and just build some toy projects - you’ll be amazed how much you already know.

jonator•3h ago
I've done the same, but with AI generating a lot of the boilerplate, and helping generate automated tests, has accelerated this process considerably.
hn_throwaway_99•3h ago
I would just add that gen AI can actually be a fantastic aid when you're building some toy projects just for yourself.

I am primarily a backend engineer, though I am capable on the front end, just not particularly fast. I am especially slow at the voodoo that is CSS. In the past, I would have been turned off from doing some end-to-end personal projects because I know I would have been bogged down just battling CSS for hours and hours (it's particularly problematic that I'm slow at CSS but also a stickler for how I want things to look). With AI tools I can literally just say "make it pretty". It gets me about 85% of the way there, but importantly it gets me to the point where it puts in all the styling framework and then I just have to fix bugs/edit/tweak it, which goes very quickly.

So now I've found myself much more likely to build personal projects because I know I can get past things that in the past felt a bit like quicksand to me.

whartung•2h ago
It's a balance I find.

On the one hand, the machines can spin up these bridges over unfamiliar code chasms.

But on the other hand, you (at least I) have no investment in the code. No familiarity with it. No "skin in the game" when I can tell the AI to just redo it.

One way around that is by using the "Chat bots as search engine", and then, rather than cut and pasting stuff into your project, type it in by hand. Even if you're just straight up copying it, by typing it in you have a bit more connection to it. When I do that I can better see the unfamiliar patterns rise out of the code. It's much better for me than just reading it.

Also gives me opportunity to tweak it as I like, which can break things, which can teach me things.

Mind, I've been advocating this "type it, don't paste it" philosophy for years and years, for any code snippet found in a book or tutorial or wherever. It's just now with the bots, the code is more tuned to our exact use case, and the incentive for moving it over is less.

But I find grabbing a blob of code, pasting it into my project, and getting errors so that I can tell the bot whats wrong is not particularly satisfying.

Watching Claude figure out its own errors even less so. (It's very cool to watch, just not very joyful to me outside of "wow, that's cool".)

On the other hand, I have no problem pasting a snippet back with a "what exactly is this doing here" to get better explanations of what I'm seeing.

roughly•2h ago
The joy of personal projects is they can look like shit! You'd also be surprised how much you can learn by just screwing around with something for a day. A big part of the whole exercise for me was getting out of my comfort zone and learning that I can learn. I'm primarily backend as well, and came up through the ops side (as opposed to formal CS), which always led to a lot of imposter syndrome, so a lot of the benefit came from just putting myself in an uncomfortable position and just staying there long enough to work my way through it.

That said, my goal for this was to wear the hair shirt (and also this was before GenAI was really a Thing) - if you just want to make something neat, absolutely vibe your way there.

alganet•2h ago
A good reality check is: if a stranger asks you about a specific part of your toy project, would you be able to explain it?

If you can't, it means there's something there you don't understand, and you lost an opportunity to learn. Of course, this is also true for reusing libraries and stuff.

Within a job, what matters is the _team learning_, and it's roughly the same idea. At least one person in the team should be able to explain anything the team does. Trusting it to an AI puts the whole team in a precarious situation, even if it is something as simple as a CSS layout.

josefresco•1h ago
> So now I've found myself much more likely to build personal projects because I know I can get past things that in the past felt a bit like quicksand to me.

I'm the opposite of you (my strength is in voodoo) but my experience is the same. Whereas before I'd spend 2-3 weekends getting bogged down on elements that aren't my strengths and never complete, now I can easily whip up a mostly functioning web app (just for me) in just a few hours.

neogodless•1h ago
In my younger years, classic ASP + SQL was easy, and I had IIS + SQL Server set up on a server at my house. And I could write HTML/CSS/JavaScript.

Deployment was... run update scripts, push ASP files via FTP.

Now I know there are newer ways to do things, and I'd love to set up CI/CD in my personal life, but every time I want to do a "toy project" I get hung up researching and thinking about my own personal software development life cycle.

What you choose for hosting and deployment for your toy projects?

roughly•55m ago
I've got a VPS and domain I've had for a long time - for most of these, docker compose + the VPS did the job just fine. I was in the same boat - I'd fallen behind on a lot of the ops stack, and project setup wound up being a tar pit for a couple projects before I got frustrated and just said "Fuck it" and did it the dumb way, which wound up being the correct approach.

I found the trick with the personal projects was to pick the thing I was trying to learn with that project and focus on that - if I was trying to learn React, don't also try to learn kubernetes or lambdas or anything else. You really have to be comfortable with your project kind of sucking for all this to work.

So I'd say if you want to learn proper modern deploy + CI/CD + etc, take a project where you already know the rest of the stack (hell, make it Hello World if you have to) and use that. Keep things simple and in scope, get something stupid working, and then iterate to make it better.

tayo42•1h ago
Unfortunately the leet coding is key to getting the next job
roughly•48m ago
For what it's worth, the two tricks I found for leet-code interviews were 1) do the simple stupid thing first - get something _working_, and then make it good and 2) explain what you're doing and what you're thinking about to your interviewers. I'm still not Great at the leet-code style, but you can get a lot of the way there with some basic knowledge about algorithmic design and complexity and data structures. In general, I've found finishing the problem and being able to talk coherently about it trumps finding the ideal solution.

(I also code like a psychopath - I'm constantly rewriting what I'm writing while I'm writing it, so a) slowing down and b) telling interviewers what I'm doing and why made that look less chaotic.)

I'm also not the person you want to hire if you're looking for deep algorithmic knowledge, though - I've got a long career of delivering high impact systems and solutions, but if you want someone to rewrite the index parsing algorithm in your mature database software to minimize lookup speed, you've got the wrong guy.

zffr•41m ago
Out of curiosity, how did you end up with 6 months off between jobs?

I would love the opportunity to take ~6 months off, but I feel scared that if I just quit, it might take me a longer time to find a job again.

roughly•25m ago
I'm single, rent controlled, and was working at a FAANG-ish company.

The fear was real, for sure, but it honestly made a huge, huge difference for both my mental health and my employability afterwards. I also got to spend some time figuring out what I actually wanted to be doing, so I had a much clearer picture of where my skills and interests aligned after, which helped the search as well.

ravenstine•3h ago
One thing I've learned about building toy software projects or even just small personal software (stuff that's actually useful) is to avoid implementing flexible configuration engines. I used to fall into this trap where I thought I should make my software to be configuration-centric so that it would be usable for others in case I decided to make my code FOSS. The problem with that is making a configuration engine is a lot less efficient than just writing the code to do the damn thing. I've almost never shared any code outside of small libraries that were very low in complexity, and I wasted a lot of time writing code for other hypothetical people when I should have just been writing it for myself.
dockercompost•3h ago
A rite of passage! :D
bob1029•2h ago
> The problem with that is making a configuration engine is a lot less efficient than just writing the code to do the damn thing.

http://mikehadlow.blogspot.com/2012/05/configuration-complex...

It took me a solid decade to accept these lessons. I cannot build a product that even remotely competes with things like Visual Studio and .NET tooling. How many hours would it take a solo developer to recreate a debugger experience that anyone else could be bothered to look at for more than 5 seconds?

The hardest part of building something configurable is the UI/UX. The moment you step outside of the host language, your tooling support goes to zero. Sure, you can pick other popular languages as the language of configuration (SQL, python, Lua, etc.) and piggyback off those ecosystems. But, you still have to build a way for a "non programmer" to visit all of the patchwork sites of "configuration" in a coherent way. Telling the business people to go edit a folder full of .py and .sql files will probably not be received well. Wrapping all of this with a fancy web interface doesn't make the problem less severe either (it makes it substantially worse).

If you have a way to build/deploy your product in <60 seconds from source, worrying about elaborate configuration and customization architecture seems extremely idiotic to me now. The best path I've found is something approximating a common library and a per-customer executable that consumes it and implements the expected contracts. Each customer's project lives in a subfolder on the same monorepo. The power of the hierarchical filesystem is tragically understated throughout our industry.

declan_roberts•3h ago
This is one thing I don't get about the LLM people. For most of us who are professionals, writing software is not very hard, and it is in fact fun!

I don't need to let a computer write my software. I already know how, and I enjoy it. I need the computer to do the hard part (gathering requirements, speaking with stakeholders, etc).

Software is a joy.

marginalia_nu•3h ago
There are several sources of joy in programming. Some lean more toward the process and exploration of the problem domain, others more toward the outcome and impact.

I had a shift of perspective at some point where I realized that software wasn't just fun to create, but you can solve problems with it, including your own, which is incredibly rewarding and kinda feels like wizardry.

Ultimately I find both to be enjoyable, though in terms of career and life outcomes, focusing on solving real problems and producing tangible outcomes has had more of an impact than noodling with neat implementations that nobody but me cared about.

Turns out if you solve your own problems (or just publicly work toward solving them), there are often other people who also struggle with the sam problems, who may throw money your way ;-)

heroku•3h ago
Reinventing existing software has 0 merit. If you cannot be creative enough to invent new things, you shouldn't bother working.
simonw•2h ago
That's rubbish. Reinventing existing software as a learning exercise has plenty of merit.
coolThingsFirst•2h ago
No it doesnt. Build new things or dont waste your time.

Learning exercise lol.

amunozo•2h ago
How are you supposed to learn to invent new things if you don't know how existing things work?
coolThingsFirst•1h ago
There's ZERO room for innovation in the projects suggested.

Wanna do some creative thinking? Read some books, learn how normal people think. Explore latest datasets. That's where the meat is. 98% of what you read online has been written by super uncreative(boring) people. They have no imagination whatsoever, IQ is well statistically speaking not too flattering.

Internet is ran by the bottom. It's slop by the bottom, for the bottom. So you need to hang out with creative people.

Tech people write the most boring blog posts because it's aimed at getting hired. Nothing of substance is shared. That's why gwern stands out like a sore thumb. The majority of human beings are incapable of creative thought.

bowsamic•1h ago
Novelty is not the only value. Slop comes from your attitude: people like you who think that things must be new to be worth something
didip•3h ago
Big time! Almost all of my interesting knowledge came from toy projects I made to solve my own problems (or zero problem solved but it was fun so I did it anyway).

For example, I wanted to know if I can make 1 Kubernetes cluster span multi region, multi cloud. So I slapped TailScale for networking, replaced etcd with multi-region PostgreSQL Aurora, and span the Kubelets between my Raspberry Pi, Digital Ocean VMs, and AWS EC2. And then as the "customer app", I run CockroachDB, rqlite, and tiDB on it (one at a time, I don't want to burn money for this).

It was janky, zero SLA, I likely mis-tuned all the databases, and cost a bit of money :(. But it totally worked, all the db nodes can discover each other. I was satisfied and that's enough.

Another example would be writing my own Raft-backed database, similar to the ToyDB Rust project posted here. Is the DB useful? No. But it is so much fun and I learned a lot.

My AWS S3 bucket and private Git repo are a graveyard full of toy projects. My own Dropbox clone, Pinterest clone, Delicious clone, subset of Google Maps clone, etc. etc. are all RIP in there.

FirmwareBurner•2h ago
>I wanted to know if I can make 1 Kubernetes cluster span multi region, multi cloud

Can I ask what you had running on that cluster?

didip•1h ago
As of right now? Nothing important. If I want to use it day-to-day, then I have to care about SLA, then I have to be the sysadmin of that thing.

Not exactly fun :)

What's interesting is that the TailScale network allows the local daemon be exposed on the internet with small settings change. Pretty revolutionary for personal/home IoT projects.

otoolep•55m ago
rqlite[1] creator here, happy to answer any questions.

If you're interested in writing Raft-backed databases you might be interested in my talk at GopherCon 2023. It walks through doing exactly that, step by step: https://www.youtube.com/watch?v=8XbxQ1Epi5w

[1] https://rqlite.io

falcor84•3h ago
I love that attitude! This is essentially my preferred answer to "what would people do in a post-AGI world when they don't need to work any more".
oconnor663•3h ago
> Perhaps you’re a user of LLMs. I get it, they’re neat tools. They’re useful for certain kinds of learning. But I might suggest resisting the temptation to use them for projects like this. Knowledge is not supposed to be fed to you on a plate.

I get where this is coming from, and I even agree with it today, but I also want to tag it as "don't cache this opinion too hard". It's interesting to notice when and how our advice for getting help from AI is different from our advice for getting help from other humans. It would be kind of odd, wouldn't it, to put a paragraph at the bottom of a blog post that said "by the way if you have friends who are expert programmers, I don't recommend asking them for help." I think there are two clear reasons that feels odd: 1) expert friends can actually answer your questions and get you personally unstuck, which is huge, and 2) expert friends usually understand why you're doing what you're doing and that they're supposed to help do it yourself instead of just doing it for you.

One thing I bet few people have tried (because I haven't tried it myself) is actually asking an LLM to guide you like an expert friend would, instead of just spitting out code to solve your problem. Maybe they're bad at that, I wouldn't be surprised. But if so, I bet in a year or two they'll be amazing at it. It might be good to build the habit of clarifying what sort of help you need, instead of assuming an LLM will give you the wrong kind of help?

leeoniya•2h ago
> "by the way if you have friends who are expert programmers, I don't recommend asking them for help."

AI is not an expert programmer [today]. and it doesnt take an expert programmer to arrive at that conclusion.

superb_dev•2h ago
I also bet your expert programmer friend is give you pointers and not writing the whole thing for you
hbn•14m ago
Call it whatever you want, it helps me get unstuck when my dependencies aren't getting along, or when I need to figure out what's wrong with my usage of an API I'm not familiar with, or why my build won't startup based on the code and the vague error message, etc.

I don't care if it's a human or a robot telling me, I just want to get unstuck and I've been getting unstuck more since the advent of LLMs than in the rest of my programming career. Digging through bad documentation and Googling for old form posts of similar-but-not-quite-the-same-issues was always the worst part of programming to me, and I'm glad there's a tool that finally solved that problem.

amunozo•2h ago
I try to do exactly that. I phrase it as using LLM as teachers instead of interns.
bitwize•1h ago
I don't trust Dissociated Press on steroids as an intern; why TF do you think I'd trust it as a teacher?!
Vegenoid•2h ago
This is by far my most common usage of LLMs, and they’re good at it. Sometimes you have to be intentional about preventing it from being sycophantic and just telling you that you’re right, through a system prompt or by phrasing the question such that it’s comparing ideas neutrally instead of comparing “your” idea to some other idea.

It feels like Claude and ChatGPT have both become more sycophantic over the past months.

fragmede•1h ago
Tell it to ask you questions
vinceguidry•3h ago
I'm writing a shell right now in ruby after seeing a few other folks doing so and looking at the current state of shell development and not finding anything I really liked. It is indeed, a lot of fun. Using Vidar's really quite nice text editor to do so is equally pleasurable.

https://github.com/vidarh/re

Got a few PRs for you when you get to this, friend.

hu3•3h ago
I've written a ton of throwaway toy applications for personal use.

The tip I can share is: publish them on GitHub.

You'll find out some of them are useful to a lot of people.

I have multiple toy repos with 20+ stars and one with 200+ stars.

Just put one screenshot and simple instructions to run on README.md, no need to write a manual.

As simple as `npm install && npm run start` is enough instruction for most.

The screenshot is important tho.

simonw•2h ago
This is also a great way to stand out among other candidates in the resume-review stage of a hiring process.

The number one question I have as a hiring manager is always "can this person actually write code". A GitHub profile with 2-3 projects with multiple commits to each one answers that question really well. I won't filter out people who don't have that - lots of great engineers have never published code before - but the people who do have that are much more likely to get picked for the phone screen.

thrtythreeforty•1h ago
The converse is actually a negative signal for me. If you list a GitHub profile on your resume, but that GitHub profile is a ghost town consisting exclusively of "test repo please ignore" and "freshman-year assignments I was required to fork from professor's repo," that tells me you don't have an above-average understanding of why you add something to your resume.

If you don't have an impressive GitHub profile, that's fine. To your point - the absence of it is not a penalty, and the presence of a good one is a very positive signal. But the presence of one that turns out to be a dud is a negative.

simonw•1h ago
It partly depends on the level I'm hiring for. A junior candidate with a GitHub profile full of obvious tutorial projects still helps me skip putting them through FizzBuzz. A senior candidate with a ghost town could reflect poorly on them.
bbkane•2h ago
I've been using vhs ( https://github.com/charmbracelet/vhs ) to script gif creation- really showcases CLI workflows if you're demoing multiple commands.

Examples: https://github.com/bbkane

padraigf•2h ago
Thanks, I'll try it. I have a few things knocking around.
notepad0x90•2h ago
I have a couple of projects like this and I'm not sure if they'll ever see the light of day. I enjoy writing code, simple as that. Only a small part of my day job is coding, but honestly, it's more like a hobby than anything.

The whole thing with getting people to like your work, using it for clout or padding your resume has an appeal to it that I won't dismiss, but all that takes the fun out of it.

I just don't have much else I actually enjoy in life, so ruining it with peer-pressure, chasing clout, impressing people, worrying about career prospects is a buzz-kill. I used to think that if I am passionate about something like this and I get really good at it, maybe it will help my career and prospects but the real world doesn't work that way. it sucks the joy, fun and passion out of you if you let it.

All that to say it is perfectly fine to like coding for the sake of enjoying it and nothing more. Others play a sport (or watch it), work on arts & crafts, or raise chickens or whatever, I code. I am not particularly skilled or great at coding either, I just enjoy it, and that's it.

If you have fun coding, be protective of your joy! even if you don't take it to the extreme like I do. that's my only point.

ethinton•2h ago
I love this take, and I’m reminded of the important idea that while we all are encouraged to be productive, our own joy is also an important thing for us to produce.
kgwxd•2h ago
I've abandoned tons of toy code but I have 1 thing I wrote in a weekend for myself that I've been mostly blindly using ever since. I just realized while typing this that it's been 8 years. It's a Firefox add-on that I only published to the "store" because running a local-only add-on is a PITA.

It takes regex(s), searches attribute values and/or inner text, and applies a given CSS rule to elements that match. The UI is awful (regex escaped to be inside a json string escaped to be inside a textarea all parsed by javascript) but I know how to use it.

It can probably be used for many things, but I just use it to set visibility: none on elements that link to sites I don't ever want to see (facebook, twitter, linkedin, popular pay/register-walled sites, etc). For example, my HN and reddit views just have blank lines where links any of those sites would normally be. For the most part, I add a site once, and forget they ever existed (except when their CEOs do awful things).

dwh452•2h ago
What's sad is how difficult it is to write software today. In the old days your dad could buy a C64 and cobble together an application. It should be vastly easier to do the same kind of thing with vastly better building blocks today. Why can't some Grandma drag and drop some widgets and have a recipe manager with sharing features amongst her friends and family?
01HNNWZ0MV43FF•2h ago
Here's a few disorganized thoughts in good faith

1. Because half her friends and family are on iOS, and that means fighting the App Store. (This is a social problem essentially, in fighting Apple)

2. Because networking is hard. How would you have shared recipes with a computer in the C64 days? Email? BBS? (There are partial technical solutions to this, but they would require people to run something like friend-to-friend overlay networks)

3. Because most stuff happens in web browsers and that means pay-to-play, or vendor lock-in, or using AWS free tier and being a programmer. (Ass, grass, or cash, nobody hosts for free. Friend-to-friend networks may also help with this)

4. Because a recipe manager with sharing is best implemented as just emailing your recipes to your friends and storing them as txt files locally. Anything more complicated is beyond the scope of a Visual Basic-style drag-and-drop WYSIWYG anyway

5. When was drag-and-drop enough? The widgets need code behind them to save and open files, right?

6. You might be kinda onto something, and the longer I write async code I more I think the programming world is ready for another big pruning. Like when structured programming said "No goto, no long jumps, if-else and exceptions is all you need", we might be ready for "A single control thread which never blocks and never awaits, and delegates to worker tasks, is all you need until you are building some C100k shit"

jlarocco•2h ago
> Why can't some Grandma drag and drop some widgets and have a recipe manager with sharing features amongst her friends and family?

Because there's no money in it.

hathawsh•1h ago
I think the main difficulty is deployment. Grandma wants that recipe manager to be available to her family 24x7. How can she deploy it easily for free or very low cost? If there were a modern Hypercard, I think the key to its success would be making deployment extremely simple, reliable, and safe.
Karrot_Kream•1h ago
There are platforms like Observable and Repl.It that just let you deploy code/data pretty quickly.
bundie•49m ago
> Observable

> Repl.it

Sorry, Grandma has never heard of those fancy-pansy platforms.

fragmede•1h ago
NextJS with Neon on Vercel has a capable free tier, and there's enough training data that LLMs are decent at it. If Grandma is that interested in building an app, I'm sure she'd love to spend a few hours with a grandkid to set things up and then being taught how to vibe code (and also how to call said grand kid for help).
fragmede•1h ago
How hard did you look? WordPress has a few recipe maker plugins if you didn't want to code anything. Just install one and password protect the whole thing, and then teach (and write instructions for) Grandma to use it.

In the age of powerful computers, you can use Hypercard on an emulated Mac, you can use any number of hypercard-clones out there. She can just use Google slides. etc.

dakiol•2h ago
> Perhaps you’re a user of LLMs. I get it, they’re neat tools. They’re useful for certain kinds of learning. But I might suggest resisting the temptation to use them for projects like this. Knowledge is not supposed to be fed to you on a plate

Am I the only one using LLMs as if they were a search engine? So before LLMs I was searching on Google things like "pros cons mysql mongodb". I would read the official documentation of each db, forums, blog posts, stackoverflow entries, etc. It was time consuming on the searching side. The time it took to read all the sources was fine for me (it's learning time, so that's always welcomed). Now with LLMs, I simply prompt the same with a little bit more of context "pros and cons of using mysql vs mongodb when storing photos. Link references". So, I get a quick overview of what to keep an eye on, and the references are there to avoid relying on hallucination.

It's true that sometimes I go ahead and say "give me a data schema for storing photos metadata in postgres. I wanna keep X in a different table, though" (or something like that). But I do that because I know very well what the output should look like (I just don't wanna spend time typing it, and sometimes I forget the actual type that I should use (int vs integer?)).

Viliam1234•2h ago
> Now with LLMs, I simply prompt the same with a little bit more of context "pros and cons of using mysql vs mongodb when storing photos. Link references".

In near future, companies will probably be able to pay lots of money to have their products come up better in the comparison. LLMs are smart enough to make the result seem "organic" -- all verifiable information will be true and supported by references, it will only be about proper framing and emphasis, etc.

pietmichal•1h ago
This was already a problem in a world without LLMs. Reputation is the only human mechanism that mitigates this.
Toritori12•1h ago
tbf, Google has pretty the monopoly on search engines, the rest is way behind (even after enshitification). LLMs seems to be a more competitive space.
teaearlgraycold•18m ago
They’re already talking about llm search optimization as the new SEO.
imnotlost•2h ago
This work great for me too, when learning something new the LLM brings in all sorts of perspectives and contexts I don’t know about yet.

It pulls in info from the docs, forums, code samples, shows me how things are connected, and may even suggest why something is good or bad.

Plenty of opportunity to look up docs I didn’t even know about yet.

DanielHB•2h ago
My main use for LLMs is to ask it to give me some boilerplate configuration for some library/tool I am not very familiar with and then look up the docs for the options it spits out. Like:

"give me the terraform configuration for an AWS ECS cluster with 2 services that can talk to each other, with one of them available publicly and the other one private"

Occasionally to give some small self-contained algorithms, for example:

Give me a way to format the difference between dates as human-readable text. For example: 1 day, 16 hours.

amunozo•2h ago
I tell to myself to use them as "teachers", not "interns", i.e. ask them questions to guide my process or look for the sources of knowledge needed to understand or do something, instead of asking them to get things done (except tedious, simple tasks).
el_benhameen•2h ago
This plus easier search of poorly/not-at-all documented APIs is like 80% of my usage too. Besides that, a lot of “here’s my design for xyz system, am I a stupid idiot for using this architecture?”.
AstroBen•2h ago
Yup this is where 90% of the productivity benefits come from for me. Instead of needing to spend an hour scouring documentation I can ask an LLM and have an answer in 5 minutes
gherkinnn•1h ago
Same. By appending a ? to a query, Kagi returns a summary with references. Quick and easy.
JohnMakin•1h ago
This, and I use them for code review and rapidly generating prototypes that I heavily edit. Almost none of the LLM code survives usually. You could ask "Why dont you just write it yourself then?" but sometimes getting started with the skeleton of a working project is the most difficult part of it.
ryoshu•1h ago
I learned about window functions in SQL using an LLM. I hadn't written SQL in over a decade and never ran across them. It explained how they work and the trade-offs. It was great!
polytely•1h ago
It is nice when it works, but sometimes I run into trouble where I don't know a right word to put in the prompt to get the answer I'm looking for. I've recently been playing around with Raku and had a really cryptic type signature error and Claude was of absolutely no help because it didn't know about the interaction of Signature literals and 'Slurpy' sigils in method parameters. Only when I learned about it and included the word Slurpy in my prompt would it actually regurgitate the information I was looking for but at that point I already knew it.
rokkamokka•28m ago
To be fair, this isn't a new problem - many times I've wanted to find something but not even known what to Google for.
sailorganymede•1h ago
Nope, I do this too (most of the time.) I don’t like working on code I don’t understand. I have started to ask it to use a client API I’ve written to figure out how clients would work with the stuff I write though. It’s great.
captainbland•1h ago
> Am I the only one using LLMs as if they were a search engine?

I quite like the search-first LLMs like Gemini and Copilot for this reason. They give you links which you can use to verify the output and seem to be less prone to directing you to SEO spam than Google Search/Bing.

Although I do partly think that search engines today are delivering poor performance compared to what they delivered historically so LLMs are benefiting from that.

citizenpaul•1h ago
I think one of the major issues I (and others) have with LLM's as search is they are heavily biased towards outdated data. The other day I was trying to have it get me the most updated versions of X, X, X from an old project. I tried several providers and all of them without exception gave me an "upgrade" to an older version than was in the project for at least 1 item(by years). I'm sure they are choosing LTS releases over the new ones because that is most popular overall in a dataset. However no matter how "hard" I prompt they keep giving me those old ones over "latest"
carlhjerpe•43m ago
I do this. But the killer usecase for me is writing all boilerplate and implementing some half-working stuff keeps my attention on the issue which makes me able to complete more complex things.

A recent example is when I implemented a (Kubernetes) CSI driver that makes /nix available in a container so you can run an empty image and skip a lot of infra to manage.

I talked to it a bit and eventually it wrote a Nix derivation that runs the CSI codegen for Python and packages it so I could import it. Then I asked it to implement the gRPC interface it had generated and managed to get a "Hello World' when mounting this volume (just an empty dir). I also asked it to generate the YAML for the StorageClass, CSIDriver, Deployment and DaemonSet.

So LLM left me with a CSI driver that does nothing in Python (rather than Go which is what everything Kubernetes is implemented in) that I could then rewrite to run a Nix build and copy storepaths into a folder that's mounted into the container.

Sure implementing a gRPC interface might not be the hardest thing in hindsight, but I've never done it before and it's now a fully functional(ish) implementation of what i described.

It even managed to switch gRPC implementations because the Python one was funky with protoc versions in Nix(Python bundles the grpc codegen it's so stupid) so i asked it to do the same thing for grpclib instead which worked.

cdelsolar•2h ago
I love the article but disagree with the final point. It wasn't until LLMs came out that my toy projects have all been greatly upgraded with features and functionality. I simply didn't have time to do so before.
coolThingsFirst•2h ago
Waste of time, you wont impress anyone because there are no more software jobs left.

Go to gym.

01HNNWZ0MV43FF•2h ago
Who am I impressing at the gym? The weights have already been lifted
coolThingsFirst•2h ago
So you don't look like sh* that's more impressive than cranking out code that absolutely no one cares about. Especially things that have been done 100s of times.
z0r•19m ago
Please work out. But also please write software if you want to improve your skills.
coolThingsFirst•1h ago
udk what you're missing out if you aren't in the gym twice a week.
munificent•2h ago
An anecdote about how a toy project _really_ helped me out:

I work on Dart professionally. I've also been tinkering on a toy programming language that may never see the light of day. My toy language has gone through several incarnations but a while back I was working on adding algebraic datatypes, pattern matching, and exhaustiveness checking to it.

The canonical algorithm for exhaustiveness checking is this paper by Luc Maranget: http://moscova.inria.fr/~maranget/papers/warn/warn.pdf

When I first started dabbling in programming languages over a decade ago, I tried to understand that paper for weeks and just could not wrap my head around it. I don't have much of a formal CS background and that paper was impenetrable to me.

So here I am tinkering on my toy programming language and I run into again. I give it another try and laboriously implement it in my interpreter, basically doing a straight translation. I don't understand the code, but it seems to sort of work. So then I start refactoring it a tiny bit at a time into a style that fits the way I think about code. Eventually the algorithm sort of folds into itself and before I know it, I finally understand how it works. The end result was only a page or so of code, but my toy language had real exhaustiveness checking work.

Meanwhile, at work, I am working on adding pattern matching and exhaustiveness checking to Dart [1]. Exhaustiveness checking here is a much harder proposition because Dart has subtyping, unlike my toy language and the ML languages that Maranget's paper works on.

I'd been hacking away at an exhaustiveness algorithm for Dart based on a couple of papers about Scala's approach but they were sort of approximative and inelegant (in my opinion, maybe they are a great fit for Scala).

But once I understood Maranget's algorithm from implementing it in my toy project, it finally clicked for me how it could be adapted to work with subtyping in a sound, coherent way. I wrote it up as quickly as I could and (with a lot of additional help from a teammate to handle generics), that became the algorithm we shipped:

https://github.com/dart-lang/language/blob/main/accepted/3.0...

It wouldn't have happened if I hadn't coincidentally been working on a toy pattern matching implementation at home.

[1]: https://dart.dev/language/patterns

aldousd666•2h ago
I've done a lot of these kinds of projects. I got really sucked into a rabbit hole with the parser/interpreter/compiler that I was stuck (happily) in "I need to understand this so I will build one" mode. I eventually built a database server and query language for it. (for a business) This was in 2009, but I highly identify with his method of learning by doing for fun!
jekwoooooe•2h ago
I agree. It’s fun to just write code to solve problems or even for fun. I love go (it’s the best all around language and it’s not even close) so for fun I wrote a game engine and a small game that I might try to turn into an actual game. It’s good to keep fresh. I’ve also tried to do llm free days
ppqqrr•2h ago
Problem/Truth is that writing toy software is not profitable - that's not to say one must always work on profitable things; what i mean is that it's being kept unprofitable, because in a hyper-saturated monopolized attention economy, every piece of "toy" software that isn't a video game or a plugin to some proprietary app ecosystem is essentially an act of subversion, an attempted "theft" or piracy of what the Company considers its rightful property: the sum of all disposable human attention.
linsomniac•1h ago
>Perhaps you’re a user of LLMs. [...] But I might suggest resisting the temptation to use them for projects like this.

I agree. However: Your best bet is likely to build it by hand and then see if you can get an LLM to build it.

It is looking like we are living in a world where an important tool to have in your toolbox is going to be the skills and experience of working with the LLM/AI tooling. There are skills, knowledge, tools, tips and techniques that you need to develop to effectively use these tools, just like the honing you get from writing the code.

Over just the last half hour I did a brain dump of "hot tips" to a friend of mine who is just starting to use Claude Code to kick-start him.

The LLMs are REALLY good at writing small toy programs, and at the end of the day it's great to have little tools that you'll use every day.

_benton•1h ago
Possibly tangential, but I've really been enjoying writing software with very minimal tech stacks with no dependencies (or very few). Go works well for this, but really any language that lets you create a file and just start writing straightforward code is sufficient. As soon as I need to use some CLI to scaffold out a project with tens or hundreds of files, or pull in a ton of dependencies, I kind of check out. It's fine when you have a team and a big serious project, but in my free time I really just enjoy having a couple files of straightforward code and that's it.
josefresco•1h ago
Vibe coding via Claude has re-ignited my passion for fun, side programming projects. After a few false starts, I figured out the tooling, processes and in just a few weeks I've built several apps and I'm having new ideas consistently:

-Family calendar/weather dashboard

-Bluesky reader that allows you to hide posts you've "seen"

-Work PM dashboard to make time tracking more gamified and dare I say... fun?

-Chrome Reddit extension that hides posts after viewing for X seconds

-A WordPress plugin to replace a plugin no longer maintained

What I love and had to get used to was looking/using these apps and being happy with them being only 90%. Initially I had Claude make many UI enhancements but I learned to just let most stuff go and focus on the function and building new stuff, not refinement.

snarf21•1h ago
I struggle with Claude fixing a bug and not giving me the updated output. Like explicitly having to ask it for the fix 6 times while it insists the update is in the output. Did you ever have that happen?
rokkamokka•31m ago
Personally, I just fix the bug myself. It's way less aggravating for me than prompting back and forth many times.
dpkirchner•3m ago
I haven't seen this, unless I don't understand exactly what you mean. I can ask it questions about my code and get answers most easily if I explicitly say "don't write any code".
AutistiCoder•1h ago
I know writing "toy" software has exposed me to new tools I might not have otherwise even known about.

I can't afford much n the way of software, so I've been trying to learn to make do with FOSS.

bitwize•1h ago
Ever since Nintendo let the mask slip and got up to their old evil bullshit with the Switch 2 launch, I decided to dust off the solution my teenage self came up with: I'll just play the video games I write. Even if they're small and amateurish, they're worlds and experiences crafted personally for me. And I don't have to pay a cent for them, let alone put up with "key carts", DRM bullshit, or we-can-remotely-brick-your-console bullshit.

I'm sure I'll keep buying commercial games from companies with reasonable terms (GOG, maybe?). But writing my own is great fun. It'd be nice if someone else enjoys them, but they're mainly for my own enjoyment.

Oh, and I "vibe code" the old fashioned way: with a REPL and some chill tunes.

tanjtanjtanj•24m ago
What sort of evil bullshit did Nintendo get up to with the Switch 2 launch? I don't follow gaming news.
eliasdorneles•1h ago
I quite enjoy the spirit of the article, and I believe joy in programming has become even more important in the AI agent coding age we're leaving.

However, am I the only one finding those time estimates way too short?

I'm not the fastest programmer on Earth, but I'm not the slowest either, and I think most of those projects would take me a lot more time than those estimates, specially if I'd be working only 2-3 hours per day.

I feel most of those projects would take significant time researching and learning about the subjects, before even starting to code.

Example: recently I replaced my Pelican blog by my own hacky static site generator written in Odin, working 2-3h per day, it took me 2 weeks -- and this is a simpler project than many on that list.

sowbug•54m ago
Your project is vastly more specified than a toy project, because it has a real customer (you) who will expect it to work after it ships. That expectation is what separates toys from real tools.

I bet you could write a word processor in an hour. It might only add or delete one character at a time (no selections). It might persist only to a hard-coded "output.txt" filename. You might have to kill the process because there's no quit operation. But that would suffice for a toy word processor.

eliasdorneles•19m ago
Fair point, my example was indeed "shipped to production" and may not compare a throwaway static generator toy project.

I still think those estimates are off, because I think many of those projects would need significant research and learning time, possibly more than actually coding -- not to mention time spent troubleshooting when something goes wrong.

alanbernstein•1h ago
I agree with the sentiment in theory, but the time pressures of adult life make this difficult.

> What I cannot create, I do not understand

I suspect Mr Feynman would have phrased this a bit differently if he had first-hand experience with the modern front-end technology treadmill.

bowsamic•1h ago
If you're allowed! Apple says no
purplesyringa•1h ago
I'm surprised by the number of bad takes on LLMs in this thread.

LLMs spoon-feed you with information about how things are implemented. You are not supposed to know how everything works when you start these projects. You're supposed to try your best, inevitably fail, then research the topic and understand where you went wrong, then adjust your approach. If you know how everything works and just follow the tutorial, you won't know what makes other methods fail, and by proxy what makes the one you chose work.

Write a language parser with a regex. Find out that it can't parse recursive statements. You've now learnt that regex can only parse a specific subset of syntaxes. Try to workaround this by pattern-matching the most nested statement first. Find out that it blows up performance. You now know more about time complexity and know what to watch out for when you write a real parser.

Write a non-optimizing compiler from scratch. Find out that you can't make do with unsound optimizations because you can't keep track of what optimizations are applied where. Find out that implementing sound optimizations is hard because you need to track use-def chains. Then you'll understand why SSA is used. Find out that code motion is a mess. Learn about sea of nodes. Merge every optimization pass into one because you're unable to order passes right. Learn how e-graphs solve this.

Write a layout engine. Get stuck on being unable to define what a "width" is. Workaround this with min/max/natural widths, introduce binary search, etc. Learn how this stuff works in practice (this is something I haven't personally done yet).

They say we learn from mistakes. Please don't let the smart (or "smart", depending on how you look at it) machine stop you from making them. It's not a teacher and it doesn't know how to educate.

b0a04gl•43m ago
it's more of compression. fastest way to get 10 yrs of backend sense in like 3 weekends is build fake OS scheduler or just kv store with fs persistence. and the shortcuts your brain takes after that, scary fast. you just start seeing stuff everywhere. like oh this LRU cache is just dumb DLL with hashmap. or this parser is just recursive descent with some peek-ahead logic stapled on. and then you can't unsee it. you start breaking down every abstraction you touch. even prod libs look like toys.

also lol toy projects expose your defaults hard. how you name vars when there's no PR. how you layout dirs when no one's looking. do you even test stuff or just printf until it works. do you log or do you trace or just guess.

tayo42•2m ago
I'm always mixed on this. In the moment it can be fun. In the end when it inevitably feels useless, idk it feels bad. Like I spent a ton of time on something and get some knowledge out of it. It doesn't make my job better and I guess doesn't improve my situation much. My rust sub-directory feels like a digital closet of rpis collecting dust.

The things I find fun writing and learning about and the tools I use to do it are so disconnected from anything i do professionally.