As a reminder, virtually all assertions about the relative qualities of different bracket styles are either opinion or outright false.
That said, the correct response by the professor would have been "because you are giving your code to someone that requires it that way", with maybe an explanation thrown in about how almost every non-personal project has a code style that needs to be adhered to, even if it doesn't line up with personal preference.
A suggestion: try to get used to look at code formatted differently than how you'd format it. I generally write in K&R (if (){) and I inherited a codebase in Allman (if ()\n{) and I eventually learned to tolerate writing in it. Reformatting it was out of the question, obviously.
You should take this chance to acclimate to an unfamiliar style.
I am quite happy to have 2 formatters when there is a requirement. One to put in the required submitted form and one for working on it / reading it. Currently I get to define my own format, within reason. (No one cares about the brackets, but it still needs to be neat / good names / comments / etc).
Speaking of, I just put the pedal to the metal with my application. I tested it with some code I'd already written and it didn't seem to mess anything up, hope it never will. If it sees that an opening bracket (except for initializers) it'll move it the the previous line. If there's a comment on that previous line (which I tend to do and would make the bracket get commented out), it'll take that comment and move it an empty line above - with the correct spacing.
If anyone can test it out, see if it ruins their code or not, that would be great ! It'll make a new .cpp file - not alter the one given. Enter the directory or the file name (if working directory).
I hope it's sufficient for your needs, because I can spot some ways that it would break in general use (also the empty lines it generates are an ugly giveaway that something happened). I'm not sure what level of feedback you'd like, so I'll leave it at that.
Personally I use clang-format, and am kinda surprised that nobody's recommended it yet.
if (foo) /*this is
{ a comment*/
single_line_if();
if (foo) //this is\
{ a comment
single_line_if();
if (foo) now_theyre_just_messing_with_you("hehehe\
{");
My program wouldn't break in any of those cases. Not that I tested, but it wont even touch multiline comments. But if there's something AFTER the "{" then it'll leave it alone since it'll be an initializer.
Two words (alas):
“string literals”
Is that bad? ;-;
I'll look up clang though. I don't know if my code is unbreakable, but at the very least I don't code in a way that would break it. The ugly empty lines are for the professor's viewing pleasure.
Holy Hell. I didn't even know that was a thing. I didn't see it because the formatting on this site didn't make the next line green, but I guess //\ makes that line and the following one a comment. Never used that before. A simple solution would be an extra line under the comment - just implemented it.
My Professor will love my code's layout :)
It appears you are using Visual Studio? If you are you can use Clang instead of the usual VS C++ compiler.
I don't know why I'd want to switch, VS's compiler has been great, don't know what Clang would do and I don't have much incentive to change it out.
I am not talking about Clang format, as was a large chunk of the previous discussion, I'm talking about having two different compiler tool chains available to use at your discretion.
Installing Clang in VS would give you an alternate compiler to use. You'd still have MSBuild to use the built-in VS compiler, or CMake scripts editable in the VS IDE to use Clang.
\
lets you extend a line. its really 1 line, but visually broken in the editor. It is common in complex macros.
mine would fail on that too. I handled comments, nested comments, strings, and more but not the multi-line thing.
I wasn't going to sell it or anything, its just something that can reformat most code stolen from online into the format I use.... a full featured one takes a lot of thought and time.
Mine basically finds /* and sets a boolean to do nothing (just dump input to output) until */ or whatever ending symbol(s) is found. Same for // and "" and so on.
I'm talking about having two different compiler tool chains available to use at your discretion.
I suppose that might come in handy! Probably will end up being too lazy to do it though.
a full featured one takes a lot of thought and time.
Yea, seems not worth the trouble because most cases wouldn't even be realistic. So far, the only case I know of that my program would fail is this one: