/* { dg-options "-std=c99 -w" } */ /* From c_by_val.c in gfortran.dg. */ #define _Complex_I (1.0iF) #define NUM_ELEMS 10 void test_complex_scalars (float _Complex *float_complex_ptr, double _Complex *double_complex_ptr, long double _Complex *long_double_complex_ptr); void test_complex_arrays (float _Complex *float_complex_array, double _Complex *double_complex_array, long double _Complex *long_double_complex_array, int num_elems); int main (int argc, char **argv) { float _Complex c1; double _Complex c2; long double _Complex c3; float _Complex c1_array[NUM_ELEMS]; double _Complex c2_array[NUM_ELEMS]; long double _Complex c3_array[NUM_ELEMS]; int i; c1 = 1.0 + 0.0 * _Complex_I; c2 = 2.0 + 0.0 * _Complex_I; c3 = 3.0 + 0.0 * _Complex_I; test_complex_scalars (&c1, &c2, &c3); for (i = 0; i < NUM_ELEMS; i++) { c1_array[i] = 1.0 * (i+1) + 0.0 * _Complex_I; c2_array[i] = 1.0 * (i+1) + 0.0 * _Complex_I; c3_array[i] = 1.0 * (i+1) + 0.0 * _Complex_I; } test_complex_arrays (c1_array, c2_array, c3_array, NUM_ELEMS); return 0; }