// { dg-do compile { target c++11 } }
//  Integer imaginary...
constexpr unsigned long long
operator"" i(unsigned long long n)
{ return 4 * n + 0; }
constexpr unsigned long long
operator"" I(unsigned long long n)
{ return 4 * n + 1; }
constexpr unsigned long long
operator"" j(unsigned long long n)
{ return 4 * n + 2; }
constexpr unsigned long long
operator"" J(unsigned long long n)
{ return 4 * n + 3; }
//  Floating-point imaginary...
constexpr long double
operator"" i(long double n)
{ return 4.0L * n + 0.0L; }
constexpr long double
operator"" I(long double n)
{ return 4.0L * n + 1.0L; }
constexpr long double
operator"" j(long double n)
{ return 4.0L * n + 2.0L; }
constexpr long double
operator"" J(long double n)
{ return 4.0L * n + 3.0L; }
//  Fixed-point...
constexpr long double
operator"" k(long double n)
{ return 4 * (n + 1) + 0; }
constexpr long double
operator"" K(long double n)
{ return 4 * (n + 1) + 1; }
constexpr long double
operator"" r(long double n)
{ return 4 * (n + 1) + 2; }
constexpr long double
operator"" R(long double n)
{ return 4 * (n + 1) + 3; }
//  Machine-defined...
constexpr long double
operator"" w(long double n)
{ return 4 * (n + 2) + 0; }
constexpr long double
operator"" W(long double n)
{ return 4 * (n + 2) + 1; }
constexpr long double
operator"" q(long double n)
{ return 4 * (n + 2) + 2; }
constexpr long double
operator"" Q(long double n)
{ return 4 * (n + 2) + 3; }
int
main()
{
  auto ii = 1i;
  auto Ii = 1I;
  auto ji = 1j;
  auto Ji = 1J;
  auto ifp = 1.0i;
  auto Ifp = 1.0I;
  auto jfp = 1.0j;
  auto Jfp = 1.0J;
  auto kfp = 1.0k;
  auto Kfp = 1.0K;
  auto rfp = 1.0r;
  auto Rfp = 1.0R;
  auto wfp = 1.0w;
  auto Wfp = 1.0W;
  auto qfp = 1.0q;
  auto Qfp = 1.0Q;
}
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 7 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 11 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 15 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 19 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 25 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 29 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 33 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 37 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 43 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 47 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 51 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 55 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 61 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 65 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 69 }
// { dg-warning "1:literal operator suffixes not preceded by" "" { target *-*-* } 73 }