This one was kind of meandering. I think a little tighter focus would have made the episode better.
Two thoughts:
People generally don't care about the details but I have seen some people get caught up in the details just enough to freeze and stop learning and being productive. It takes just one more layer to learn to end someone's journey.
I don't remember what the lynchpin comment is referring to. I got sick just after recording this episode so I don't have all the context loaded in my head.
The discussion was about you somehow writing some code either as open source or in a company and then being obligated to maintain it and it being a burden. You guys mentioned some log4j and some other products.
My point is that open source authors don't owe anybody anything. If you don't want to maintain it anymore, don't. Look at boltdb for example. If somebody values it they should pay you to maintain it. If they are not paying they don't value it. i guess somebody took over boltdb, forked it and life goes on for everybody. It wasn't a lynchpin at all.
I'll say one more thing that might be unpopular.
In every team you need different types of people. You can't have a basketball team full of Michael Jordans, you need a Dennis Rodman and a Scottie Pippen and a Steve Kerr etc to form a championship team. You need those "nine to five" devs who can sit down and plow through the tickets and get stuff done. Who don't want to re-architect the code or change how things work or even care about all that. You need unproductive juniors, you need crazy thinkers, and you need nose to the ground get crap done devs. As a manager it's your job to put this team together and to make sure they work as a well oiled machine. I don't care if every member of my team is constantly learning new and esoteric things. Some should but honestly most don't need to at all. If I have a codebase to maintain that's making money for the company the last thing I want is to rewrite it or re architect it or whatever.
No one owes anyone anything, correct. There is hesitation to put things out there in public because there will be people creating issues, treating it load bearing, or just being mean in comments. That hesitation prevents people from wanting to contribute or write open source code. Then there's the opposite mentality where the maintainer expects payment for their work even though it was released for free.
I don't think it's strictly always true that if someone doesn't pay for something it's not valuable. Most people don't pay for Linux or Git and those are quite valuable to many people. Heck, most people don't pay for a programming language and we make a living with it.
Agree that a good team is well diversified in both experience and skill.
If we value it then we should pay for it. Somehow, some way. I think the reason people don't pay is because they just don't value it that much. If linux went away they would switch to something else, if go went away they would switch to rust or whatever. Of course some companies are invested in the success of Linux and Go and that's why they pay for it. We are just freeloaders :)
I think paying for something with money is one way to show that you value it but that doesn't strictly mean you value it. I pay money to ride the train but I don't value it, it's just the most efficient for my time which I value more than the train.
Spending time with something is another way to show you value it. One can argue that's "paying" with your time. Point is I don't think everything of value needs to be traded for money.
And yes, of course when things go away there's an opportunity to replace it with something else to fill that void. Doesn't mean the original thing wasn't valuable.
There's this post about how profit/produce is distributed in one version of a hunter economy, and it makes me wonder if software development could map to this: https://unintendedconsequenc.es/borrowing-an-arrow/
That was an interesting read about passing the heroism to the next layer of abstraction essentially.
What's the parallel in software? Do we pass our glory to the programming language creator? To the hosting provider of our source code? To electrical engineers?
(I'm asking rhetorically, but it's a good thought experiment.)
Some sort of improved profit/resource sharing with our dependencies? And not just software libraries and compilers, but all the way out to the real world
I wonder how much of a crisis the world would be if gigantic corporations and billionaires didn't bargain their suppliers (water, electricity, governments, etc) down to 0% margins or worse
Here is a vision to consider.
A software delivery mechanism based on a blockchain like database. You put your packages there and dependencies are fetched from there. This would solve a lot of problems because packages would be immutable and ownership would be verifiable so hijacking packages for nefarious purposes, clear tracking of uploads etc.
Each author sets a price for their software or package. You pay when you fetch it. If you think it costs too much you use something else. If people like your free package you can charge more for the next version while the people can continue to fetch the previous version for free.
Immutable content-addressed packages are a great idea
It doesn't really need block-chain though, any package repository that exists today could add this as a feature
I'd also love repeatable and reproducible builds, so we can tell which commit in the package source produces the distributed package
in order to guarantee immutability you need an immutable data store. IPFS would be a great baseline you could build something on top of.
Provided you also have repeatability and reproducibility, you can trust any vendor offering a content-addressed API for packages
Isn't there a license component to this? How does one prevent someone from paying for a package, copying it in to your own free package or cheaper package, and offering back to others?
Copyright law already exists
There's no technology solution for copying that isn't awful, especially because only a human court can say what is and isn't breaching terms of copyright
So, sure, there's a licence/law angle here
Last updated: Apr 04 2025 at 01:15 UTC