summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Eisentraut <peter_e@gmx.net>2010-02-15 19:59:47 +0000
committerPeter Eisentraut <peter_e@gmx.net>2010-02-15 19:59:47 +0000
commit1acc06a1f4ae752793d2199d8d462a6708c8acc2 (patch)
treeda2720b5c7bb84c6081cde3047841024a24df7d8
parentec86ef7a21b537087ae59706cdb6f8747fc287a3 (diff)
downloadpostgresql-1acc06a1f4ae752793d2199d8d462a6708c8acc2.tar.gz
When sorting functions in pg_dump, break ties (same name) by number of arguments
-rw-r--r--src/bin/pg_dump/pg_dump_sort.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/bin/pg_dump/pg_dump_sort.c b/src/bin/pg_dump/pg_dump_sort.c
index 33d29ae1a2..1551af3dbe 100644
--- a/src/bin/pg_dump/pg_dump_sort.c
+++ b/src/bin/pg_dump/pg_dump_sort.c
@@ -9,7 +9,7 @@
*
*
* IDENTIFICATION
- * $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump_sort.c,v 1.27 2010/01/02 16:57:59 momjian Exp $
+ * $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump_sort.c,v 1.28 2010/02/15 19:59:47 petere Exp $
*
*-------------------------------------------------------------------------
*/
@@ -163,7 +163,18 @@ DOTypeNameCompare(const void *p1, const void *p2)
if (cmpval != 0)
return cmpval;
- /* Probably shouldn't get here, but if we do, sort by OID */
+ /* To have a stable sort order, break ties for some object types */
+ if (obj1->objType == DO_FUNC || obj1->objType == DO_AGG)
+ {
+ FuncInfo *fobj1 = *(FuncInfo **) p1;
+ FuncInfo *fobj2 = *(FuncInfo **) p2;
+
+ cmpval = fobj1->nargs - fobj2->nargs;
+ if (cmpval != 0)
+ return cmpval;
+ }
+
+ /* Usually shouldn't get here, but if we do, sort by OID */
return oidcmp(obj1->catId.oid, obj2->catId.oid);
}