From: Tom de Vries Date: Sun, 17 Apr 2016 05:22:45 +0000 (+0000) Subject: Simplify loop in pp_write_text_as_dot_label_to_stream X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=da3ebf2ddefe30d18110c6f73ca8abe644c46b5d;p=gcc.git Simplify loop in pp_write_text_as_dot_label_to_stream 2016-04-17 Tom de Vries * pretty-print.c (pp_write_text_as_dot_label_to_stream): Simplify loop structure. From-SVN: r235075 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2a20ceee5ba..2bd0d6fb6d0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2016-04-17 Tom de Vries + + * pretty-print.c (pp_write_text_as_dot_label_to_stream): Simplify loop + structure. + 2016-04-17 Tom de Vries PR other/70185 diff --git a/gcc/pretty-print.c b/gcc/pretty-print.c index acb89e6c8b9..f6e4b43d9fb 100644 --- a/gcc/pretty-print.c +++ b/gcc/pretty-print.c @@ -159,20 +159,20 @@ pp_write_text_as_dot_label_to_stream (pretty_printer *pp, bool for_record) const char *p = text; FILE *fp = pp_buffer (pp)->stream; - while (*p) + for (;*p; p++) { + bool escape_char; switch (*p) { /* Print newlines as a left-aligned newline. */ case '\n': - fputs ("\\l\\\n", fp); + fputs ("\\l", fp); + escape_char = true; break; /* A pipe is only special for record-shape nodes. */ case '|': - if (for_record) - fputc ('\\', fp); - fputc (*p, fp); + escape_char = for_record; break; /* The following characters always have to be escaped @@ -183,13 +183,18 @@ pp_write_text_as_dot_label_to_stream (pretty_printer *pp, bool for_record) case '>': case '"': case ' ': - fputc ('\\', fp); - /* fall through */ + escape_char = true; + break; + default: - fputc (*p, fp); + escape_char = false; break; } - p++; + + if (escape_char) + fputc ('\\', fp); + + fputc (*p, fp); } pp_clear_output_area (pp);