Introduces DefineInline action and initial version of availability
checks.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
- Build Status
Buildable 38600 Build 38599: arc lint + arc unit
Event Timeline
clang-tools-extra/clangd/unittests/TweakTests.cpp | ||
---|---|---|
52 | This function, and all the other helpers in this file, are actually imminently going away in favor of TweakTesting.h. We should work out how to do that stuff there. ExtraFiles["foo.h"] = "..."; EXPECT_EQ(apply("..."), "..."); EXPECT_THAT(EditedFiles, ElementsAre(Pair(testPath("foo.h"), "..."); or something like this. (Whatever we do, we should bear in mind the fact that out-line will mean we need to supply an index too) | |
544 | I don't think so | |
566 | nit: NoForwardDecl | |
596 | FWIW, I find these params rather cryptic - it'd be nice to have an API for the helpers that is explicit about this being files/filenames |
When fully implemented, will define inline tweak work with C++ methods in classes as well?
E.g.
HEADER: class Foo { void foo(); } CPP: #include "Header.h" void Foo::foo() {}
becomes:
HEADER: class Foo { void foo() { } } CPP: #include "Header.h"
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
193 | Sorry, I'm not really familiar with design of tweaks, so this might be a bad question: Is it possible to change the title of the tweak on a per-TU basis. More specifically, some tweaks might want to have different titles for Objective-C actions compared to their C++ siblings. |
Yes you can see an example of it in the tests provided in TweakTests.cpp
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
193 | Current design returns a constant string per tweak, but we can change that behaviour easily by making this a function of language options. You can take a look at ClangdServer::enumerateTweaks for details. |
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
193 | This isn't quite true: id() must be constant but title() need not be. See ExpandMacro for an example. The only constraint is it shouldn't be terribly expensive (this is why ExpandAuto doesn't include the type in the title, due to an AST bug it requires a new traversal).
I think this is possible and the right idea. But for completeness I should mention: having multiple Tweak subclasses that share implementation is also possible. In particular in cases where you have two related actions and may want to provide *both* as options (maybe extract function vs method?), they'd need to be separate subclasses. (Or we'd need to change the design a bit) |
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
193 | Oh yes, I think it's probably better to use the Tweak subclasses like you said. This will be better for ObjC++, which could have either a C++ or an ObjC tweak available depending on the current AST selection. |
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
66 | nit: maybe use auto? | |
79 | thinking this a bit more, the function is non-trivial, we probably want unit test for it. | |
106 | IIUC, I believe this function relies on the flag "Opts.IndexFunctionLocals"? could we spell it explicitly in the code even its default value false fits our use case. | |
114 | hmm, looks like we don't use TargetContext in the implemenation at all. Is the comment out-of-date now? | |
142 | we are distinguishing two cases here: normal functions and the class methods. Could we make the code handle these two cases separately? e.g. if (Class) { // check whether they are in the same class; } else { // handle normal function // call isBeforeInTranslation } | |
161 | function template is tricky, I may be not aware of the context, what's our plan for supporting it? could you give an concrete example? it seems that the current unit test doesn't cover it. | |
173 | I believe it also works for class methods? | |
184 | now we get a potential ODR violation in this example, maybe choose a different example? | |
225 | The tweak is under development, do we need to hide it until it is completed? | |
clang-tools-extra/clangd/unittests/TweakTests.cpp | ||
25 | the header seems irrelevant to me. | |
708 | The a.h seems to be non-existed unless you explicitly set it via ExtraFiles["a.h"]? |
- Address comments
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
79 | agreed, sent out D67748 | |
114 | we are still checking its visibility in target context, but without making use of declcontext. Updating the comment. | |
161 | Yes we plan to support them, added a test case thanks for pointing it out. This basically ensures that we select the correct decl in the case of template spec decls, because canonical decl is function template itself, instead of the specialization decl. | |
184 | You are right, but we cannot get away from it by changing the example. Adding an "inline " instead, and I believe that's what we should do if we are moving a function definition to a header. | |
225 | I wasn't planning to land it before all of its dependencies are LGTM'd, but marking it as hidden just in case. |
mostly good to me, a few more comments.
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
157 | maybe name it findTarget? I think the function is used to find a potential target decl which the definition will be moved to, Canonical doesn't provide much information here. | |
161 | We may get a nullptr if FD is the first declaration, I think we need to handle the nullptr case, otherwise the check will crash. | |
184 | I think not all cases will need inline, e.g. class method, or function template(?). Fix these problems is out-scope of the tweak (there is a clang-tidy check handling this case), and probably add complexity to the implementation. I'm leaning on not fixing it. Maybe a better example is class method? | |
186 | I'm not sure Inline function definition is a widely-known refactoring term, I think "Move function definition to declaration" is probably easier for normal C++ developers to understand? | |
clang-tools-extra/clangd/unittests/TweakTests.cpp | ||
712 | I think we missing a basic test where a declaration is in the header and it can be moved? Header = "void foo();" |
- Address comments
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
161 | theoretically, a template specialization cannot be the first decl, as one needs to declare function template first. | |
184 | yes clang-tidy can generate those fixes but I believe a code-action should not generate code that relies on a clang-tidy check to fix it. | |
clang-tools-extra/clangd/unittests/TweakTests.cpp | ||
712 | isn't it covered by the next testcase ? |
looks good with a few nits.
clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp | ||
---|---|---|
155 | nit: the comment is out of date with the new change? | |
184 | I'm still not convinced that we should fix it in the check. but we don't have to solve it out in this patch, could we remove the inline from the sample? (adding it now seems to confuse users, we don't support it yet). | |
clang-tools-extra/clangd/unittests/TweakTesting.h | ||
52 | nit: add a comment // file name => file content. | |
clang-tools-extra/clangd/unittests/TweakTests.cpp | ||
712 | ah, sorry, I missed that. |
The test fails in Windows: http://45.33.8.238/win/1112/step_7.txt
Ptal, and if it takes a while to investigate please revert while you look.
nit: maybe use auto?