<div dir="ltr">On Sun, May 5, 2013 at 9:50 AM, Abramo Bagnara <span dir="ltr"><<a href="mailto:abramo.bagnara@bugseng.com" target="_blank">abramo.bagnara@bugseng.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote">
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Il 05/05/2013 18:41, Richard Smith ha scritto:<br>
<div class="im">> On Sun, May 5, 2013 at 9:17 AM, Richard Smith <<a href="mailto:richard@metafoo.co.uk">richard@metafoo.co.uk</a><br>
</div><div class="im">> <mailto:<a href="mailto:richard@metafoo.co.uk">richard@metafoo.co.uk</a>>> wrote:<br>
><br>
>     On Sun, May 5, 2013 at 8:45 AM, Abramo Bagnara<br>
</div><div class="im">>     <<a href="mailto:abramo.bagnara@bugseng.com">abramo.bagnara@bugseng.com</a> <mailto:<a href="mailto:abramo.bagnara@bugseng.com">abramo.bagnara@bugseng.com</a>>> wrote:<br>
><br>
>         Il 05/05/2013 17:05, Richard Smith ha scritto:<br>
>         > On Sun, May 5, 2013 at 2:53 AM, Abramo Bagnara<br>
>         > <<a href="mailto:abramo.bagnara@bugseng.com">abramo.bagnara@bugseng.com</a><br>
>         <mailto:<a href="mailto:abramo.bagnara@bugseng.com">abramo.bagnara@bugseng.com</a>><br>
</div>>         <mailto:<a href="mailto:abramo.bagnara@bugseng.com">abramo.bagnara@bugseng.com</a><br>
<div><div class="h5">>         <mailto:<a href="mailto:abramo.bagnara@bugseng.com">abramo.bagnara@bugseng.com</a>>>> wrote:<br>
>         ><br>
>         >     Il 26/04/2013 16:36, Richard Smith ha scritto:<br>
>         >     > Modified: cfe/trunk/lib/Sema/SemaInit.cpp<br>
>         >     > URL:<br>
>         ><br>
>         <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaInit.cpp?rev=180603&r1=180602&r2=180603&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaInit.cpp?rev=180603&r1=180602&r2=180603&view=diff</a><br>

>         >     ><br>
>         ><br>
>         ==============================================================================<br>
>         >     > --- cfe/trunk/lib/Sema/SemaInit.cpp (original)<br>
>         >     > +++ cfe/trunk/lib/Sema/SemaInit.cpp Fri Apr 26 09:36:30 2013<br>
>         >     > @@ -97,6 +97,7 @@ static void CheckStringInit(Expr *Str, Q<br>
>         >     >      DeclT =<br>
>         S.Context.getConstantArrayType(IAT->getElementType(),<br>
>         >     >                                             ConstVal,<br>
>         >     ><br>
>         ArrayType::Normal, 0);<br>
>         >     > +    Str->setType(DeclT);<br>
>         >     >      return;<br>
>         >     >    }<br>
>         ><br>
>         >     Is this change deliberate? It seems to introduce a regression:<br>
>         ><br>
>         >     $ cat z.c<br>
>         ><br>
>         >     void f() {<br>
>         >       signed char s[] = "a";<br>
>         >       unsigned char u[] = "a";<br>
>         >     }<br>
>         >     $ _clang -cc1 -ast-dump z.c<br>
>         >     TranslationUnitDecl 0x67d96e0 <<invalid sloc>><br>
>         >     |-TypedefDecl 0x67d9bc0 <<invalid sloc>> __int128_t '__int128'<br>
>         >     |-TypedefDecl 0x67d9c20 <<invalid sloc>> __uint128_t<br>
>         'unsigned __int128'<br>
>         >     |-TypedefDecl 0x67d9f70 <<invalid sloc>> __builtin_va_list<br>
>         >     '__va_list_tag [1]'<br>
>         >     `-FunctionDecl 0x67da010 <z.c:2:1, line:5:1> f 'void ()'<br>
>         >       `-CompoundStmt 0x67da350 <line:2:10, line:5:1><br>
>         >         |-DeclStmt 0x67da208 <line:3:3, col:24><br>
>         >         | `-VarDecl 0x67da100 <col:3, col:21> s 'signed char [2]'<br>
>         >         |   `-StringLiteral 0x67da198 <col:21> 'signed char<br>
>         [2]' lvalue "a"<br>
>         >         `-DeclStmt 0x67da338 <line:4:3, col:26><br>
>         >           `-VarDecl 0x67da270 <col:3, col:23> u 'unsigned char<br>
>         [2]'<br>
>         >             `-StringLiteral 0x67da2c8 <col:23> 'unsigned char [2]'<br>
>         >     lvalue "a"<br>
>         ><br>
>         >     Type of string literal should be plain char.<br>
>         ><br>
>         ><br>
>         > Yes, this is deliberate; we intended to set the string<br>
>         literal's type to<br>
>         > the type of the initialized variable (otherwise we would be<br>
>         initializing<br>
>         > an array of 'unsigned char' from an array of 'char'), but<br>
>         accidentally<br>
>         > only updated it in either the array bound or the type, but not<br>
>         both.<br>
>         ><br>
>         >   unsigned char a[] = "foo", b[4] = "bar";<br>
>         ><br>
>         > ... used to produce ...<br>
>         ><br>
>         > |-VarDecl 0x6222ad0 <<stdin>:1:1, col:21> a 'unsigned char [4]'<br>
>         > | `-StringLiteral 0x6222ba8 <col:21> 'const char [4]' lvalue "foo"<br>
>         > `-VarDecl 0x6222c60 <col:1, col:35> b 'unsigned char [4]'<br>
>         >   `-StringLiteral 0x6222cb8 <col:35> 'unsigned char [4]'<br>
>         lvalue "bar"<br>
><br>
>         BTW: uniformity is still not there:<br>
>         $ cat z.c<br>
>         void f() {<br>
>           unsigned char q[] = ("a");<br>
>         }<br>
>         $ _clang -cc1 -ast-dump z.c<br>
>         TranslationUnitDecl 0x6f296e0 <<invalid sloc>><br>
>         |-TypedefDecl 0x6f29bc0 <<invalid sloc>> __int128_t '__int128'<br>
>         |-TypedefDecl 0x6f29c20 <<invalid sloc>> __uint128_t 'unsigned<br>
>         __int128'<br>
>         |-TypedefDecl 0x6f29f70 <<invalid sloc>> __builtin_va_list<br>
>         '__va_list_tag [1]'<br>
>         `-FunctionDecl 0x6f2a010 <z.c:2:1, line:4:1> f 'void ()'<br>
>           `-CompoundStmt 0x6f2a240 <line:2:10, line:4:1><br>
>             `-DeclStmt 0x6f2a228 <line:3:3, col:28><br>
>               `-VarDecl 0x6f2a100 <col:3, col:27> q 'unsigned char [2]'<br>
>                 `-ParenExpr 0x6f2a1c8 <col:23, col:27> 'unsigned char<br>
>         [2]' lvalue<br>
>                   `-StringLiteral 0x6f2a198 <col:24> 'char [2]' lvalue "a"<br>
><br>
><br>
>     Yes, this is definitely wrong. A ParenExpr shouldn't change the type<br>
>     of its operand.<br>
><br>
><br>
> Fixed in r181159, thanks; this could be coaxed into producing a<br>
> crash-on-valid.<br>
<br>
<br>
void f() {<br>
</div></div>  unsigned char q[2] = __extension__ ("a");<br>
}<br>
<br>
Consider also this case.</blockquote><div><br></div><div style>Thanks, same problem for</div><div style><br></div><div style>  char cs[] = _Generic(5, int: "foo");</div><div style><br></div><div style>I'll look into this later today.</div>
<div style><br></div><div style>As an aside, it's not obvious to me that any of these cases are actually valid in C; C++ says that "The parenthesized expression can be used in exactly the same contexts as those where the enclosed expression can be used, and with the same meaning, except as otherwise indicated." but C has no matching rule.</div>
</div></div></div>