Details
Joined devRant on 2/26/2018
			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
			- 
				    
				    It was when I ditched React. I replaced it with raw JavaScript, with frontend being built with Gulp and Twig (just because HTML has no includes). Here are the results:
 1. Previously, a production frontend build took 1.5 minutes. Build time became so fast that after I push the code, the build was done before me going to Netlify to check build status. I go there, and it’s almost always already done.
 2. In a gallery with a lot of cards, with every card opening a modal, the number of listeners was reduced from N to one. With React, I needed 1000 listeners for 1000 cards. With raw JavaScript, I needed just one click listener with checking event target to handle all of the cards.
 3. Page load time and time-to-interactive was reduced from seconds to milliseconds.
 4. Lighthouse rating became 100 for desktop and 93 for mobile.
 
 But there is one more thing that is way better than all of the above: cognitive complexity.
 
 Tasks that took days now take hours. Tasks that took hours now take minutes.
 Tasks that took thousands of lines now take hundreds. Tasks that took hundreds of lines now take tens.
 
 In real business apps, it is common to build features and then realize it’s not needed and should be discarded. Business is volatile, just because the real world is volatile too. With this kind of cost reduction per feature, it became way less painful to discard them. Throwing out something you spent time and emotional resource on doesn’t feel good. But with features taking minutes to build, it became easier.22
- 
				    
				    long time ago....
 Feature request: We want an android backup solution in Our app!
 UI guy has already developed it, you just need to see if his solution is solid!
 Ok then - lets look at the UI: Nice progress bars, that turn into green checkmarks. Looks good.
 Now lets look at the code: ... Ok. loading some files into memory.... and... dafuq? does not write to a file?
 
 Backup to RAM. With no restore. 🤦♂️.3
- 
				    
				    It seems which the crazy enterprise microservice project which I'm doing (an awful distributed monolith splitted in 10+ microservices, hard to test and requiring continued context switching and running on an unreliable platform) has finally won over my brain.
 It's so boring and frustrating to work with which I lost all my ability to focus, I used to be able to program well even under significant distress but more than two years of continued boredom, repetitive tasks and frustrations destroyed my motivation and with that my ability of focusing died. It doesn't matter if I'm at home or in the office, my brain is like a car stuck in neutral gear and I struggle to focus in every task.2
- 
				    
				    My employer doesn't allow us to use Linux; I have to use MacOS because "Windows is sooooo bad".
 Fucking hell I'd choose Windows every day if the year over this garbage fucking OS9
- 
				    
				    Perfect job is when sandbox and production api endpoints works the same.
 
 Fuck all api endpoints where their sandbox works differently than the production.
 
 Fuck all those error messages that appear only in production, despite faithfully following the documentations.
 
 Fuck the gateways where their sandbox is more stable than the production.
 
 Fuck the endpoints whose api parameters differ in what they accept between sandbox and production.
 
 Fuck those manuals that does not document these diferrences.
 
 Fuck those developers and support team who don't know how to support integrators. They don't even know how their apis work!9
- 
				    
				    So, none other than the father of our beloved Linux kernel - Linus Torvalds, just totally put an antivax guy down in the public kernel mailing list.
 
 I think I love Linus even more now. He may not be a people person, but he sure does know how to totally rip people into shreds lol.
 
 https://lore.kernel.org/ksummit/...22
- 
				    
				    How to open source 101:
 
 1. Have GitHub repo
 2. Install a stale-and-auto-close bot
 3. Never respond to issues
 4. Have a project so good it has no open issues
 
 Why?!3
- 
				    
				    YOU ARE A FUCKING SOFTWARE DEVELOPER WITH AT LEAST A LITTLE TRAINING FOR THE LOVE OF GOD PLEASE STOP FUCKING UP THE GIT REPOSITORY BY COMMITTING THE GODDAMN NODE_MODULES13
- 
				    
				    The last person who might have taken offense at this recently quit, so time for a consequence-free rant. I just want to say...
 
 Fuck absolutely every single one of my teammates who quit this year. Fuck your shitty, undocumented spaghetti code from hell that the rest of us will have to rewrite because it's utterly broken and functions mostly on prayer and luck. Fuck the 1000+ git repos we'll have to rename so we can even begin to tell them apart. Fuck your complete lack of any sort of processes or procedures or standards. Fuck the person who hated tickets and decided we could just have hundreds of people ask us for help on Slack whenever they need it. Fuck the people who quit because we got a new manager who told us we need to support the applications we build. Fuck the person who said "I'm leaving because I want to move forwards instead of backwards" as if fixing bugs in the code YOU WROTE TWO WEEKS AGO is really moving backwards. Fuck the two people who designed their own separate pipelines and then used both without bothering to debate and pick the better one (spoiler: both are completely undocumented and broken as hell).
 
 I hope your various new employers figure out that your strategy of covering shit with gold paint doesn't change the smell.
 
 Now the rest of us have to fix it all, and we're probably going to start by demolishing most of it so we can rebuild it from scratch.12
- 
				    
				    I am scratching my head since 2 days cause a rather large Dockerfile doesn't work as expected.
 
 CMD Execution just leads to "File not found".
 
 Thanks, that's as useless as one ply toilet paper...
 
 Whoever wrote the Dockerfile (not me…) should get an oscar...
 
 Even in diarrhea after eating the good one day old extra hot china takeout from dubious sources I couldn't produce such a dumpster fire of bullshit.
 
 The worst: The author thought layering helps - except it doesn't really, as it's a giant file with roughly 14 layers If I count correctly.
 
 I just found out the problem...
 
 The author thought it would be great to add the source files of the node project that should be built as a volume to docker... Which would work I guess....
 
 Except that the author is a clueless chimp who thought at the same time seemingly that folder organization means to just pour everything into one folder....
 
 Yeah. That fucker just shoved everything into one folder.
 
 Yeeeeeesssssssss.
 
 It looks like this:
 source
 docker-compose.mounts.yml
 docker-compose.services.yml
 docker-compose.yml
 Dockerfile-development
 Dockerfile-production
 Dockerfile
 several bash scripts
 several TS / JS / config files
 ...
 
 If you read the above.... Yes.
 He went so far to copy the large Dockerfile 3 times to add development and production specific overrides.
 
 I can only repeat what I said many times before: If you don't like doing stuff, ask for fucking help you moron.
 
 -.-
 
 *gooozfraba*
 
 Anyways...
 
 He directly mounts this source directory as a volume.
 
 And then executes a shell script from this directory...
 
 And before that shit was copied in the large gooozfraba Dockerfile into the volume.
 
 Yeeeaaah.
 
 We copy stuff inside the container, then we just mount on start the whole folder and overwrite the copied stuff.
 
 *rolls eyes* which is completely obvious in this pit latrine of YML fuckery called Dockerfile.
 
 As soon as I moved the start script outside the folder and don't have it running inside the folder that is mounted via volume, everything works.
 
 Yeah.... Maybe one should seperate deployment from source files, runtime related stuff from build stuff.
 
 *rolls eyes*
 
 I really hate Docker sometimes. This is stuff that breaks easily for reasons, but you cannot see it unless you really grind your teeth and start manually tracing and debugging what the frigging fuck the maniac called author produced.1
- 
				    
				    I. FUCKING. HATE. MOBILE. DEVELOPMENT.
 
 I already manage the data, devops, infra, and most of the backend dev.
 
 We had a mobile guy. He was great. I never had to think about it and kept moving quickly on my work. #SpecializationOfLaborFTW
 
 He left. Why? Because they wouldn't give him a small raise despite being one of the best mobile engineers in the firm. WTF.
 
 I made the mistake of picking up just enough slack on this workflow in the interim such that I'm, apparently, the fucking god-damned release manager, fixer of pipelines, fixer of build configs, fixer of anything where someone just needs to RTFM for a half-hour to not fucking break things.
 
 Now, 8 months later...and, apparently, Fortune 500 companies are too fucking god-damned cheap to pay for someone who actually knows WTF they're doing for a very reasonable thing to have at least one dedicated set of eyes for.
 
 I never wanted to be a mobile dev.
 I never will want to be a mobile dev.
 And I certainly don't want to manage your HALF-FACE-FUCKED detached expo configs.
 
 There's a reason I never intentionally involved myself in mobile. All the way down, it's just shitty cross-compilation, transpilation, dependency-hell, brittle-as-fuck build processes so we can foot-gun and mouth-gun react-native and expo and babel and whatever the fuck else cargo-culted horseshit into the wild.
 
 And why? What's the actual fucking root cause? The biggest white elephant that ever fucking elephant-ed? It's because Apple and Google decided to never collaborate on a truly-native cross-platform SDK--where engineers could write native code that compiles to native binaries that's simply write-once, run-everywhere. They know they could have done that, and they didn't. So what'd they get back? Expo--a too-cleverly-designed backdoor/hack--more-or-less a way to circumvent the sane release process software has usually followed: code -> executable -> deploy. Or code -> deploy (for interpreted langs). Expo's like "keep your same executable, we're just gonna to do updates by injecting new code into it whenever we want". Didn't we learn anything with web? Shit gets messy real quick? Not to mention: HEY EXPO, WE WERE ALREADY BUILDING NATIVE APPS, YOU SHORT-SIGHTED FUCKS. THANKS FOR LURING OUR CTOs INTO FORCING EXPO DOWN OUR THROATS W/ THE IMPLICIT (BUT INCORRECT) TOO-GOOD-TO-BE-TRUE PROMISE THAT WE CAN HAVE WRITE-ONCE, RUN-ANYWHERE WITHOUT ANY BUY-IN OR COOPERATION FROM THE ACTUAL TARGET PLATFORMS.
 
 And, we just, like, accept this? We all know it's garbage engineering. The principles we learned in the classroom aren't just academic abstractions--they actually yield real-world results--and eschewing them yields real-world failures. Expo is tightly-coupled to high-heaven, with leaky abstractions six-ways-to-christmas, chock-full of foot-guns, and fails the most basic test of quality: does it, "just work?"
 
 Expo is fucking shameful and it should fucking die. Its promises are too bold, its land-mines too many, its future-proof-ness is alway, always, always questionable as fuck and a risk to every project that uses it.
 
 You want a rant? This is my fucking venue, 'tis not? Well, then this is a piss and vinegar rant straight from my blood-red, beating fucking heart:
 
 EXPO FUCKING SUCKS. AND IF YOU'RE A FAN, YOU FUCKING SUCK TOO.25
- 
				    
				    3 SQL Databases went into a NoSQL Bar.
 After a while, they walked out because
 .
 .
 They couldn't find tables there.5
- 
				    
				    After 3 years of working with Node.js, I have finally snapped
 
 Node.js is cringe
 
 I am .NET gang now14
- 
				    
				    Fuck you haters, I'm not dying of corona so PHP dies with it.
 
 PHP is an amazing language. It has evolved nicely has almost all high performing functionally you need build in. Has a good package manager eco system. It's insanely fast (since 7.0, older versions where just fast with opcache).
 Most of the called out inconsistencies are actually because it is consistently following C/POSIX equivalent or people that don't understand dynamic typing (it doesn't mean any shit will stick).
 
 https://awesomeopensource.com/proje...
 Fuck off with your JS backend solution because it's faster...
 
 This is a big thanks to all the amazing members of the PHP community that worked hard to make PHP the great language it is today!!!82
- 
				    
				    WASM was a mistake. I just wanted to learn C++ and have fast code on the web. Everyone praised it. No one mentioned that it would double or quadruple my development time. That it would cause me to curse repeatedly at the screen until I wanted to harm myself.
 
 The problem was never C++, which was a respectable if long-winded language. No no no. The problem was the lack of support for 'objects' or 'arrays' as parameters or return types. Anything of any complexity lives on one giant Float32Array which must surely bring a look of disgust from every programmer on this muddy rock. That is, one single array variable that you re-use for EVERYTHING.
 
 Have a color? Throw it on the array. 10 floats in an object? Push it on the array - and split off the two bools via dependency injection (why do I have 3-4 line function parameter lists?!). Have an image with 1,000,000 floats? Drop it in the array. Want to return an array? Provide a malloc ptr into the code and write to it, then read from that location in JS after running the function, modifying the array as a side effect.
 
 My- hahaha, my web worker has two images it's working with, calculations for all the planets, sun and moon in the solar system, and bunch of other calculations I wanted offloaded from the main thread... they all live in ONE GIANT ARRAY. LMFAO.If I want to find an element? I have to know exactly where to look or else, good luck finding it among the millions of numbers on that thing.
 
 And of course, if you work with these, you put them in loops. Then you can have the joys of off-by-one errors that not only result in bad results in the returned array, but inexplicable errors in which code you haven't even touched suddenly has bad values. I've had entire functions suddenly explode with random errors because I accidentally overwrote the wrong section of that float array. Not like, the variable the function was using was wrong. No. WASM acted like the function didn't even exist and it didn't know why. Because, somehow, the function ALSO lived on that Float32Array.
 
 And because you're using WASM to be fast, you're typically trying to overwrite things that do O(N) operations or more. NO ONE is going to use this return a + b. One off functions just aren't worth programming in WASM. Worst of all, debugging this is often a matter of writing print and console.log statements everywhere, to try and 'eat' the whole array at once to find out what portion got corrupted or is broke. Or comment out your code line by line to see what in forsaken 9 circles of coding hell caused your problem. It's like debugging blind in a strange and overgrown forest of code that you don't even recognize because most of it is there to satisfy the needs of WASM.
 
 And because it takes so long to debug, it takes a massively long time to create things, and by the time you're done, the dependent package you're building for has 'moved on' and find you suddenly need to update a bunch of crap when you're not even finished. All of this, purely because of a horribly designed technology.
 
 And do they have sympathy for you for forcing you to update all this stuff? No. They don't owe you sympathy, and god forbid they give you any. You are a developer and so it is your duty to suffer - for some kind of karma.
 
 I wanted to love WASM, but screw that thing, it's horrible errors and most of all, the WASM heap32.7
- 
				    
				    Recently in a project of mine people started to raise tons of issues and suggesting fixes "just slap this module on it", "just do this", "just do that". And no respect for the project whatsoever. Code contributions? Don't even think about it.
 
 The users raising these do not know what language the project is written in, they do not know whether it supports modules at all (let alone that particular one), and they have no idea whatsoever what the code is like, or how this suggestion 99% of the time would not at all integrate with the overall structure of the project. And aside from all that, don't fucking tell me what to do with my project!
 
 My question is, how do you deal with these people? All I can think of is "wontfix™️" or even "cantfix™️" in some cases. Given that this is an endless slew of users, anything long-term?1
- 
				    
				    Took over a NodeJS/SailsJS project from a previous developer that is no longer working at the company. There's no documentation or requirement docs and the models need to be rewritten as some have up to 67 attributes in them.
 
 Looked through the source code file by file to see how bad it was and it will more than likely be easier to start over then to try and refactor and cleanup the existing project into a usable state.
 
 As bonus, I was given the option to switch the entire stack if needed as well.5
- 
				    
				    Decent family tree software that's capable of sanely organising photos, letters etc.
 
 I'm sure none actually exists, web based or otherwise.4

 
		
		
	



