On Wed, Apr 16, 2025 at 09:25:00PM +0200, Jakub Jelinek wrote:
> Hi!
> 
> Aaron mentioned in the PR that late in C23 N3124 was adopted and
> $@` are now part of basic character set.  The paper has been implemented
> in GCC from what I can see, but we should allow for GNU23/2Y $@` in
> raw string delimiters as well, like they are allowed for C++26, because
> the delimiters can contain anything from basic character set but space,
> ()\, tab, form-feed, newline and backspace.
> 
> Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
> 
> 2025-04-16  Jakub Jelinek  <ja...@redhat.com>
> 
>       PR c++/110343
>       * lex.cc (lex_raw_string): For C allow $@` in raw string delimiters
>       if CPP_OPTION (pfile, low_ucns) i.e. for C23 and later.
> 
>       * gcc.dg/raw-string-1.c: New test.
> 
> --- libcpp/lex.cc.jj  2025-04-08 14:09:47.173503355 +0200
> +++ libcpp/lex.cc     2025-04-16 17:18:04.556931275 +0200
> @@ -2711,8 +2711,9 @@ lex_raw_string (cpp_reader *pfile, cpp_t
>                      || c == '!' || c == '=' || c == ','
>                      || c == '"' || c == '\''
>                      || ((c == '$' || c == '@' || c == '`')
> -                        && CPP_OPTION (pfile, cplusplus)
> -                        && CPP_OPTION (pfile, lang) > CLK_CXX23)))
> +                        && (CPP_OPTION (pfile, cplusplus)
> +                            ? CPP_OPTION (pfile, lang) > CLK_CXX23
> +                            : CPP_OPTION (pfile, low_ucns)))))
>           prefix[prefix_len++] = c;
>         else
>           {
> --- gcc/testsuite/gcc.dg/raw-string-1.c.jj    2025-04-16 17:32:20.595541753 
> +0200
> +++ gcc/testsuite/gcc.dg/raw-string-1.c       2025-04-16 17:35:09.266302136 
> +0200
> @@ -0,0 +1,24 @@
> +/* { dg-do compile } */
> +/* { dg-options "-std=gnu23" } */

Maybe mention PR c++/110343?

I think the patch is OK though.  Thanks.
 
> +const void *s0 = R"0123456789abcdefg()0123456789abcdefg" 0;
> +     /* { dg-error "raw string delimiter longer" "longer" { target *-*-* } 
> .-1 } */
> +     /* { dg-error "stray" "stray" { target *-*-* } .-2 } */
> +const void *s1 = R" () " 0;
> +     /* { dg-error "invalid character" "invalid" { target *-*-* } .-1 } */
> +     /* { dg-error "stray" "stray" { target *-*-* } .-2 } */
> +const void *s2 = R"  ()      " 0;
> +     /* { dg-error "invalid character" "invalid" { target *-*-* } .-1 } */
> +     /* { dg-error "stray" "stray" { target *-*-* } .-2 } */
> +const void *s3 = R")())" 0;
> +     /* { dg-error "invalid character" "invalid" { target *-*-* } .-1 } */
> +     /* { dg-error "stray" "stray" { target *-*-* } .-2 } */
> +const char *s4 = R"@()@";
> +const char *s5 = R"$()$";
> +const char *s6 = R"`()`";
> +const void *s7 = R"\u0040()\u0040" 0;
> +     /* { dg-error "invalid character" "invalid" { target *-*-* } .-1 } */
> +     /* { dg-error "stray" "stray" { target *-*-* } .-2 } */
> +const char *s8 = R"`@$$@`@`$()`@$$@`@`$";
> +
> +int main () {}

Marek

Reply via email to