Commit e044a449 authored by Robert Haas's avatar Robert Haas

Deparse named arguments to use the new => operator instead of :=

Tom Lane pointed out that this wasn't done, and asked whether that was
intentional.  Subsequent discussion was in favor of making the change,
so here we go.
parent e7cb7ee1
...@@ -1860,7 +1860,7 @@ funcname_signature_string(const char *funcname, int nargs, ...@@ -1860,7 +1860,7 @@ funcname_signature_string(const char *funcname, int nargs,
appendStringInfoString(&argbuf, ", "); appendStringInfoString(&argbuf, ", ");
if (i >= numposargs) if (i >= numposargs)
{ {
appendStringInfo(&argbuf, "%s := ", (char *) lfirst(lc)); appendStringInfo(&argbuf, "%s => ", (char *) lfirst(lc));
lc = lnext(lc); lc = lnext(lc);
} }
appendStringInfoString(&argbuf, format_type_be(argtypes[i])); appendStringInfoString(&argbuf, format_type_be(argtypes[i]));
......
...@@ -6856,7 +6856,7 @@ get_rule_expr(Node *node, deparse_context *context, ...@@ -6856,7 +6856,7 @@ get_rule_expr(Node *node, deparse_context *context,
{ {
NamedArgExpr *na = (NamedArgExpr *) node; NamedArgExpr *na = (NamedArgExpr *) node;
appendStringInfo(buf, "%s := ", quote_identifier(na->name)); appendStringInfo(buf, "%s => ", quote_identifier(na->name));
get_rule_expr((Node *) na->arg, context, showimplicit); get_rule_expr((Node *) na->arg, context, showimplicit);
} }
break; break;
......
...@@ -1124,17 +1124,17 @@ ERROR: positional argument cannot follow named argument ...@@ -1124,17 +1124,17 @@ ERROR: positional argument cannot follow named argument
LINE 1: select * from dfunc(10, b := 20, 30); LINE 1: select * from dfunc(10, b := 20, 30);
^ ^
select * from dfunc(x := 10, b := 20, c := 30); -- fail, unknown param select * from dfunc(x := 10, b := 20, c := 30); -- fail, unknown param
ERROR: function dfunc(x := integer, b := integer, c := integer) does not exist ERROR: function dfunc(x => integer, b => integer, c => integer) does not exist
LINE 1: select * from dfunc(x := 10, b := 20, c := 30); LINE 1: select * from dfunc(x := 10, b := 20, c := 30);
^ ^
HINT: No function matches the given name and argument types. You might need to add explicit type casts. HINT: No function matches the given name and argument types. You might need to add explicit type casts.
select * from dfunc(10, 10, a := 20); -- fail, a overlaps positional parameter select * from dfunc(10, 10, a := 20); -- fail, a overlaps positional parameter
ERROR: function dfunc(integer, integer, a := integer) does not exist ERROR: function dfunc(integer, integer, a => integer) does not exist
LINE 1: select * from dfunc(10, 10, a := 20); LINE 1: select * from dfunc(10, 10, a := 20);
^ ^
HINT: No function matches the given name and argument types. You might need to add explicit type casts. HINT: No function matches the given name and argument types. You might need to add explicit type casts.
select * from dfunc(1,c := 2,d := 3); -- fail, no value for b select * from dfunc(1,c := 2,d := 3); -- fail, no value for b
ERROR: function dfunc(integer, c := integer, d := integer) does not exist ERROR: function dfunc(integer, c => integer, d => integer) does not exist
LINE 1: select * from dfunc(1,c := 2,d := 3); LINE 1: select * from dfunc(1,c := 2,d := 3);
^ ^
HINT: No function matches the given name and argument types. You might need to add explicit type casts. HINT: No function matches the given name and argument types. You might need to add explicit type casts.
...@@ -1175,7 +1175,7 @@ select * from dfunc('Hello World', c := '2009-07-25'::date, b := 20); ...@@ -1175,7 +1175,7 @@ select * from dfunc('Hello World', c := '2009-07-25'::date, b := 20);
(1 row) (1 row)
select * from dfunc('Hello World', c := 20, b := '2009-07-25'::date); -- fail select * from dfunc('Hello World', c := 20, b := '2009-07-25'::date); -- fail
ERROR: function dfunc(unknown, c := integer, b := date) does not exist ERROR: function dfunc(unknown, c => integer, b => date) does not exist
LINE 1: select * from dfunc('Hello World', c := 20, b := '2009-07-25... LINE 1: select * from dfunc('Hello World', c := 20, b := '2009-07-25...
^ ^
HINT: No function matches the given name and argument types. You might need to add explicit type casts. HINT: No function matches the given name and argument types. You might need to add explicit type casts.
...@@ -1450,8 +1450,8 @@ select * from dfview; ...@@ -1450,8 +1450,8 @@ select * from dfview;
View definition: View definition:
SELECT int8_tbl.q1, SELECT int8_tbl.q1,
int8_tbl.q2, int8_tbl.q2,
dfunc(int8_tbl.q1, int8_tbl.q2, flag := int8_tbl.q1 > int8_tbl.q2) AS c3, dfunc(int8_tbl.q1, int8_tbl.q2, flag => int8_tbl.q1 > int8_tbl.q2) AS c3,
dfunc(int8_tbl.q1, flag := int8_tbl.q1 < int8_tbl.q2, b := int8_tbl.q2) AS c4 dfunc(int8_tbl.q1, flag => int8_tbl.q1 < int8_tbl.q2, b => int8_tbl.q2) AS c4
FROM int8_tbl; FROM int8_tbl;
drop view dfview; drop view dfview;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment