-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
camelCase vs. under_scores #425
Comments
I prefer underscores as it very clearly defines the separation between words. That is to say: camel_case looks more like two words than camelCase. |
I worried about this issue a bit while working on the compiler -- which currently uses underscore style. If we're looking at pure readability, I don't think that there's much argument to be made for camelcase ... it's just so much harder to read as phrase than underscores are. Unfortunately, readability isn't the only consideration -- we have to think about interoperability with javascript native functions, as well as the wealth of existing JavaScript libraries. Writing libraries in CoffeeScript that are later used from JavaScript is another concern. I think that our real options are:
As much as I hate to admit it, I think that option 2 might make the most sense... |
Actually, I must say that I find camelCase more readable. This may well be because the first language I achieved fluency in was Java (I know, ugh), so switching to a language like Ruby, my thinking is: "This is great, but why_are_these_variable_names_so_long_and_hard_to_type"? I suspect that many people who've achieved fluency in JavaScript feel the same way. So, I favor the consistent approach. I honestly don't see any advantage to underscores. Every time I have to type an underscore, I sigh and think, "Why can't I just hold 'shift' and be done with it?" But then, I know other folks who find camelCase to be utterly hideous. I agree that option 3 is the worst option. I think option 1 is only viable if you were to jury-rig the compiler to map |
Is it too wishful to think that CoffeeScript could rewrite identifiers to camelCase. It would make me :( to see a project like CoffeeScript go so far in making writing JavaScript nicer cave in at the end like this. |
collin: Unfortunately, we can't muck with literal identifiers. Since you can access the property of an object by a string index ( |
Let's go with camelCase (option 2). I see coffeScript more as a javascript upgrade, not as a language for ruby converts. Readability is concern for random people looking at the code from outside. But javascript/coffescript programmers should have their brains already re-wired to read camelcase fluently. Option (1) is also pretty bad, because not everyone is going to read coding rules and it takes some time for coffeescript libraries to appear to show the right way of naming things. |
jashknas: Yeah, definitely a technical limitation. Sad shame of a limitation. Well, CoffeeScript is still streets ahead of JavaScript and I agree #2 is a sensible choice given the limitation. |
I've had years of experimenting with conventions and my view is probably the most controversial. I would go for option #3. Why would you mind the inconsistency? Is it really that bad? I've been working with a team where we don't have a convention and everyone has to use their own style. I find it people adopt a lot faster than you would expect just by looking at a screen of someone else's code.
|
I agree with Stan - there doesn't need to be a convention - just do whatever works for you are your peers. However a function is named, it doesn't offer more or less information if it's camel cased or underscored. |
App code often gets converted to lib code and vice versa, so consistency is very important here. Consistency between CoffeeScript and JavaScript makes sense too, as CoffeeScript's code gets translated to it. E.g., using the browser's Inspector and then finding a variable/function name (in our local source files) which can be in our code and/or in other people's JS code... So I'd definitely go for option #2. |
I would also vote for option #3. As long as a library is consistent I don't mind either style in Coffee. (For instance, I'd hate to see the source code switch to camelCase.) But for all external JS-facing interfaces (even the exposed CoffeeScript object), there's really only one choice. My personal preference is camelCase--I don't come from a Python/Ruby background where underscores may be accepted, but while under_scores may be more legible for reading, they don't feel pretty, and I like coffee_script for the prettiness. ;) Plus, camelCase feels most natural for "web scripting", after years of JS abuse. |
@jashknas: I think this is where StanAngeloff's extension patch will hopefully inspire a culture of Coffee extensions. For instance, authors could opt for an extension which translates all explicit property and variable references from under_scores to camelCase, provided they follow certain formatting rules (not using string indexes). Or have brackets, or use defer, or have matching JS line numbers. ;) Since coffee's just a preprocessor, I don't see why each author couldn't use their own flavor. Sounds exciting, really. |
@timcameronryan I like that. I understand the limitations of the identifier translation so I'm willing to take on the responsibility, but I don't want everybody to have to live in my insane fantasy world. |
Alright, as of this commit, I guess that the official CoffeeScript convention is to use camelCase: A sad day, but it's for the best, I'm sure. This'll be documented for the next release. Closing the ticket. |
I use snake_case all the time. camelCase isJustPlainUgly. |
I just wanted to say that after many months of coffee programming, choosing camelCase was a very bad idea. Code lacks readability of ruby VERY much. |
We're trying so hard to fix JavaScript; to make it look like Python or Ruby. Camel case is the exact opposite of that. I'm switching back to underscore, whatever the convention is. |
Should the CoffeeScript convention for variable names be camelCase (as in JavaScript) or underscores (as in Ruby)? I'd like to hear some thoughts on the matter.
The text was updated successfully, but these errors were encountered: