Remix.run Logo
don-code 2 days ago

I have a coworker who _excels_ at writing code - one of those engineers who can metabolize caffeine directly into code.

They write code to implement the all-important features. They write code to work around lack of process. They write code to work around problem people not doing their jobs well. They write code to work around buggy code by other developers. They write code to work around their own code, written weeks or months earlier.

I've been encouraging them to _reduce_ the amount of code they write, and instead consider the context around why they're writing the code. Code is just one way - and not always a particularly good way - that we can solve people and process problems.

ck425 a day ago | parent | next [-]

Best Software Engineering advice I ever heard was at a conference talk by a guy called Dan North: "Think of code like surgery".

Basically Surgery is a means to an end (patient gets better) and a useful tool for achieving that but it's also dangerous so only used when necessary. If other treatments can fix the problem you try them first. If surgery is required you only do the minimum required to treat the issue.

Code is similar. More code means more maintenance, more tech debt, slower deliverables in future and higher risk of dependencies no one understands. So when coding ask "Can I fix this without code?" because if yes it's often easier in the long run and "What's the bare minimum/simplest code I need to write to fix the issue?".

stephenbez 20 hours ago | parent [-]

That's a really interesting metaphor. I worked with Dan years ago.

It seems like the talk was at CraftCon 15 and called "Beyond Features: rethinking agile software delivery with Dan North".

I couldn't find it, but I found a similar talk he gave at a meetup that discussed surgery: https://youtu.be/EoJFWdhv8q0?feature=shared&t=1564 or https://www.youtube.com/watch?v=lz5HBtDl-1A

mcv a day ago | parent | prev | next [-]

I try to write as little code as possible. I do love writing code, but I've learned to love removing code even more.

The big problem in many companies is that often programmers are kept out of that context. Problems are discussed without programmers, and only tossed to programmers once non-programmers have decided what they need to do. I think we need to be more involved in those decisions.

mberlove a day ago | parent [-]

Completely agree. This is a great insight. IMHO part of the growth of a programmer is learning how the code fits the context, and a large part of that is writing less code, not more, or getting rid of some entirely.

pydry a day ago | parent | prev [-]

I'd be trying to make better use of this tendency and talent, not trying to curtail it.

MultifokalHirn a day ago | parent [-]

you are clearly missing the point, and probably feel like you have that tendency and talent yourself

pydry a day ago | parent [-]

Not at all. Im more of an all rounder. I just like to see people matched to tasks which suit their temperament and talent.

I hate seeing people who would rather be doing customer interaction half heartedly refuctoring while people who live and breathe code sit on customer calls bored out of their minds.

I also feel a little disgusted at seeing talent wantonly squandered unnecessarily.

9029 20 hours ago | parent [-]

I'm having kind of a hard time imagining how such position would look like. Only working on greenfield projects, moving onto the next project once the codebase gets intolerable?

pydry 17 hours ago | parent [-]

What such position? Im a little unclear on what you're asking.