2018-10-23 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / testsuite / g++.dg / tree-ssa / pr27549.C
blobcd5944d2439984502b57c8d7b4c29e983e8bea63
1 // PR tree-optimization/27549
2 // { dg-do compile }
3 // { dg-options "-O2" }
5 typedef __SIZE_TYPE__ size_t;
7 struct E
9   virtual ~E () {}
10   virtual size_t e () const = 0;
11   virtual void f (char *x) const = 0;
14 struct F : public E
16   F () {}
17   virtual ~F () {}
18   virtual size_t e () const { return 0; }
19   virtual void f (char *x) const { *x = '\0'; }
22 struct S
24   S () { a = new char[32]; b = 32; c = 0; a[0] = 0; }
25   void s (const char *x, size_t y) { v (c + y + 1); __builtin_memcpy(a + c, x, y); c += y; a[c] = '\0'; }
26   void s (const E *x) { size_t l = x->e(); v (c + l + 1); x->f (a + c); c += l; }
27   const char *t () { return a; }
28   void v (size_t n)
29     {
30       if (b >= n) return;
32       size_t b2 = b;
33       char *a2 = a;
35       for (;;)
36         {
37           b *= 2;
38           if (b >= n)
39             break;
40         }
42       a = new char[b];
44       if (b2)
45         {
46           __builtin_memcpy(a, a2, c);
47           a2[0] = 0;
48           for (size_t i = 1; i < b2; i++)
49             a2[i] = a2[i - 1];
50           delete[] a2;
51         }
52     }
54   ~S ()
55     {
56       if (b)
57         {
58           a[0] = 0;
59           for (size_t i = 1; i < b; i++)
60             a[i] = a[i - 1];
61         }
62       delete[] a;
63     }
64   char * a;
65   size_t b, c;
68 const char *p;
69 size_t q;
70 const F u;
72 const char *
73 foo ()
75   S s;
76   s.s (p, q);
77   s.s (&u);
78   return s.t ();