Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			Search - "commented out code"
		- 
				    					
					
					"You gave us bad code! We ran it and now production is DOWN! Join this bridgeline now and help us fix this!"
 
 So, as the author of the code in question, I join the bridge... And what happens next, I will simply never forget.
 
 First, a little backstory... Another team within our company needed some vendor client software installed and maintained across the enterprise. Multiple OSes (Linux, AIX, Solaris, HPUX, etc.), so packaging and consistent update methods were a a challenge. I wrote an entire set of utilities to install, update and generally maintain the software; intending all the time that this other team would eventually own the process and code. With this in mind, I wrote extensive documentation, and conducted a formal turnover / training season with the other team.
 
 So, fast forward to when the other team now owns my code, has been trained on how to use it, including (perhaps most importantly) how to send out updates when the vendor released upgrades to the agent software.
 
 Now, this other team had the responsibility of releasing their first update since I gave them the process. Very simple upgrade process, already fully automated. What could have gone so horribly wrong? Did something the vendor supplied break their client?
 
 I asked for the log files from the upgrade process. They sent them, and they looked... wrong. Very, very wrong.
 
 Did you run the code I gave you to do this update?
 
 "Yes, your code is broken - fix it! Production is down! Rabble, rabble, rabble!"
 
 So, I go into our code management tool and review the _actual_ script they ran. Sure enough, it is my code... But something is very wrong.
 
 More than 2/3rds of my code... has been commented out. The code is "there"... but has been commented out so it is not being executed. WT-actual-F?!
 
 I question this on the bridge line. Silence. I insist someone explain what is going on. Is this a joke? Is this some kind of work version of candid camera?
 Finally someone breaks the silence and explains.
 
 And this, my friends, is the part I will never forget.
 
 "We wanted to look through your code before we ran the update. When we looked at it, there was some stuff we didn't understand, so we commented that stuff out."
 
 You... you didn't... understand... my some of the code... so you... you didn't ask me about it... you didn't try to actually figure out what it did... you... commented it OUT?!
 
 "Right, we figured it was better to only run the parts we understood... But now we ran it and everything is broken and you need to fix your code."
 
 I cannot repeat the things I said next, even here on devRant. Let's just say that call did not go well.
 
 So, lesson learned? If you don't know what some code does? Just comment that shit out. Then blame the original author when it doesn't work.
 
 You just cannot make this kind of stuff up.104
- 
				    					
					
					This code review gave me eye cancer.
 
 So, first of all, let me apologize to anyone impacted by eye cancer, if that really is a thing... because that sounds absolutely horrible. But, believe me, this code was absolutely horrible, too.
 
 I was asked to code review another team's script. I don't like reviewing code from other teams, as I'm pretty "intense" and a nit-picker -- my own team knows and expects this, but I tend to really piss off other people who don't expect my level of input on "what I really think" about their code...
 
 So, I get this script to review. It's over 200 lines of bash (so right away, it's fair game for a boilerplate "this should be re-written in python" or similar reply)... but I dive in to see what they sent.
 
 My eyes.
 
 My eyes.
 
 MY EYES.
 
 So, I certainly cannot violate IP rules and post any of the actual code here (be thankful - be very thankful), but let me just say, I think it may be the worst code I've ever seen. And I've been coding and code-reviewing for upwards of 30 years now. And I've seen a LOT of bad code...
 
 I imagine the author of this script was a rebellious teenager who found the google shell scripting style guide and screamed "YOU'RE NOT MY REAL DAD!" at it and then set out to flagrantly violate every single rule and suggestion in the most dramatic ways possible.
 
 Then they found every other style guide they could, and violated all THOSE rules, too. Just because they were there.
 
 Within the same script... within the SAME CODE BLOCK... 2-space indentation... 4-space indentation... 8-space indentation... TAB indentation... and (just to be complete) NO indentation (entire blocks of code within another function of conditional block, all left-justified, no indentation at all).
 
 lowercase variable/function names, UPPERCASE names, underscore_separated_names, CamelCase names, and every permutation of those as well.
 
 Comments? Not a single one to be found, aside from a 4-line stanza at the top, containing a brief description of that the script did and (to their shame), the name of the author. There were, however, ENTIRE BLOCKS of code commented out.
 
 [ In the examples below, I've replaced indentation spacing with '-', as I couldn't get devrant to format the indentation in a way to suitably share my pain otherwise... ]
 
 Within just a few lines of one another, functions defined as...
 
 function somefunction {
 ----stuff
 }
 
 Another_Function() {
 ------------stuff
 }
 
 There were conditionals blocks in various forms, indentation be damned...
 
 if [ ... ]; then
 --stuff
 fi
 
 if [ ... ]
 --then
 ----some_stuff
 fi
 
 if [ ... ]
 then
 ----something
 something_else
 --another_thing
 fi
 
 And brilliantly un-reachable code blocks, like:
 
 if [ -z "$SOME_VAR" ]; then
 --SOME_VAR="blah"
 fi
 
 if [ -z "$SOME_VAR" ]
 ----then
 ----SOME_VAR="foo"
 fi
 
 if [ -z "$SOME_VAR" ]
 --then
 --echo "SOME_VAR must be set"
 fi
 
 Do you remember the classic "demo" programs people used to distribute (like back in the 90s) -- where the program had no real purpose other than to demonstrate various graphics, just for the sake of demonstrating graphics techniques? Or some of those really bad photo slideshows, were the person making the slideshow used EVERY transition possible (slide, wipe, cross-fade, shapes, spins, on and on)? All just for the sake of "showing off" what they could do with the software? I honestly felt like I was looking at some kind of perverse shell-script demo, where the author was trying to use every possible style or obscure syntax possible, just to do it.
 
 But this was PRODUCTION CODE.
 
 There was absolutely no consistency, even within 1-2 adjacent lines. There is no way to maintain this. It's nearly impossible even understand what it's trying to do. It was just pure insanity. Lines and lines of insanity.
 
 I picture the author of this code as some sort of hybrid hipster-artist-goth-mental-patient, chain-smoking clove cigarettes in their office, flinging their own poo at their monitor, frothing at the mouth and screaming "I CODE MY TRUTH! THIS CODE IS MY ART! IT WILL NOT CONFORM TO YOUR WORLDLY STANDARDS!"
 
 I gave up after the first 100 lines.
 
 Gave up.
 
 I washed my eyes out with bleach.
 
 Then I contacted my HR hotline to see if our medical insurance covers eye cancer.32
- 
				    					
					
					"Sir, I fixed the recent bug"
 
 "Great, what did you do?"
 
 "I commented out the code that was causing it :)"
 
 "Brilliant! You didn't forget to push the code to production, did you?"
 
 "No Sir, I pushed it immediately"
 
 "Marvelous! I'll arrange a promotion for you next month"5
- 
				    					
					
					Code not working.
 Comment out code.
 Slowly rewrite it bit by bit till it works again.
 Check against commented code.
 They're the same.
 Wtf.
 
 Seven hours wasted on this shit :/3
- 
				    					
					
					Dude, for the hundredth time, stop leaving random chunks of commented out code all over the place in case we "need to find it easily later"...
 
 This is literally the reason we use git.
 
 No, I will not pass it in a code review. The same as last time. And the time before...
 
 Dahhhhh15
- 
				    					
					
					This codebase reminds me of a large, rotting, barely-alive dromedary. Parts of it function quite well, but large swaths of it are necrotic, foul-smelling, and even rotted away. Were it healthy, it would still exude a terrible stench, and its temperament would easily match: If you managed to get near enough, it would spit and try to bite you.
 
 Swaths of code are commented out -- entire classes simply don't exist anymore, and the ghosts of several-year-old methods still linger. Despite this, large and deprecated (yet uncommented) sections of the application depend on those undefined classes/methods. Navigating the codebase is akin to walking through a minefield: if you reference the wrong method on the wrong object... fatal exception. And being very new to this project, I have no idea what's live and what isn't.
 
 The naming scheme doesn't help, either: it's impossible to know what's still functional without asking because nothing's marked. Instead, I've been working backwards from multiple points to try to find code paths between objects/events. I'm rarely successful.
 
 Not only can I not tell what's live code and what's interactive death, the code itself is messy and awful. Don't get me wrong: it's solid. There's virtually no way to break it. But trying to understand it ... I feel like I'm looking at a huge, sprawling MC Escher landscape through a microscope. (No exaggeration: a magnifying glass would show a larger view that included paradoxes / dubious structures, and these are not readily apparent to me.)
 
 It's also rife with bad practices. Terrible naming choices consisting of arbitrarily-placed acronyms, bad word choices, and simply inconsistent naming (hash vs hsh vs hs vs h). The indentation is a mix of spaces and tabs. There's magic numbers galore, and variable re-use -- not just local scope, but public methods on objects as well. I've also seen countless assignments within conditionals, and these are apparently intentional! The reasoning: to ensure the code only runs with non-falsey values. While that would indeed work, an early return/next is much clearer, and reduces indentation. It's just. reading through this makes me cringe or literally throw my hands up in frustration and exasperation.
 
 Honestly though, I know why the code is so terrible, and I understand:
 
 The architect/sole dev was new to coding -- I have 5-7 times his current experience -- and the project scope expanded significantly and extremely quickly, and also broke all of its foundation rules. Non-developers also dictated architecture, creating further mess. It's the stuff of nightmares. Looking at what he was able to accomplish, though, I'm impressed. Horrified at the details, but impressed with the whole.
 
 This project is the epitome of "I wrote it quickly and just made it work."
 
 Fortunately, he and I both agree that a rewrite is in order. but at 76k lines (without styling or configuration), it's quite the undertaking.
 
 ------
 
 Amusing: after running the codebase through `wc`, it apparently sums to half the word count of "War and Peace"15
- 
				    					
					
					Why in the name of Donald Knuth did you think it was a good idea to have a 1500 line Java Method? What THE HELL WERE YOU SMOKING THE ENTIRE FILE IS OVER 3000 LINES AND HALF OF THEM ARE COMMENTED OUT!
 
 Don't even get me started on your "unit tests" which is a massive 5000 line behemoth that randomly has massive swaths of code commented out.
 
 And of course no solution like this would be complete with you HARD CODING EVERY F****INIG STRING IN EVERY TIME!
 
 And it's not like you don't know how to use classes as you have several of them, every single one of which is over 500+ lines and consists of only getters and setters. LET ME INTRODUCE YOU TO A MAP! REALLY WHY WOULD YOU USE 500 LINES FOR A CLASS THAT IS JUST GETTERS AND SETTERS?!
 
 The part that really burns me about all of this though, isn't the fact that you sent it to me when I was running into a similar issue, and said "check this out it should help", what bothers me most isn't the indescribable rage I felt looking at your code, the part that really really really bothers me is that you are a veteran with over 15 years in Java development, and according to the org chart are a lead senior engineer getting paid substantially more than me, whereas I am considered a lowly mid-level developer, who isn't worth promoting to your level.
 
 On the plus side you are now going to be featured on theDailyWTF so congrats on the notoriety.8
- 
				    					
					
					Worst of many. Had to work with someone who could be accurately described as a monkey in trousers with strategically cut fur.
 
 Him: "I have refactored code now I have to refactor all your goddamn unit tests"
 Me: "so?"
 <silence>
 <checks his commit>
 Me: "why have you commented out every single line in all the unit tests?"
 Him: "I DON'T BELIEVE WE SHOULD HAVE ANY UNIT TEST. THEY ADD TIME".
 Me:"You cannot be serious. Apart from the obvious mistake in judgement why in the name of blue buggery fuck did you not delete the files? Have you not heard of source history?"
 Him:"...."
 
 I became his lead.
 He left.5
- 
				    					
					
					!rant
 
 Someone just downvoted four of my answers on Stackoverflow just because I commented on one of his answers that "please include some description, just code won't be helpful"
 
 PEOPLE IF YOU CAN'T ACCEPT YOU ARE WRONG THEN GET THE FUCK OUT FROM OUR COMMUNITY AND STOP RUINING IT.2
- 
				    					
					
					I'm editing the sidebar on one of our websites, and shuffling some entries. It involves moving some entries in/out of a dropdown and contextual sidebars, in/out of submenus, etc. It sounds a little tedious but overall pretty trivial, right?
 
 This is day three.
 I learned React+Redux from scratch (and rebuilt the latter for fun) in twice that long.
 
 In my defense, I've been working on other tasks (see: Alerts), but mostly because I'd rather gouge my freaking eyes out than continue on this one.
 
 Everything that could be wrong about this is. Everything that could be over-engineered is. Everything that could be written worse... can't, actually; it's awful.
 
 Major grievances:
 1) The sidebars (yes, there are several) are spread across a ridiculous number of folders. I stopped counting at 20.
 2) Instead of icon fonts, this uses multiple images for entry states.
 3) The image filenames don't match the menu entry names. at all. ("sb_gifts.png" -> orders); active filenames are e.g. "sb_giftsactive.png"
 4) The actions don't match the menu entry names.
 5) Menu state is handled within the root application controller, and doesn't use bools, but strings. (and these state flags never seem to get reset anywhere...)
 6) These strings are used to construct the image filenames within the sidebar views/partials.
 7) Sometimes access restrictions (employee, manager, etc.) are around the individual menu entries, sometimes they're around a partial include, meaning it's extremely difficult to determine which menu entries/sections/subsections are permission-locked without digging through everything.
 8) Within different conditionals there are duplicate blocks markup, with duplicate includes, that end up render different partials/markup due to different state.
 9) There are parent tags outside of includes, such as `<ul>#{render 'horrific-eye-stabbing'}</ul>`
 10) The markup differs per location: sometimes it's a huge blob of non-semantic filthiness, sometimes it's a simple div+span. Example filth: section->p->a->(img,span) ... per menu entry.
 11) In some places, the markup is broken, e.g. `<li><u>...</li></u>`
 12) In other places, markup is used for layout adjustments, such as an single   nested within several divs adorned with lots of styles/classes.
 13) Per-device layouts are handled, not within separate views, but by conditionally enabling/disabling swaths of markup, e.g. (if is_cordova_session?).
 14) `is_cordova_session` in particular is stored within a cookie that does not expire, and within your user session. disabling it is annoying and very non-obvious. It can get set whether or not you're using cordova.
 15) There are virtually no stylesheets; almost everything is inline (but of course not actually everything), which makes for fun layout debugging.
 16) Some of the markup (with inline styling, no less) is generated within a goddamn controller.
 17) The markup does use css classes, but it's predominately not for actual styling: they're used to pick out elements within unit tests. An example class name: "hide-for-medium-down"; and no, I can't figure out what it means, even when looking at the tests that use it. There are no styles attached to that particular class.
 18) The tests have not been updated for three years, and that last update was an rspec version bump.
 19) Mixed tabs and spaces, with mixed indentation level (given spaces, it's sometimes 2, 4, 4, 5, or 6, and sometimes one of those levels consistently, plus an extra space thereafter.)
 20) Intentional assignment within conditionals (`if var=possibly_nil_return_value()`)
 21) hardcoded (and occasionally incorrect) values/urls.
 
 ... and last but not least:
 22) Adding a new "menu sections unit" (I still haven't determined what the crap that means) requires changing two constants and writing a goddamn database migration.
 
 I'm not even including minor annoyances like non-enclosed ternaries, poor naming conventions, commented out code, highly inefficient code, a 512-character regex (at least it's even, right?), etc.
 
 just.
 
 what the _fuck_
 
 Who knew a sidebar could be so utterly convoluted?6
- 
				    					
					
					POSTMORTEM
 
 "4096 bit ~ 96 hours is what he said.
 
 IDK why, but when he took the challenge, he posted that it'd take 36 hours"
 
 As @cbsa wrote, and nitwhiz wrote "but the statement was that op's i3 did it in 11 hours. So there must be a result already, which can be verified?"
 
 I added time because I was in the middle of a port involving ArbFloat so I could get arbitrary precision. I had a crude desmos graph doing projections on what I'd already factored in order to get an idea of how long it'd take to do larger
 bit lengths
 
 @p100sch speculated on the walked back time, and overstating the rig capabilities. Instead I spent a lot of time trying to get it 'just-so'.
 Worse, because I had to resort to "Decimal" in python (and am currently experimenting with the same in Julia), both of which are immutable types, the GC was taking > 25% of the cpu time.
 
 Performancewise, the numbers I cited in the actual thread, as of this time:
 largest product factored was 32bit, 1855526741 * 2163967087, took 1116.111s in python.
 Julia build used a slightly different method, & managed to factor a 27 bit number, 103147223 * 88789957 in 20.9s,
 but this wasn't typical.
 
 What surprised me was the variability. One bit length could take 100s or a couple thousand seconds even, and a product that was 1-2 bits longer could return a result in under a minute, sometimes in seconds.
 
 This started cropping up, ironically, right after I posted the thread, whats a man to do?
 
 So I started trying a bunch of things, some of which worked. Shameless as I am, I accepted the challenge. Things weren't perfect but it was going well enough. At that point I hadn't slept in 30~ hours so when I thought I had it I let it run and went to bed. 5 AM comes, I check the program. Still calculating, and way overshot. Fuuuuuuccc...
 So here we are now and it's say to safe the worlds not gonna burn if I explain it seeing as it doesn't work, or at least only some of the time.
 
 Others people, much smarter than me, mentioned it may be a means of finding more secure pairs, and maybe so, I'm not familiar enough to know.
 
 For everyone that followed, commented, those who contributed, even the doubters who kept a sanity check on this without whom this would have been an even bigger embarassement, and the people with their pins and tactical dots, thanks.
 
 So here it is.
 A few assumptions first.
 Assuming p = the product,
 a = some prime,
 b = another prime,
 and r = a/b (where a is smaller than b)
 w = 1/sqrt(p)
 (also experimented with w = 1/sqrt(p)*2 but I kept overshooting my a very small margin)
 
 x = a/p
 y = b/p
 
 1. for every two numbers, there is a ratio (r) that you can search for among the decimals, starting at 1.0, counting down. You can use this to find the original factors e.x. p*r=n, p/n=m (assuming the product has only two factors), instead of having to do a sieve.
 
 2. You don't need the first number you find to be the precise value of a factor (we're doing floating point math), a large subset of decimal values for the value of a or b will naturally 'fall' into the value of a (or b) + some fractional number, which is lost. Some of you will object, "But if thats wrong, your result will be wrong!" but hear me out.
 
 3. You round for the first factor 'found', and from there, you take the result and do p/a to get b. If 'a' is actually a factor of p, then mod(b, 1) == 0, and then naturally, a*b SHOULD equal p.
 If not, you throw out both numbers, rinse and repeat.
 
 Now I knew this this could be faster. Realized the finer the representation, the less important the fractional digits further right in the number were, it was just a matter of how much precision I could AFFORD to lose and still get an accurate result for r*p=a.
 
 Fast forward, lot of experimentation, was hitting a lot of worst case time complexities, where the most significant digits had a bunch of zeroes in front of them so starting at 1.0 was a no go in many situations. Started looking and realized
 I didn't NEED the ratio of a/b, I just needed the ratio of a to p.
 
 Intuitively it made sense, but starting at 1.0 was blowing up the calculation time, and this made it so much worse.
 
 I realized if I could start at r=1/sqrt(p) instead, and that because of certain properties, the fractional result of this, r, would ALWAYS be 1. close to one of the factors fractional value of n/p, and 2. it looked like it was guaranteed that r=1/sqrt(p) would ALWAYS be less than at least one of the primes, putting a bound on worst case.
 
 The final result in executable pseudo code (python lol) looks something like the above variables plus
 
 while w >= 0.0:
 if (p / round(w*p)) % 1 == 0:
 x = round(w*p)
 y = p / round(w*p)
 if x*y == p:
 print("factors found!")
 print(x)
 print(y)
 break
 w = w + i
 
 Still working but if anyone sees obvious problems I'd LOVE to hear about it.36
- 
				    					
					
					There was a time I made an update on one of our client's e-commerce website sign-up page. The update caused a bug that allowed new users to create an account without actually creating an account.
 
 The code block meant to save user credentials (i.e email address and password) to the database was commented out for some reasons I still can't remember to this day. After registration new users had their session created just as normal but in reality they have no recorded account on the platform. This shit went on like this for a whole week affecting over 350 new customers before the devil sent me a DM.
 
 I got a call from my boss on that weekend that some users who had made purchases recently can't access their account from a different device and cannot also update their password. Nobody likes duty calls on a weekend, I grudgingly and sluggishly opened up my PC to create a quick fix but when I saw what the problem was I shut down my PC immediately, I ran into the shower like I was being chased by a ghost, I kept screaming "what tha fuck! what tha fuck!!" cus I knew hell was about to break loose.
 
 At that moment everything seemed off as if I could feel everything, I felt the water dripping down my spine, I could hear the tiniest of sound. I thought about the 350 new customers the client just lost, I imagined the raving anger on the face of my boss, I thought about how dumb my colleagues would think I was for such a stupid long running bug.
 
 I wondered through all possible solutions that could save me from this embarrassment.
 -- "If this shitty client would have just allowed us verify users email before usage things wouldn't have gotten to this extent"
 -- "Should I call the customers to get their email address using their provided telephone?... No they'd think I'm a scammer"
 -- "Should I tell my boss the database was hacked? Pffft hack my a**",
 -- "Should I create a page for the affected users to re-verify their email address and password? No, some sessions may have expired"
 -- "Or maybe this the best time to quit this f*ckn job!"
 ... Different thoughts from all four corners of the bathroom made it a really long bath. Finally, I decided it was best I told my boss what had happened. So I fixed the code, called my boss the next day and explained the situation on ground to him and yes he was furious. "What a silly mistake..!" he raged and raged. See me in my office by Monday.
 That night felt longer than usual, I couldn't sleep properly. I felt pity for the client and I blamed it all on myself... yeah the "silly mistake", I could have been more careful.
 
 Monday came boss wasn't at the office, Tuesday, Wednesday, Thursday, Friday not available. Next week he was around and when we both met the discussion was about a different project. I tried briefing him about last week incident, he seems not to recall and demands we focus on the current project.
 
 However, over three hundred and fifty customers swept under the carpet courtesy of me. I still felt the guilt of that f*ck up till this day.1
- 
				    					
					
					Let's comment out this block of code so later we know we have this feature and bring it back if we need it.
 
 Later: commented code everywhere, literally everywhere!!! Shit7
- 
				    					
					
					Refactoring code of somebody who left and:
 
 - Plagued the code with TYPOS (milions of them but ok I can live with those... to a certain point)
 - Used global variables by default.... of course even where they're not needed
 - Used comments only in parts of code where... well they're not needed, important ones are of course left out
 - Did not indent code. 3..2..1... Did not FUCKING indent code properly and when he did... did WRONG!
 - Instead of indentation he used commented line with multiple ==== signes.... so far top is 60 consecutive lines with olny ==== again no apparent pattern here
 - Did not follow a fucking standard in variable naming... no camle casing... there are varaibles assigned multiple times to "temp" variables without no reason just for the sake of wasting resources on the system I guess
 
 This is just the beginning of the review but I already want to change job, die, scream, cry... not in any specific order.10
- 
				    					
					
					A colleague named Sam was really pissed off today at an out sourcing firm from India.
 
 My Boss outsourced an application to India based firm. Sam was the one handling the project after the handover. Sam coded a feature 2 weeks ago and moved to staging server for approval. After the sign off from the lead developer of the outsourcing firm, he moved the feature to production. For the past 2 days the application was crashing over and over again so Sam went to check and found out that the feature he coded was causing the issue. When he pulled the feature to his computer and had a look at the code, it wasn’t his code. The code he wrote was commented out and the lead developer of the outsourcing firm wrote new code.
 
 When Sam emailed to him regarding this he replied that he re-wrote his code to fix issues with the feature. Sam and outsourcing firm lead developer had heated argument about this. It’s turns out that the outsourcing developer re-wrote the code without anyone’s approval and on production server.
 
 The lead developer of the outsourcing firm was fired.7
- 
				    					
					
					Mom bought me this mousepad... Written in visual basic...
 What's worse is that the code has five lines that have been commented out 5 5
- 
				    					
					
					Keeping old and unused code blocks commented out and not deleting them immediately is the equivalent of leaving that bottle of soy sauce in the fridge even though you know very well that you won't use them ever again.7
- 
				    					
					
					I've run into problems with the app I'm working on, the problems are related to issues regarding code.
 
 No in fact it's related the last guy who wrote the app, the code has no comments and the variable names make no sense, the only comments in the code are blocks of code... With no reason as to why it was commented.
 
 I have to add in some checks to determine if a person that has logged in is a full member or not (full member has access to the feature I've added) and the way the guy has made this app works makes no sense to me at all.
 
 I've tried my best to avoid all contact with his code because it makes me want to yell out in frustration.
 
 But for this one case I have to work with what's there.
 
 I know I've mentioned this before but I've hit my limit yet again.
 
 And for those who don't know this guy managed to scrape together skeleton code from two apps to make part of this app, rather than using parts of the other apps he left out code that was specifically made for the other apps, (majority of the commented out code).
 
 One app was a taxi app and from the looks of it the feature he used was to get GPS location (which I don't understand before Google maps is a think after all... The taxi app USES Google maps), the other app is some sort of funeral webcasting app (I found code imports for it, without any actual code).
 
 I don't actual understand how this guy could put this together without not thinking "maybe this is a bad idea"
 
 Always code as if the person who ends up maintaining your code is a violent psychopath who knows where you live
 
 I'm that psychopath right now..... Fuck that guy (don't know where he lives though)1
- 
				    					
					
					I was supporting a legacy CRM app which front end used Visual Basic 6 and almost the entire business logic was written on SQL store procedures.
 
 A "feature" of the product was the open code, anyone with admin access could modify forms, code and store procedures.
 
 We also sold "official" (and expensive) consulting services to modify the code.
 
 A long time customer owned this thing and it was heavily customized. They had hired us to change something, hired a third party to make other changes and decided to modify some stuff themselves because, why not?
 
 Suddenly they came to product support asking to fix a bug. The problem happened on a non customized form.
 
 After reviewing, I realized the form used several of the modified store procedures in the business layer. I tried saying we don't support custom code but my boss was being pushed and said "look into it"
 
 All 3 parties denied responsibility and said their changes were NOT the problem (of course). Neither of them commented or documented their changes.
 
 The customer started to threaten to sue us.
 
 I spent 5 full days following every field on the form through the nested and recurrent SQL store procedures and turns out it was a very simple error. A failed insert statement.
 
 I was puzzled of why the thing didn't throw any error even while debugging. Turns out in SQL 2003 (this was a while ago) someone used a print line statement and SQL stopped throwing errors to the console. I can only assume "printing" in SQL empties the buffered error which would be shown in the console.
 
 I removed the print statement and the error showed up, we fixed it and didn't get sued
 :)4
- 
				    					
					
					There was an error in one of my Java file. Impossible to find it. I commented all the code and the error remain. I commented the import of that class and no more error. How the f**** is possible that a empty class give an error ?
 I opened the file in another text editor and found out that the last character was a symbol that wasn't recognize or display in other text editor.
 I was really proud (and confused)3
- 
				    					
					
					One of our senior dev enjoys berating the other devs because they don't check-in code according to his schedule (once a day, once an hour..he flip-flops a lot), then when they do, he 'reviews' their code, beating them up because of incomplete features, commented out code..petty..petty nonsense.
 Ex. (this occurred couple of weeks ago).
 
 Ralph: "The button click code in this event isn't complete"
 Dev: "No, its not, the code in my development branch. You said it was best practice to check in code daily whether the code worked or not. I didn't finish the event last night and ..."
 Ralph: "Exactly. Before you check any code into source control, it has to work and be 100% complete. What if someone moved that code into production? What happens if that code got deployed? I'm not even going talk about the lack of unit tests."
 Dev: "Uh..well..the code is on the development channel, and I branched the project in my folder ...I didn't think it mattered.."
 Ralph: "Ha ha...you see what happens when you don't think...listen..."
 - blah blah blah for 10 minutes of hyperbole nonsense of source control check-in 'best practice'
 
 This morning Ralph's computer's hard-drive crashed.
 Ralph: "F-k! ..F-k! ... my f-king computer hard drive crashed!"
 Me: "Ouch...did you loose anything important?"
 Ralph: "A f-king week of code changes."
 Me: "You checked everything into source control on Friday ...didn't you?"
 Ralph: "F-k no!...I got busy...and...f-k!"
 Me: "Look at the bright side, you'll have a good story to tell about the importance of daily check-ins"
 
 Oh...if looks could kill. Karma...you're the best.
- 
				    					
					
					I was reading the post made by another ranter in which he was basically asked to lower the complexity of an automation script he wrote in place of something everyone else could understand. Another dev commented that more than likely it had to do with the company being worried that ranter_1 would leave and there would be no one capable of maintaining the code.
 
 I understood this completely from both perspectives. It makes me worry how real this sometimes is. We don't get to implement X tech stack because people are worried that no one would be able to maintain Y project in the event of someone leaving. But fuck man, sometimes one wants to expand more and do things differently.
 
 At work I came to find out that the main reason why the entirety of our stack is built in PHP is because the first dev hired into the web tech department(which is only about 12 years old in my institution) only knew PHP. The other part that deals with Java is due to some extensions to some third party applications that we have, Java knowledge (more specifically Spring and Grails) is used for those, the rest is mostly PHP. And while I LOVE PHP and don't really have anything against the language I really wonder what would it be of the institution had we've had a developer with a more....esoteric taste. Clojure, Elixir, Haskell, F# and many others. These are languages and tech stacks that bring such a forward way of thinking into the way we build things.
 
 On the other hand, I understand if the talent pool for each of these stacks is somewhat hard to come up with, but if we don't push for certain items then they will never grow.
 
 The other week I got scolded by the lead dev from the web tech department for using Clojure to create the demo of an application. He said that the project will most likely fall into his hands and he does not know the stack. I calmly mentioned that I would gladly take care of it if given the opportunity as well as to explain to him how the code works and provide training to everyone for it :D I also (in all of my greatness) built the same program for him in PHP. Now, I outrank him :P so the scold bounced out of the window, plus he is a friend, but the fact remains that we reached the situation in which the performance as well as the benefits of one stack were shadowed by the fact that it holds a more esoteric place in the development community.
 
 In the end I am happy to provide the PHP codebase to him. The head of the department + my boss were already impressed with the fact that I was able to build the product in a small amount of time using a potent tech stack, they know where my abilities are and what I can do. That to me was all that matters, even if the project gets shelved, the fact that I was able to use it at work for something means a lot to me.
 
 That and I got permission to use it for the things that will happen with my new department + the collective interest of everyone in paying me to give support even if I ever leave the institution.
 
 Win.13
- 
				    					
					
					LPT: NEVER accept a freelance job without looking at the project's source first
 
 Client: I have a project made by a company that is now abandoning it, I want you to fix some bugs
 
 Me: Okay, can you:
 1) Give me a build to test the current state of the game
 2) Tell me what the bugs are
 3) Show me the source
 4) Tell me your budget
 
 Client: *sends a list of 10 bugs* Here's the APK and to give you the project I'll need you to sign an NDA
 
 Me: Sure...
 
 *tests build*
 *sees at least 20 bugs*
 *still downloading source*
 *bugs look quite easy to fix should be done under an hour*
 
 Me: Okay, so, I can fix each bug for $10 and I can do 2 today
 
 Client: Okay can you fix 8 bugs today for $40??
 
 *sigh*
 
 Me: No I cannot.
 
 Client: okay then 2 today for $20 is fine, I want a refund if you can't fix them today
 
 *sigh*
 
 Me: Look dude, this isn't the first time I am doing this, aight? I'll fix the bugs today you can pay me after check they are done, savvy?
 
 Client: okay
 
 *source is downloaded*
 *literal apes wrote the scripts, commented out code EVERYWHERE
 Debug logs after every line printing every frame causing FPS drops, empty objects in the scene
 multiple unused UI objects
 everything is spaghetti*
 
 *give up, after 2 hours of hell*
 *tfw averted an order cancellation by not taking the order and telling client that they can pay me after I am done*
 
 Attached is an image of a level object pool
 It's an array with each element representing a level.
 The numbers and "Final" are ids for objects in an object pool
 The whole string is .Split(',') into an array (RIP MEMORY BTW) and then a loop goes through each element in the split array and instantiates the object from an object pool 5 5
- 
				    					
					
					I have this project I've inherited, yea I seem to do that a lot, but this damn thing, has to run in php5.4, has deprecated functions for php7 everywhere and a lot of them and there's no classes anywhere beyond some libraries.
 
 Everything is procedural with random scripts being injected left right and center.
 
 I kid you not,
 
 $thisThing = true;
 If(x==y)
 require "path/to/some/script.php";
 else
 require "path/to/a/slightly/different/script.php";
 
 If($thisThing === false){
 // well it was modified in that small block about 10 different times
 }
 
 Those injected scripts then accept data from the parent scope so, looking at file X, you need to have open file A,B, E, and M to understand where variables have been initialised and what there current state could potentially be.
 
 Basically this thing was bandaid after bandaid for feature requests with 0 refactoring.
 
 Here I am trying to implement some basic functionality (should only take an hour or so + a bit of manual testing) but no, I'm literally at the point of hitting the delete button on the entire project and starting again.rant why you no work what did i do to deserve this alcohol is your friend commented out blocks everywhere even with git there was no deleted code kill me now where the hell did that thing come from cocaine may help is this v2 file the right one don't do drugs18
- 
				    					
					
					"I couldn't fix the test so I commented it out."
 
 "I removed build timeouts because our jobs started taking that long."
 
 Next I'm waiting for "Compiling the code is good enough we don't need tests" before I lose it...
- 
				    					
					
					800 line file.
 
 Could be 300 lines but despite having version control, the devs didn't have the balls to remove any of the code. Just commented it out or appended _old to the function names.
 
 "It's easier to undo than version control"
 
 Sure, but how much time are you spending wading through the waist-high swamp of shitty, useless code?6
- 
				    					
					
					Our website stopped working. A coworker said her guess from an error she saw in the logs was that it might have something to do with a bit of a commented line in .htaccess taking itself out of comment and into code due to a specific set of characters the line contained. I looked at .htaccess and thought “Nah, that can’t be it.” and proceeded to troubleshoot pretty much everything but that. After 30 minutes my coworker opened the file and fixed the comment and all was well. I felt stupid because on our team I’m supposed to be the expert that figures out stuff like this.
- 
				    					
					
					I'm working at this company where I have to update their app both for Android and iOS and it was originally coded by what seems to be one guy, that has written some of the worse code I've seen (I've seen pretty bad code when I was at uni), there is so much uncommented code, commented code with no real reason on why it's commented, variables that are one or two letters, Lots and Lots of magical numbers for things like images! And for the first few weeks working on the iOS app I was also still learning objective-c and had to look at his code for reference, I cringed so much.
 
 I take pride in my commented code, I take pride in writing description for methods and having my variables at the top of a class and explain exactly why it's a constant. I'm also only just a recent graduate.
 
 This guy that worked out this app is a senior developer, now working on security software for a bank, how is he even allowed to code?3
- 
				    					
					
					So, I got a ticket to make a page using a given wireframe that had submit buttons and other buttons to add more items in the wireframe.
 
 So, I pull the html, hook up the abilty to submit the form and add items, and send it out for review.
 
 One comment on the review.
 
 "Remove the functionality, you'll handle it in the next ticket"
 
 So I commented out the javascript. Guess what I'm doing on the next 10 minutes.1
- 
				    					
					
					There was an android project that I got from my senior.
 
 he told me that another developer already completed most the project and all I have to do is minor changes...
 
 Well when i saw, i was amazed that the code he commented is more than the actual working code without any structure.
 He copied most of code from internet.
 
 If it's not working, put in comment else use it.
 
 It took me a whole month to figure out what's going on.
 
 And another 2 months to fix the issues.
 
 Well in last my senior told me that the developer took 1 year to write this code
 (to be honest any normal developer can complete that project in less than 3 month)2
- 
				    					
					
					1) Read the wiki on git. I probably have enough shorthands and test methods that you won't need much other shit to debug issues.
 
 2) when debugging, remember that if it is there, there's a good reason why I put it there.
 
 3) commented-out code is probably useful for maintenance. I left it there for a good reason. 😛
 
 4) chances are whatever I wrote, was the state of the art at the time I wrote it. There might be better ways to do it now tho.
 
 5) I always work modular. First, understand the structure. (probably also documented on wiki) DO NOT fuck up the structure. If you change it, you document it.
 
 6) If you feel I wrote shit, it's probably because management annoyed the living shit out of me. Pun intended.
 
 7) Your confusion is normal. I don't do dumb shit.4
- 
				    					
					
					Maintaining old code as comments, coz... you never know when that bug in your commented code turns out to be the next big feature.5
- 
				    					
					
					I've been using devRantron recently to try it out. It's hard enough to be productive when I just get notifications on my phone, but getting desktop notifications that pop up over my code... how can I not immediately go look who commented on what??
 
 So thanks guys, the app is great, but I have a love/hate relationship with the desktop notifs due to my lack of self-control.2
- 
				    					
					
					I was out sick the day an urgent ETL job I was building would be due, so it got reassigned. When I return, I find most of my code commented out and replaced.
 
 The first step was rewritten, with a comment that reads "Made changes to run faster." What used to be a single execution lasting 30 seconds was now a 4 step process taking 5 minutes, and yielding identical results.
 
 Being a one-time execution (not a recurring job), I'm left wondering why they thought execution speed was even an issue, let alone what about their redesign they felt was an improvement...2
- 
				    					
					
					Does most memorable in a bad way count? 🤔
 
 He left almost 2 years ago..or even more.. left a bunch of bugs and logical fuckups for me to fix.. some already fixed, some still lingering there..
 
 I want to not blame him for everything, since we lack proper code review protocols and all.. but I've asked on several occasions if he understands the problem and what must be done..and the answer was always yes..results, after I got time to check up on him, the code he wrote was most probably copy pasted from stack overflow or somewhere else.. butchered in any and every way possible..
 
 And of course already checked in to TFS.. along with bunch of files that were not even changed (he didn't bother to check that and exclude them) + a bunch of files from other projects... Told him to not do that on several occasions too, but he still managed to fuck things up this way.. leaving all the uncommented debugger; crap and alerts in the js files..
 
 On one occasion I was working on new GUI..api part I already finished..got the order from above to delegate this to him as it is not much he can fuck up so I could focus on more important & complex stuff..
 Maybe additional 4h of work + testing for everything..
 I show him the prepared files, one controller, one view..explained what parts of code goes where etc.. a little short of writing everything myself.. Ask if he understands what needs to be done & how and told him if he has any problems/questions to ask me asap..
 Said he understood what needs to be done.. after a day or two he asks me why something is not workig as expected.. I check the files, correct initialization was commented out and all the code was stuffed in the view file.. Took him another day to move the code to proper files.. Not sure about the possible bugs left there as the client later decided that they will not be using this..
 
 I later found out that years of C# experience on his CV was actually a school course.. he didn't even know why the changes on api are not showing up..because he didn't know that he has to build the code..
 
 I mean, if he was honest when asked about experience with .net, we would've taken a month or two to just explain everything from the start..
 
 But as he didn't and based on his CV (much more experience with .net than me) and 'I understand everything' attitude from the start I assumed he knows WTF was he doing..
 
 Boy was I wrong..
 
 He was also more interested in how much I get payed and if I have a company phone etc..than actually doing his job.. I fucking hate chit chat, and this..well.. he didn't get the hints that this is in no way appropriate to ask.. I've told him that if he has problems with his pay and bonuses that he should talk to the management and not me about this..and that I'm only interested in his actual work and progress..
 
 So yeah, I'll definitely be remembering this guy till the day I die..3
- 
				    					
					
					Had to fix a bug in flask App built by 3 ppl !
 So I some how roughly figured out the code and was trying to fix.
 The bug was
 I click on submit, two times the record was entered into database.
 (Second time, duplicate error).
 
 So to figure out ,I just commented the code which inserts to DB!
 
 Whola!
 Now only one record is inserted!
 I still don't know where it's actually inserting !, And IDC , problem fixed
 
 Shall I boast about my skills!?😂3
- 
				    					
					
					(first post/rant on here)
 So I recently started at a new company. I was kinda aware that the project I'm working on would be rather old school (to put it in a nice way :-)).
 
 Part of my job is to 'industrialize' and update/clean up the existing code so there is less time spent on fixing bugs due to bad design.
 
 One of the first things I had to do was to write a new interface to integrate with external software.
 
 I already noticed some rather nasty habits, like prefixing every variable with m (don't know why), private fields for every property (all simple properties) and a whole lot of other stuff that either is obsolete or just bad practice.
 
 Started writing clean code (simple classes with properties only, no m prefixing, making sure everything is single responsibility, unit tests, ...).
 
 So I check in the code, don't hear much from it again besides the original dev/architect that started the project using my code to further work on that integration.
 
 Now recently I started converting everything from TFVC to Git (which is the company standard but wasn't used by our team yet). And I quickly skimmed through my code to check if everything was there before pushing it to the remote repo.
 
 To my surprise, all the code I had written was replaced by m prefixed private variables used in simple properties. BL classes were thrown in together, creating giant monstrosities that did everything. And last but not least, all unit tests were commented out.
 
 Not sure what I got myself into ... but the facepalming has commenced.14
- 
				    					
					
					I have been very inactive in these last couple of months but I really need to rant right now:
 
 I am working on a project, which is also part of a contest, with a few of my friends. I asked one of them to write a bit of code and some documentation about it, here's the result:
 
 He wrote half a page of text with plenty of spelling mistakes and grammatical errors but here comes the even worse part:
 Instead of just leaving the code in its own file he copied it into the word (libre office writer) file as well. Now I have got 3 pages of non-indented code with a few comments flying around here and there, weird variable names and a lot of commented out pieces of code.
 
 Bloody hell I feel like I am the only one in this team taking this contest serious.3
- 
				    					
					
					I have always believed that clean code is readable code, and if your code is readable, then it shouldn't require masses of comments to explain it. However, in the course I am being taught, we are being told that in programming, comments are massively important to help another developer understand your code and what it does. So what is the consensus of the dev community?
 
 Do you feel comments are key, or redundant if your code is written well?19
- 
				    					
					
					So first of all merry delayed Xmas and of course wishing you all a happy new year.
 
 Now...
 
 I always loved designing and coding, yes I actually like it, I must be absolutely mental or something.. I finally after pushing myself through hours upon hours of courses, finishing most within 15% of the allotted time, and doing more then was requested, I finally found a job, related to front-end development. You might think "Gee; good for you buddy, you filthy commoner.." Well; it didn't last all too long, I basically after nailing the interview process got my first day there within a few days, now I am absolutely stoked and my nerves are shot, plus the 4 cups of coffee aren't helping. I literally was so nervous to do well on my first day, that I slept for only one hour, literally one bloody hour.
 
 I get into the office where I am greeted by an amazing laptop, I mean high-end gaming 360 no-scope all over the place gaming. I sit down and start on getting all my tools ready to go (they let us use whatever IDE we wanted, which I thought was amazing) after getting my IDE and the plugins and all the emails/Slack etc setup, I then get told to get a Dropbox account. I assumed the Dropbox account was just there to share things quickly with the designers, we would obviously be using Git right?! Well; no not exactly, actually not at all - we all used the Dropbox account of one of the bosses, I swear everybody pushed and pulled stuff all the time, a copy of the boss's passport was in there as well, and they had projects from and up to 3 years ago, still in there... It took my Dropbox 3 bloody hours to grab as much as it could to actually allow me to get started...
 
 I then to my absolute dismay notice that I would be working on a prefab of a prefab, basically the only thing I would be responsible for, is to adjust the animations and aligning elements.... Aligning and animations.... Fine, I guess it could be worse right? Started going along with it, using a framework that I never heard of before, till like a good 3 days before starting there called "Greensock" which is amazing I must admit, could've helped me allot on my solo-projects. Problem was; we had designers who wanted things, that just looked plain horrible, it was never 'on-point' so to say, maybe it's just me being a perfectionist but it just looked wrong.
 
 Finally got it done after struggling with the prefabs and what not, then the day was almost over and I finally got to go home, fortunately dodging the drinking that was occurring around 4 in the afternoon in the middle of the office, it wasn't beers or anything of the sort - but hard liquor along the lines of Wodka and straight up Gin. I fortunately had a personal issue I had to attend too, so I got out of there before things got too crazy and they went out for dinner stumbling all over the place.
 
 Well this wen't for a few more days (minus the drinking), with 8 being the exact number of days and my grievance list only kept growing. I was for one a junior-developer and thus with them knowing was supposed to get training from our lead, however; that never occurred instead said 'lead' would leave early or be completely absent on most days, leaving me to mess around with prefabs that did my head in, with no comments nor any indication what it did or should've done, I spent hours just adjusting one line of code at a time to see what would happen.
 
 Eventually they told us to work from home only, so I did - did a project here and there and then got told they wouldn't keep me on board any longer, stating I was too inexperienced and they didn't have enough work (which was a load of bs) and that I lacked "office experience" whatever the heck that means, I was always sociable and hell I ever cracked people up, kept a neat and orderly list of things that needed doing, I even contrary to most commented on my code, so the next poor sod wouldn't be going through 'try by error' hell that I wen't through.
 
 Either way; I currently have been feeling absolutely wrecked in terms of motivation, that job would've solved my financial situation and allowed me to finally do what I wanted to do. Instead of doing some random dead-end job each week or month, I would've had a steady income and something I could've built on.
 
 But to add some positivism to this endless and too long of a rant... I'm currently going through a boot-camp and doing a small Linux based course on the side, this little thing isn't going to hold me back; yeah it will be tough, but then again most things don't come easy..
 
 Thank you for reading and I hope you have allot and I mean allot more luck on your first job.5
- 
				    					
					
					I don't know what you did yesterday, but i did make my company throw away 2 months of progress.
 It all started in the beginning, since that i've made numerous complaints about the workflow or code and how to improve it. I've been told off every time, and every time i either told the boss who agreed in the end or wrote code to prove myself. Everything was a hassle and my tasks weren't better.
 Team lead: you'll do X now, please do that by making Y.
 Me: but Y is insecure, we should do Z.
 Team lead: please do Y
 Later it turns out Y is impossible and we do Z in the end...
 Team lead: please do W now
 Me, a few days later: i've tried and their server doesn't give http cors headers, doing W in the browser is impossible
 Team lead, a few days later: have you made progress on W?
 Me: * tells again it's impossible and uploads code to prove it *
 Team lead: * no response *
 
 After that i had enough. Technically i still was assigned to do W, but i used my time to look over the application and list all the things wrong with it. We had everything, giant commits, commented out code, unnecessary packages, a new commit introduced packages that crashed npm install on non-macs, angularjs-packages even though we use angular, weird logic, a security bug, all css in one file even though you can use component-specific css files...
 
 I sent that to my boss, telling him to let the backend-guys have a look at it too and we had a meeting about this. I couldn't attend but they agreed with me completely. They decided to throw away what we have already and to let one of the backend-guys supervise our team. I guess there will be another talk with the team lead, but time will tell.
 It feels so good having hope to finally escape this hellish development cycle of badly defined task, bad communication and headache-inducing merges.
- 
				    					
					
					After CR. Seen a function called "initConfig", with another version of it commented out.
 I said in the CR - delete the commented function out.
 
 In response, the developer said that it is needed. The commented version is for local run, while the other is for production.
 
 After a lovely argument about cancer in our Code-base, the project manager concluded that we don't have time to do it better, and basically forced me to basically accept.
 
 I hate being sane sometimes.
- 
				    					
					
					When you accidentally commit and push code that has massively commented out sections that you meant to remove >:/  
- 
				    					
					
					Not sure to delete this block of code... or just comment it out until product owner changes her mind!3
- 
				    					
					
					I'm in a situation here, I had an idea for an app and I started coding it. Since I'm a front end developer I find it not amusing to do the backend part. I then started to share the idea and such with good classmate (not a coder). I then made him join me on this adventure. After a lot of coding he said he wanted to contribute with something since I'm coding all day and he's not. Then we agreed freelancing the back end part.
 
 Some time later we got a pretty good deal on some Indians doing the whole app. I thought to myself "this feels kinda good!" so we went on with the freelancer.
 
 Days went to months and we finally got the app back. I did a mistake of paying him all the milestones without testing the app in its wholeness, later finding out that one part of the login system didn't work. That lead to a deeper debug to find out that the core function of the app was commented out.. I then wrote the freelancer back with minimal and slow response.
 
 Now the deadline of the app is like in 2 months. If not we miss a whole year.
 
 My classmate knows about this and he's the one who played for the freelancing. Now we have talked about me doing the whole backend myself.
 
 The only issue I have now is that I feel like he's just sitting home doing nothing other than flashing money around and me busting my ass of writing code that I really am not good at. (basically learning more than coding)
 
 But he played a lot of money for this.. So I feel kinda bad for him.
 
 Rip life.15
- 
				    					
					
					So.. I'm giving one of my employers webapps a visual refresher, new company branding and whatnot.
 
 And then I stumbled onto a check that is not returning what anybody expects, and, well , I'm busy fixing things, yeah..? so I go digging.. 🤔
 
 ```
 function isDefined(obj) {
 return !(typeof obj === "undefined") || obj !== null;
 }
 ```
 
 Here's the fun part, these particular lines have been in the code base since before 2017, which is when my Git history starts, because that's when we migrated projects from Visual SourceSafe 6 over to Git. Yes, you read that right. They were still using VSS in 2017.
 
 I've begged and pleaded with my last 3 bosses to let us thrown this piece of shit out our second story window and rewrite it properly. But no, we don't have time to rewrite, so we must fix what we have instead.
 
 I lost 4 hours of my life earlier today, tracking down another error that has been silently swallowed by a handler with its "console.log" call commented out, only to find that it's always been like that, and it's an "expected error". 🤦
 
 Please, just fucking kill me now... I just, I can't deal with this shit anymore.5
- 
				    					
					
					Ah, love it when my code doesn't work because it's commented out and I have no fucking idea when I did that :)1
- 
				    					
					
					Recently, I had to make a minor modification to some Node.js code a coworker wrote a year ago which buffers stringified JSON into Kinesis. I just needed to add a new key to the input object, it took minutes to make the change, but hours to make sense out the absolute trash spaghetti code this guy wrote. After spending half a day trying to make his code readable, I just got so pissed off. I replaced his 15 files/+1,500 lines of uncommented code, filled with classes, factory functions, poorly named functions and vars, and so, so many spelling mistakes.
 
 We now have a single, well commented, 300 line file that does the same thing.
 
 Get that shit code out of here.
- 
				    					
					
					My first rant for ages
 
 I'm working on a new project at a new company. We ha e a bunch of front end clients talking to an api.
 
 I suggested that the api only communicate in terms of view models in order to bring some kind of standardisation to the project since at the time the gets and posts were either dB entities, view models, or just whatever the dev at the time decided.
 
 I got a no, but that we could do posts and gets just with database entities. OK better than nothing..
 
 I'm the front end angular app I implemented a generic form component and a generic data table component. The models given to these to build the components need to implement a view model interface.
 
 Now we have a problem of the api giving us not view models and the front end needing view models so I put together a way to handle this in the front end.
 
 My colleague with 8 years experience asks for my help and I'm happy to oblige. It turns out a model should have multiple child models in the database but the database entity models don't reflect this and therefore there is no way to build the view models. The data just isn't there from the api... Still I show him what the front end model should look like and write all the front end code for him to handle that.
 
 2 days later he asks for my help again. It's exactly the same problem. Instead of fixing the backend and setting up the one to many relationship he has ignore the problem, retrieved a one to one relationship model and is just trying to force it to work - even though the data isn't there. He has also commented or removed all the code I helped him write and overwritten a file of typescript models that get autogenerated for us to be in sync with the backend...
 
 I actually felt bad afterwards but I got frustrated as hell and he could tell...1
- 
				    					
					
					I understand that changing code requires it to be tested, but removing code that has been commented out for years shouldn’t matter!
 
 Save my soul11
- 
				    					
					
					Technical debt.... so much technical debt it’s driving me crazy!
 
 It’s not only that there’s commented out lines in abundance, methods and whole classes not used anywhere anymore in a decade and code using not only deprecated standard library functions, but some that have been REMOVED in earlier versions of the language (have no idea how those have even stayed functional...), and documentation that has very little to do with the reality... but today, I submitted a pr to fix the documentation for setting up dev env - which was outdated already when I started a few years ago!
 
 I know we are understaffed and busy, but c’mon - it doesn’t take much to leave the code in a better place than when found...4
- 
				    					
					
					So @SirusAmory inspired me to put a commented out youtube link in a source code featuring my sickest kickflips.3
- 
				    					
					
					Typescript: All of your javascript code is valid typescript
 Installs Typescript
 runs typescript
 Typescript: line x in function y has an error
 Checking the function for error and the code is fine
 After wasting an hour comment out all the linez in function y
 Run typescript
 Typescript: you have an error on line x which is commented in function y
 
 ERROR IN A COMMENTED LINE :(4
- 
				    					
					
					i was hired to join a team of old devs (40+) in an unnamed European country "yay goodbye 3rd world it's time to enjoy the quality of life" assist with enhancing already existing software and creating new solutions.
 prior to my arrival most things were slow and super buggy, looking at the code base it shouldn't be a surprise, amateur hour everyone, logic implemented that is not needed, comment driven development, last time code review was done back in 1996. lots of anti patterns.
 i swear there is a for loop that does nothing but it loops through a 100+ elements list, trunk based development with tfs since git is "not really needed"
 test projects are not there.
 >enter me an educated fool, with genuine passion for the craft and somehow a decent amount of knowledge.
 >spent the last year fixing stuff educating people on principles and qualities.
 > countless hours of training and explaining. team is showing cooperation, a new requirement comes in to develop with react.
 > tear my ass creating reusable shit and self explanatory code with proper naming etc using git with feature branching, monday is first deployment day.
 > today a colleague was working on an item submit a pull request and self approve it
 > look at the code..... WTF the dumb fuck copied and pasted the whole code from different kendo components but somehow managed to refractor the name to test component, commented out all the code that he didn't use did the api call directly from the component, has 2 useeffects that depends on the a fucking text box changes for no reason, no redux implementation, the acceptance criteria is not achieved, and it doesn't work it just look right.
 > first world country shit cannot scold, cannot complain, lead by example.
 >asked him why you did this, the response was yeah probably i shouldn't have done that, i really didn't understand anything in the training but didn't want to waste time!!!!
 > rest of the team created a different styled disaster with different flavors they don't even name their shit the same way.
 
 fellow developers I'm stuck in a spaceship with a bunch of imposters, seriously i never cried in my entire life now I'm teary and on the verge of a break down.
 talk with management "improving needs time" and offers me to join a yoga session to release the stress as if reaching nirvana would deliver shit on monday.
 i really don't know what do is this a rant, is this a cry for help, I'm not sure, any advice is welcomed.7
- 
				    					
					
					Looking through code, discovered a front end plugin wasn't activating right on a form input. Go look at the code, intern commented it out and wrote a comment saying "This didn't work and I didn't know how to fix it. So I turned it off." If you don't know, then ask. Don't leave it broken and not tell anyone! I am so glad this kid is gone. I really hope he doesn't come back after term.1
- 
				    					
					
					I have a friend which have a hoarding disorder when it comes to coding. Here are some of the things he does:
 
 1: If he rewrites, remove, or in any other way refactor a function, then he keeps the old one in the file commented out.
 
 2: If he deletes a class then he takes the code and paste it into a class that he have just for old code. AN ACTUAL CLASS! Not just some random text file somewhere. Even though it is commented out, he leaves it so that you can initiate his garbage.
 
 3: In point 1, the code is not pasted on the end. It inside all the other actual code.
 
 So if you try to help him with something, then you have to dig through a mountain of shit just to find some code.5
- 
				    					
					
					my fist job... i get to edit a c++ code written by a (mind you) programming company that they teamed with for the past(mind you again) 3 years ...
 now just for starters, this code was edited by self taught coders that are really good engineers(they are really good), that didnt really know how the code worked before yet they still changed it, and it worked, how ever they wanted some changes.
 i get the project files, and there is not one single comment describing what is happening... only code commented out... and no documentation what so ever were done....
 so below are some of my comments that i wrote after i finished adding what i had to add, and fixing what i had to fix:
 
 /*first rule of C anything coding, no actual functions in the header, well let me introduce you to a fully functioning thread running program all in the header, enjoy*/
 
 //used to control the thread
 // i honestly dont know why, but it worked soooooo yea...
 
 // TG uncommented // for absolutely no reason what so ever...
 
 //used to communicate with the port
 
 //the message to be sent to the inverter, which has a code that will handle it
 //hmmmmmm...
 
 //again not usefull since we are using radioButtons
 // same ...
 // same ...
 // same ...
 // they said they dont even use this mode, but none the less, same ...
 // calculate the checksum for the message
 // ....
 // one of the things that work, and god forbids i touch
 // used for the status displayed on screen
 // used for the (censored :P) status in the message
 // used for the (censored :P) status in the message
 // not used at all, but the message structure contains it and i refuse to edit that abomination
 // used for the (censored :P) status in the message
 // used for the (censored :P) status in the message
 // just dont ask and roll with it, i didnt want to touch this
 // saaaaame ...
 // if before true this saaaaaame ...
 // value of the (censored :P)
 // it pains me to say it again, but this is no use
 // (censored :P) input
 // (censored :P) input
 // only place seen , like for real it was just defined,sooooo yea :D
 // well you know how it is
 // message string
 // check sum string
 /****below from feed back****/
 // (censored :P) coming in
 // (censored :P) coming in
 // (censored :P) coming in
 // (censored :P)
 /****below is the output to the receiver ****/
 //(censored :P)
 // (censored :P)
 // (censored :P)
 // (censored :P)
 //you thought we were done.... nope, no idea. it comes in the feedback
 // not used, literally commented out the one time it was used
 // same ...
 // XD, man this is a blast, same ...
 // nope ...
 // used to store the port chosen for the communication
 // is a static for the number of data we have recorded so far, and as a row indicator for the recording method
 // used to indicate the page we are on in the excel file, as well as the point in physical point in the test
 // same ... oh look at this a positive same :D
 // same ...
 // same ...6
- 
				    					
					
					Coworker pushed some changes and gave me good reason to rant.
 Here's my story:
 I start implementing a new feature, senior reviews it and suggest some changes, which are actually good ideas. I continue developing and implement the suggested changes.
 The next day, senior keeps working on outdated source and makes similar changes like i did on the day before. Just pushes it anyway and breaks fucking everything.
 The api now contains redundant information.
 My classes still exist, but aren't used anymore. Let's keep some redundant code in the project, because deleting it is so much work.
 All the unit tests broke, but he just commented them out, so everything is green again. We have now 0 tests which actually do something in the project, but at least the build is green...1
- 
				    					
					
					Whenever I cancel out old chunks of code that do not serve their function anymore, or that I commented out in early phases to make space for better functions, I feel dead inside. It's almost like if I was saying goodbye to a very old friend, who supported me through the project and reminded me of how I started it.
 
 Than I notice how stupid and/or inelegant that chunk was, and feel better. 😂
- 
				    					
					
					Today we found out that my brother has a condition, triggered by a stressful event, that causes his heart to try and shutdown.
 
 The dev in me is screaming "fix the bug!"
 The crazy in me wants to start punching doctors in the face til we find a solution.
 
 But the rational side of me knows there's nothing that I can do because that magical asshole in the sky didn't commented his code...3
- 
				    					
					
					I have a nightmare project that I will probably be ranting about quite a lot in the coming weeks, but I don't want SEO to pick up the specifics on the off chance my peers Google the issues we're facing and my profile comes up.
 
 Let me set up the scene by describing the predicament, and then I'll get to the most outrageous thing I've heard while working at this job. It gives you a CLEAR idea of why we're in this situation in the first place.
 
 Anyways, the nightmare project only runs in IE with compatibility mode set to version 6. So it only runs in IE 6 at the latest.
 
 And it is massive. I'm talking real, real enormous.
 
 The most recent roadblock I ran into while Chrome-ifying it is the extensive use of a browser API that was removed 8 years ago.
 
 It involves synchronous data input and I know for a relatively certain fact there's no way to fix it without combing through every single reference to this API and converting the ones that need sync data (not all of them do) to callbacks. How big of an issue is that?
 
 Well, just one of that 15-ish modules has over 900 references to it. Even just creating a spreadsheet of "commented out / doesn't need a fix / needs fix" for each reference in 1/15th of this project would take days of manual labor.
 
 Here's the rant.
 
 So after discussing this issue in the meeting (we ended on "they don't believe me that we can't just replace it with jQuery") I brought up the next issue. One of our 3rd party libraries is so old it doesn't work anymore and we can't modify that code (it's compiled).
 
 They said that even if it was backwards compatible (no fucking way. This version is like, at least 10 years old, I guarantee it) they can't simply replace it because we don't have a subscription to this product anymore (suggesting we find an alternative).
 
 And I fucking kid you not, this is what happened next.
 
 They then began discussing how this is why you shouldn't use 3rd party code. Because it becomes obsolete and you can't even fix it yourself because it's not yours to edit.
 
 Yes. They said this DIRECTLY after we discussed our 900+ references to a browser API >>REMOVED<< 8 years ago. Yes, they said this about a 3rd party library that receives regular support but is totally FUCKED because we NEVER updated it after adding it and we never even renewed the LICENSE.
 
 What the FUCK2
- 
				    					
					
					Stop commenting out code blocks!
 
 Either fix your shit or delete it.
 
 I am open to argue what fixing may mean, as it is perfectly fine to make your broken code not reachable, e.g. via feature flags or skipping certain tests. Yet never ever should you comment those blocks!
 
 So you say you want to keep it for historic reasons? You know, that is why we use version control! If you ever need certain functionality back, you can restore that state.
 
 Each decent IDE also offers a local history where you can even restore code blocks that weren't even pushed or committed. So use that!
 
 Commenting out test cases is a really bad habit, as you have no reminder that you shall restore it.
 
 And no, a TODO and a FIXME won't count as a reminder as you have to actively look for them. And we all know how well that goes, don't we? (One time, I found a typo of a `TDO`. So even with a regular lookup for TODO, stuff will slip.)
 
 Each test suite offers you ways to skip tests if there are valid reasons why they should not fail the build temporary and they offer colorful feedback. Yes, that means that your tests won't be green, but guess what: That's a feature! They shouldn't be.
 
 That yellow is a fine reminder, aka warning!, that you should really fix your shit.
 
 Commented code screams: "I DON'T KNOW WHAT I WAS DOING!" and it confuses the hell out of other developers ("Was this commented because of debugging purposes and should be active again or can I safely delete this!?") and adds verbose crap to the code base.
 
 If you find yourself to be in a place that you comment code a lot, I also argue that your workflow is broken.
 
 When you are using a decent debugger, there shouldn't that much of a need to comment in and out a lot of code in order to reason about your code-base.3
- 
				    					
					
					Blaming the computer when in reality you commented out about 80% of the code (by accident), and not noticing for a good hour.
- 
				    					
					
					In CS class I had a only 10 lines long python script (everything else was commented out). It didn't work and I searched the bug for ca 20 minutes. I asked a class mate (who commented the other code out) if he could figure it out and he just says: "The indention of the comment is wrong". We had a discussion that it doesn't matter how to indent comments. In the end he selected all the lines, pressed tab and it just worked ?!?!6
- 
				    					
					
					Created a piece of code (code A). It didn't work.
 Found a replacement on StackOverflow (code B), commented out my code A and tried the new one.
 Everything seemed fine, deleted code A. Tried the app and it crashed.
 Re-added the commented code, and the app started working again.
 
 -_____________________-2
- 
				    					
					
					The worst kind of legacy code is the one in which a function body run miles climbing if-else ladders until nobody knows where the sky hits the floor, and returns when nobody is looking.
 The best kind of legacy code is the one which is fully commented out!
- 
				    					
					
					Some of you know I'm an amateur programmer (ok, you all do). But recently I decided I'm gonna go for a career in it.
 
 I thought projects to demo what I know were important, but everything I've seen so far says otherwise. Seems like the most important thing to hiring managers is knowing how to solve small, arbitrary problems. Specifics can be learned and a lot of 'requirements' are actually optional to scare off wannabes and tryhards looking for a sweet paycheck.
 
 So I've gone back, dusted off all the areas where I'm rusty (curse you regex!), and am relearning, properly. Flash cards and all. Getting the essentials committed to memory, instead of fumbling through, and having to look at docs every five minutes to remember how to do something because I switch languages, frameworks, and tooling so often. Really committing toward one set of technologies and drilling the fundamentals.
 
 Would you say this is the correct approach to gaining a position in 2020, for a junior dev?
 I know for a long time, 'entry level' positions didn't really exist, but from what I'm hearing around the net, thats changing.
 
 Heres what I'm learning (or relearning since I've used em only occasionally):
 
 * Git (small personal projects, only used it a few times)
 * SQL
 * Backend (Flask, Django)
 * Frontend (React)
 * Testing with Cypress or Jest
 
 Any of you have further recommendations?
 
 Gulp? Grunt? Are these considered 'matter of course' (simply expected), or learn-as-you for a beginner like myself?
 
 Is knowing the agile 'manifesto' (whatever that means) by heart really considered a big deal?
 
 What about the basics of BDD and XP?
 
 Is knowing how to properly write user-stories worth a damn or considered a waste of time to managers?
 
 Am I going to be tested on obscure minutiae like little-used yarn/npm commands?
 
 Would it be considered a bonus to have all the various HTTP codes memorized? I mean thats probably a great idea, but is that an absolute requirement for newbies, or something you learn as you practice?
 
 During interviews, is there an emphasis on speed or correctness? I'm nitpicky, like to write cleanly commented code, and prefer to have documentation open at all times.
 Am I going to, eh, 'lose points' for relying on documentation during an interview?
 
 I'm an average programmer on my good days, and the only thing I really have going for me is a *weird* combination of ADD and autism-like focus that basically neutralize each other. The only other skill I have is talking at people's own level to gauge what they need and understand. Unfortunately, and contrary to the grifter persona I present for lulz, I hate selling, let alone grifting.
 Otherwise I would have enjoyed telemarketing way more and wouldn't even be asking this question. But thankfully I escaped that hell and am now here, asking for your timeless nuggets of bitter wisdom.
 
 What are truly *entry level* web developers *expected* to know, *right out the gate*, obviously besides the language they're using?
 
 Also, what is the language they use to program websites? It's like java right? I need to know. I'm in an interview RIGHT now and they left me alone with a PC for 30 minutes. I've been surfing pornhub for the last 25 minutes. I figure the answer should take about 5 minutes, could you help me out and copypasta it?
 
 Okay, okay, I'm kidding, I couldn't help myself. The rest of the questions are serious and I'd love to know what your opinions are on what is important for web developers in 2020, especially entry level developers.7
- 
				    					
					
					i once explored our codebase and copied every line of commented out code into a text file. that file is over 350 lines long.1
- 
				    					
					
					Working on a new release. This release was tested locally and pronounced good. The release went to the QA environment. QA responds that a new feature is doing nothing. There are no errors reported, and work is being done on the UI, but is not get getting persisted to the database so all changes are lost when the session is lost. Do some investigating. I find that a web service had the code in two of its methods commented out. Why? No idea. No response yet from the developer who just had the two methods return a boolean denoting success while all other operations were commented out.
 
 I need an appropriate punishment for this...3
- 
				    					
					
					In my first dev role I commented out the code for sending acknowledgement emails when a user placed their order, and didn't realize when I committed it. It got pushed to production and we found it a week or so later.
 
 Was probably a factor in me getting sacked from there.4
- 
				    					
					
					That moment when the code that was supposed to be removed in only commented out!!! The guy butchered a bunch of classes by commenting out about 1000 lines of code
- 
				    					
					
					Best debug ever?
 
 Some years ago we had to do a web project as group. It was a cinema like website with backend and front-end.
 
 So in the end we arrived at the presentation and while scrolling the code I found commented out some authentication controls 😅😆 (probably for debug reason lol)
 Whatever, meanwhile, while I was talking with the professor two of my mates were whispering... Turns out they found what he mail service wasn't working. And what's best than fix it, push it to the Heroku server and restart all? XD
 The professor noticed some little lag in a button and asked "what's happening?"
 "oh, nothing we just restarted the server "
- 
				    					
					
					How "commented" is your org's codebase?
 
 I joined this company a few months ago, and I've yet to see a single comment explaining how/why some code (doesn't) work.
 
 It's a great company for the most part, this just seems to be the standard practice here and I'm wondering how many more like it are out there.7
- 
				    					
					
					Mid - senior dev (L from now on) comes in on a project to help out. Starts working on creating a dashboard for the application. Work is progressing, new ideas come in, team lead (TL) is ok with everything, business analyst (BA) is also ok. The dashboard even gets thru testing (T), everything is great. In comes (A), a (probably bored) junior backend dev.
 
 A little backstory about (A):
 - seated right next to (TL)
 - most discussion about every developed feature take place at (TL)-s desk, right next to (A)
 - (A) was also present when discussions took place between (TL) and (BA) about dashboard
 - (A) could have easily heard any number of the other team members (over 15) talk about the dashboard
 
 Well, (A) comes into the picture ... and the dashboard (first page after login, big shiny new thing, working just fine ...) breaks. Well, breaks is a little understated. Disappears would be more exact. Cause (A) commented it out. NOT deleted from code. JUST commented out the code.
 
 But why you ask? Because he didn't know what it did and why it was there.
 No asking around, no looking up history in repository, no looking up tasks that might be related to that ... no nothing.
 He's a backend dev, there's something new and unknown in the backend, the new thing has to go.
 
 (L) didn't scream, (TL) didn't scream, (BA) didn't scream, (T) didn't scream ...
 I almost screamed. This didn't happen to me, or (A) would have screamed!3
- 
				    					
					
					I have nothing to do today. I could go Jack off in the bathroom for 3 hours, then go home and my boss would be proud of my hard work. He told me to leave him alone because he is busy today after I went back 10 time for more tasks. We don't use any issue tracker or anything, and I already commented all the code I have access to(microservices means it is all developed in small stand alone parts and I can only see mine. No repo....). But I get in chewed out if I seem unbusy!!!1
- 
				    					
					
					Comments throughout code with things like "changed to fix bug #". And commented out code all over.
 
 We have source control, why the hell are you doing this?
- 
				    					
					
					Long time nothing from Mr. Gitmaster, somehow made my peace with him as the project moved out of my focus and he actually seemed to be contributing.
 But now some pull request exchanges burst into flames as if they were on LKLM before Linus got castrated. Actually it's with the guy who is jamming out most of the front end code trying to make a really shiny UI with lots of animations that turn our macs into heaters.
 Well, debate was over JS code styles or lack thereof and how commented out code should be removed (would actually support Mr gitmaster here). They have me a bit lost there, as I expect the freestyle JS code we produce without any agreed Coding Style Guideline to be an even greater clusterfuck than our C++ code base.
 
 Anyway, hope they come to terms again, like at the start of the project when they jokingly attributed one another as assholes. Their opposing characters could actually benefit from each other.
- 
				    					
					
					So made this component that my colleagues also use.
 Today i checked source control...
 
 What did they do to my creation?
 
 Lines commented out here and there. Features destroyed by rewriting it, instead of just using it. Related unit tests broken of course. It had everything. And why not ask me?
 
 According to Source control they helped each other. Working together as a team, desecrating my code.1
- 
				    					
					
					Nothing like trying to understand a single 1500-line source file that implements the API usage in the frontend. Without a single comment.
 No, wait. There are comments! But it's only commented-out code. Or explicit shit (like "gets the version" before a getAssetVersion function).
 
 Functions with unused parameters? ✅
 Weird var names (like "tmpX")? ✅
 `console.log(var)` everywhere? ✅
 Long-ass lines with 150+ chars? ✅
 Duplicate code? ✅✅
 Not a single interface was used so everything is var: any? ✅
 Random unreadable RegEx? ✅
 If-chains of 6+ more levels? ✅
 Many `else if` towers instead of a switch? ✅
 And did I mention it was written by a fucker who can't speak proper English so shit like visiable, cataloge and isExist is everywhere? Yeah.
 
 Fun day at the office reading spaghetti code 🙃
- 
				    					
					
					The worst documentation I've ever seen:
 
 /*******************************************
 $NAME CODE UPDATE
 ********************************************/
 // CALCULATIONS
 
 Followed by a dozen of of poorly named functions for complex calculations, with no comments whatsoever (save for the commented out debug statements)
- 
				    					
					
					Maybe you people will like this story.
 The past semester I studied Java in class. First time doing object oriented programming, I had an annoying teacher but got the hang of it. I still miss C from the last year.
 As a final project we had to do any program and apply some stuff we saw in class (The program should have an array list, use interfaces, bla bla bla bery simple stuff). It also must have a complete documentation, a manual and a diary explaining what was developed every week. Bonus points if it was in a repository like GitLab.
 I wanted to do an RPG game in a matrix, like a rougelike or an old FF game, that should be a map or two, a few monsters and items and that's it. Enough to show what can I do and to have enough excuses to apply everything that the teacher asked. I had a team with two friends who wanted to do the same.
 After making accounts in three different pages that apparently would help us to be more organized (One to make charts and two task trackers) I lost all patience and made an account in GitLab, made the basic classes that we had defined in a chart, divided the tasks and put them in to do on GitLab and we started to work.
 One of my companions caused a lot of problems. First, he didin't wanted to learn how to use GitLab (I simply asked them to do merge requests) and he insisted to use GitHub. Then he started to say that using the console version was even better (Pretty sure he said thet he never used Git, but maybe was gas poisoning). The GitLab repository never had a single commit to his name.
 BUT WAIT IT GETS BETTER all the entire time, he was complaining about the graphical interface of the game, wanting to use some SDK for RPGs that he found. I told him that we will see that at the end, that first we should have all the mechanics done, test it in ASCII in the console and then, if we have time, we will put the visual interface, separated and optional from the main program to avoid problems.
 After two weeks where he gave me very simple standard stuff late, half done and through Google Drive, I discovered he was most of the time working on... the graphical interface SDK! He took the job already done by me and the other guy and making a pretty hardcoded integration with the graphical interface and making everything that he tought it would be necesary. Soon enough the GitLab repository was totally outdated and completly useless. He had the totallity of the project in his half broken laptop, and sometimes he gave us a zip with all the code, outdated after a few minutes. Most of the stuff that I made was modified, a lot of the code was totally unknown to what it was and I had no idea even of how the folders were organised.
 We had a month to finish it. I got totally disconected from the project and just hoped for the best, sometimes doing a handful of generic and adaptable lines of code for a specific thing (Funny enough, many core mechanics were nonexistent). The other guy managed to work more on the project, mostly fixing the mess that the guy did: apparently he didin't read the documentation of the SDK and just experimented and saw tutorials and tried to figure out how to do what he wanted.
 Talking about documentation: we dont had yet. The code wasn't even commented propely. We did all that the last week and some stuff was finished the last night. The program apparently worked but I had no idea.
 Thank God, the teacher just looked over everything and was very impressed by the working camera and the FF tiles. I don't think he saw the code or read too much of the documentation, much less when I directly wrote how I lost all access to the project.
 I had a 10/10. I didin't complained. Most easy and annoying ten I ever had. I will never do a project with that guy.
- 
				    					
					
					Things that annoy me about my current place:
 
 1 - Only 3 people out of a team of 12 developers are allowed to purge akamai, or merge pull requests to master on any of our 200+ websites. Apparently this is because us contractors are not allowed because the permanent employees have to be accountable for the code.
 
 Despite this, no-one actually reads the code. You just throw up a request in the slack channel and boom, instantly 30 seconds later someone approves it, even if its 500+ lines of code.
 
 2 - I've pushed for us to move to agile instead of waterfall, and got declined (which is fine), but the reasoning was that the dev team are not 'mature enough' to work that way. Half the devs here have 5+ years of experience so I don't get the problem here.
 
 3 - There is zero code reviewing process in place. I just watched as a developer's 300 line merge request was approved within 8 seconds of it going live. No-one is allowed to comment on the code review or suggest changes as this would 'slow down development'. Within that 300 line merge request were tons of css being aimlessly commented out, and invalid javascript (introducing both bugs and security issues) that were totally ignored.
 
 What is your thoughts on these above points?
 
 Am I too narrow minded or is the development manager clueless?1
- 
				    					
					
					The Node and its magic tricks never cease to surprise me.
 
 I created several new components and tried to compile them for verification. Then this big fat error popped up.
 
 I commented out all the newly created code (didn't remove any files, just did ^A^/). Recompiled. This big fat error again.
 
 Undid modifications I made to the files that existed there before. Recompiled. This big fat error again.
 
 Moved the newly created files outside of the project scope (mv app/<...>/featureX/ ../bkup/). Recompiled. SUCCESS.
 
 Moved all of those files back (mv ../bkup/featureX app/<...>/). Recompiled. SUCCESS.
 
 wtf... 2 2
- 
				    					
					
					TL;DR I just recently started my apprenticeship, it's horrible so far, I want to quit, but don't know what to do next...
 
 Okay, first of all, hey there! My name is Cave and I haven't been on here for a while, so I hope the majority of you is doing rather okay. I'm programming for 6 years now, have some work experience already, since I used to volunteer for a company for half a year, in which I discovered my love for integrations and stuff. These background information will probably be necessary to understand my agony in full extend.
 
 So, okay, this is about my apprenticeship. Generally speaking, I was expecting to work, and to learn something, gaining experience. So far, it only involved me, reading through horrible code, fixing and replacing stuff for them, I didn't learn a thing yet, and we are already a month in.
 
 When I said the code is horrible, well, it is the worst I have ever seen since I started programming. Little documentation - if any -, everywhere you look there is deprecated code, which may or may not been commented out, often loops or simply methods seem to be foreign for them, as the code is cluttered with copy paste code everywhere and on top of that all, the code is slow as heck, like wtf.
 
 I spent my past month with reading their code, trying to understand what most of this nonsense is for, and then just deleting and rewriting it entirely. My code suddenly is only 5% or their size and about 1000 times faster. Did I mention I am new to this programming language yet? That I have absolutely no experience in that programming language? Because well I am new and don't have any experience, yet, I have little to no struggle doing it better.
 
 Okay, so, imagine, you started programming like 20 years ago, you were able to found your own business, you are getting paid a decent amount of money, sounds alright, right? Here comes the twist: you have been neglecting every advancement made in developing software for the past 20 years, yup, that's what it feels like to work here.
 
 At this point I don't even know, like is this normal? Did git, VSCode and co. spoil me? Am I supposed to use ancient software with ancient programming languages to make my life hell? Is programming supposed to be like this? I have no clue, you tell me, I always thought I was doing stuff right.
 
 Well, this company is not using git, infact, they have every of their project in a single folder and deleting it by accident is not that hard, I almost did once, that was scary. I started out working locally, just copying files, so shit like that won't happen, they told me to work directly in the source. They said it's fine, that's why you can see 20 copies of the folder, in the same folder... Yes, right, whatever.
 
 I work using a remote desktop, the server I work on is Windows server 2008, you want to make icons using gimp? Too bad, Gimp doesn't support windows server 2008, I don't think anything does anymore, at least I haven't found anything, lol.
 
 They asked me to integrate Google Maps into their projects, I thought it is gonna be fun, well, turns out their software uses internet explorer 9.. and Google maps api does not support internet explorer 9... I ended up somehow installing CEF3 on that shit and wrote an API for it in JS. Writing the API was actually kind of fun, but integrating it in their software sucked and they told me I will never integrate stuff ever again, since they usually don't do that. I mean, they don't have a Backend as far as I can tell, it looks like stuff directly connects with their database, so I believe them, but you know... I love integrating stuff..
 
 So at this point you might be thinking, then why don't you just quit? Well I would, definitely. I'm lucky that till December I can quit without prior notice, just need a resignation as far as I can tell, but when I quit, what do I do next? Like, I volunteered for a company for half a year and I'd argue I did a good job, but with this apprenticeship it only adds up to about 7 months of actual work experience. Would anybody hire somebody with this much actual work experience? I also consider doing freelancing, making a living out of just integrating stuff, but would people pay for that? And then again, would they hire somebody with this much experience? I don't want to quit without a plan on what to do next, but I have no clue.
 
 Am I just spoiled, is programming really just like that, using ancient tools and stuff? Let me know. Advice is welcomed as well, because I'm at a loss. Thanks for reading.10
- 
				    					
					
					I've spent a day trying to figure out a code logic. Couldn't figure out why some codes that shouldn't be commented out are commented out.
 
 Out of frustration, I went to see the user. She explained to me the logic behind it and I got it right away within 5 minutes.
 
 Ask your user when in doubt and in trouble figuring out the logic.
- 
				    					
					
					At what point do you say a junior dev is no longer a junior? What metrics do you use? Like scope of knowledge, impact on team / code decisions, years experience, management skills, etc.?
 
 I feel I'm qualified as a mid level developer now despite only being a junior for a little over a year. I had tons of internships in college and was kind of placed in a role where growing fast was required.
 
 I broke a sweat for most of that ~1 year I worked as a junior and my contributions to my project aren't insignificant
 
 I don't say that to toot my own horn here, I really do want to ground myself in reality. But I don't know if my standards are too low or my organizations standards are too high. FWIW, other devs on my team have commented privately / informally that the junior title isn't super fitting.
 
 I'm still pretty dependent on my boss but that's more for final say of things. He'll often have some input to my work but I'll also be involved with design discussion and take up a large chunk of work without question. On light sprints I'm knocking out 20+ taskhours of work, going closer to 30/40 when things pick up. Not uncommon to kill 10 user stories in a sprint.
 
 I don't know, what do you guys think?8
- 
				    					
					
					Remarked out code which has been commented out since 2015, now been checked in with a simple line comment of todo above it .....
- 
				    					
					
					Or when I'm working on some legacy mess of php code and changing nothing and then reverting even that causes the whole code to act in some nonsensical way with three buttons hooked to the same code doing three completely different things and none of them having any remote connection to what is in the code. Sometimes I get it to get its act somehow together by fucking rebooting my computer (???). What the fuck is wrong with php and wordpress in particular? Could it be any more of a mess?
 
 I literally commented out my whole fucking code, rebooted the server. Is there some cache I'm not aware of involved? It all feels like some fucked up nightmare.6
- 
				    					
					
					I was given a project to fix and improve a legacy unity VR project I was told was for the oculus rift Now the problems started almost immediately partly stemming from the fact I’ve never used unity before this project was handed to me as my long term TA assignment
 And partly from the fact there was no oculus integration in the game at all. it was built for GoogleVr and most of the code the last person wrote consisted of massive sections (25-50 lines) of commented out code and no explanation of what the hell the non-commented parts are supposed to be doing
 
 So long story short. I’m now in a basic unity course, six feet deep in documentation trying to read resources that go way over my head in understanding, and am rebuilding the project from basically scratch (took the assets and saved the c# scripts for reference) and have finally figured out how to at least get the player character constantly moving forward and stream in the WRLD3D environment like the last guy did. Now to get the player character to turn and change direction when the player turns their head with the oculus headset
 
 By the way. WRLD3D is a really cool api thing in my opinion
- 
				    					
					
					Not really most painful, but definitely most painful of the recent bunch..
 // yup, a bunch.. I've managed to fuck up a little on every thing I did that day :/ little friday the 13th for me, especially as I went on sick leave the next day and had to fixup my fuckups with a friggin migrane..
 
 Anyways, I was fixing fallback to some default value in plsql.. before it didn't check what the input format was and simply relied on certain format, parsed that and converted to number..threw an error, duh!
 
 I fixed it somehow elegantly to check with regex if the format is as expected and if not default to xy value..and if format is as expected to parse out the number..except that when I copied (or typed?! for the sake of me, I cannot recall how the fuck I managed to fuck this up) over the code to the package I didn't see additional [ at the begining, so everything went to the default.. Most embarrassing part is I commented everything, how it should work, use cases, what the input was and what was expected output..and failed to see the friggin extra [..
 It was fixed easily, the extra [ stood out later when I saw the code, but it bothers me how I managed to overlook that in the first place. I think I need a vacation.. but have to fix other fuckups first.. :/

















































































