summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.dg/torture/pr51482.C
blob: 28435919f467a1041bc043fc4d5e3923876b4374 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// { dg-do compile }

typedef enum { CLASS_IN = 1, CLASS_OUT = -1 } FERGUSON_KEY_CLASS, BEZIER_KEY_CLASS;
typedef class flag_interface { } VECT3DF_SIMPLE;
typedef struct vect3df {
    float x,y,z;
} VECT3DF, VECT;
typedef struct vect4df : public vect3df {
    float w;
} VECT4DF, WVECT;
typedef class llist_item { } ANIM_KEY;
typedef class anim_track : public flag_interface, public llist_item { } ANIM_KEY_BEZ;
typedef class anim_track_bezier : public anim_track { } ANIM_KEY_BEZ_WVECT;
typedef class anim_track_bez_wvect : public anim_track_bezier {
    WVECT * tangent(int kn, BEZIER_KEY_CLASS key_class, WVECT *p_tn);
} ANIM_TRACK_BEZ_WVECT;
WVECT * anim_track_bez_wvect::tangent(int kn, BEZIER_KEY_CLASS key_class, WVECT *p_tn)
{
  float bias,continuity,tension,tn1,bp1;
  WVECT *p_p0,*p_p1,*p_p2,         t1,         g1,g2,g3;
  g1.x = (p_p1->x - p_p0->x)*bp1;
  g1.y = (p_p1->y - p_p0->y)*bp1;
  g1.z = (p_p1->z - p_p0->z)*bp1;
  g1.w = (p_p1->w - p_p0->w)*bp1;
  bp1 = (0.5f + key_class*0.5f*continuity);
  p_tn->x = (g1.x + g3.x*bp1)*tn1;
  p_tn->y = (g1.y + g3.y*bp1)*tn1;
  p_tn->z = (g1.z + g3.z*bp1)*tn1;
  p_tn->w = (g1.w + g3.w*bp1)*tn1;
}