do as i say...
do as i say...
do as i say...
Many years ago I had to try to debug a memory manager written by a really talented software engineer, with an interesting take on naming things…
Naming things is one of the two hardest problems in computer science. The other one is cache coherency and off by one errors.
That's three... Ohhhh....😅
The number of times I have labeled something as fart, poop, fart_poop, temp_fart_poop, etc, and just forgot about it is not okay.
U nd to rembr tht mny snr devs grw up prgrmng on old hrdwr tht ddn't hv mch mmry & oftn th lang ony allwd shrt var nms anywy. Also thy wr th gen of txtspk fr smlr rsns.
Yngr snr devs pckd up bd hbts frm tht gen.
And here's a sentence that's not squashed to cleanse your palettes / give a sigh of relief because I figure if I need a break from typing like that, you need a break from reading it.
Nmng thngs s hrd.
I’ve been at this for 25 years and a restriction on variable name length hasn’t been a problem since then.
A good senior dev shouldn’t just be older, they should have continued to learn and evolve.
I do remember texting abbreviations because we texted on a number pad with no autocomplete.
Everyone I know was happy to switch to better keyboards and autocomplete as soon as they were available.
Speak for yourself. My company only stopped using Fortran this decade.
I was mostly poking (heh) fun at myself, (also) a member of the generation I spoke about. Very much not a professional, but I do code a little, and know about the non-triviality of naming things.
Also also, for reasons I won't go into, my phone is still a flip phone.
Fck ff wth yr rbtrr lngth vrbl nms.
oftn th lang ony allwd shrt var nms
I started coding with TurboBasic which allowed variable names of any length but the compiler only looked at the first two letters (and case-insensitive at that), so DOUGHNUT_COUNT and DoobieCounter were actually the same variable. Good times debugging that kind of shit.
Yeah, I was thinking of old 8-bit computers that did the same ignore-after-second-char thing. Most people didn't bother typing the extra characters though because 1) those characters took up valuable memory and 2) if you accidentally put a keyword in the middle of your longer name, the tokeniser would see it and assume it was a keyword.
e.g. Calling your variable FORGET
seemed like a good idea until you got a syntax error because FOR
and GET
are both keywords. FO
it is, then. Or just F
.
COLOR
was cursed too; OR
is usually a keyword, even if COLOR
itself isn't. British English COLOUR
might save you here, but you're still losing those four extra bytes.
U nd to rembr tht mny snr devs grw up prgrmng on old hrdwr tht ddn't hv mch mmry & oftn th lang ony allwd shrt var nms anywy.
My generation. Many of us learned and adapted over time, and use perfectly decent variable names now.
Also thy wr th gen of txtspk fr smlr rsns.
Nope. Got my first cell phone 8 years into my professional life, and 18-20 years after I started programming. Txtspkrs r th nxt gnrtn. Whippersnappers!
Now get the hell off my lawn!
Jks on u I invntd my own lphbt onc, whr vwls r a mrk n th nxt lttr nstd of seprt lttrs. I gt vry gd at rdng cnsnnts.
Hey, sometimes we put a little effort into our acronyms. I published a component named UTI and it was too late to change it by the time management caught on.
That can’t be true, because it’s never to late for management to edict changes to a project, even just on a whim.
"Actually we decided we're going to take this project in a completely different direction. Go ahead and rework 90% of what you just created over the last six months."
It was a trivial enough component that upper management couldn't be bothered to give a shit, and middle management was toothless. I left before HR had to get involved again.
Fuck character limits for names. Looking at you, ABAP.
Character limits and a stupid badly used Hungarian notation to waste limited characters to tell use what the ide already knows.
If you have a table, (that’s an array for sane programmers) name the variable as a plural and we will know it’s a table.
Don’t name two variables the same stupid abbreviation with different Hungarian notation characters stuck to the front
Ah yes, gotta love /company/product_abc table names.
doSomeAwesomeStuffThatCanBeUsedInVariousEnvironmentsWithoutHavingToCareAboutTheReturnValue()
Hah, I (a Sr developer at the time) once built an entire mapping layer in our ETL system to deal with the fact that our product had long and expressive names for every data point but our scientists used statistical tools that had no autocomplete and choked on variable names longer than 32 chars so they named everything in like 8 chars of disemvoweled nonsense.
May those who build such unergonomic tools choke on a hair ball
That just sounds to me like he hasn't worked on large code bases with multiple teams. No way it would be considered acceptable once you're interesting with enough other people.
Or just worked on codebases long enough to forget them... the biggest bastard I've encountered has been past me
Is he perhaps a decompiler?
I found a variable named "t" Friday. I figured I must be looking at the minified version, but nope! Someone just decided to name something "t", I have no idea why.
I pity the fool!
Also, can somebody explain this to sysadmins when it comes to naming computers?
I mean programmers can have some weird naming conventions, but I've never met an adult professional programmer who named all his variables after planets or Harry Potter characters or just called everything stuff like ADMUTIL6 or PBLAB03T1 or PBPCD1602.
Windows backwards compatibility can't handle more than 15 characters in a name.
Harry1
Harry2
Harry3

RFC1123 supports 63 chars, but even that gets problematic when you have things like $cluster-$datacenter-$node-additional-seed-service in k8s.
Harry Potter characters is a perfectly reasonable server naming scheme. Server names should be easily recognisable but not tied to any particular service/project/function on that machine (as the server may be used for other things later etc)
See RFC 1178: https://www.rfc-editor.org/rfc/rfc1178
There was a thread about that on c/selfhosted a few weeks ago. Created by a particular wild-cat-inspired sysadmin, I might add.
But on a more serious note, the interactions between a sysadmin and their servers (that they have enough responsibility for to be able to name) are much more intimate than the interactions between a dev and their variables. The server names also exist in a much larger namespace, so they need to be more unique.
Every place I've ever worked has had a bobafet.
Documentation is like sex: Even when it's bad, it's still pretty good.
You've obviously never used Google Cloud documentation.
Does that mean self-documenting code is actually masturbation?
Which makes my incomprehensible notes to my future self an elaborate form of masturbation.
...Because no one else wants to write my documentation.
What kind of shit senior devs are you working with?
Any one who worked on an Oracle DB when they had the 30 character object name limit learned to make names like this. You'd figure out all your domain objects, and abbreviate them all (person could be PRS_, account could be ACCT_, etc). It was a horrible experience.
I mean, sure, but it's not like that makes you forget the normal English words. Just don't abbreviate those words and you've likely got a semi-decent variable name.
Well, and my expectation for non-shit seniors is to be somewhat good at their job and to lead by example.
Nah, always use as lewd names as possible, like really over the top, preferably r34 compliant. And the comments need to be there to explain the fictional stories behind all the names and all the lewdness - and not really to explain what the code does, that's just a common misconception.
If someones dares to look into my code they need to be ready to suffer.
(And no, I'm not a dev, no one in my team can code anything, boss won't give me a an actual dev - and when I write something for other ppl as a favor I make an effort to make the code clean and comments only mildly amusing)
Reminds me when back in the day I was working on a system where one of major component's acronym was BOOTY. It was hard picking right terms and names for the new parts, but I managed to fit a variable named BOOTY_SLAP in there such that none of the reviewers even questioned it.
Does anyone have any good advice on variable naming? Here's some of my rules I try to live by:
utils_FooBar
is
not
in bool names._
g_VARIABLENAME
calc_ImportantValueThatWillDecideTheUsersView
is better than calc_SumYears
if the variable is more important than the others.Edit: I realize I was speaking about function-naming with the prefix stuff.
For variables, I still use prefixes, but for variable type. Even if you define the variables as types, it's still incredibly useful. For instance,
a string is s_MyName
,
enumerable is e_MyType
,
A number is int or double or whatever i_MyAge
or d_MyWeight
This might be obvious for custom objects, but I'd still do it like this p_Person
or per_Person
.
Seriously it does make a huge difference
I have to disagree on some points, but I def feel like you're helping me learn, so for that I am grateful.
I feel like you're speaking from the perspective of a perfect coding environment, which if you have that, that's great. Maybe all your code is in one place, maybe you have an IDE that does a lot of the work for you, and that's great. However, for most of us, that's rarely the case.
Prefixes have been an absolute game changer for me personally, and I will never not use them again.
I have also found that verbosity of variable name and readability are mutually exclusive. A long variable name, most of the time, takes away from the logic. Yes, they are "free" as far as memory, but are very expensive to reliability.
Units tests, again are great, but most places think unit tests are like golden toilets. It sucks, but that's the way it is. Usually you're given a task, and if it's not done next week, maybe you're not as good as they thought.
I might be already exposing myself as an emacs user, but I think Lisp naming convention is pretty reasonable. I use it in other languages as far as their language rules allow me
p
or _p
/-p
variable-name-here
. Sub for _
in languages that dont allow -
in names_
. cool-package
then variables or functions that are specific to it are cool-package-variable
(especially if it is exposed to other packages). cool-package/variable
is also good if allowed. /
. So there's main-function
and my/main-function
. If /
is reserved, then I assume the language has a way of segmenting namespaces already and just default to that since _
or -
would get ambiguous here.See the rest here: https://github.com/bbatsov/emacs-lisp-style-guide
I have never had any patience with variable names when I realize I have to do a 3-way swap: c=a, a=b, b=c. I'm sure there's 40 years of goddamit=a and fml=a in the wake I've left behind me.
Programmers really like their AJTI (acronyms just to impress)
BTDTGTTSAWIO
Banana bread at work is pretty good though.
I see this a lot less with developers whose companies actually provide decent IDEs. Especially front end devs or older devs who still use text editors.