Over the years I’ve noticed that I’m often operating in various “modes”. Some of this is related to depressive episodes, but often it’s just a more neutral ebb and flow. I’ll have a week where ideas are flowing and connections form easily. I’ll have a week where it feels like I can’t engage so deeply - like my system is cooling off after exertion.
And this is one of the reasons writing things down has been such a useful tool, and starting with a spec is something I now do religiously after spending the first half of my life just diving in haphazardly (and often not getting very far).
Those ultra productive days are often enough to get a pretty decent spec written; something I can flesh out in far greater detail than I could with a productive coding day. Those down days are now bolstered by the thinking of a version of myself that was firing on all cylinders, and solved many of the problems I probably don’t have the brain power to tackle on the fly when I’m tired and stressed for life reasons.
I feel like I’ve squandered really good trains of thought by telling myself “I’ll remember this and write it down later”. So I always start with writing. Future me always appreciates it.
j_bum 155 days ago [-]
Your comment resonates with me.
I totally agree about writing things down being useful. I also like the author’s timebox plan as well. I’m great at writing specs to define what I want to build, but my hobby project timelines are nonexistent. I think I’ll give this a try!
TrainedMonkey 155 days ago [-]
Do you keep a journal? Things like sunlight, diet, schedule, socialization, can have a big effect.
haswell 155 days ago [-]
I do. These days, I'm all in on Obsidian. It's been a great tool for thought that ebbs and flows with me, and helps me see how things have been going.
Without peeling the whole onion, I've been dealing with a series of autoimmune issues in combination with complex PTSD. I'm working with some really great people to address these issues on all fronts and I'm much better these days than I've been in the past, but it's a work in progress that I'll have to manage for awhile.
A huge +1 to the importance of core habits. Focusing on this has been a key aspect of recovery.
notjoemama 154 days ago [-]
But also, don't over optimize. For example, if your routine or schedule is mostly working but you feel like you need some less structured time, don't schedule it, just go out and do that. Don't work it in for the purpose of being more "productive" later.
I've been feeling like the software industry is over optimizing engineering output just a smidge beyond what is morally acceptable. Not enough to raise red flags about cruel and unusual, but just over the line of "it's ok to be human". Maybe that's just me and I'm someone who doesn't need a Pomodoro timer or multiple "just for an update" meetings to get work done. But maybe it's also upper management trying to turn business school theory into something real. You're not a number or a widget or for God sakes a brand. You're a person. Remember that.
0x008 154 days ago [-]
These pointless meetings are usually a result of the fact that people feel things are going better if they are a little bit involved, even if their involvement is not actually contributing to the solution.
Also it’s a lot about lack of trust in large orgs.
TrainedMonkey 153 days ago [-]
Feeling important is definitely a thing, at my old place we've had a saying - meetings are a practical alternative to real work.
0x008 152 days ago [-]
I think its not always that people want to feel important. It's more like the subtle change perception: Whenever you are part of a discussion, you have the feeling that it's going better, just because you are there.
jdswain 154 days ago [-]
I've come to a similar conclusion lately. I used to spend a lot of time jumping on my latest idea, researching and even writing a bit of code to get started. I'm much better off writing my ideas down, hopefully in a form where I can consolidate the ideas into a few projects, but even if it just stops me wasting time on an idea that I'll lose interest in soon, it's worthwhile.
On the other hand, I've got one large ongoing series of projects that are relatively pointless, and that is the whole point of them. I'm learning from them and I don't have the pressure of completing anything (although I would really like to). From time to time they have been really important for my mental health, and I value them for that.
I'm also quite aware now that I need to feel achievement to keep me motivated, and if I have a plan and can check off an item on that plan then that counts as a good day. Work doesn't always give me that sense of achievement, so having something else that does can be really valuable.
pstorm 154 days ago [-]
This resonates a lot. For years, I would dive in for a week or two, sometimes I would make it to a few months. Lately, I've just been telling myself no, to keep focus on my start up, but it sometimes feels like I'm squandering this spark of energy you described. I absolutely love your approach of doing the planning in that initial burst rather than just getting some part of the idea working in a day or two.
I think those ultra-productive days earlier in my career account for some of the best learning, but now, over a decade into software engineering, focusing on the planning aspect seems much more prudent.
copperx 154 days ago [-]
That's me. I even have days that I'm completely enthralled in a project and work 12 hours straight in it. And the next day I don't care about it.
I'm sure it's human nature. But there are some beasts out there like Don Knuth, Torvalds, DHH, that seem to have unlimited stamina. They are the people who advance stuff.
cloverich 155 days ago [-]
I resonate strongly with this. I found something pretty simple thats been helping me lately though. I uhh, i just force myself to keep working on it until its done. Grind it out. Work on it especially when i dont want to. Ditch those little relaxing moments for it. Wake up early to find time for it. Its torture.
And also therapeutic. I see the incompleteness of my original idea, or plan. I see that the things i declare important feel less so when i have to keep working on it. I start to permanently discard essays, apps, ideas, as i appreciate what it would really take to do them. I say no to myself far more often. I become more disciplined in my work. And more disciplined in my play. I start making more realistic plans and exit points because im not a masochist.
Ultimately i let it change me. I obviously wont grind like this forever. But the grind teaches me, and changes me, into the kind of person that finishes things. Which is mostly about learning to be more selective and less impulsive, and knowing when to play and when to put things down and truly let them go.
wonger_ 155 days ago [-]
+1 to being selective and ruthlessly deleting time-draining ideas.
I'm not sure I can force myself to keep working, though. Self-imposed deadlines don't help me either. It seems like a willpower problem, like going to the gym.
What's helped me is making projects alongside a small group of fellow programmers. Seems like the author has done something similar with a hackers co-op chat and with Recurse. External accountability is my most successful motivator.
8n4vidtmkvmk 155 days ago [-]
Where do you find these fellow programmers? Are they working on the project with you, or their own things?
I work with oodles of software developers and almost none of them program on the side.
wonger_ 155 days ago [-]
Yeah, finding them is difficult. Lots of Internet wandering. Mainly finding links through people's blogs.
A few open-source communities have forums/channels like #showcase, where it's easy to drop a screenshot and get feedback. I'm thinking of the Discord chats for Textual and p5.js, for example, if your project uses their libraries.
Or if you're the party planning type, perhaps consider forming your own group. Even ~6 people meeting once a week for a month works well.
Everyone works on their own things.
turtledragonfly 155 days ago [-]
> I start making more realistic plans and exit points because im not a masochist.
Or, you start to enjoy the pain, because you enjoy the result. But then your mind does its illogical associative thing and you start to just enjoy the pain on its own. Now you're a masochist!
I jest, but only some. Ask me how I know ...
FrankyHollywood 155 days ago [-]
How do you know? :)
turtledragonfly 154 days ago [-]
Fine I'll bite :Þ
Have a poorly-ordered braindump:
In my life, I've kindof developed a rule of thumb: if it's the more difficult path, it's probably the better path.
That heuristic isn't always correct, but I find it to be pretty good. Problems can arise when I follow it blindly, though.[1]
I've just generally found that a lot of good things in life are on the other side of a barrier, and crossing that barrier usually involves effort and pain.
So, it starts to develop into an association of "if it's hard/painful, it's probably leading somewhere good."
And that starts to develop into "seek out pain/difficulty."
Ironically, I'm also someone who values being comfortable in my own skin.
But I feel more comfortable doing something painful for my own (masochistic?) reasons than doing something painful for an external goal.
----
I do feel like there's often an element of masochism in people who excel at some activity. Plenty of stories of top athletes or musicians etc. who do it for their own reasons, and not to win a trophy or acclaim. Getting good at something is generally a painful process of dealing with failure over and over. If you don't have a stomach for that pain, you'll give up. If you grit your teeth and force your way through it, you may become competent, but probably won't excel. If, somehow, you enjoy that pain and are drawn to it, then you will put in the hours to keep getting better and better, unboundedly.
But that's just one perspective.
The grandparent comment seems more like someone who likes to "keep their eye on the prize," whereas I'm more of a "do it because I enjoy[2] it" person. I suppose if you are motivated strongly enough by some external goal, it could push you through the hard times, too. And if the goal keeps moving, you might keep pushing, unboundedly, too. Not my path, though.
Also, I find taking a hard path is sort of a Great Filter for other people; there will be fewer others on that path (I'm fairly solitary, so it suits me), and what people there are will have something in common with me.
----
[1] When I hear about people trapped in abusive relationships, trying to "fix" it rather than leaving, I feel like I understand them somewhat. At the same time, some relationships are worth saving, even (especially?) in the hard times, so being able to navigate the pain rather than run away can a strength, too. Depends on the situation.
[2] with "enjoy" being somewhat perverse, at times (:
FrankyHollywood 154 days ago [-]
Thx for sharing!
For a long time, I was lazy, and took pride in quoting Bill Gates "I choose a lazy person to do a hard job. Because a lazy person will find an easy way to do it."
I thought I was smart, but after years I discovered I became more lazy, and had never developed any deep knowledge on matter.
"if it's the more difficult path, it's probably the better path", I like that :)
halfcat 155 days ago [-]
> ”i just force myself to keep working on it until its done.”
I’ll admit I’m jealous of this. Most days at 5pm I’m just hitting a groove, but kids need to eat, need family time, etc. I’d love to grind from 8am-11pm but rarely have that luxury.
0x008 154 days ago [-]
Just to give you maybe another perspective: I think part of what makes the work interesting is that I can’t do it all day as I please. So when I have time to work, I am super motivated. As unsatisfying as that might be.
Whenever I have holidays and weekends or unlimited time and want to work on something I usually don’t follow through.
a-french-anon 155 days ago [-]
I don't want to be too abrasive, but family people unironically complaining (almost humble-bragging in some cases) about their lack of time to others who may or may not have had the same opportunities on that front (e.g. no marriage prospect, possibly loveless life) can be very tiring.
tl;dr TRIGGERED
Philpax 155 days ago [-]
Please get therapy.
bartonfink 155 days ago [-]
I don't want to be too abrasive, but people without families or hobbies tend to fuck up work life balance for the rest of us. It's very tiring dealing with people like you who do nothing but work and bitch about how they don't have anything else going on.
reichertjalex 155 days ago [-]
Yeah, definitely. I know this is a somewhat controversial opinion, but I do think there's value in developing the muscle around "grinding it out". I think the tricky part (depending on your personality type) is knowing when it makes sense to give up and move on to something else.
munificent 155 days ago [-]
Reposting an old Reddit comment of mine that I think agrees with much of this article:
I'm in my 40s and for most of my life I had an unending series of unfinished projects that I felt guilty about. Today, I am able to finish some stuff, including some pretty large, hard projects. Better, I don't feel guilty about the stuff I don't finish.
The trick for me is to be deliberate and mindful about why I'm embarking on a particular project.
If it's because I want to feel good by:
* Sharing something with others.
* Accomplishing a difficult, challenging task.
* Proving to myself that I can do something.
* Getting the social cachet of being a creative, productive person. (Maybe this is shallow, but who doesn't like to feel impressive in the eyes of their peers?)
Then the goal of the project is the product it and I focus my attention and discipline on it. I try to have as few of these as possible—like only one at a time—so that my willpower is not diluted.
If it's because I want to feel good by:
* Improving a skill.
* Exploring an unfamiliar domain or learning something new.
* Relaxing by tinkering on something I like.
Then the goal of the project is the process and I don't feel bad about not finishing. The real treasure is all the stuff I learned and did along the way and there is no real destination. I can have as many of these as I want because there's no real failure mode here. They're all recreation.
Once I got more honest and clear with myself about my goals for each project, I started to be able to finish the ones where that mattered and stopped feeling bad about the ones where it doesn't.
turtledragonfly 155 days ago [-]
> Better, I don't feel guilty about the stuff I don't finish.
I think this is key, and demonstrates the real personal growth, which is more valuable than being able to finish things per-se.
It's the old saw: "what's the hardest thing? To know oneself."
There's a lot of eagerness to jump on bandwagons and do whatever the motivational speakers recommend, but you're not going to find the answers specific to you until you look inside yourself.
Anyway, in short: I agree (:
I'd also add: the reasons and mindset can change not just from project to project, but from day to day as well. Very context-dependent (at least in my experience).
thehappyfellow 155 days ago [-]
So you’re saying in order to finish projects I just need to learn how to be honest and clear with myself? Seems like a reduction to a harder problem :)
Joking aside, I came to believe that various form of procrastination are a response to pursuing wrong or unclear goals - even when I don’t state them clearly, my brain still somehow knows that I’m not aligned with what my goals should be. Good job, brain!
munificent 154 days ago [-]
> Seems like a reduction to a harder problem :)
Yes, but there may be other positive benefits to solving it as well. :)
0x008 154 days ago [-]
For me this sounds a lot like a distinction between being intrinsically motivated (“because it is fun for me”) and extrinsic motivation (“I want to achieve something in the outside world”)
g4zj 155 days ago [-]
I genuinely consider two of my greatest accomplishments to be building a game and composing a song.
Neither are very impressive, but in both cases, I ended up having to simply decide I was done and stop working on them. I could continue making changes indefinitely, adding little improvements and such every day, but they were also complete as they were. Once I learned to be okay with that and move on, I learned what finishing a project really meant (or at least one form of it).
maroonblazer 155 days ago [-]
‘Art is never finished, only abandoned’ - Leonardo Da Vinci
jappgar 154 days ago [-]
I've composed and released several albums and it's still exactly as you describe.
With any art, a certain amount of polish is desirable but too much will destroy the essence of the work.
I will find myself actively making a song worse... and then go back a few versions to find the peak.
tkubacki 155 days ago [-]
Can you post game link ?
ChrisMarshallNY 155 days ago [-]
I had a teacher once, at a training seminar, that kept repeating the phrase "We need to know what 'done' looks like."
"Done" is often a compromise. There's more that can be added, there's still burrs and "rough spots," but we need to declare it ready to go out the door, and be prepared to fully support our release.
I've been shipping software for my entire adult life, and have had to embrace this philosophy.
Just the other day, I stopped working on a "play" project that I was working on, because it was a rabbithole, and not worth the agita of fixing the fundamental design issues that I was encountering (an unfortunate by-product of my "Evolutionary Design" process, is that it's quite easy to fall into Wonderland, and I need to learn to understand that I should just let the rabbit go).
mandeepj 155 days ago [-]
> "We need to know what 'done' looks like."
As much hate as Agile gets here at HN because of its wrong usage by many people, one thing that Agile recommends is setting up a 'Definition of Done' within your team before even starting your very first sprint.
ChrisMarshallNY 155 days ago [-]
It’s much older than Agile. The Japanese company I worked for, did that.
They would start at the end, and work backwards.
They hated Agile.
mandeepj 155 days ago [-]
> It’s much older than Agile. The Japanese company I worked for, did that.
How old? The origin of Agile goes back to the 1950s in Japan
randomdata 154 days ago [-]
Agile is from 2001. What you seem to be thinking of is the Toyota Production System. It is quite possible that TPS inspired Agile, but to claim that it is Agile is like saying that GPT is from the 1960s (because it shares some resemblance to Eliza).
ChrisMarshallNY 154 days ago [-]
Yeah, the Toyota JiT stuff, but the company I worked for is a 100+-year-old engineering corporation, and didn't do stuff in no new-fangled, 1950s-kid-playground way.
But the term "Agile," is a lot more recent (and US-based). I rapidly learned never to use that word within earshot of my managers. Sort of like saying "California Roll" in a traditional Tokyo sushi joint.
randomdata 154 days ago [-]
> I rapidly learned never to use that word within earshot of my managers.
Stands to reason. Agile, in the Manifesto sense, defines the considerations to consider should managers be eliminated from the picture. Nobody is going to be comfortable knowing that their job is on the chopping block.
ChrisMarshallNY 154 days ago [-]
It's not really that.
It's because that company is laser-focused on Quality (they have a well-earned reputation as one of the highest-Quality manufacturers in the world).
They believe that Agile promotes bad-quality work, because it promotes a lack of Discipline and checks and balances (which are necessary components of high-Quality production).
I disagree, but many of the Agile proponents exemplify low-quality work, because they deliberately eschew Discipline and checks and balances. They use Agile as "Santa Claus for young developers," as opposed to what I believe is Agile's focus on delivering high-quality, useful, and timely, product to end-users.
We need more examples of the Agile process doing really good work.
randomdata 152 days ago [-]
> They believe that Agile promotes bad-quality work
Whether or not that is true, why would they care? They'll be gone.
> Agile's focus on delivering high-quality, useful, and timely, product to end-users.
I tend to agree. As managers are removed from the picture, there is no manager to hide behind. You're working directly, each day, with those who are going to hold you accountable.
> We need more examples of the Agile process doing really good work.
To be fair to the managers, are there any? Even the C3 project that gave birth to Agile is widely regarded as a failure.
ChrisMarshallNY 152 days ago [-]
> Whether or not that is true, why would they care? They'll be gone.
Well, it’s not true (in my opinion), but try telling that to people who have been successfully shipping world-class optical gear, for a century.
I have learned that, if we want to introduce new paradigms, it’s a very bad idea to do so, by telling folks that the way they do it now, is wrong (even if it is).
That experience taught me a great deal about working within a super-high-Quality context. The personalities and opinions are very powerful, and most of the senior folks involved, got there, by being very, very good at their jobs. A true meritocracy.
They won’t react well to having some wet-behind-the-ears yank, come in and tell them that they are wrong, when that’s clearly not the case (in their eyes).
I’ve found that, if I want to introduce change, I need to begin by respecting the context and the people, and using that as a substrate for change, as opposed to suggesting it be removed, wholesale.
Or start my own company, which is what a lot of folks do, these days. It’s not an option that’s available to many. Also, those companies often encounter problems that have nothing to do with the tech, and everything to do with the inexperience of the founders (like reckless behavior).
randomdata 154 days ago [-]
Agile says nothing about defining what is done.
Scrum uses the exact "Definition of Done" language, though. I suspect that you are really thinking of it...
Which is humorous given what you said about wrong usage of Agile. Case in point?
154 days ago [-]
reichertjalex 155 days ago [-]
> "We need to know what 'done' looks like."
Ugh, yes... I wish I had internalized this sooner!
daelon 155 days ago [-]
> agita
Interesting word, thank you!
ChrisMarshallNY 155 days ago [-]
Lots of folks of Italian ancestry, around here.
I hear the word used, often.
turtledragonfly 155 days ago [-]
Always glad to see articles discussing an emotional side of software development (:
I do disagree with this claim (though later points temper it a bit):
Why is it important to share your work with the world? First, because
there's practically no downside, and very, very high potential upside.
There is a big downside: as the author states, finishing/releasing is hard and time-consuming. You only get one life. Every hour spent doing that stuff you won't get back. So, not a direct cost, but an opportunity cost. Personally, I find it important to acknowledge this and face it head-on, rather than waving one's hands and saying "oh, there's basically no downside." Though I admit that the latter can be a useful self-mind-hack to get the ball rolling. But first you decide what you want to do, and why you want to do it, and then you tell yourself whatever lies you need to help it get done (:
The "why is it important..." question is really critical to motivation, at least for me. A person should give that question honest thought and an answer that rings true to them.
I agree about the therapeutic aspect of putting things out into the public.
Though I don't plan to publicly share all of these proactively, just
knowing that they're publicly viewable helps give me a stronger sense
of accountability. I'm curious if it will make a difference.
Just getting things out of one's mind, and into the world (even if nobody sees them), can be important (helps my sanity, at least).
Even just the "rubber duck" sense of imagining someone might see it, can catalyze thoughts in a way that wouldn't otherwise happen, too.
Then, having people actually see them is another layer, and can be humbling and educational.
Also, apropos of nothing, this article made me think of the (mis-)quote:
We do these things not because they are easy, but because we thought they would be easy!
Good article (:
jauntywundrkind 155 days ago [-]
You cite this part of the article,
> Why is it important to share your work with the world? First, because there's practically no downside, and very, very high potential upside.
And say,
> There is a big downside: as the author states, finishing/releasing is hard and time-consuming. You only get one life. Every hour spent doing that stuff you won't get back
Working in public (or working at least from the assumption it will soon be made public), is something folks should try really hard to get into. It should be a default expectation for yourself. The cost is mostly mindshift!
Once you can change your default position, it no longer feels like a cost to work in public. Every action brings release.
nilirl 155 days ago [-]
My biggest tip: Have a system you can rely on even when you're struggling. Take the magic out of progress.
Use curiosity and excitement when you can but don't let them be the only way you can work on something.
Some practical strategies I've written about:
- How to prevent stagnation while building products alone [0]
- Multi-Perspective Note-Taking: Mastering focus as a solo-developer [1]
Very philosophical texts. These are good reads. Thanks for sharing!
ryandrake 155 days ago [-]
I really disagree that releasing a project publicly is a necessary step to deem something done. I have so many projects in my src/ directory that are (in my mind) finished, but that I will never release to the public. I wrote them for my own education and entertainment, not as things that I think the rest of the world would benefit from. And certainly not as a way to build some kind of (ick) -personal brand- among the open source community, or to give me some sense of accountability (to whom?). I don't need GitHub stars or social media thumbs up or hacker news upvotes to measure the worth of something I made.
shepherdjerred 154 days ago [-]
I just put these in a big GitHub repo so that I consider them shared and therefore finished.
>I think there are two strategies that would help a lot: 1) writing a spec (i.e. a plan) upfront, and 2) timeboxing the project by giving myself a deadline.
I would like to add another possible strategy: watching a number go up.
Recently I have started tracking the books I am reading. I track the page number I am currently on via a dashboard I made in Obsidian, which displays a %-read for each book. I have found that "number goes up" gives me just enough of a dopeamine hit to encourage me to pick the books up more frequently than I had before.
reichertjalex 155 days ago [-]
Ooh I like that! I definitely feel that in some sense when I have a good streak of commits per day, where I don't want to break the streak. Or for workouts, it's suuuper motivating to see the number continue to go up.
But oftentimes when a project or essay is incomplete, it's hard for me to think of a good "number" to track that would be a good motivator (since i.e. lines of code, or the number of words in a draft, don't necessarily feel like a good proxy for progress all the time). I'm curious if there's a metric that would work better?
jschulenklopper 154 days ago [-]
My approach for finishing projects: team up with a Finisher. I found one at work, and we became good friends along the way.
I'm a typical Starter, and all of the side projects we've been working on together were my idea. All of the projects that we completed and released were solely because of his endurance, discipline and focus. And his constant reminders to not start a new project before the current one was done.
mxuribe 154 days ago [-]
You really lucked out, and ended up with a great partner there! If i am honest with myself, on most things i would say i'm 75% the starter and 25% finisher...but at current $dayJob, oof, i'm surrounded by all starters (and not that great at starting either), but not a single finisher. Congrats to you! :-)
pablomendes 154 days ago [-]
One thing that works well for me is going working-to-working. Get a simple, de-scoped, incomplete, probably crappy version done end-to-end. Now it's not about finishing, it's about improving. And if it was worth building in the first place, it will beg for improvement. And then it's easier to just keep turning the crank, working-to-working.
SCUSKU 154 days ago [-]
In Pragmatic Programmer, this is called the "tracer bullet" approach. Basically just another word for end-to-end, but with the emphasis that by completing a slice end-to-end you'll get feedback much faster (as in the feedback tracer bullets provide when shooting a target).
breakingcups 154 days ago [-]
So... MVP?
mncharity 154 days ago [-]
Hmm, how about... End-to-end: "can really implement?". Tracer-bullet: "can adjust aim?". MVP: "can make user happy?". Though there's more to each.
So then market fit exploration benefits from tracer-bullet, but you might do iterative reimplementation instead. And it might be overkill for a one-shot market test. MVP is largely orthogonal to end-to-end - "Submit button emails founder who does the thing by hand over breakfast" is fine MVP but isn't very end-to-end. And a non-MVP non-product end-to-end can be tracer-bullet or not. A soundly architected low-debt end-to-end yes, a hackathon high-debut "to adjust, rewrite", or a throwaway end-to-end exploratory spike, no.
jmbwell 155 days ago [-]
I sometimes battle perfectionism for various reasons. Someone pointed out that it can’t be perfect if it isn’t even finished, so why not add “done” to what it means to be “perfect.” Somehow that tweaked my perspective in a helpful way. Edit: on reflection, possibly because it doesn’t imply a compromise of my standards, but actually strengthens them, so I don’t have the feeling of giving up or giving less.
Also very much believe in doing some kind of planning, any kind being better than none at all. Otherwise you put yourself in a tunnel but you don’t give yourself a light at the end. The plan can change and it will, but if you have none, you might end up digging forever
codr7 155 days ago [-]
I don't plan much, first I set a goal and then break it down into manageable steps. Designs without goals rarely turn out well from my experience.
daliusd 155 days ago [-]
I don’t remember which book
I got idea from but idea is to work in different modes. When you work as programmer then there are no deadlines and etc. So sometimes you have to put different hat, e.g. CEO hat. It took several months to work out but overall result is reasonably good.
j7ake 155 days ago [-]
I found it takes the same amount of time to go from 0 to 50% completion as it is to go from 50% to 80%, and similarly from 80 to 90%.
This means when you are at 50% completion, you need to spend more than two times more effort to hit >90% completion.
99 to 100% takes an infinite amount of time.
brainzap 155 days ago [-]
I wonder how many people are missing out because there is no friend or SO that really push and supports.
In the comment section we probably have a lot of “me” stories, but should we not think “we”?
bitbasher 153 days ago [-]
This is something I struggled with personally for a long time. I had a list of projects I wanted to complete ranging from SaaS products to video games.
I tried working on multiple projects but my mind always focused on one at the detriment of the others (before ultimately working on something else).
After some time and deep introspecting, I realized working on multiple projects was some complex form of procrastination (avoiding doing hard or boring things on other projects). I also realized working on other projects may have been some sorta coping mechanism to avoid possible failure (if I never finish projects I can never fail).
After the introspection I hit a turning point with two words, "what if".
Instead of bouncing around, trying and learning new things, what if I focused all of my attention on one stack/product/project/industry/thing?
I haven't solved what "done" means yet, but I have come to terms with the shortness of life and my own capabilities. I know who I am and what I can do. It's a start.
andrewstuart 155 days ago [-]
There was a post on HN recently about building software for yourself - forget the possible audience of millions. If you focus on yourself as the end user then the whole thing becomes easier.
I couldn't find it after a brief search. Maybe someone else remembers it.
I already have a job, my side projects are all about having fun and learning new tricks.
kazinator 154 days ago [-]
This is more about launching. Launching is not finishing. We are using recent versions of things that launched decades ago.
When you're working on software that has no obvious finish (development could go on indefinitely) you have to set up small milestones. Okay, in this release we're going to get this and that and other thing working, with documentation and test cases. That is in a concrete target. When we have those three things with documentation and test cases we've hit the target and nothing blocks that release anymore.
Aleksdev 155 days ago [-]
I don’t want to come off as mean and spoil the article but the author writes he can’t get anything done and the strategies that might help him with finishing things is..
“1) writing a spec (i.e. a plan) upfront, and 2) timeboxing the project by giving myself a deadline.”
Isn’t this just agile? I’m pretty sure every developer already does this, it’s kind of the whole strategy for completing any project.
Not sure what the point of this article was. He could have wrote “make a sprint and stick to it”
bbor 155 days ago [-]
Great stream-of-consciousness style article, I relate and appreciated the practical advice!
This isn't enough on its own obviously, but just in case anyone's been noticing something of a trend: inability to finish projects is verbatim one of the DSM-V entries for Inattentive-presenting ADHD: https://www.cdc.gov/adhd/diagnosis/index.html
vouaobrasil 155 days ago [-]
I consider myself very productive. But I don't care about finished projects. The key is that some get finished. I naturally let projects languish as soon as they lose interest for me. If I lose interest I feel that it's not worth expending effort against the current to finish it. That's perhaps why I'm terrible in a corporate setting but great as an independent. I hate routine.
NicoJuicy 155 days ago [-]
The hard thing is staying focused on finishing things.
New projects are always nice and "productive", because it's fine. It's meeting the end goal that is harder.
vouaobrasil 155 days ago [-]
Personally, I find that meeting the end goal is easy if the project suits my personality and tastes. So my point was to discard the projects if I eventually discover that some part of the work doesn't satisfy that criteria.
NicoJuicy 154 days ago [-]
I think that mostly means, for a lot of people, working on your own projects instead of customer projects
roshankhan28 155 days ago [-]
i feel like we only lose interest in a project when we get extra perfectionist. i tried this thing a week back where i had to finish doing my task at work (Marketing). instead of making it perfect i just tried to do. just finish it. if it marked all the checks then it was good to go.
vouaobrasil 155 days ago [-]
Nah, I lose interest for many reasons, more than perfectionism -- and I am very far from a perfectionist. Rather, I lose interest because:
1. Not the right format (essay versus video versus book)
2. My overall philosophy on the topic has changed and I need to restart with something new
anon291 155 days ago [-]
There's no such thing as finishing a project. My most successful open source projects requires ongoing maintenance work to this day and the various dependency updates require constant refactoring.
To me something is done when it reaches a state where you don't feel you need to tend to it. But it's never actually done. The only things that are truly done are things that will never be used again.
lurn_mor 154 days ago [-]
Not to nitpick, but in this blog post, mostly every first sentence after a heading doesn't add anything, but simply repeats the heading in a longer, more rambling format. Are you bumping your word count to achieve some imagined length goal/page count?
Brevity and Ruthless Editing should be incorporated into your final cycles of 'finishing' working on projects.
shepherdjerred 154 days ago [-]
This is so very unhelpful and completely against the spirit of the post.
The author knows their work isn't perfect, but they're sharing it anyway. This is covered in the first paragraph.
Regardless, I found this post to be perfect. There are good takeaways, it was easy to read, and it wasn't too long.
I'd imagine that the author would happily consider your opinion if you posed it in a more constructive manner.
lurn_mor 154 days ago [-]
The author actually asked for feedback on this platform (in the spirit of the post...). Constructive criticism is not part of your process, huh?
Poor writing turns off readers, who won't come back and visit again, and it diminishes your effort and message. Pretty basic.
ziofill 155 days ago [-]
I have an endless streak of unfinished projects, at various stages of completion. All the ones that I finished had something in common: they served a purpose I cared about. If you don’t really care about what a project can do for you it’s nearly impossible to muster the mental energy to carry it out to completion. At least, I can’t.
docandrew 155 days ago [-]
I needed this. I have so many half-finished projects, it’s nice to think that there’s still a way to make them valuable in some way.
maninblackv2 155 days ago [-]
Im on the same sitatuation, i had an idea month ago that i thought it might be useful,started building, but when i finished the main parts i gave up, i just had the "what if" question, what if nobody actually want this and i've never touched since then the code is still in github tho
jschulenklopper 154 days ago [-]
Here's another approach not mentioned: have an accountability partner. Promise that person something specific to be done, with a delivery date.
My observation: a promise I made to someone else is harder to break than a promise I made to myself.
breakingcups 154 days ago [-]
Until you figure out the first excuse that works.
mxstbr 155 days ago [-]
I recently saw this related article[0] on the HN frontpage and I've already been applying it.
TL;DR: To build more quickly, do "outline speedrunning": Recursively outline an MVP, speedrun filling it in, and only then go back and perfect.
I keep reminding myself when working on my projects
- don't wait until you feel like doing something
and
- half-ass it
sph 155 days ago [-]
"A thing worth doing is worth doing badly" [rather than not at all, and expecting to do it perfectly is a sure way to never get started]
This is a fantastic rule-of-thumb no one ever talks about. We focus too much on learning, honing our skills, becoming experts, and we never find the time to start.
max_ 155 days ago [-]
I heard that finnished software is dead software
jaydeegee 155 days ago [-]
I hadn't realised people finished projects.
pcblues 155 days ago [-]
Here's just a little silly story from my own life of unfinished projects. I wanted to make a sort of shazam where I could hum the tune of a classical piece of music and find out what it was. I hacked together an enormous midi database of classical music with a couple of libraries to take a hum and turn it into midi notes in order to find the pattern in the database based on the difference between each note in a melody of a classical piece as an identifying key (pun intended). As a really bad singer, I couldn't hold a note, but you can imagine the work required to get this to actually work.
The amusing part was that I told a prospective software development employer about the project because it was consuming a fair part of my life at the time and showed an interest in software development in my spare time. They asked, "Did it work?" I said, "Nope"
I didn't get the job but we both had a laugh about it during the interview.
shreyshnaccount 154 days ago [-]
making a (smol) platform to share and find incomplete projects (on github?) devs can pick up and contribute to in a short duration. any interest?
seigel 154 days ago [-]
Hey great to see another mud slinger! Share some pictures sometime!
And this is one of the reasons writing things down has been such a useful tool, and starting with a spec is something I now do religiously after spending the first half of my life just diving in haphazardly (and often not getting very far).
Those ultra productive days are often enough to get a pretty decent spec written; something I can flesh out in far greater detail than I could with a productive coding day. Those down days are now bolstered by the thinking of a version of myself that was firing on all cylinders, and solved many of the problems I probably don’t have the brain power to tackle on the fly when I’m tired and stressed for life reasons.
I feel like I’ve squandered really good trains of thought by telling myself “I’ll remember this and write it down later”. So I always start with writing. Future me always appreciates it.
I totally agree about writing things down being useful. I also like the author’s timebox plan as well. I’m great at writing specs to define what I want to build, but my hobby project timelines are nonexistent. I think I’ll give this a try!
Without peeling the whole onion, I've been dealing with a series of autoimmune issues in combination with complex PTSD. I'm working with some really great people to address these issues on all fronts and I'm much better these days than I've been in the past, but it's a work in progress that I'll have to manage for awhile.
A huge +1 to the importance of core habits. Focusing on this has been a key aspect of recovery.
I've been feeling like the software industry is over optimizing engineering output just a smidge beyond what is morally acceptable. Not enough to raise red flags about cruel and unusual, but just over the line of "it's ok to be human". Maybe that's just me and I'm someone who doesn't need a Pomodoro timer or multiple "just for an update" meetings to get work done. But maybe it's also upper management trying to turn business school theory into something real. You're not a number or a widget or for God sakes a brand. You're a person. Remember that.
Also it’s a lot about lack of trust in large orgs.
On the other hand, I've got one large ongoing series of projects that are relatively pointless, and that is the whole point of them. I'm learning from them and I don't have the pressure of completing anything (although I would really like to). From time to time they have been really important for my mental health, and I value them for that.
I'm also quite aware now that I need to feel achievement to keep me motivated, and if I have a plan and can check off an item on that plan then that counts as a good day. Work doesn't always give me that sense of achievement, so having something else that does can be really valuable.
I think those ultra-productive days earlier in my career account for some of the best learning, but now, over a decade into software engineering, focusing on the planning aspect seems much more prudent.
I'm sure it's human nature. But there are some beasts out there like Don Knuth, Torvalds, DHH, that seem to have unlimited stamina. They are the people who advance stuff.
And also therapeutic. I see the incompleteness of my original idea, or plan. I see that the things i declare important feel less so when i have to keep working on it. I start to permanently discard essays, apps, ideas, as i appreciate what it would really take to do them. I say no to myself far more often. I become more disciplined in my work. And more disciplined in my play. I start making more realistic plans and exit points because im not a masochist.
Ultimately i let it change me. I obviously wont grind like this forever. But the grind teaches me, and changes me, into the kind of person that finishes things. Which is mostly about learning to be more selective and less impulsive, and knowing when to play and when to put things down and truly let them go.
I'm not sure I can force myself to keep working, though. Self-imposed deadlines don't help me either. It seems like a willpower problem, like going to the gym.
What's helped me is making projects alongside a small group of fellow programmers. Seems like the author has done something similar with a hackers co-op chat and with Recurse. External accountability is my most successful motivator.
I work with oodles of software developers and almost none of them program on the side.
I found this group recently: https://lmt2.com/
The author made a group: https://www.hackercoop.dev/
If you like fiddling with HTML, there's groups like the homebrew website club https://indieweb.org/Homebrew_Website_Club or sunday sites https://sundaysites.cafe/.
A few open-source communities have forums/channels like #showcase, where it's easy to drop a screenshot and get feedback. I'm thinking of the Discord chats for Textual and p5.js, for example, if your project uses their libraries.
Or if you're the party planning type, perhaps consider forming your own group. Even ~6 people meeting once a week for a month works well.
Everyone works on their own things.
Or, you start to enjoy the pain, because you enjoy the result. But then your mind does its illogical associative thing and you start to just enjoy the pain on its own. Now you're a masochist!
I jest, but only some. Ask me how I know ...
Have a poorly-ordered braindump:
In my life, I've kindof developed a rule of thumb: if it's the more difficult path, it's probably the better path. That heuristic isn't always correct, but I find it to be pretty good. Problems can arise when I follow it blindly, though.[1]
I've just generally found that a lot of good things in life are on the other side of a barrier, and crossing that barrier usually involves effort and pain.
So, it starts to develop into an association of "if it's hard/painful, it's probably leading somewhere good." And that starts to develop into "seek out pain/difficulty."
Ironically, I'm also someone who values being comfortable in my own skin. But I feel more comfortable doing something painful for my own (masochistic?) reasons than doing something painful for an external goal.
----
I do feel like there's often an element of masochism in people who excel at some activity. Plenty of stories of top athletes or musicians etc. who do it for their own reasons, and not to win a trophy or acclaim. Getting good at something is generally a painful process of dealing with failure over and over. If you don't have a stomach for that pain, you'll give up. If you grit your teeth and force your way through it, you may become competent, but probably won't excel. If, somehow, you enjoy that pain and are drawn to it, then you will put in the hours to keep getting better and better, unboundedly.
But that's just one perspective.
The grandparent comment seems more like someone who likes to "keep their eye on the prize," whereas I'm more of a "do it because I enjoy[2] it" person. I suppose if you are motivated strongly enough by some external goal, it could push you through the hard times, too. And if the goal keeps moving, you might keep pushing, unboundedly, too. Not my path, though.
See also "Type 1,2,3 fun", eg: https://essentialwilderness.com/type-1-2-and-3-fun/ (definitions vary)
----
Also, I find taking a hard path is sort of a Great Filter for other people; there will be fewer others on that path (I'm fairly solitary, so it suits me), and what people there are will have something in common with me.
----
[1] When I hear about people trapped in abusive relationships, trying to "fix" it rather than leaving, I feel like I understand them somewhat. At the same time, some relationships are worth saving, even (especially?) in the hard times, so being able to navigate the pain rather than run away can a strength, too. Depends on the situation.
[2] with "enjoy" being somewhat perverse, at times (:
For a long time, I was lazy, and took pride in quoting Bill Gates "I choose a lazy person to do a hard job. Because a lazy person will find an easy way to do it."
I thought I was smart, but after years I discovered I became more lazy, and had never developed any deep knowledge on matter.
"if it's the more difficult path, it's probably the better path", I like that :)
I’ll admit I’m jealous of this. Most days at 5pm I’m just hitting a groove, but kids need to eat, need family time, etc. I’d love to grind from 8am-11pm but rarely have that luxury.
Whenever I have holidays and weekends or unlimited time and want to work on something I usually don’t follow through.
tl;dr TRIGGERED
I'm in my 40s and for most of my life I had an unending series of unfinished projects that I felt guilty about. Today, I am able to finish some stuff, including some pretty large, hard projects. Better, I don't feel guilty about the stuff I don't finish.
The trick for me is to be deliberate and mindful about why I'm embarking on a particular project.
If it's because I want to feel good by:
* Sharing something with others.
* Accomplishing a difficult, challenging task.
* Proving to myself that I can do something.
* Getting the social cachet of being a creative, productive person. (Maybe this is shallow, but who doesn't like to feel impressive in the eyes of their peers?)
Then the goal of the project is the product it and I focus my attention and discipline on it. I try to have as few of these as possible—like only one at a time—so that my willpower is not diluted.
If it's because I want to feel good by:
* Improving a skill.
* Exploring an unfamiliar domain or learning something new.
* Relaxing by tinkering on something I like.
Then the goal of the project is the process and I don't feel bad about not finishing. The real treasure is all the stuff I learned and did along the way and there is no real destination. I can have as many of these as I want because there's no real failure mode here. They're all recreation.
Once I got more honest and clear with myself about my goals for each project, I started to be able to finish the ones where that mattered and stopped feeling bad about the ones where it doesn't.
I think this is key, and demonstrates the real personal growth, which is more valuable than being able to finish things per-se.
It's the old saw: "what's the hardest thing? To know oneself."
There's a lot of eagerness to jump on bandwagons and do whatever the motivational speakers recommend, but you're not going to find the answers specific to you until you look inside yourself.
Anyway, in short: I agree (:
I'd also add: the reasons and mindset can change not just from project to project, but from day to day as well. Very context-dependent (at least in my experience).
Joking aside, I came to believe that various form of procrastination are a response to pursuing wrong or unclear goals - even when I don’t state them clearly, my brain still somehow knows that I’m not aligned with what my goals should be. Good job, brain!
Yes, but there may be other positive benefits to solving it as well. :)
Neither are very impressive, but in both cases, I ended up having to simply decide I was done and stop working on them. I could continue making changes indefinitely, adding little improvements and such every day, but they were also complete as they were. Once I learned to be okay with that and move on, I learned what finishing a project really meant (or at least one form of it).
With any art, a certain amount of polish is desirable but too much will destroy the essence of the work.
I will find myself actively making a song worse... and then go back a few versions to find the peak.
"Done" is often a compromise. There's more that can be added, there's still burrs and "rough spots," but we need to declare it ready to go out the door, and be prepared to fully support our release.
I've been shipping software for my entire adult life, and have had to embrace this philosophy.
Just the other day, I stopped working on a "play" project that I was working on, because it was a rabbithole, and not worth the agita of fixing the fundamental design issues that I was encountering (an unfortunate by-product of my "Evolutionary Design" process, is that it's quite easy to fall into Wonderland, and I need to learn to understand that I should just let the rabbit go).
As much hate as Agile gets here at HN because of its wrong usage by many people, one thing that Agile recommends is setting up a 'Definition of Done' within your team before even starting your very first sprint.
They would start at the end, and work backwards.
They hated Agile.
How old? The origin of Agile goes back to the 1950s in Japan
But the term "Agile," is a lot more recent (and US-based). I rapidly learned never to use that word within earshot of my managers. Sort of like saying "California Roll" in a traditional Tokyo sushi joint.
Stands to reason. Agile, in the Manifesto sense, defines the considerations to consider should managers be eliminated from the picture. Nobody is going to be comfortable knowing that their job is on the chopping block.
It's because that company is laser-focused on Quality (they have a well-earned reputation as one of the highest-Quality manufacturers in the world).
They believe that Agile promotes bad-quality work, because it promotes a lack of Discipline and checks and balances (which are necessary components of high-Quality production).
I disagree, but many of the Agile proponents exemplify low-quality work, because they deliberately eschew Discipline and checks and balances. They use Agile as "Santa Claus for young developers," as opposed to what I believe is Agile's focus on delivering high-quality, useful, and timely, product to end-users.
We need more examples of the Agile process doing really good work.
Whether or not that is true, why would they care? They'll be gone.
> Agile's focus on delivering high-quality, useful, and timely, product to end-users.
I tend to agree. As managers are removed from the picture, there is no manager to hide behind. You're working directly, each day, with those who are going to hold you accountable.
> We need more examples of the Agile process doing really good work.
To be fair to the managers, are there any? Even the C3 project that gave birth to Agile is widely regarded as a failure.
Well, it’s not true (in my opinion), but try telling that to people who have been successfully shipping world-class optical gear, for a century.
I have learned that, if we want to introduce new paradigms, it’s a very bad idea to do so, by telling folks that the way they do it now, is wrong (even if it is).
That experience taught me a great deal about working within a super-high-Quality context. The personalities and opinions are very powerful, and most of the senior folks involved, got there, by being very, very good at their jobs. A true meritocracy.
They won’t react well to having some wet-behind-the-ears yank, come in and tell them that they are wrong, when that’s clearly not the case (in their eyes).
I’ve found that, if I want to introduce change, I need to begin by respecting the context and the people, and using that as a substrate for change, as opposed to suggesting it be removed, wholesale.
Or start my own company, which is what a lot of folks do, these days. It’s not an option that’s available to many. Also, those companies often encounter problems that have nothing to do with the tech, and everything to do with the inexperience of the founders (like reckless behavior).
Scrum uses the exact "Definition of Done" language, though. I suspect that you are really thinking of it...
Which is humorous given what you said about wrong usage of Agile. Case in point?
Ugh, yes... I wish I had internalized this sooner!
Interesting word, thank you!
I hear the word used, often.
I do disagree with this claim (though later points temper it a bit):
There is a big downside: as the author states, finishing/releasing is hard and time-consuming. You only get one life. Every hour spent doing that stuff you won't get back. So, not a direct cost, but an opportunity cost. Personally, I find it important to acknowledge this and face it head-on, rather than waving one's hands and saying "oh, there's basically no downside." Though I admit that the latter can be a useful self-mind-hack to get the ball rolling. But first you decide what you want to do, and why you want to do it, and then you tell yourself whatever lies you need to help it get done (:The "why is it important..." question is really critical to motivation, at least for me. A person should give that question honest thought and an answer that rings true to them.
I agree about the therapeutic aspect of putting things out into the public.
Just getting things out of one's mind, and into the world (even if nobody sees them), can be important (helps my sanity, at least). Even just the "rubber duck" sense of imagining someone might see it, can catalyze thoughts in a way that wouldn't otherwise happen, too. Then, having people actually see them is another layer, and can be humbling and educational.Also, apropos of nothing, this article made me think of the (mis-)quote:
Good article (:> Why is it important to share your work with the world? First, because there's practically no downside, and very, very high potential upside.
And say,
> There is a big downside: as the author states, finishing/releasing is hard and time-consuming. You only get one life. Every hour spent doing that stuff you won't get back
Working in public (or working at least from the assumption it will soon be made public), is something folks should try really hard to get into. It should be a default expectation for yourself. The cost is mostly mindshift!
Once you can change your default position, it no longer feels like a cost to work in public. Every action brings release.
Use curiosity and excitement when you can but don't let them be the only way you can work on something.
Some practical strategies I've written about:
- How to prevent stagnation while building products alone [0]
- Multi-Perspective Note-Taking: Mastering focus as a solo-developer [1]
[0] https://www.idiotlamborghini.com/articles/how_to_prevent_sta...
[1] https://www.idiotlamborghini.com/articles/mastering_focus_as...
https://github.com/shepherdjerred/practice
https://github.com/shepherdjerred/archive
I would like to add another possible strategy: watching a number go up.
Recently I have started tracking the books I am reading. I track the page number I am currently on via a dashboard I made in Obsidian, which displays a %-read for each book. I have found that "number goes up" gives me just enough of a dopeamine hit to encourage me to pick the books up more frequently than I had before.
But oftentimes when a project or essay is incomplete, it's hard for me to think of a good "number" to track that would be a good motivator (since i.e. lines of code, or the number of words in a draft, don't necessarily feel like a good proxy for progress all the time). I'm curious if there's a metric that would work better?
I'm a typical Starter, and all of the side projects we've been working on together were my idea. All of the projects that we completed and released were solely because of his endurance, discipline and focus. And his constant reminders to not start a new project before the current one was done.
So then market fit exploration benefits from tracer-bullet, but you might do iterative reimplementation instead. And it might be overkill for a one-shot market test. MVP is largely orthogonal to end-to-end - "Submit button emails founder who does the thing by hand over breakfast" is fine MVP but isn't very end-to-end. And a non-MVP non-product end-to-end can be tracer-bullet or not. A soundly architected low-debt end-to-end yes, a hackathon high-debut "to adjust, rewrite", or a throwaway end-to-end exploratory spike, no.
Also very much believe in doing some kind of planning, any kind being better than none at all. Otherwise you put yourself in a tunnel but you don’t give yourself a light at the end. The plan can change and it will, but if you have none, you might end up digging forever
This means when you are at 50% completion, you need to spend more than two times more effort to hit >90% completion.
99 to 100% takes an infinite amount of time.
In the comment section we probably have a lot of “me” stories, but should we not think “we”?
I tried working on multiple projects but my mind always focused on one at the detriment of the others (before ultimately working on something else).
After some time and deep introspecting, I realized working on multiple projects was some complex form of procrastination (avoiding doing hard or boring things on other projects). I also realized working on other projects may have been some sorta coping mechanism to avoid possible failure (if I never finish projects I can never fail).
After the introspection I hit a turning point with two words, "what if".
Instead of bouncing around, trying and learning new things, what if I focused all of my attention on one stack/product/project/industry/thing?
I haven't solved what "done" means yet, but I have come to terms with the shortness of life and my own capabilities. I know who I am and what I can do. It's a start.
I couldn't find it after a brief search. Maybe someone else remembers it.
https://www.robinsloan.com/notes/home-cooked-app/
When you're working on software that has no obvious finish (development could go on indefinitely) you have to set up small milestones. Okay, in this release we're going to get this and that and other thing working, with documentation and test cases. That is in a concrete target. When we have those three things with documentation and test cases we've hit the target and nothing blocks that release anymore.
“1) writing a spec (i.e. a plan) upfront, and 2) timeboxing the project by giving myself a deadline.”
Isn’t this just agile? I’m pretty sure every developer already does this, it’s kind of the whole strategy for completing any project.
Not sure what the point of this article was. He could have wrote “make a sprint and stick to it”
This isn't enough on its own obviously, but just in case anyone's been noticing something of a trend: inability to finish projects is verbatim one of the DSM-V entries for Inattentive-presenting ADHD: https://www.cdc.gov/adhd/diagnosis/index.html
New projects are always nice and "productive", because it's fine. It's meeting the end goal that is harder.
1. Not the right format (essay versus video versus book)
2. My overall philosophy on the topic has changed and I need to restart with something new
To me something is done when it reaches a state where you don't feel you need to tend to it. But it's never actually done. The only things that are truly done are things that will never be used again.
Brevity and Ruthless Editing should be incorporated into your final cycles of 'finishing' working on projects.
The author knows their work isn't perfect, but they're sharing it anyway. This is covered in the first paragraph.
Regardless, I found this post to be perfect. There are good takeaways, it was easy to read, and it wasn't too long.
I'd imagine that the author would happily consider your opinion if you posed it in a more constructive manner.
Poor writing turns off readers, who won't come back and visit again, and it diminishes your effort and message. Pretty basic.
My observation: a promise I made to someone else is harder to break than a promise I made to myself.
TL;DR: To build more quickly, do "outline speedrunning": Recursively outline an MVP, speedrun filling it in, and only then go back and perfect.
[0]: with me: https://learnhowtolearn.org/how-to-build-extremely-quickly/
- don't wait until you feel like doing something
and
- half-ass it
This is a fantastic rule-of-thumb no one ever talks about. We focus too much on learning, honing our skills, becoming experts, and we never find the time to start.
The amusing part was that I told a prospective software development employer about the project because it was consuming a fair part of my life at the time and showed an interest in software development in my spare time. They asked, "Did it work?" I said, "Nope"
I didn't get the job but we both had a laugh about it during the interview.