-
Notifications
You must be signed in to change notification settings - Fork 4.1k
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
Proposal: Names with whitespaces #8542
Comments
My eyes.
If you argue that PascalCase is not readable enough, how do you propose an alternative that you know it is less readable? |
Technically legal to the CLR but I really don't think that this is a good idea, particularly with white space. I honestly think that your escaped example is much less readable given that you have to visually parse out the specific beginning and ending escape quotes while mentally bookkeeping the whitespace which would otherwise serve as visual indicators. |
F# supports that, which is actually very nice for unit tests -- especially since test runners such as Resharper's already display the test names correctly. [<Test>]
let `2 times 2 should be 4`` () =
2 * 2 |> should be 4 Except for tests, however, this naming style should be avoided, in my opinion, as it makes things less readable. |
@axel-habermaier Agreed, but when you start to use it like everywhere, it becomes less nice. |
Then don't use it like everywhere :) It's a really nice feature for test method names and therefore is a good proposal. The fact that bad programmers will misuse it should not be a blocker to this proposal. If we adopted that strategy, we'd have no programming languages at all! |
Test reports could just as easily replace underscores with spaces. Language features shouldn't be designed around how very specific tools happen to display their data. |
"Language features shouldn't be designed around tests" (slight misquote) is a dubious assertion. I start with a test ... therefore it's reasonable to expect my language of choice to at least make writing that test as easy as possible. Therefore features that enhance test writing should be considered simply on that merit, unless they adversely affect other areas of coding. |
@DavidArno This feature doesn't affect how you write tests, it affects how you visualize the results, and only because the tools currently just vomit the names into their reports. There are plenty of other options that don't require modifying the entirety of the language, such as reformatting the class/method names or including free-form descriptions in the attributes. |
Whitespace as part of legal identifier names is useful in languages where data is a first class object (such as SQL). I think it's confusing and counterproductive in a general purpose language like C#. |
versus
Expressing test methods in natural language inherently makes the test's purpose easier to determine. It's not just about the output of test results. Which is why this feature is so useful in F#, regardless of the test framework used. Part of the reasoning behind some of the feature choices for C# 7 is to make it more of a data-orientated language. Thus your argument actually counts as a plus point for this feature... |
@DavidArno Do you really write all the arrange, act and assertion in your test method name? |
This discussion has me fun. I'm rolling on the floor :) In languages where there is such feature, it is used where it is really needed. How often a DB table names contain spaces? If it shouldn't give freedom, let it limit. Strong names have to match the regular expression "[_A-Za-z][_A-Za-z0-9]*". Not everyone understands the name of the variable "НеКаждыйПойметНазваниеЭтойПеременной" ^) |
This suggestion could lead to easier translations from data languages that allow spaces in their keys or names, such as JSON. |
All the time; don't you? :) Perhaps that wasn't a great example, but taking a real example, I find I tend to use a weird pigeon English with test method names, eg
Using natural language, it becomes much clearer, I feel, as to what I mean with the test:
|
@DavidArno I'd say the compiler should infer the whole method body right from the name. You've just discovered yet another recursively nonsensical point. Because if you write type/method/properties' names in your test method, it doesn't even support refactoring. What a disappointment. I think it should be integrated with something like #8503 so you can actually write your test in the method name and it gets compiled right there. #MakeC#GreatAgain |
I do note that this'd be more of a tooling improvement rather than language change, see this blog post. |
@p-e-timoshenko Anyway why can't these things be presented by metadata? |
@GeirGrusom I can list a number of cases where the strange names are generated. For example, resource property names have it. using static Properties.Resources;
MessageBox.Show(`Do you want to quit?`); |
But isn't that with the specific intention that those identifiers should be inaccessible from the language? Anonymous types and closures have special names generated as well which currently cannot be expressed in C#, but this proposal would suddenly allow it.
If you change the value to "Are you sure you want to quit?" without changing the resource name that would would be confusing like hell. There is very little reason to not call that resource ExitQuery or something similar instead. |
Is that a declaration of a new variable named |
@gafter I don't think that syntax was proposed. ``String s |
You have completely misunderstood this proposal. Identifiers with spaces would need to be enclosed in eg
Please re-open this issues and it has not been "resolution answered" |
I think @gafter just answered the question.
Therefore, Resolution-Answered. |
Generally, it helps to wind people up less if one reads the whole question, rather than just the first sentence, before answering... |
I understand how it feels like having +400 items in the Backlog. I don't bother a bit if my proposal has been misunderstood so I try to keep it concise and right to the point. I'm just saying that it is not a reasonable question to ask in the first place — seems like the motivation for the proposal. Just to point out that you're not being fair. |
What programming languages support whitespaces in identifiers? I think, this feature can be used to name compatibility purposes with other programming languages.
In this restricted setting of a comma-separated list of key-value pairs, there's no parsing difficulty. In fact, I think it's much easier to read than the alternatives like topColor, top_color or topcolor.
You could just as easily write
The various scopes in Coldfusion can also be treated as either a (dict|hash|associative array) or a name.
|
@p-e-timoshenko The only language in that list that is somewhat in the C/C++ family of languages, at least in terms of syntax, is JavaScript, and in that case you're not permitted to have identifiers with whitespace in them. But since every object is effectively a dictionary you can have keys of any arbitrary string. You cannot declare anything which requires an identifier with an arbitrary name containing whitespace, such as a variable or class. |
@HaloFour Not many languages in the C/C++ family had lambda expressions before C#, that didn't mean it was a bad idea. |
@bondsbw Lambda expressions in the language provide compelling use cases. Whitespace in the identifiers in the language does not. Anywho, seems the team has spoken and I doubt that the answer will change. |
Is there a technical reason why white spaces aren't allowed in names of constants, variables, methods, classes and namespaces or is it in accordance with any convention? This question can also be asked in relation to the digits that can’t be placed at the beginning of the name.
The main reason to follow a naming convention is to reduce the effort needed to read and understand source code. The developers could focus on more important issues than arguing over syntax and naming standards. For this reason there is a strict rule that names are usually case-sensitive. A name can be any legal identifier — an unlimited-length sequence of Unicode letters and digits, beginning with a letter or the underscore character. White space in names is not permitted.
The last rule is used not only due to the difficulties with code understanding. The compiler needs to find out the meaning of words. It works on a “State Machine” method, and it needs to distinguish key words. However, there are languages like SQL or Maple where names can contain white spaces. They are enclosed on both sides of special quotation mark characters: “[” and “]” in SQL, “`” (U+0060, grave accent) in Maple. In C# square brackets are used as indexers of collection items. But the grave accent symbol can be successfully used as enclosed symbol.
Let's try to write a code in C# using quite long names containing white spaces and see what happens.
No doubt, it is possible to make the compiler to parse this code. However, the code has become much harder to read. Surprising for me, the readability of the code decreased just slightly! The first place is taken by already existing issue of too long names. There are a large number of articles (“Very Long Descriptive Names That Programming Pairs Think Provide Good Descriptions” or “Best Practices for Variable and Method Naming”) to provide some useful solutions. This issue has existed since the origin of object-oriented languages. According my point of view, while thinking about code it is useful to look at it from the other developers side who may use it. This will help not only with picking names, but with keeping your code more readable without writing a documentation and unnecessary comments. If the name is too long, then maybe this part of the code has multiple responsibilities and it should be written separately. In other words, the code should be re-factored.
Also there is a question, how to improve the readability and where to use the feature. The main areas of application might be defined as unit testing classes and classes contained internationalization string properties implemented by string resource or configuration settings sections wrapper classes. The readability could be improved due to features of IDE. For example, the names with white spaces can be highlighted by thin dotted border. This approach will allow developers to identify such names visually and quickly, and will restrict the widespread thoughtless use of names with white spaces.
Let's try to write a simple unit test in C#.
The unit test code in C# has a very good readability. It doesn't need additional attributes to be displayed correctly in the test reporting window. However, it could be useful to write the attributes specified the test categories.
The often use of such a long names in the code isn’t the best way. But if there is a necessary to refer to them, it may be useful to apply the standard way to reduce such names by the method presented in natural languages. Some non-significant parts of the name can be replaced by ellipsis characters.
The text was updated successfully, but these errors were encountered: