nridge added inline comments.

================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:136
+// Whether D is const in a loose sense (should it be highlighted as such?)
+bool isConst(const Decl *D) {
+  if (llvm::isa<EnumConstantDecl>(D) || llvm::isa<NonTypeTemplateParmDecl>(D))
----------------
nridge wrote:
> sammccall wrote:
> > nridge wrote:
> > > Do you think in the future it might make sense to have the `readonly` 
> > > modifier reflect, at least for variables, whether //the particular 
> > > reference// to the variable is a readonly reference (e.g. binding the 
> > > variable to a `const X&` vs. an `X&`)?
> > Do I understand correctly?
> > 
> > ```
> > std::vector<int> X; // X is not readonly
> > X.push_back(42); // X is not readonly
> > X.size(); // X is readonly
> > ```
> > 
> > Distinguishing potentially-mutating from non-mutating uses seems really 
> > useful to me.
> > My only question is whether mapping this concept onto `readonly` is the 
> > right thing to do:
> >  - there are really three sets: const access, mutable access, and 
> > non-access (e.g. declaration, or on RHS of `using a=b`). And I think maybe 
> > the most useful thing to distinguish is mutable access vs everything else, 
> > which is awkward with an attribute called "readonly".
> >  - this also seems likely to diverge from how other languages use the 
> > attribute (most don't have this concept)
> >  - on the other hand, standard attribute names will be better supported by 
> > clients
> > 
> > This also might be somewhat complicated to implement :-)
> > I'd like to leave in this simple decl-based thing as a placeholder, and 
> > either we can replace it and add an additional "mutation" attribute later 
> > (once we work out how to implement it!) I've left a comment about this...
> > 
> > (Related: a while ago Google's style guide dropped its requirement to use 
> > pointers rather than references for mutable function params. Having `&x` at 
> > the callsite rather than just `x` is a useful hint, but obviously diverging 
> > from common practice has a cost. We discussed how we could use semantic 
> > highlighting to highlight where a param was being passed by mutable 
> > reference, though didn't have client-side support for it yet)
> > Do I understand correctly?
> > 
> > ```
> > std::vector<int> X; // X is not readonly
> > X.push_back(42); // X is not readonly
> > X.size(); // X is readonly
> > ```
> 
> Yup, that's what I had in mind.
> 
> > Distinguishing potentially-mutating from non-mutating uses seems really 
> > useful to me.
> > My only question is whether mapping this concept onto `readonly` is the 
> > right thing to do:
> >  - there are really three sets: const access, mutable access, and 
> > non-access (e.g. declaration, or on RHS of `using a=b`). And I think maybe 
> > the most useful thing to distinguish is mutable access vs everything else, 
> > which is awkward with an attribute called "readonly".
> >  - this also seems likely to diverge from how other languages use the 
> > attribute (most don't have this concept)
> >  - on the other hand, standard attribute names will be better supported by 
> > clients
> > 
> > This also might be somewhat complicated to implement :-)
> > I'd like to leave in this simple decl-based thing as a placeholder, and 
> > either we can replace it and add an additional "mutation" attribute later 
> > (once we work out how to implement it!) I've left a comment about this...
> 
> Sounds good!
> 
> > (Related: a while ago Google's style guide dropped its requirement to use 
> > pointers rather than references for mutable function params. Having `&x` at 
> > the callsite rather than just `x` is a useful hint, but obviously diverging 
> > from common practice has a cost. We discussed how we could use semantic 
> > highlighting to highlight where a param was being passed by mutable 
> > reference, though didn't have client-side support for it yet)
> 
> Funny you mention this, because I implemented this exact highlighting in 
> Eclipse a few years ago:
> 
> https://wiki.eclipse.org/CDT/User/NewIn92#Syntax_coloring_for_variables_passed_by_non-const_reference
> 
> (and it's my main motivation for the suggestion I've made here).
> I implemented this exact highlighting in Eclipse a few years ago

I will readily admit that classifying references as mutable or not can get 
tricky. For example:

```
int* array = new int[10];
array[0] = 42;
```

Is the reference to `array` on the second line mutable? Does the answer change 
if the declaration is changed to `int array[10];`?

Fun questions to figure out later :-)


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D77811

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

Reply via email to