Hello,
Comments are an essential part of any coding practice whether you are using traditional languages that are quite verbose with their syntax and vocabulary i.e. Java, C# or RPG/COBOL. Even code generation environments like 2E and Plex benefit hugely from appropriate commenting.
Modern low-code platforms like Appian, Mendix and Outsystems (to name a few) who shield you from code (as much as possible) benefit from correctly named functions and comments/annotation within them.
Without comments, what was as relatively simple coding process to the creator is now a moderate pain in the butt for the developer maintaining your code. Multiply that with a complicated piece of technical logic and/or business logic which is now practically impossible for a maintenance developer to pick up and be successful.
Chances are you will NOT be maintaining your code. Get this into your heads.....
To avoid this, structure your comments professionally and ensure that the comment adds value.
Commenting out old code for safety reasons in the modern world is simply unacceptable. With repositories like GitHub etc you can be brave and make changes. Sure, comment some stuff out locally whilst trialing a few ideas....I get it. But to commit that code to the main branch or the model if programming in Plex/2E is just unforgivable.
If you have got to the point where you have unit tested your code and are 1000% happy, remove the commented out code....NOW.
I'd also go as far to say that you should remove all legacy commented out code at the time you checkout the function...I mean where others have failed before you.
There are no excuses for leaving commented out code in a production object/branch.
Thanks for reading.
Lee.