dgoldman marked 3 inline comments as not done.
dgoldman added inline comments.


================
Comment at: 
clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp:113
+    if (MD->getMethodFamily() == OMF_init) {
+      Loc = effectiveEndLoc(MD, SM).getLocWithOffset(1);
+    } else if (Loc.isValid()) {
----------------
sammccall wrote:
> This algorithm doesn't make much sense to me. 
> You want to insert before the first non-init instance method, falling back to 
> the end.
> So why do you need to do more than search for the first non-init instance 
> method, and find the location before it? In particular why are we looking at 
> init methods and locations after them?
Yeah, I think that makes more sense, changed.


================
Comment at: 
clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp:199
+
+  // We support the following selected decls:
+  // - ObjCInterfaceDecl/ObjCImplementationDecl only - generate for all
----------------
sammccall wrote:
> I understand the desire to select the particular fields, but given the 
> limitation of the interaction I wonder whether these cases are useful & 
> discoverable enough to be worth the complexity.
> 
> - how often is an initializer that sets one variable of many useful?
> - out of the times when a subset of variables should be initialized, how 
> often are they contiguous in the code?
> 
> I think it would likely be better to start with initializing all members...
I didn't realize that VS Code only lets you select a range, not selecting 
multiple points (e.g. multiple cursors). I still think this could be useful and 
it isn't that hard to support, although yes, ideally we could do something like 
IntelliJ where it presents you a UI to select fields. The main use case of this 
atm is for simple model objects, and for those I think it could be useful to 
make some params optional although the contiguous limitation is definitely 
restrictive.

FWIW I don't think code actions in general are particularly discoverable.


================
Comment at: 
clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp:285
+
+  SmallVector<MethodParameter, 8> Params;
+  initParams(N, Params);
----------------
sammccall wrote:
> nit: why isn't this a return value?
IIUC this (having the impl vector be an out param) seems to be the convention - 
`SmallVectorImpl(const SmallVectorImpl &) = delete;`, but I can change the 
return type to instead be SmallVector<MethodParameter, 8>, WDYT?


================
Comment at: 
clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp:290
+
+  bool GenerateImpl = isa<ObjCImplementationDecl>(Container);
+  llvm::SmallString<256> Text(std::string(LocPadding.PadStart, '\n'));
----------------
sammccall wrote:
> Wait, so if the user triggers the action on @interface then they'll get a 
> decl with no impl, and if they trigger on @implementation they'll get the 
> opposite?
> 
> Seems like we should at least try to generate both, no? (May not be possible 
> if we're triggering on @interface and index lookup fails, but still...)
Yeah, I decided to avoid this due to the complexity for a v1, could look into 
adding it in a follow up. For sourcekit-lsp, it would only work if you've 
opened the impl first (since it will only have the dynamic index available). Is 
there anything I could look at which does something similar?


================
Comment at: 
clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp:291
+  bool GenerateImpl = isa<ObjCImplementationDecl>(Container);
+  llvm::SmallString<256> Text(std::string(LocPadding.PadStart, '\n'));
+
----------------
sammccall wrote:
> For building strings like this with formatting, we usually use 
> raw_string_ostream and `formatv`.
> This would make the stuff starting at 303 easier to read
Yep that helps quite a bit


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D116385/new/

https://reviews.llvm.org/D116385

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to