There is a fluidity to great design that when it is done well, it disappears. The greatest design is invisible.
This is the same ethos I would like to see applied to development and programming. Of course, there isn't going to be a one to one translation, but good development should be easily digestible, not a marathon of unraveling some random insufferable person's theories.
I'm often disappointed with devs because so many are invested in keeping it a mystery.
And that's some bullshit.
One of the things I am proud of is that I consistently hear how easy my code is to follow and pick up. I value that feedback from my peers.
On the flip, it's interesting how I've actually gotten push back from others 'critiquing' my coding saying it is 'too simple', which generally reveals to me the mindset of a shop. A lot of folks, A LOT, get off by making overly complicated code.
In my estimation, this one of the biggest reasons that keeps programming from being as accessible as it should
@Are0h That's a great source of pride! Write code that looks like anyone could write it, and anyone will be able to read and enjoy.
Someone was just explaining the logic to me that simpler code is easier to debug, anyway. I already thought people should keep it clear and straightforward, but I haven't gotten far enough into writing my own to have made the connection that it's a bad move on its face. So really the only justification to make code flashy is... to feel superior?
@pamela There are some times that really require some complex thinking, so not across the board.
But most of us aren't building proprietary enterprise level solutions that require this kind of work.
So I'd say either superiority or to hide the fact one just doesn't know what they're doing.
The enterprise level solutions are the ones that need simply and easy to read code the most. These projects last a long time and you have many developers working on the same code.
But just as you said there are cases where code has to be complex. I think the key word here is that it needs to be as simple as possible but no simpler, to paraphrase Einstein who I believe said it first.
@loke To a certain extent this is true, but when you're building something specific that there aren't readily available solutions for, you have to figure it out. And that process isn't always sexy.
Ideally, you'll get to that point with enough effort, but you can't really solve problems until you know they are problems, so it takes time to figure that out.
@Are0h @loke @pamela honestly in my experience the enterprise solutions are the ones with the most unnecessary complexity and shows of machismo X'D
(although open source has a *lot* of that too!—to our perpetual chagrin..)
i think the only things that really need to be truly complex are little algorithms of the kind you read about in Donald Knuth's books or in cryptography or etc., but those can be tucked away into cute little bundles with abstraction so people don't need to be overwhelmed :'3
@Are0h Wait like, literally "too simple"? I've never heard that one before. I have heard "oh that's nice and simple" as praise, though.
@Are0h Reminds me of how Mark Twain could write very accessible prose only because he was such a skilled writer.
@Are0h like unless simplicity somehow majorly detracts from efficiency somehow, I don't see how anyone could mount a reasonable argument for "more complicated code" other than to just be elitist. Like that goes against like all the best practices of programming!!
Good for you for doing your best to make accessable and usable code :D
@bamfic I haven't paid much attention to Go, so I didn't know this. That's pretty damning.
@stsp @trwnh Back in the day when I was first starting doing corporate design work, me and my team would just make up words to see if other departments would start using them to sound like they knew what they were talking about.
They always did. And they had no idea that the words they were using were completely meaningless.
It was... educational.
@Are0h I recently learned from a friend there's a start-up culture that divides co-workers into two categories: "good" developers and "bad" developers. Such toxic nonsense.
I've gotten used to the mindset that complexity is the enemy and my code will be ugly and have bugs no matter how hard I try and I'm always happy when others locate issues in my code. I wouldn't wanna work with people telling me I was a bad developer for making mistakes. Glad I don't have to work for start-ups!
@stsp Honestly, I don't like working for start-ups. They promise all of these grand ideas and outcomes, but more often than not just result in one being overworked in the extreme and underpaid.
It's a culture that pits people against each other in terms of who is willing to be exploited the most to the the 'best'.
Toxic is a great word for it. They are just not healthy places and they rarely turn out good work.
Hearing you say this... yes. I don't care about "elegant" code, I care about being able to understand it.
I'm deep into writing a book and... as soon as it's in a shape where it can be critiqued, I'd love to have you be the first to peer review it.
@ghedipunk I don't think those two things are mutually exclusive. It just takes work to achieve both.
If you think I can help, sure. I appreciate the consideration.
I feel like you're totally describing my reaction whenever I try to build with any of the JS front-end frameworks.
@ross LOL, I feel you. I rarely use any of them myself, although I am a bit fond of Vue.
A lot of them just seem completely unnecessary and just complicate the goal in the first place.
@Are0h Yeah, I feel like Vue is the one that just tries to get out of my way the most, but they're all a bit much.
@Are0h "There is a fluidity to great design that when it is done well, it disappears. The greatest design is invisible." - your words? A quote?
Thinking of my preferred field (analog #GameDesign), I *both* agree w/those words and I don't.
Like, invisibility seems to me to be more of a starting point than the height of achievement: that's the black belt, then we're out of the kids' pool and things get real. Might be a divide between *expressive* design vs. "merely" functional #design, though.
@rafu Ha, this is an odd question. Why would you assume they weren't my words?
This doesn't make much sense to me because it takes time and effort to the get to the point where design, whether functional or expressive, it supplements the experience rather than dominate it.
Elaborate on what you mean as a 'starting point'. A starting point for what?
@Are0h well, that sounded like a very polished aphorism, so I thought it might have been a well-known maxim from some design bible you were quoting.* Seemed like a sensible thing to ask as I was elaborating on that paragraph.
Congrats for crafting a nice #DesignMaxim worth quoting, then!
* = That's probably because I've met a couple people who were *really* into general design (as opposed to _just_ game-design) and used to do that all the time.
@rafu LOL, because for some magical reason Black folks can't create 'a very well polished aphorism' so it has to be a quote from somewhere? And that's a 'sensible' question to you?
Ha, I'm just going to end this exchange here. For your sake.
@Are0h Uh... I didn't know you are black until you mentioned it, that is right now? Uh, I guess I could've known from your profile pic, except those show up very small on my screen. Awkward.
I now see huge unintended implications for which I apologize. Sorry.
@rafu Whatever, man.
The social network of the future: No ads, no corporate surveillance, ethical design, and decentralization! Own your data with Mastodon!