cor3ntin marked 6 inline comments as done.
cor3ntin added inline comments.

================
Comment at: clang/include/clang/Basic/Attr.td:1411
   let Documentation = [DeprecatedDocs];
+  let ParseArgumentsAsUnevaluated = 1;
 }
----------------
aaron.ballman wrote:
> What is the plan for non-standard attributes? Are you planning to handle 
> those in a follow-up, or should we be investigating those right now?
I don't feel I'm qualified to answer that. Ideally, attributes that expect 
string literals that are not evaluated should follow suite.


================
Comment at: clang/include/clang/Parse/Parser.h:1857-1859
                            bool FailImmediatelyOnInvalidExpr = false,
-                           bool EarlyTypoCorrection = false);
+                           bool EarlyTypoCorrection = false,
+                           bool AllowEvaluatedString = true);
----------------
aaron.ballman wrote:
> Two default `bool` params is a bad thing but three default `bool` params 
> seems like we should fix the interface at this point. WDYT?
> 
> Also, it's not clear what the new parameter will do, the function could use 
> comments unless fixing the interface makes it sufficiently clear.
I'm still not sure that's the best solution. `AllowEvaluatedString` would only 
ever be false for attributes, I consider duplicating the function, except it 
does quite a bit for variadics, which apparently attribute support

Maybe would could have

```
ParseAttributeArgumentList
ParseExpressionList
ParseExpressionListImpl?
```
?




================
Comment at: clang/lib/AST/Expr.cpp:1165
+    unsigned CharByteWidth = mapCharByteWidth(Ctx.getTargetInfo(), Kind);
+    unsigned ByteLength = Str.size();
+    assert((ByteLength % CharByteWidth == 0) &&
----------------
cor3ntin wrote:
> aaron.ballman wrote:
> > shafik wrote:
> > > Isn't this the same as `Length`?
> > It is -- I think we can get rid of `ByteLength`, but it's possible that 
> > this exists because of the optimization comment below. I don't insist, but 
> > it would be nice to know if we can replace the switch with `Length /= 
> > CharByteWidth` these days.
> Only when CharByteWidth == 1
I think we should.


================
Comment at: clang/lib/Lex/LiteralSupport.cpp:98
+  case 't':
+  case 'r':
+    return true;
----------------
aaron.ballman wrote:
> We're still missing support for some escape characters from: 
> http://eel.is/c++draft/lex#nt:simple-escape-sequence-char
> 
> Just to verify, UCNs have already been handled by the time we get here, so we 
> don't need to care about those, correct?
> Just to verify, UCNs have already been handled by the time we get here, so we 
> don't need to care about those, correct?

They are dealt with elsewhere yes (and supported)


================
Comment at: clang/lib/Lex/LiteralSupport.cpp:2080-2082
+      if (!isUnevaluated() && Features.PascalStrings &&
+          ThisTokBuf + 1 != ThisTokEnd && ThisTokBuf[0] == '\\' &&
+          ThisTokBuf[1] == 'p') {
----------------
aaron.ballman wrote:
> Is there test coverage that we diagnose this properly?
What sort of test would you like to see?


================
Comment at: clang/lib/Parse/ParseExpr.cpp:3501-3503
+    } else if (!AllowEvaluatedString && tok::isStringLiteral(Tok.getKind())) {
+      Expr = ParseUnevaluatedStringLiteralExpression();
+    } else {
----------------
aaron.ballman wrote:
> I'm surprised we need special logic in `ParseExpressionList()` for handling 
> unevaluated string literals; I would have expected that to be needed when 
> parsing a string literal. Nothing changed in the grammar for 
> http://eel.is/c++draft/expr.post.general#nt:expression-list (or 
> initializer-list), so these changes seem wrong. Can you explain the changes a 
> bit more?
We use `ParseExpressionList` when parsing attribute arguments, and some 
attributes have unevaluate string as argument - I agree with you that I'd 
rather find a better solution for attributes, but I came up empty. There is no 
further reason for this change, and you are right it does not match the grammar.


================
Comment at: clang/lib/Sema/SemaDeclAttr.cpp:878-879
 
-  if (!isIntOrBool(AL.getArgAsExpr(0))) {
+  Expr *First = AL.getArgAsExpr(0);
+  if (isa<StringLiteral>(First) || !isIntOrBool(First)) {
     S.Diag(AL.getLoc(), diag::err_attribute_argument_n_type)
----------------
aaron.ballman wrote:
> Test coverage for these changes?
There is one somewhere, I don;t remember where, The reason we need to do that 
is that Unevaluated StringLiterals don''t have types


================
Comment at: clang/lib/Sema/SemaDeclCXX.cpp:16470
   StringLiteral *Lit = cast<StringLiteral>(LangStr);
-  if (!Lit->isOrdinary()) {
-    Diag(LangStr->getExprLoc(), diag::err_language_linkage_spec_not_ascii)
-      << LangStr->getSourceRange();
-    return nullptr;
-  }
+  assert(Lit->isUnevaluated() && "Unexpected string literal kind");
 
----------------
aaron.ballman wrote:
> Test coverage for changes?
There are some in dcl.link/p2.cpp


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