Before:

  Wbidirectional-1.c: In function ‘main’:
  Wbidirectional-1.c:6:43: warning: unpaired UTF-8 bidirectional character 
detected [-Wbidirectional=]
      6 |     /*‮ } ⁦if (isAdmin)⁩ ⁦ begin admins only */
        |                                           ^
  Wbidirectional-1.c:9:28: warning: unpaired UTF-8 bidirectional character 
detected [-Wbidirectional=]
      9 |     /* end admins only ‮ { ⁦*/
        |                            ^

  Wbidirectional-11.c:6:15: warning: UTF-8 vs UCN mismatch when closing a 
context by "U+202C (POP DIRECTIONAL FORMATTING)" [-Wbidirectional=]
      6 | int LRE_‪_PDF_\u202c;
        |               ^

After setting rich_loc.set_escape_on_output (true):

  Wbidirectional-1.c:6:43: warning: unpaired UTF-8 bidirectional character 
detected [-Wbidirectional=]
      6 |     /*<U+202E> } <U+2066>if (isAdmin)<U+2069> <U+2066> begin admins 
only */
        |                                                                       
    ^
  Wbidirectional-1.c:9:28: warning: unpaired UTF-8 bidirectional character 
detected [-Wbidirectional=]
      9 |     /* end admins only <U+202E> { <U+2066>*/
        |                                            ^

  Wbidirectional-11.c:6:15: warning: UTF-8 vs UCN mismatch when closing a 
context by "U+202C (POP DIRECTIONAL FORMATTING)" [-Wbidirectional=]
      6 | int LRE_<U+202A>_PDF_\u202c;
        |                       ^

libcpp/ChangeLog:
        * lex.c (maybe_warn_bidi_on_close): Use a rich_location
        and call set_escape_on_output (true) on it.
        (maybe_warn_bidi_on_char): Likewise.

Signed-off-by: David Malcolm <dmalc...@redhat.com>
---
 libcpp/lex.c | 29 +++++++++++++++++------------
 1 file changed, 17 insertions(+), 12 deletions(-)

diff --git a/libcpp/lex.c b/libcpp/lex.c
index f7a86fbe4b5..88aba307991 100644
--- a/libcpp/lex.c
+++ b/libcpp/lex.c
@@ -1387,9 +1387,11 @@ maybe_warn_bidi_on_close (cpp_reader *pfile, const uchar 
*p)
       const location_t loc
        = linemap_position_for_column (pfile->line_table,
                                       CPP_BUF_COLUMN (pfile->buffer, p));
-      cpp_warning_with_line (pfile, CPP_W_BIDIRECTIONAL, loc, 0,
-                            "unpaired UTF-8 bidirectional character "
-                            "detected");
+      rich_location rich_loc (pfile->line_table, loc);
+      rich_loc.set_escape_on_output (true);
+      cpp_warning_at (pfile, CPP_W_BIDIRECTIONAL, &rich_loc,
+                     "unpaired UTF-8 bidirectional character "
+                     "detected");
     }
   /* We're done with this context.  */
   bidi::on_close ();
@@ -1414,6 +1416,9 @@ maybe_warn_bidi_on_char (cpp_reader *pfile, const uchar 
*p, bidi::kind kind,
       const location_t loc
        = linemap_position_for_column (pfile->line_table,
                                       CPP_BUF_COLUMN (pfile->buffer, p));
+      rich_location rich_loc (pfile->line_table, loc);
+      rich_loc.set_escape_on_output (true);
+
       /* It seems excessive to warn about a PDI/PDF that is closing
         an opened context because we've already warned about the
         opening character.  Except warn when we have a UCN x UTF-8
@@ -1422,20 +1427,20 @@ maybe_warn_bidi_on_char (cpp_reader *pfile, const uchar 
*p, bidi::kind kind,
        {
          if (warn_bidi == bidirectional_unpaired
              && bidi::current_ctx_ucn_p () != ucn_p)
-           cpp_warning_with_line (pfile, CPP_W_BIDIRECTIONAL, loc, 0,
-                                  "UTF-8 vs UCN mismatch when closing "
-                                  "a context by \"%s\"", bidi::to_str (kind));
+           cpp_warning_at (pfile, CPP_W_BIDIRECTIONAL, &rich_loc,
+                           "UTF-8 vs UCN mismatch when closing "
+                           "a context by \"%s\"", bidi::to_str (kind));
        }
       else if (warn_bidi == bidirectional_any)
        {
          if (kind == bidi::kind::PDF || kind == bidi::kind::PDI)
-           cpp_warning_with_line (pfile, CPP_W_BIDIRECTIONAL, loc, 0,
-                                  "\"%s\" is closing an unopened context",
-                                  bidi::to_str (kind));
+           cpp_warning_at (pfile, CPP_W_BIDIRECTIONAL, &rich_loc,
+                           "\"%s\" is closing an unopened context",
+                           bidi::to_str (kind));
          else
-           cpp_warning_with_line (pfile, CPP_W_BIDIRECTIONAL, loc, 0,
-                                  "found problematic Unicode character \"%s\"",
-                                  bidi::to_str (kind));
+           cpp_warning_at (pfile, CPP_W_BIDIRECTIONAL, &rich_loc,
+                           "found problematic Unicode character \"%s\"",
+                           bidi::to_str (kind));
        }
     }
   /* We're done with this context.  */
-- 
2.26.3

Reply via email to