summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture/execute/20050502-1.c
diff options
context:
space:
mode:
authorupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
committerupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
commit554fd8c5195424bdbcabf5de30fdc183aba391bd (patch)
tree976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/gcc.c-torture/execute/20050502-1.c
downloadcbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.bz2
cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.xz
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository.
Diffstat (limited to 'gcc/testsuite/gcc.c-torture/execute/20050502-1.c')
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/20050502-1.c67
1 files changed, 67 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/execute/20050502-1.c b/gcc/testsuite/gcc.c-torture/execute/20050502-1.c
new file mode 100644
index 000000000..331fe5ff7
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/20050502-1.c
@@ -0,0 +1,67 @@
+/* PR rtl-optimization/21330 */
+
+extern void abort (void);
+extern int strcmp (const char *, const char *);
+
+int
+__attribute__((noinline))
+bar (const char **x)
+{
+ return *(*x)++;
+}
+
+int
+__attribute__((noinline))
+baz (int c)
+{
+ return c != '@';
+}
+
+void
+__attribute__((noinline))
+foo (const char **w, char *x, _Bool y, _Bool z)
+{
+ char c = bar (w);
+ int i = 0;
+
+ while (1)
+ {
+ x[i++] = c;
+ c = bar (w);
+ if (y && c == '\'')
+ break;
+ if (z && c == '\"')
+ break;
+ if (!y && !z && !baz (c))
+ break;
+ }
+ x[i] = 0;
+}
+
+int
+main (void)
+{
+ char buf[64];
+ const char *p;
+ p = "abcde'fgh";
+ foo (&p, buf, 1, 0);
+ if (strcmp (p, "fgh") != 0 || strcmp (buf, "abcde") != 0)
+ abort ();
+ p = "ABCDEFG\"HI";
+ foo (&p, buf, 0, 1);
+ if (strcmp (p, "HI") != 0 || strcmp (buf, "ABCDEFG") != 0)
+ abort ();
+ p = "abcd\"e'fgh";
+ foo (&p, buf, 1, 1);
+ if (strcmp (p, "e'fgh") != 0 || strcmp (buf, "abcd") != 0)
+ abort ();
+ p = "ABCDEF'G\"HI";
+ foo (&p, buf, 1, 1);
+ if (strcmp (p, "G\"HI") != 0 || strcmp (buf, "ABCDEF") != 0)
+ abort ();
+ p = "abcdef@gh";
+ foo (&p, buf, 0, 0);
+ if (strcmp (p, "gh") != 0 || strcmp (buf, "abcdef") != 0)
+ abort ();
+ return 0;
+}