kadircet added inline comments.

================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:68
+  bool hasOnlyRootStmtChildren();
+  // We only support extraction of RootStmts. A RootStmt as a statement that is
+  // fully selected including all of it's children.
----------------
Could you move the definition of `RootStmt` to class definition? Since it is 
used in a lot more places than just this one.


================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:68
+  bool hasOnlyRootStmtChildren();
+  // We only support extraction of RootStmts. A RootStmt as a statement that is
+  // fully selected including all of it's children.
----------------
kadircet wrote:
> Could you move the definition of `RootStmt` to class definition? Since it is 
> used in a lot more places than just this one.
> We only support extraction of RootStmts.

Can you also mention the reasoning/implications ?


================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:71
+  // Returns the (unselected) parent of all RootStmts.
+  static const Node *getParentOfRootStmts(const Node *CommonAnc);
+  // Find the union of source ranges of all child nodes of Parent. Returns an
----------------
Can you make this and the `computeEnclosingFunction{,Rng}` free functions 
instead of static methods?


================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:74
+  // inavlid SourceRange if it fails to do so.
+  SourceRange computeSourceRng();
+  // Finds the function in which the source lies.
----------------
haven't checked the implementation yet, but naming and the comments seem to be 
ambiguous.

Do you mean *selected* childrens of `Parent`, instead of *all*? Because IIUC, 
`Source` refers to the part of the function body that is selected, not all of 
it, right?


================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:222
+
+public:
+  std::string FuncName = "extracted";
----------------
comments for some of the fields like `SemicolonPolicy` would be nice.

also most of these looks like implementation details, consider moving internal 
ones to private


================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:286
+
+// Captures information about the source.
+class CapturedSourceInfo {
----------------
could you give more details on what is collected and how?


================
Comment at: clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp:360
+
+CapturedSourceInfo::DeclInformation &
+CapturedSourceInfo::getDeclInformationFor(const Decl *D) {
----------------
why not move this and 4 following functions into astvisitor?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D65526



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

Reply via email to