This is only updating the documentation. We'll be able to
update the codebase piece by piece.
Details
Diff Detail
- Repository
- rL LLVM
Event Timeline
:happy dance:
docs/CodingStandards.rst | ||
---|---|---|
136 ↗ | (On Diff #74931) | Can we add a comment or something to the effect of "should we reconsider this now that msvc 2013 is gone?" |
docs/CodingStandards.rst | ||
---|---|---|
136 ↗ | (On Diff #74931) | Maybe we should consider it now? |
docs/CodingStandards.rst | ||
---|---|---|
136 ↗ | (On Diff #74931) | For my part, I have no problem with braced initializers inside a class. They can be helpful. But where possible I prefer using an equals sign, int foo_member = 42, because that's just easier to understand. I dunno if that's contentious, though. |
I was looking at these files for gcc and clang, and I think we should eliminate all redundancies. You can talk about the features, but we shouldn't mention versions except in the "supported version" section.
I've removed the mention from the developer policy, pointing to the getting started because there was more involved description there, but I really think that's the wrong place, too. Though, this can be done in a separate patch.
Cheers,
Renato
docs/GettingStartedVS.rst | ||
---|---|---|
51 ↗ | (On Diff #74931) | I don't think the CMake version is still valid here? |
docs/CodingStandards.rst | ||
---|---|---|
136 ↗ | (On Diff #74931) | If MSVC was the only reason that braced initializers were disallowed then we should allow them now. Why keep that restriction after MSVC is upgraded? |
Version increase in cmake/modules/CheckCompilerVersion.cmake is missing.
The reported version of Visual Studio 2015 Update 3 (the most recent) is 19.00.24215.1
docs/CodingStandards.rst | ||
---|---|---|
136 ↗ | (On Diff #74931) | Note: the braced initializers policy is described somewhere else: http://llvm.org/docs/CodingStandards.html#do-not-use-braced-initializer-lists-to-call-a-constructor I guess it is loosely related to the issue above, but not that much. My understanding is that the rule above forbid: class X { std::string Name = "<uninitialized>"; } I don't know the motivation for it though. |
I don't know about requiring "the most recent update". But "Update 3", yes. There are some bad codegen issues in prior updates. But the wording should still say "Update 3" and not "the most recent update", because we don't want to accidentally have to bump the version in the unlikely event that an Update 4 were released, for example.
(And fwiw, YAY THANK YOU ALL)
docs/CodingStandards.rst | ||
---|---|---|
136 ↗ | (On Diff #74931) | I have no idea what the motivation here was... I am very happy with non-static class member initializers *if and only if the equals is used*. I have fairly strong objections to using braced initialization *syntax* here. But that is just about the syntax, which this comment doesn't really mention. I would just change this to say something along the lines of: * Feel free to use these wherever they make sense and where the `=` syntax is allowed. Don't use braced initialization syntax. (and link that last bit however the links work in RST) |
Can we please get a rationale added for avoiding braced syntax? Not that I disagree with it, I just think things like that should be backed up in the document that bans them.
Yea, the current wording is a bit hand-wavy. I'll send out a separate patch that spiffs up the content to make this more clear.
Use Chandler wording:
Feel free to use these wherever they make sense and where the `=` syntax is allowed. Don't use braced initialization syntax.
looks good, but you will need to rebase, I already landed a wording update. :)
docs/GettingStartedVS.rst | ||
---|---|---|
48 ↗ | (On Diff #75161) | I kind of preferred the "latest update" wording. We don't say GCC 4.8.N, we say we support GCC 4.8, and some of those micro releases might have bugs, so make sure you're not using a buggy compiler. That's not to say that MSVC 2015 Update 1 won't work, it just isn't "supported". |