%left '^'
%left '&'
%left EQUAL NOTEQUAL
-%left '<' '>' LEQ GEQ
+%left '<' '>' LEQ GEQ SPACESHIP
%left LSH RSH
%left '@'
%left '+' '-'
{ $$ = state->make_operator ("<=", 2); }
| OPERATOR GEQ
{ $$ = state->make_operator (">=", 2); }
+ | OPERATOR SPACESHIP
+ { $$ = state->make_operator ("<=>", 2); }
| OPERATOR ANDAND
{ $$ = state->make_operator ("&&", 2); }
| OPERATOR OROR
{ $$ = state->d_binary (">=", $1, $3); }
;
+exp : exp SPACESHIP exp
+ { $$ = state->d_binary ("<=>", $1, $3); }
+ ;
+
exp : exp '<' exp
{ $$ = state->d_binary ("<", $1, $3); }
;
return c;
case '<':
HANDLE_TOKEN3 ("<<=", ASSIGN_MODIFY);
+ HANDLE_TOKEN3 ("<=>", SPACESHIP);
HANDLE_TOKEN2 ("<=", LEQ);
HANDLE_TOKEN2 ("<<", LSH);
state->lexptr++;
SELF_CHECK (strcmp (one, two) == 0);
}
+static void
+should_parse (const char *name)
+{
+ std::string err;
+ auto parsed = cp_demangled_name_to_comp (name, &err);
+ SELF_CHECK (parsed != nullptr);
+}
+
static void
canonicalize_tests ()
{
should_be_the_same ("something<void ()>", "something< void() >");
should_be_the_same ("something<void ()>", "something<void (void)>");
+
+ should_parse ("void whatever::operator<=><int, int>");
}
#endif