aaron.ballman added a subscriber: clang-vendors.
aaron.ballman added a comment.

In D105759#4457041 <https://reviews.llvm.org/D105759#4457041>, @cor3ntin wrote:

> In D105759#4456864 <https://reviews.llvm.org/D105759#4456864>, @aaron.ballman 
> wrote:
>
>> I don't think it's correct to assume that all string arguments to attributes 
>> are unevaluated, but it is hard to tell where to draw the line sometimes. 
>> Backing up a step, as I understand P2361 <https://reviews.llvm.org/P2361>, 
>> an unevaluated string is one which is not converted into the execution 
>> character set (effectively). Is that correct? If so, then as an example, 
>> `[[clang::annotate()]]` should almost certainly be using an evaluated string 
>> because the argument is passed down to LLVM IR and is used in ways we cannot 
>> predict. What's more, an unevaluated string cannot have some kinds of escape 
>> characters (numeric and conditional escape sequences) and those are 
>> currently allowed by `clang::annotate` and could potentially be used by a 
>> backend plugin.
>>
>> I think other attributes may have similar issues. For example, the `alias` 
>> attribute is a bit of a question mark for me -- that takes a string literal 
>> representing an external identifier that is looked up. I'm not certain 
>> whether that should be in the execution character set or not, but we do 
>> support escape sequences for it: https://godbolt.org/z/v65Yd7a68
>>
>> I think we need to track evaluated vs not on the argument level so that the 
>> attributes in Attr.td can decide which form to use. I think we should 
>> default to "evaluated" for any attribute we're on the fence about because 
>> that's the current behavior they get today (so we should avoid regressions).
>
> I really don't think it makes sense to have both "unevaluated" and 
> "evaluated" arguments.
> We chatted offline and we struggle to find places where escape sequences are 
> used, or examples of attributes intended to be in the execution character set.

In general I agree, but the one scenario that I keep coming back to are 
attributes like `diagnose_if` where they take an expression we're evaluating at 
compile time (condition expression) and a string literal that's not evaluated 
(warning vs error, diagnostic message itself). But I think the "evaluating at 
compile time" is part of why I don't think we intend the attribute to be 
considering the execution character set.

> My suggestion would be to land the non-attributes changes now, and the 
> attributes bits in early clang 18.

I think we're almost safe enough to make the attribute changes in Clang 17 so 
that no attribute uses an evaluated argument, but given that there's less than 
a month before we make the 17 branch, I think it's probably a good idea to make 
these changes after the branch point so folks have longer to react. Adding 
`clang-vendors` to the review for awareness of the potential for a breaking 
change.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D105759

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

Reply via email to