Why I stopped using AI code editors · Article
Posted by lucianonooijen@reddit | programming | View on Reddit | 63 comments
I wrote an article about why I stopped using AI code editors
Posted by lucianonooijen@reddit | programming | View on Reddit | 63 comments
I wrote an article about why I stopped using AI code editors
dtown123@reddit
Lots of crazy talk in here. I started using cursor about a month ago and the experience has been nothing short of amazing.
Gone are the days of grunt work unit tests and coding out each crud page by hand - it’s now a 5 minute task.
Learn how to use it or be left behind.
cfehunter@reddit
You know. If you're creating crap tonnes of boilerplate, and copy paste code is necessary, you've probably screwed up your abstractions and should take a look at the architecture.
I wonder if this is why people have such split opinions in AI. I find it mostly useless for generating actual code, but then I'm very rarely writing the same thing repeatedly.
dtown123@reddit
for sure, but there's also places where abstracting is silly and you just want a good starting point to work off of. Unit tests come to mind, and it's fantastic for that.
I think a good portion of the hate for AI in development is that many developers are tired of having to learn new platforms and ways of thinking when their current skill set is working just fine. I've had to do a fair amount of convincing with members of my dev team to simply take 5 minutes and try it. "Hey compare my appsettings.json to my k8 deployment.yaml and make sure I didn't miss any env variables" sure you can do that manually, but it's tedious and error prone.
One big benefit for me - the addition of Cursor to my bag of tricks has resurrected several personal side projects that I've been putting off BECAUSE of the grunt work that needed to be done. why take all day making admin CRUD pages when you can get them done for you, in seconds, with a single sentence? Your nice-to-haves for non mission critical stuff don't have to be ignored anymore.
Lersei_Cannister@reddit
all of the disparaging comments are people who haven't used AI tools or used copilot for "over an hour" on a single problem and gave up.
there's definitely an elitist attitude towards using AI tools, probably from those who think you're using AI in place of knowing how to solve a problem yourself, rather than the reality that it's used to reduce repetitive tasks
dtown123@reddit
I get it. It’s something new that threatens the existence of old comfortable coders. Sure a junior can use it to vibe code a website and not learn anything, and they’ll be a junior forever.
AI isn’t going to replace developers - yet - but it WILL replace developers who refuse to adapt. It’s a new efficiency tool that’s improving exponentially. It’s also a lot of fun.
LinearArray@reddit
AI code editors ruin the joy of programming, period.
josfaber@reddit
I get your point but it's not that black and white.
I make interactive frontends for educational purpose (ipad webapps in schools) and an AI companion is a great tool for cumbersome and repetitive tasks. But there is no AI that will come up with a threejs based virtual dome in which interactive card like structures float and react upon user motion. Or newspaper like cutout flipcards on a reflective floor. I have more time now to explore those kinds of interfaces, because AI helps me with the tedious bits
slantview@reddit
Good luck with your early retirement.
Rojeitor@reddit
Yes because having joy is why companies hire is, not to create value. "here have my money to have joy, no matter if you're way less efficient"
john16384@reddit
I can tell you that companies consistently underestimate employee morale. An employee that enjoys their job can easily be twice as productive and proactive. A manager won't be able to tell the difference.
Rojeitor@reddit
Yes. But if you had joy riding a horse down carriage and now the car is invented... well you can have as much joy as you want in the horse
AffectionateTune9251@reddit
There was never any joy to begin with
skwee357@reddit
Very good article, and summarizes my thoughts completely.
Putting aside the fact that AI is not always generating useful code, the biggest problem I see with AI is the fact that it removes you from the equation. I believe that in the end, if everyone can prompt AI the same way you can, you are no different and very disposable. Learning and expertise come from the journey, not the destination, and it seems like AI is here to eliminate the journey altogether.
P.S. Nice blog, and lovely design.
elh0mbre@reddit
I'm not saying you should use these tools on every task, in every project or with every tech stack, but generalizing to "if you use this too much, you will lose your skills" is nonsense. Eschew these tools if you want, but I think you're doing so at a great risk to yourself.
The comparison to self-driving made me think: OP was always a bad driver, self-driving just made them realize it.
lucianonooijen@reddit (OP)
I knew I'd get at least one comment from a 'vibe coder'. Even if AI tools would give the results I need (which for the projects I'm working on currently - different ones from when I was using AI tools a lot more) which is still a very long way out, I still would not rely on it. I do like how the counterargument is "it's just nonsense" as well.
As for the driving, I think you have asked an LLM to summarize the article to bullet points for you, as I made it pretty clear that it was for a short period after switching back to manual driving after relying on FSD for two years.
Prompt away what you want, but by doing that it'll be your job gone before mine.
elh0mbre@reddit
I'm definitely not a "vibe coder", but think what you want.
lucianonooijen@reddit (OP)
"I use Cursor heavily"
"I'm not a vibe coder"
cypher0six@reddit
This statement highlights just how much you actually know about these tools.
Empanatacion@reddit
Wow, doubling down on the twat thing.
elh0mbre@reddit
Most my work product isn't code at this point.
Fit-Jeweler-1908@reddit
Just an fyi, this comment makes you sound like a massive twat..
clrbrk@reddit
I love your self driving comparison.
My wife’s grandparents are quite wealthy and drive new, top of the line cars. Her grandfather in particular is a horrifyingly terrible driver, especially on the freeways. We went to visit them last year and they had recently got a new car, I can’t remember what it was but it wasn’t a Tesla. He picked up from the airport and when we got back to their house I commented to my wife how surprisingly smooth that drive went. A little later I was talking to him about all the tech in his new car and I realized he wasn’t really the one doing the driving.
anothercoffee@reddit
I replied to a similar post here and think the comment is relevant to yours.
I've heard many senior devs make similar observations--and this is not meant to be a criticism--but I wonder if this is the same sort of elitist attitude craftsmen in the past would have had to new industrial machinery.
Essentially, I think you are broadly correct but it became clear to me very early on that 'prompting' is basically programming in human language. Non-deterministic yes, but programming nonetheless. It's just as non-deterministic as human programmers implementing the specifications from software architects and project managers. We're just at another level of abstraction and human language will be come a form of programming language.
Programming languages are different in that they are more precise and specifically designed to communicate with computers. That doesn't necessarily mean they're intrinsically better at building systems though. Programming languages are definitely better right now because that's the tool we've learned to use.
We haven't learned to use human languages to build software but people have been building things with human language long before software came along. Maybe we just haven't yet learned to use human language in place of computer language. There's no reason you can't constrain human language to be more precise. There's also no reason that building systems necessarily needs to be very precise. Perhaps the lack of precision can be made up by very quick iteration.
Think about how Agile came along when 'the professionals' were using Waterfall. People thought that the 'chaotic' nature of Agile wouldn't work, yet Agile proponents made it work, and arguably it's the most popular methodology he have right now. There is still a need for Waterfall, and there'll always be a need to have very precise language to specify what a computer should do. Nevertheless, most projects don't need Waterfall, and maybe most people won't need the precision of dedicated programming languages.
Our profession is still in the very early stages of this thing and I suspect that prompting will be the coding of the future. There will still be the need for low-level coders to some extent, but most people won't program in the way we do now.
When I was at school, we first learnt to program using logic gates, diodes, transistors, ICs and other electronic components. Afterwards it was BASIC, Pascal, C, and so on. Fast forward into the future and I no longer need to solder components onto a circuit board, nor do I need to compile a program because I mostly use Python and a bunch of web technologies to make things happen.
I don't need to be concerned about all the lower level stuff. I don't even need to remember to allocate or deallocate memory, keep track of my pointers, or clean up garbage collection. It's all done for me.
I think it will eventually be the same with AI coding. We'll tell the AI what we want and it'll figure out the details, then produce the application. This isn't some baseless hypothesising either. My workflow now has the basics of this being put in place.
I have a requirements assistant that helps me translate a client's informal discussions into a BDD document. I'll then feed that into a software architect assistant that will recommend the basic components for the solution. Then I can use something like Replit or other AI coding assistant to give me a quick prototype. From there I can start building out the components 'for real'.
Yes, all of this still requires a hands-on approach and 25+ years of programming experience. But I do wonder if future programmers will need everything I've learned, or if we'll need as many techs as we do now.
AmalgamDragon@reddit
That's exactly what programming languages are.
Sure there is. Software systems are instructions that computers follow precisely.
anothercoffee@reddit
The point is that people don't talk to each other in programming code but you can now talk to both humans and computers in human languages.
That doesn't go against what I'm saying though. With multi-modal AI, it's now demonstrably possible to create software using imprecise human languages and even images. It might not be the best or most efficient way to go about things, but it's possible. Thus, there's also no reason that building systems necessarily needs to be very precise.
tschellenbach@reddit
Next up: how i gave up on C and started using assembly to great success.
lucianonooijen@reddit (OP)
Depending on what you’re doing, asm might be the right choice though. Most of the encryption/cryptography libraries are still hand rolled asm.
RandomisedZombie@reddit
I spent over an hour trying to get copilot to do something and then 5 minutes on stack overflow finding the right answer. I’m sure for some things it works well, but if you have something a bit more complicated in a lesser used language then it struggles.
lucianonooijen@reddit (OP)
LLMs seem to be hit or miss, it misses more often for complicated tasks, but there are some cases where it really surprised me how competent it was - things with Unreal Engine netcode internals, text-serialized Blueprint nodes, but then sometimes it made the most basic Typescript errors
MINIMAN10001@reddit
LLMs have been a godsend at understanding api dumps and error messages to rapidly allow me to iterate using tools that I have no idea how to utilize.
lucianonooijen@reddit (OP)
I use it for similar tasks as well. Obscure clang errors, long log files, that sort of thing is where AI tools can really shine
BiteFancy9628@reddit
Agentic tools would just search the web and summarize the stack overflow for you if the model doesn’t know.
Tigew@reddit
The biggest help I’ve had with it, is a changing perspective. It works great as a rubber duck.
Salink@reddit
I have problems with simple stuff too. It's great as a more advanced autocomplete, but everything i asked in the prompt has failed miserably. Yesterday I asked every variation of 'move this highlighted code into a new function' and all it did was delete the code and put a function call in.
clrbrk@reddit
I have been using cursor and it nails things like this.
I even had a bunch of logic that I had written into a controller method that ended up getting more complicated than I anticipated. I told cursor “move all of that new logic into a new service called XYZ” and it built the entire file and called it correctly.
Rewind a bit to when I started this ticket and I asked cursor to come up with all of that logic and it spit out a bunch of code that on quick inspection looked legit, but it ended up taking me probably as long to fix it as it would have to just write it from scratch. But this was my first ticket using Cursor so I wanted to see what it could do.
I’m quickly finding its limitations, but there are some things it is great at.
One thing I have found super useful is to ask it “Where does X happen?” and it is pretty good at highlighting the file I’m looking for.
EveryQuantityEver@reddit
But we had refactorings like that long before "AI" was around.
clrbrk@reddit
Of course we did. But asking cursor to do it took 5-10 seconds. It would have at least taken me several minutes to find the right place to create the file and build the skeleton of the new service before copying the logic over, then making the necessary tweaks to make it work. It reduced the tedious work significantly.
jakewins@reddit
Can you give an example of how you prompt cursor for this, and which language you’re doing this in?
I feel like I do exactly this and 4/5 times it shits the bed, creating files in totally bogus places (like literally outside the source tree) or using style / libraries / approaches that are entirely out of line with the existing project..
I’ve tried with Typescript and Python, similar results.. but I’m wondering if the problem is my prompting
clrbrk@reddit
This was in a Ruby monolith. I just said “extract all of the new logic for doing X to a new service called XService”.
gwillen@reddit
One thing I've noticed is that copilot seems to have some bugs around management of the LLM context and token limits. When the file you're working on is very large, it will start to lose lines, or mangle the diffs it's trying to apply. I strongly suspect this isn't an issue in the model itself, but a bug in the code handling the integration with the model.
(This could explain why someone below says they haven't seen this issue with cursor; the quality of their integration seems to be higher.)
lucianonooijen@reddit (OP)
Though I don't use it for autocomplete myself, for some it works, and if you're cautious with it or use it only some of the time, I think the risks are much lower.
Though for the "move this code"; isn't there something available in your editor/IDE already? That sounds like something that an LSP would do without issues, and adding any unwanted code changes.
Salink@reddit
I was using vs code and I didn't see that in the refactoring menu. I know there's probably a dozen plug-ins that can do it, but copilot was already there and I wanted to see if the new toy worked.
coderemover@reddit
Sometimes it’s great. Today I modified one of the set of tests to test for additional conditions. Then In told copilot to perform a similar modification in all other tests. It did it perfectly and saved me a lot of typing.
elh0mbre@reddit
Try different tools. I never got good results with Copilot; I use Cursor heavily).
Try different tasks. I have found some it struggles with but I get a huge boost on other tasks.
Part of the learning curve is understanding what/when/where/how to use it.
ProbsNotManBearPig@reddit
Cursor unfortunately doesn’t offer a self hosted solution, which is a no go for my company due to privacy concerns. We’re currently trying codeium integrated with jetbrains IDE’s and it’s pretty mediocre for my use cases. Part of the problem is the size of our code base, which is millions of lines and thousands of files. Some of the bad files are 10k+ lines so I can’t even get codeium to read the whole file to find stuff within it.
clrbrk@reddit
I completely agree, Cursor is better than Copilot in every way. I had been using Copilot for the last few months and recently switched to Cursor.
Lersei_Cannister@reddit
I"m an intermediate and I simply can't keep up with senior engineer velocity without leveraging cursor. They themselves will use AI for all but domain modelling. The speed at which you can add unit/integration tests, frontend storybooks, and reimplement existing patterns in your codebase is hard to beat. For context, it's a full stack role in a startup working on new features (ie we're not a product company in maintenance mode).
The top comments talking about dabbling in GitHub copilot 2 years ago aren't relevant to the discussion. A coworker from my last job just sent me a screenshot of his eng slack this morning - they've moved from vsc to cursor as their default IDE.
ScriptingInJava@reddit
That's why you can't keep up, because you're not a senior. Being a senior engineer doesn't mean you're really good at using a tool, it's a skillset you learn and empower with tools.
If you rely on using LLMs to "keep up" with people who are just better at something than you, you won't learn the skills to be better. You're 50% a developer, 50% a man talking to a bot asking if they'll do your job.
If I'm really crap at repairing cars and take my project into the local garage to get it road worthy, did I really fix it? Did I learn how to solve those problems?
Lersei_Cannister@reddit
You're conflating the essence of software engineering with the writing of boilerplate. It isn't that I can't come up with the same code, it's purely a velocity / productivity boost. I would never use it to come up with the solution to a novel problem I couldn't do myself
ScriptingInJava@reddit
I get your point but equally being able to validate what an LLM is spewing out as part of an integration test is a skill equally as much as the functionality you’re testing.
They don’t have a senior version of Cursor, or aren’t using an LLM to create those tests because they can do so manually quickly due to experience.
Again you’re trying to keep up with a professional runner by using a skateboard, it’s limiting your ability to do your job without that crutch.
If the seniors aren’t using the same GenAI tools to do their job and you can’t keep up that’s okay! You’re not a senior, nobody is expecting you to be able to.
If they did expect that, you’d be a senior.
Lersei_Cannister@reddit
Are u assuming I'm not validating the code and just pushing it as-is...?
maybe you misread my original comment, the lead dev introduced cursor to the company and uses it most profusely. all senior staff are using cursor to an even larger extent than myself.
in this analogy, wouldn't it be me running to keep up with a senior using a skateboard (Cursor)?
I think you're focused too much on the title disparity and are missing the key benefits of cursor. Regardless of the title, it's definitely a producvity boost, at little to no cost to your own coding prowess (if used appropriately)
lucianonooijen@reddit (OP)
My concern here would be that your path from medior to senior will be much slower, possibly halted, if you start relying on AI tools too much.
Start-up web dev is where these AI tools really shine, I won't argue against that. The issue however is that there will be a point where the context size is too large and the tools can't keep up. You'll also create the situation where you're pretty much locked into positions where AI tools will do most of the development for you.
I don't want to sound elitist, but I think positions like this are closer to blue-collar tech work than software engineering. Which isn't to say these positions are worthless, not my any means, but I do think these are the positions that will be automated away first.
FWIW: I have used more tools than GHCopilot, also some much more integrated tools, can't give details due to NDAs, but it was all similar to Cursor, which I have some experience with as well.
Lersei_Cannister@reddit
Not sure if this is a real concern, in Cursor for example you can drag specific files in to provide context, so for example "Using as an example, create a unit test for that tests..."
Arguably, start ups where you're generating a lot of new code aren't as great a usecase as existing, established codebases where patterns are fleshed out and standardized. That being said, it's definitely the case that speed is a priority.
That's one perspective, I'd say it's overly pessimistic. I would compare it more to the introduction of Photoshop for graphic designers, or calculators for physics. I used to be of the same opinion tbh, and I don't really like that I'm almost forced to use AI to keep up. That being said, it helps me focus on more intellectual problems rather than the tedious boilerplate which one could just as easily call "blue collar tech work".
Not doubting that, seemed dumb to me that the top 2 comments on the article are from people who have barely used the tools themselves...
Mnaukovitsch@reddit
I am learning C after learning Python before as a hobby and I find Copilot in Neovim way too disruptive. I enjoy the chat as I can ask it to explain the code or concepts but the code completion mostly works against me as I need to type it myself to learn. Had to disable it.
aaulia@reddit
I never really tried co-pilot. I always thought having AI auto complete block of your code is just too much/intrusive. But as modern rubber ducking tools, it's nice.
lucianonooijen@reddit (OP)
I think using it as a fancy rubber duck is the best approach to using AI
quakedamper@reddit
I think rage hacking is a better term than vibe coding.
It’s like that Indian consulting colleague quietly sabotaging you at work. All good, all smile, 100% confidence absolutely anything can be done boss then takes your hand and leads you down an abyss of 10s of thousands of lines of utter confusion. Once you finish debugging two days later you find your tyres have been slashed and you can’t get home
Giannis4president@reddit
I find copilot very useful during a refactor / addind a property to a class with some boilerplate stuff.
Like, I have a form and I need to add a field in a CRUD form section. I need to add it on the html, on validation, on the actual model create/update etc. Copilot is pretty good at autocompleting the stuff there after the first edit.
When coding something new, the suggestions are often terrible.
I usually toggle them on/off based on the situation I'm in
voxelghost@reddit
I treat it as a rubber duck that can read the geist of stack overflow
lucianonooijen@reddit (OP)
Luckily the AI is much less passive aggressive than SO as well
Craiggles-@reddit
I usually don't read these kinds of articles but I feel like you did a great job articulating the problem with too much AI interaction: you're no longer in the drivers seat which means you start losing important skillsets that make you good at your craft.
I still use AI for really basic autocomplete via codeium extension, so its much less obtrusive as others.
For rubber ducking I do talk to AI about topics, but I make sure lead the conversation, not the other way around. So for instance, I explain the algorithm I have in mind and we discuss if that would work well in a specific context to get another perspective rather than "I have this problem what should I do".
lucianonooijen@reddit (OP)
I think this is a great way to think about using AI, you need to be in the driver's seat, not the AI.
Right now, I use it mostly as an alternative to bothering others on Slack about basic things, and in that, AI can be a great tool.
freecodeio@reddit
Don't use it to replace your logic and thinking, just use it for what it is, a glorious autocomplete and then it actually helps.