diff --git a/src/bin/pg_dump/common.c b/src/bin/pg_dump/common.c
index c384fa8756eaf0a418302a1838fa7cca6785a302..2fc9430630a839a2f3604a3240321708c5abdc96 100644
--- a/src/bin/pg_dump/common.c
+++ b/src/bin/pg_dump/common.c
@@ -8,7 +8,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/bin/pg_dump/common.c,v 1.56 2001/06/27 21:21:36 petere Exp $
+ *	  $Header: /cvsroot/pgsql/src/bin/pg_dump/common.c,v 1.57 2001/07/03 20:21:47 petere Exp $
  *
  * Modifications - 6/12/96 - dave@bensoft.com - version 1.13.dhb.2
  *
@@ -179,7 +179,7 @@ findParentsByOid(TableInfo *tblinfo, int numTables,
 								   inhinfo[i].inhparent,
 								   oid);
 
-					exit(2);
+					exit_nicely();
 				}
 				(**parentIndexes)[j] = parentInd;
 				result[j++] = tblinfo[parentInd].relname;
@@ -219,7 +219,7 @@ parseNumericArray(const char *str, char **array, int arraysize)
 				if (argNum >= arraysize)
 				{
 					write_msg(NULL, "parseNumericArray: too many numbers\n");
-					exit(2);
+					exit_nicely();
 				}
 				temp[j] = '\0';
 				array[argNum++] = strdup(temp);
@@ -234,7 +234,7 @@ parseNumericArray(const char *str, char **array, int arraysize)
 				j >= sizeof(temp) - 1)
 			{
 				write_msg(NULL, "parseNumericArray: bogus number\n");
-				exit(2);
+				exit_nicely();
 			}
 			temp[j++] = s;
 		}
@@ -297,69 +297,57 @@ dumpSchema(Archive *fout,
 	IndInfo    *indinfo = NULL;
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading user-defined types %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading user-defined types\n");
 	tinfo = getTypes(&numTypes);
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading user-defined functions %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading user-defined functions\n");
 	finfo = getFuncs(&numFuncs);
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading user-defined aggregates %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading user-defined aggregate functions\n");
 	agginfo = getAggregates(&numAggregates);
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading user-defined operators %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading user-defined operators\n");
 	oprinfo = getOperators(&numOperators);
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading user-defined tables %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading user-defined tables\n");
 	tblinfo = getTables(&numTables, finfo, numFuncs);
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading indexes information %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading index information\n");
 	indinfo = getIndexes(&numIndexes);
 
 	if (g_verbose)
-		fprintf(stderr, "%s reading table inheritance information %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "reading table inheritance information\n");
 	inhinfo = getInherits(&numInherits);
 
 	if (g_verbose)
-		fprintf(stderr, "%s finding the attribute names and types for each table %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "finding the column names and types for each table\n");
 	getTableAttrs(tblinfo, numTables);
 
 	if (g_verbose)
-		fprintf(stderr, "%s flagging inherited attributes in subtables %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "flagging inherited columns in subtables\n");
 	flagInhAttrs(tblinfo, numTables, inhinfo, numInherits);
 
 	if (!tablename && !dataOnly)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out database comment %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out database comment\n");
 		dumpDBComment(fout);
 	}
 
 	if (!tablename && fout)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out user-defined types %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out user-defined types\n");
 		dumpTypes(fout, finfo, numFuncs, tinfo, numTypes);
 	}
 
 	if (g_verbose)
-		fprintf(stderr, "%s dumping out tables %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "dumping out tables\n");
 
 	dumpTables(fout, tblinfo, numTables, indinfo, numIndexes, inhinfo, numInherits,
 	   tinfo, numTypes, tablename, aclsSkip, oids, schemaOnly, dataOnly);
@@ -367,40 +355,35 @@ dumpSchema(Archive *fout,
 	if (fout && !dataOnly)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out indexes %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out indexes\n");
 		dumpIndexes(fout, indinfo, numIndexes, tblinfo, numTables, tablename);
 	}
 
 	if (!tablename && !dataOnly)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out user-defined procedural languages %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out user-defined procedural languages\n");
 		dumpProcLangs(fout, finfo, numFuncs, tinfo, numTypes);
 	}
 
 	if (!tablename && !dataOnly)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out user-defined functions %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out user-defined functions\n");
 		dumpFuncs(fout, finfo, numFuncs, tinfo, numTypes);
 	}
 
 	if (!tablename && !dataOnly)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out user-defined aggregates %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out user-defined aggregate functions\n");
 		dumpAggs(fout, agginfo, numAggregates, tinfo, numTypes);
 	}
 
 	if (!tablename && !dataOnly)
 	{
 		if (g_verbose)
-			fprintf(stderr, "%s dumping out user-defined operators %s\n",
-					g_comment_start, g_comment_end);
+			write_msg(NULL, "dumping out user-defined operators\n");
 		dumpOprs(fout, oprinfo, numOperators, tinfo, numTypes);
 	}
 
@@ -490,7 +473,7 @@ flagInhAttrs(TableInfo *tblinfo, int numTables,
 					/* shouldn't happen unless findParentsByOid is broken */
 					write_msg(NULL, "failed sanity check, table \"%s\" not found by flagInhAttrs\n",
 							  tblinfo[i].parentRels[k]);
-					exit(2);
+					exit_nicely();
 				};
 
 				inhAttrInd = strInArray(tblinfo[i].attnames[j],
diff --git a/src/bin/pg_dump/de.po b/src/bin/pg_dump/de.po
index 1d357cf085618b1dc6c841af0a1fb7cd94f1b3c1..cefe951872c897f9821fbe1d1702835618fb76ed 100644
--- a/src/bin/pg_dump/de.po
+++ b/src/bin/pg_dump/de.po
@@ -1,15 +1,15 @@
 # German message translation file for pg_dump and friends
 # Peter Eisentraut <peter_e@gmx.net>, 2001.
 #
-# $Header: /cvsroot/pgsql/src/bin/pg_dump/Attic/de.po,v 1.1 2001/06/27 21:21:37 petere Exp $
+# $Header: /cvsroot/pgsql/src/bin/pg_dump/Attic/de.po,v 1.2 2001/07/03 20:21:48 petere Exp $
 #
 # Use these quotes: »%s«
 #
 msgid ""
 msgstr ""
 "Project-Id-Version: pg_dump (PostgreSQL) 7.2\n"
-"POT-Creation-Date: 2001-06-27 21:58+0200\n"
-"PO-Revision-Date: 2001-06-27 22:02+0200\n"
+"POT-Creation-Date: 2001-07-03 22:11+0200\n"
+"PO-Revision-Date: 2001-07-03 21:05+0200\n"
 "Last-Translator: Peter Eisentraut <peter_e@gmx.net>\n"
 "Language-Team: German <de@li.org>\n"
 "MIME-Version: 1.0\n"
@@ -118,47 +118,70 @@ msgstr ""
 "\n"
 "Berichten Sie Fehler an <pgsql-bugs@postgresql.org>."
 
-#: pg_dump.c:380
+#: pg_backup_archiver.c:1265 pg_dump.c:322
+msgid "*** aborted because of error\n"
+msgstr "*** abgebrochen wegen Fehler\n"
+
+#: pg_dump.c:349
+#, c-format
+msgid "dumping out the contents of table %s\n"
+msgstr ""
+
+#: pg_dump.c:382
 #, c-format
 msgid "SQL command to dump the contents of table \"%s\" failed\n"
 msgstr ""
 
-#: pg_dump.c:382 pg_dump.c:478 pg_dump.c:511 pg_dump.c:1183
+#: pg_dump.c:384 pg_dump.c:480 pg_dump.c:513 pg_dump.c:1174
 #, c-format
 msgid "Error message from server: %s"
 msgstr "Fehlermeldung vom Server: %s"
 
-#: pg_dump.c:383 pg_dump.c:394 pg_dump.c:479 pg_dump.c:512 pg_dump.c:1184
+#: pg_dump.c:385 pg_dump.c:396 pg_dump.c:481 pg_dump.c:514 pg_dump.c:1175
 #, c-format
 msgid "The command was: %s\n"
 msgstr "Die Anweisung war: %s\n"
 
-#: pg_dump.c:390
+#: pg_dump.c:392
 #, c-format
 msgid "SQL command to dump the contents of table \"%s\" executed abnormally.\n"
 msgstr ""
 
-#: pg_dump.c:392
+#: pg_dump.c:394
 #, c-format
 msgid "The server returned status %d when %d was expected.\n"
 msgstr "Der Server gab Status %d zurück, aber %d wurde erwartet.\n"
 
-#: pg_dump.c:477
+#: pg_dump.c:479
 #, c-format
 msgid ""
 "SQL command to dump the contents of table \"%s\" failed: PQendcopy() "
 "failed.\n"
 msgstr ""
 
-#: pg_dump.c:510
+#: pg_dump.c:512
 msgid "dumpClasses(): SQL command failed\n"
 msgstr "dumpClasses(): SQL-Anweisung schlug fehl\n"
 
-#: pg_dump.c:924 pg_restore.c:251
-msgid "Username: "
+#: pg_dump.c:643
+#, c-format
+msgid "preparing to dump the contents of all %d tables/sequences\n"
+msgstr ""
+
+#: pg_dump.c:645
+msgid "preparing to dump the contents of only one table/sequence\n"
+msgstr ""
+
+#: pg_dump.c:662
+#, c-format
+msgid "preparing to dump the contents of table %s\n"
+msgstr ""
+
+#: pg_dump.c:921 pg_restore.c:251
+msgid "User name: "
 msgstr "Benutzername: "
 
-#: pg_dump.c:955
+#: pg_dump.c:947
 #, c-format
 msgid ""
 "%s was compiled without support for long options.\n"
@@ -167,12 +190,12 @@ msgstr ""
 "%s wurde ohne Unterstützung für lange Optionen kompiliert.\n"
 "Verwenden Sie --help für Hilfe.\n"
 
-#: pg_dump.c:962 pg_restore.c:270
+#: pg_dump.c:954 pg_restore.c:270
 #, c-format
 msgid "Try '%s --help' for more information.\n"
 msgstr "Versuchen Sie »%s --help« für weitere Informationen.\n"
 
-#: pg_dump.c:970
+#: pg_dump.c:962
 #, c-format
 msgid ""
 "%s: too many command line options (first is '%s')\n"
@@ -181,450 +204,570 @@ msgstr ""
 "%s: zu Viele Kommandozeilenoptionen (die Erste ist »%s«)\n"
 "Versuchen Sie »%s --help« für weitere Informationen.\n"
 
-#: pg_backup_db.c:353 pg_dump.c:983
+#: pg_backup_db.c:352 pg_dump.c:975
 msgid "no database name specified\n"
 msgstr "kein Datenbankname angegeben\n"
 
-#: pg_dump.c:989
-msgid "'Schema only' and 'data only' are incompatible options.\n"
+#: pg_dump.c:981
+msgid ""
+"The options \"schema only\" (-s) and \"data only\" (-a) cannot be used "
+"together.\n"
 msgstr ""
 
-#: pg_dump.c:995
+#: pg_dump.c:987
 msgid "BLOB output is not supported for a single table.\n"
 msgstr ""
 
-#: pg_dump.c:996
+#: pg_dump.c:988
 msgid "Use all tables or a full dump instead.\n"
 msgstr ""
 
-#: pg_dump.c:1002
+#: pg_dump.c:994
 msgid "INSERT (-d, -D) and OID (-o) options cannot be used together.\n"
 msgstr ""
 "Die Optionen INSERT (-d, -D) und OID (-o) können nicht zusammen verwendet "
 "werden.\n"
 
-#: pg_dump.c:1003
+#: pg_dump.c:995
 msgid "(The INSERT command cannot set oids.)\n"
 msgstr "(Die INSERT-Anweisung kann Oids nicht setzen.)\n"
 
-#: pg_dump.c:1009
+#: pg_dump.c:1001
 msgid "BLOB output is not supported for plain text dump files.\n"
 msgstr ""
 
-#: pg_dump.c:1010
+#: pg_dump.c:1002
 msgid "(Use a different output format.)\n"
 msgstr ""
 
-#: pg_dump.c:1040
+#: pg_dump.c:1032
 #, c-format
 msgid "invalid output format '%s' specified\n"
 msgstr "ungültiges Ausgabeformat »%s« angegeben\n"
 
-#: pg_dump.c:1046
+#: pg_dump.c:1038
 #, c-format
 msgid "could not open output file %s for writing\n"
 msgstr "konnte Ausgabedatei %s nicht zum Schreiben öffnen\n"
 
-#: pg_dump.c:1069
+#: pg_dump.c:1061
 #, c-format
 msgid "BEGIN command failed: %s"
 msgstr "BEGIN-Anweisung schlug fehl: %s"
 
-#: pg_dump.c:1075
+#: pg_dump.c:1067
 #, c-format
 msgid "could not set transaction isolation level to serializable: %s"
 msgstr ""
 
-#: pg_dump.c:1182
+#: pg_dump.c:1086
+#, c-format
+msgid "last built-in oid is %u\n"
+msgstr "letzte eingebaute Oid ist %u\n"
+
+#: pg_dump.c:1162
+msgid "saving database definition\n"
+msgstr "sichere Datenbankdefinition\n"
+
+#: pg_dump.c:1173
 msgid "SQL command failed\n"
 msgstr "SQL-Anweisung schlug fehl\n"
 
-#: pg_dump.c:1192
+#: pg_dump.c:1183
 #, c-format
 msgid "missing pg_database entry for database \"%s\"\n"
 msgstr "fehlender pg_database-Eintrag für Datenbank »%s«\n"
 
-#: pg_dump.c:1198
+#: pg_dump.c:1189
 #, c-format
 msgid ""
 "query returned more than one (%d) pg_database entry for database \"%s\"\n"
 msgstr ""
+"Abfrage ergab mehr als einen (%d) pg_database-Eintrag für Datenbank »%s«\n"
+
+#: pg_dump.c:1231
+msgid "saving BLOBs\n"
+msgstr ""
 
-#: pg_dump.c:1253
+#: pg_dump.c:1244
 #, c-format
 msgid "dumpBlobs(): cursor declaration failed: %s"
 msgstr ""
 
-#: pg_dump.c:1268
+#: pg_dump.c:1259
 #, c-format
 msgid "dumpBlobs(): fetch from cursor failed: %s"
 msgstr ""
 
-#: pg_dump.c:1281
+#: pg_dump.c:1272
 #, c-format
 msgid "dumpBlobs(): could not open large object: %s"
 msgstr ""
 
-#: pg_dump.c:1294
+#: pg_dump.c:1285
 #, c-format
 msgid "dumpBlobs(): error reading large object: %s"
 msgstr ""
 
-#: pg_dump.c:1379
+#: pg_dump.c:1370
 #, c-format
 msgid "query to obtain list of data types failed: %s"
 msgstr ""
 
-#: pg_dump.c:1423
+#: pg_dump.c:1414
 #, c-format
 msgid "WARNING: owner of data type %s appears to be invalid\n"
 msgstr "WARNUNG: Eigentümer des Datentypen %s scheint ungültig zu sein\n"
 
-#: pg_dump.c:1497
+#: pg_dump.c:1488
 #, c-format
 msgid "query to obtain list of operators failed: %s"
-msgstr ""
+msgstr "Abfrage um Liste der Operatoren zu ermitteln schlug fehl: %s"
 
-#: pg_dump.c:1539
+#: pg_dump.c:1530
 #, c-format
 msgid "WARNING: owner of operator \"%s\" appears to be invalid\n"
 msgstr "WARNUNG: Eigentümer des Operatoren »%s« scheint ungültig zu sein\n"
 
-#: pg_dump.c:1861
+#: pg_dump.c:1852
 #, c-format
-msgid "query to obtain list of aggregate functions failed: %s\n"
-msgstr ""
+msgid "query to obtain list of aggregate functions failed: %s"
+msgstr "Abfrage um Liste der Aggregatfunktionen zu ermitteln schlug fehl: %s"
 
-#: pg_dump.c:1892
+#: pg_dump.c:1883
 #, c-format
 msgid "WARNING: owner of aggregate function \"%s\" appears to be invalid\n"
 msgstr ""
+"WARNUNG: Eigentümer der Aggregatfunktion »%s« scheint ungültig zu sein\n"
 
-#: pg_dump.c:1962
+#: pg_dump.c:1953
 #, c-format
 msgid "query to obtain list of functions failed: %s"
 msgstr "Abfrage um Liste der Funktionen zu ermitteln schlug fehl: %s"
 
-#: pg_dump.c:2005
+#: pg_dump.c:1996
 #, c-format
 msgid "WARNING: owner of function \"%s\" appears to be invalid\n"
-msgstr ""
+msgstr "WARNUNG: Eigentümer der Funktion »%s« scheint ungültig zu sein\n"
 
-#: pg_dump.c:2010
+#: pg_dump.c:2001
 #, c-format
 msgid ""
 "failed sanity check: function %s has more than %d (namely %d) arguments\n"
 msgstr ""
 
-#: pg_dump.c:2105
+#: pg_dump.c:2096
 #, c-format
 msgid "query to obtain list of tables failed: %s"
 msgstr "Abfrage um Liste der Tabellen zu ermitteln schlug fehl: %s"
 
-#: pg_dump.c:2136
+#: pg_dump.c:2127
 #, c-format
 msgid "WARNING: owner of table \"%s\" appears to be invalid\n"
-msgstr ""
+msgstr "WARNUNG: Eigentümer der Tabelle »%s« scheint ungültig zu sein\n"
 
-#: pg_dump.c:2156
+#: pg_dump.c:2147
 #, c-format
 msgid "query to obtain definition of view \"%s\" failed: %s"
-msgstr ""
+msgstr "Abfrage um die Definition der Sicht »%s« zu ermitteln schlug fehl: %s"
 
-#: pg_dump.c:2164
+#: pg_dump.c:2155
 #, c-format
 msgid "query to obtain definition of view \"%s\" returned no data\n"
 msgstr ""
+"Abfrage um die Definition der Sicht »%s« zu ermitteln lieferte keine Daten\n"
 
-#: pg_dump.c:2167
+#: pg_dump.c:2158
 #, c-format
 msgid ""
 "query to obtain definition of view \"%s\" returned more than one definition\n"
 msgstr ""
+"Abfrage um die Definition der Sicht »%s« zu ermitteln lieferte mehr als eine "
+"Definition\n"
 
-#: pg_dump.c:2174
+#: pg_dump.c:2165
 #, c-format
 msgid "query to obtain definition of view \"%s\" returned NULL oid\n"
 msgstr ""
 
-#: pg_dump.c:2184
+#: pg_dump.c:2175
 #, c-format
 msgid "definition of view \"%s\" appears to be empty (length zero)\n"
+msgstr "Definition der Sicht »%s« scheint leer zu sein (Länge null)\n"
+
+#: pg_dump.c:2200
+#, c-format
+msgid "finding CHECK constraints for table %s\n"
 msgstr ""
 
-#: pg_dump.c:2232
+#: pg_dump.c:2221
 #, c-format
 msgid "query to obtain check constraints failed: %s"
 msgstr ""
 
-#: pg_dump.c:2238
+#: pg_dump.c:2227
 #, c-format
 msgid "expected %d check constraints on table \"%s\" but found %d\n"
 msgstr ""
 
-#: pg_dump.c:2240
+#: pg_dump.c:2229
 msgid "(The system catalogs might be corrupted.)\n"
 msgstr ""
 
-#: pg_dump.c:2281
+#: pg_dump.c:2270
 #, c-format
 msgid "query to obtain primary key of table \"%s\" failed: %s"
 msgstr ""
 
-#: pg_dump.c:2288
+#: pg_dump.c:2277
 #, c-format
 msgid ""
 "query to obtain primary key of table \"%s\" produced more than one result\n"
 msgstr ""
 
-#: pg_dump.c:2338
+#: pg_dump.c:2327
 #, c-format
 msgid "query to obtain name of primary key of table \"%s\" failed: %s"
 msgstr ""
 
-#: pg_dump.c:2346
+#: pg_dump.c:2335
 #, c-format
 msgid ""
 "query to obtain name of primary key of table \"%s\" did not return exactly "
 "one result\n"
 msgstr ""
 
-#: pg_dump.c:2354
+#: pg_dump.c:2343
 #, c-format
 msgid "name of primary key of table \"%s\" returned NULL value\n"
 msgstr ""
 
-#: pg_backup_archiver.c:620 pg_backup_archiver.c:1030
-#: pg_backup_archiver.c:1150 pg_backup_archiver.c:1436
-#: pg_backup_archiver.c:1578 pg_backup_archiver.c:1607 pg_backup_custom.c:149
+#: pg_backup_archiver.c:621 pg_backup_archiver.c:1031
+#: pg_backup_archiver.c:1151 pg_backup_archiver.c:1439
+#: pg_backup_archiver.c:1581 pg_backup_archiver.c:1610 pg_backup_custom.c:149
 #: pg_backup_custom.c:154 pg_backup_custom.c:169 pg_backup_custom.c:564
-#: pg_backup_db.c:284 pg_backup_db.c:376 pg_backup_tar.c:992 pg_dump.c:2363
+#: pg_backup_db.c:283 pg_backup_db.c:375 pg_backup_tar.c:992 pg_dump.c:2352
 msgid "out of memory\n"
 msgstr "Speicher aufgebraucht\n"
 
-#: pg_dump.c:2409
+#: pg_dump.c:2379
+#, c-format
+msgid "finding triggers for table %s\n"
+msgstr ""
+
+#: pg_dump.c:2395
 #, c-format
 msgid "query to obtain list of triggers failed: %s"
 msgstr ""
 
-#: pg_dump.c:2415
+#: pg_dump.c:2401
 #, c-format
 msgid "expected %d triggers on table \"%s\" but found %d\n"
 msgstr ""
 
-#: pg_dump.c:2495
+#: pg_dump.c:2481
 #, c-format
 msgid "query to obtain procedure name for trigger \"%s\" failed: %s"
 msgstr ""
 
-#: pg_dump.c:2504
+#: pg_dump.c:2490
 #, c-format
 msgid ""
 "query to obtain procedure name for trigger \"%s\" did not return exactly one "
 "result\n"
 msgstr ""
 
-#: pg_dump.c:2567
+#: pg_dump.c:2553
 #, c-format
 msgid ""
 "query produced NULL referenced table name for trigger \"%s\" on table \"%s"
 "\" (oid was %s)\n"
 msgstr ""
 
-#: pg_dump.c:2597
+#: pg_dump.c:2583
 #, c-format
 msgid "bad argument string (%s) for trigger \"%s\" on table \"%s\"\n"
 msgstr ""
 
-#: pg_dump.c:2685
+#: pg_dump.c:2671
 #, c-format
 msgid "query to obtain inheritance relationships failed: %s"
 msgstr ""
 
-#: pg_dump.c:2788
+#: pg_dump.c:2735
+#, c-format
+msgid "finding the columns and types for table %s\n"
+msgstr ""
+
+#: pg_dump.c:2772
 #, c-format
 msgid "query to get table columns failed: %s"
 msgstr ""
 
-#: pg_dump.c:2820
+#: pg_dump.c:2804
 #, c-format
 msgid "query produced NULL name for data type of column %d of table %s\n"
 msgstr ""
 
-#: pg_dump.c:2855
+#: pg_dump.c:2826
+#, c-format
+msgid "finding DEFAULT expression for column %s\n"
+msgstr ""
+
+#: pg_dump.c:2837
 #, c-format
 msgid "query to get column default value failed: %s"
 msgstr ""
 
-#: pg_dump.c:2864
+#: pg_dump.c:2846
 #, c-format
 msgid ""
 "query to get default value for column \"%s\" returned %d rows; expected 1\n"
 msgstr ""
 
-#: pg_dump.c:2937
+#: pg_dump.c:2919
 #, c-format
 msgid "query to obtain list of indexes failed: %s"
 msgstr ""
 
-#: pg_dump.c:3017
+#: pg_dump.c:2999
 #, c-format
 msgid "query to get comment on oid %s failed: %s"
 msgstr ""
 
-#: pg_dump.c:3072
+#: pg_dump.c:3054
 #, c-format
 msgid "query to get database oid failed: %s"
 msgstr ""
 
-#: pg_dump.c:3172
+#: pg_dump.c:3154
 #, c-format
-msgid "Notice: array type %s - type for elements (oid %s) is not dumped.\n"
+msgid "notice: array type %s - type for elements (oid %s) is not dumped\n"
 msgstr ""
 
-#: pg_dump.c:3239
+#: pg_dump.c:3221
 #, c-format
 msgid "query to obtain list of procedural languages failed: %s"
 msgstr ""
 
-#: pg_dump.c:3267
+#: pg_dump.c:3249
 #, c-format
 msgid "handler procedure for procedural language %s not found\n"
 msgstr ""
 
-#: pg_dump.c:3357
+#: pg_dump.c:3339
 #, c-format
 msgid "query to get name of procedural language failed: %s"
 msgstr ""
 
-#: pg_dump.c:3364
+#: pg_dump.c:3346
 #, c-format
 msgid "procedural language for function %s not found\n"
 msgstr ""
 
-#: pg_dump.c:3406 pg_dump.c:3435
+#: pg_dump.c:3388 pg_dump.c:3417
+#, c-format
+msgid "WARNING: function \"%s\" not dumped\n"
+msgstr ""
+
+#: pg_dump.c:3391
+#, c-format
+msgid "reason: data type name of argument %d (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3420
+#, c-format
+msgid "reason: name of return data type (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3528 pg_dump.c:3544 pg_dump.c:3558 pg_dump.c:3572 pg_dump.c:3592
+#: pg_dump.c:3606
+#, c-format
+msgid "WARNING: operator \"%s\" (oid %s) not dumped\n"
+msgstr ""
+
+#: pg_dump.c:3530
+#, c-format
+msgid "reason: oprleft (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3546
+#, c-format
+msgid "reason: oprright (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3560
+#, c-format
+msgid "reason: oprcom (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3574
 #, c-format
-msgid "Notice: function \"%s\" not dumped\n"
+msgid "reason: oprnegate (oid %s) not found\n"
 msgstr ""
 
-#: pg_dump.c:3409
+#: pg_dump.c:3594
 #, c-format
-msgid "Reason: data type name of argument %d (oid %s) not found\n"
+msgid "reason: oprlsortop (oid %s) not found\n"
 msgstr ""
 
-#: pg_dump.c:3438
+#: pg_dump.c:3608
 #, c-format
-msgid "Reason: name of return data type (oid %s) not found\n"
+msgid "reason: oprrsortop (oid %s) not found\n"
 msgstr ""
 
-#: pg_dump.c:4108
+#: pg_dump.c:3673
+#, c-format
+msgid ""
+"WARNING: aggregate function %s could not be dumped correctly for this "
+"database version; ignored\n"
+msgstr ""
+
+#: pg_dump.c:3687 pg_dump.c:3704
+#, c-format
+msgid "WARNING: aggregate function \"%s\" (oid %s) not dumped\n"
+msgstr ""
+
+#: pg_dump.c:3689
+#, c-format
+msgid "reason: aggbasetype (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3706
+#, c-format
+msgid "reason: aggtranstype (oid %s) not found\n"
+msgstr ""
+
+#: pg_dump.c:3870
+#, c-format
+msgid "could not parse ACL list ('%s') for relation %s\n"
+msgstr ""
+
+#: pg_dump.c:4111
 #, c-format
 msgid ""
 "dumpTables(): failed sanity check, could not find index (%s) for primary key "
 "constraint\n"
 msgstr ""
 
-#: pg_dump.c:4232
+#: pg_dump.c:4235
 #, c-format
 msgid "getAttrName(): invalid column number %d for table %s\n"
 msgstr ""
 
-#: pg_dump.c:4268
+#: pg_dump.c:4271
 #, c-format
 msgid "dumpIndexes(): failed sanity check, table %s was not found\n"
 msgstr ""
 
-#: pg_dump.c:4322
+#: pg_dump.c:4325
 #, c-format
 msgid "query to get function name of oid %s failed: %s"
 msgstr ""
 
-#: pg_dump.c:4331
+#: pg_dump.c:4334
 #, c-format
 msgid "query to get function name of oid %s returned %d rows; expected 1\n"
 msgstr ""
 
-#: pg_dump.c:4356
+#: pg_dump.c:4359
 #, c-format
 msgid "query to get operator class name of oid %u failed: %s"
 msgstr ""
 
-#: pg_dump.c:4365
+#: pg_dump.c:4368
 #, c-format
 msgid ""
 "query to get operator class name of oid %u returned %d rows; expected 1\n"
 msgstr ""
 
-#: pg_dump.c:4376
+#: pg_dump.c:4379
 #, c-format
 msgid "There must be exactly one OpClass for functional index \"%s\".\n"
 msgstr ""
 
-#: pg_dump.c:4400
+#: pg_dump.c:4403
 #, c-format
 msgid "no operator class found for column \"%s\" of index \"%s\"\n"
 msgstr ""
 
-#: pg_dump.c:4542
+#: pg_dump.c:4545
 #, c-format
 msgid "could not create pgdump_oid table: %s"
-msgstr ""
+msgstr "konnte Tabelle pgdump_oid nicht erstellen: %s"
 
-#: pg_dump.c:4550
+#: pg_dump.c:4553
 #, c-format
 msgid "could not insert into pgdump_oid table: %s"
-msgstr ""
+msgstr "konnte nicht in Tabelle pgdump_oid einfügen: %s"
 
-#: pg_dump.c:4556
+#: pg_dump.c:4559
 msgid "inserted invalid oid\n"
-msgstr ""
+msgstr "ungültige Oid eingefügt\n"
 
-#: pg_dump.c:4564
+#: pg_dump.c:4567
 #, c-format
 msgid "could not drop pgdump_oid table: %s"
-msgstr ""
+msgstr "konnte Tabelle pgdump_oid nicht entfernen: %s"
+
+#: pg_dump.c:4572
+#, c-format
+msgid "maximum system oid is %u\n"
+msgstr "höchste System-Oid ist %u\n"
 
-#: pg_dump.c:4604
+#: pg_dump.c:4606
 #, c-format
 msgid "error in finding the last system oid: %s"
 msgstr ""
 
-#: pg_dump.c:4610
+#: pg_dump.c:4612
 msgid "missing pg_database entry for this database\n"
-msgstr ""
+msgstr "fehlender pg_database-Eintrag für diese Datenbank\n"
 
-#: pg_dump.c:4615
+#: pg_dump.c:4617
 msgid "found more than one pg_database entry for this database\n"
-msgstr ""
+msgstr "mehr als einen pg_database-Eintrag für diese Datenbank gefunden\n"
 
-#: pg_dump.c:4642
+#: pg_dump.c:4644
 #, c-format
 msgid "error in finding the template1 database: %s"
-msgstr ""
+msgstr "Fehler beim Finden der Datenbank template1: %s"
 
-#: pg_dump.c:4648
+#: pg_dump.c:4650
 msgid "could not find template1 database entry in the pg_database table\n"
 msgstr ""
+"konnte Eintrag für Datenbank template1 nicht in der Tabelle pg_database "
+"finden\n"
 
-#: pg_dump.c:4653
+#: pg_dump.c:4655
 msgid "found more than one template1 database entry in the pg_database table\n"
 msgstr ""
+"mehr als ein Eintrag für Datenbank template1 in der Tabelle pg_database "
+"gefunden\n"
 
-#: pg_dump.c:4684
+#: pg_dump.c:4686
 #, c-format
 msgid "query to get data of sequence \"%s\" failed: %s"
 msgstr ""
 
-#: pg_dump.c:4690
+#: pg_dump.c:4692
 #, c-format
 msgid "query to get data of sequence \"%s\" returned %d rows (expected 1)\n"
 msgstr ""
 
-#: pg_dump.c:4697
+#: pg_dump.c:4699
 #, c-format
 msgid "query to get data of sequence \"%s\" returned name \"%s\"\n"
 msgstr ""
 
+#: pg_dump.c:4774
+msgid "dumping out triggers\n"
+msgstr ""
+
+#: pg_dump.c:4808
+msgid "dumping out rules\n"
+msgstr ""
+
 #: pg_dump.c:4840
 #, c-format
 msgid "query to get rules associated with table \"%s\" failed: %s"
@@ -653,11 +796,83 @@ msgstr ""
 msgid "parseNumericArray: bogus number\n"
 msgstr ""
 
-#: common.c:491
+#: common.c:300
+msgid "reading user-defined types\n"
+msgstr "lese benutzerdefinierte Typen\n"
+
+#: common.c:304
+msgid "reading user-defined functions\n"
+msgstr "lese benutzerdefinierte Funktionen\n"
+
+#: common.c:308
+msgid "reading user-defined aggregate functions\n"
+msgstr "lese benutzerdefinierte Aggregatfunktionen\n"
+
+#: common.c:312
+msgid "reading user-defined operators\n"
+msgstr "lese benutzerdefinierte Operatoren\n"
+
+#: common.c:316
+msgid "reading user-defined tables\n"
+msgstr "lese benutzerdefinierte Tabellen\n"
+
+#: common.c:320
+msgid "reading index information\n"
+msgstr "lese Indexinformationen\n"
+
+#: common.c:324
+msgid "reading table inheritance information\n"
+msgstr "lese Tabellenvererbungsinformationen\n"
+
+#: common.c:328
+msgid "finding the column names and types for each table\n"
+msgstr "finde Spaltennamen und -typen für jede Tabelle\n"
+
+#: common.c:332
+msgid "flagging inherited columns in subtables\n"
+msgstr ""
+
+#: common.c:338
+msgid "dumping out database comment\n"
+msgstr ""
+
+#: common.c:345
+msgid "dumping out user-defined types\n"
+msgstr ""
+
+#: common.c:350
+msgid "dumping out tables\n"
+msgstr ""
+
+#: common.c:358
+msgid "dumping out indexes\n"
+msgstr ""
+
+#: common.c:365
+msgid "dumping out user-defined procedural languages\n"
+msgstr ""
+
+#: common.c:372
+msgid "dumping out user-defined functions\n"
+msgstr ""
+
+#: common.c:379
+msgid "dumping out user-defined aggregate functions\n"
+msgstr ""
+
+#: common.c:386
+msgid "dumping out user-defined operators\n"
+msgstr ""
+
+#: common.c:474
 #, c-format
 msgid "failed sanity check, table \"%s\" not found by flagInhAttrs\n"
 msgstr ""
 
+#: pg_backup_archiver.c:94
+msgid "archiver"
+msgstr "Archivierer"
+
 #: pg_backup_archiver.c:149
 msgid "could not close the output file in CloseArchive\n"
 msgstr ""
@@ -666,10 +881,18 @@ msgstr ""
 msgid "-C and -R are incompatible options\n"
 msgstr ""
 
+#: pg_backup_archiver.c:173
+msgid "connecting to database for restore\n"
+msgstr ""
+
 #: pg_backup_archiver.c:175
 msgid "direct database connections are not supported in pre-1.3 archives\n"
 msgstr ""
 
+#: pg_backup_archiver.c:222
+msgid "implied data-only restore\n"
+msgstr ""
+
 #: pg_backup_archiver.c:227
 msgid ""
 "WARNING:\n"
@@ -685,200 +908,277 @@ msgstr ""
 "Trigger\n"
 "  enthält.\n"
 
-#: pg_backup_archiver.c:275 pg_backup_archiver.c:277
+#: pg_backup_archiver.c:252
+#, c-format
+msgid "dropping %s %s\n"
+msgstr "entferne %s %s\n"
+
+#: pg_backup_archiver.c:276 pg_backup_archiver.c:278
 #, c-format
 msgid "warning from original dump file: %s\n"
 msgstr ""
 
-#: pg_backup_archiver.c:317
+#: pg_backup_archiver.c:288
+#, c-format
+msgid "creating %s %s\n"
+msgstr "erstelle %s %s\n"
+
+#: pg_backup_archiver.c:295
+#, c-format
+msgid "connecting to new database %s as user %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:318
 msgid ""
 "unable to restore from compressed archive (not configured for compression "
 "support)\n"
 msgstr ""
 
-#: pg_backup_archiver.c:335
+#: pg_backup_archiver.c:336
 msgid "WARNING: skipping BLOB restoration\n"
 msgstr ""
 
-#: pg_backup_archiver.c:595
+#: pg_backup_archiver.c:350
+#, c-format
+msgid "restoring data for table %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:371
+#, c-format
+msgid "executing %s %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:395
+#, c-format
+msgid "checking whether we loaded %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:401
+#, c-format
+msgid "fixing up BLOB reference for %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:406
+#, c-format
+msgid "ignoring BLOB cross-references for %s %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:493
+msgid "disabling triggers\n"
+msgstr "schalte Trigger aus\n"
+
+#: pg_backup_archiver.c:553
+msgid "enabling triggers\n"
+msgstr "schalte Trigger ein\n"
+
+#: pg_backup_archiver.c:596
 msgid ""
 "WriteData cannot be called outside the context of a DataDumper routine\n"
 msgstr ""
 
-#: pg_backup_archiver.c:715
+#: pg_backup_archiver.c:716
 msgid "BLOB output not supported in chosen format\n"
 msgstr ""
 
-#: pg_backup_archiver.c:779
+#: pg_backup_archiver.c:756 pg_backup_archiver.c:823
+msgid "committing BLOB transactions\n"
+msgstr ""
+
+#: pg_backup_archiver.c:763
+#, c-format
+msgid "restored %d BLOBs\n"
+msgstr ""
+
+#: pg_backup_archiver.c:780
 msgid "cannot restore BLOBs without a database connection"
 msgstr ""
 
-#: pg_backup_archiver.c:798
+#: pg_backup_archiver.c:791
+msgid "starting BLOB transactions\n"
+msgstr ""
+
+#: pg_backup_archiver.c:799
 msgid "could not create BLOB\n"
 msgstr ""
 
-#: pg_backup_archiver.c:806
+#: pg_backup_archiver.c:801
+#, c-format
+msgid "restoring BLOB oid %u as %u\n"
+msgstr ""
+
+#: pg_backup_archiver.c:807
 msgid "could not open BLOB\n"
 msgstr ""
 
-#: pg_backup_archiver.c:946
+#: pg_backup_archiver.c:947
 msgid "could not open TOC file\n"
 msgstr ""
 
-#: pg_backup_archiver.c:967
+#: pg_backup_archiver.c:968
 #, c-format
 msgid "WARNING: line ignored: %s\n"
 msgstr "WARNUNG: Zeile ignoriert: %s\n"
 
-#: pg_backup_archiver.c:974
+#: pg_backup_archiver.c:975
 #, c-format
 msgid "could not find entry for id %d\n"
 msgstr ""
 
-#: pg_backup_archiver.c:983 pg_backup_files.c:158 pg_backup_files.c:443
+#: pg_backup_archiver.c:984 pg_backup_files.c:158 pg_backup_files.c:443
 #, c-format
 msgid "could not close TOC file: %s\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1099 pg_backup_files.c:132
+#: pg_backup_archiver.c:1100 pg_backup_files.c:132
 #, c-format
 msgid "could not open output file: %s\n"
 msgstr "konnte Ausgabedatei nicht öffnen: %s\n"
 
-#: pg_backup_archiver.c:1115
+#: pg_backup_archiver.c:1116
 #, c-format
 msgid "could not close output file: %s\n"
 msgstr "konnte Ausgabedatei nicht schließen: %s\n"
 
-#: pg_backup_archiver.c:1198
+#: pg_backup_archiver.c:1197
+#, c-format
+msgid "wrote %d bytes of BLOB data (result = %d)\n"
+msgstr ""
+
+#: pg_backup_archiver.c:1199
 #, c-format
 msgid "could not write to large object (result: %d, expected: %d)\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1207
+#: pg_backup_archiver.c:1208
 msgid "could not write to compressed archive\n"
 msgstr "konnte nicht in komprimiertes Archiv schreiben\n"
 
-#: pg_backup_archiver.c:1215
+#: pg_backup_archiver.c:1216
 msgid "could not write to custom output routine\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1231
+#: pg_backup_archiver.c:1232
 #, c-format
 msgid "could not write to output file (%d != %d)\n"
 msgstr "konnte nicht in Ausgabedatei schreiben (%d != %d)\n"
 
-#: pg_backup_archiver.c:1454
+#: pg_backup_archiver.c:1457
 msgid "attempting to ascertain archive format\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1474 pg_backup_files.c:150
+#: pg_backup_archiver.c:1477 pg_backup_files.c:150
 #, c-format
 msgid "could not open input file: %s\n"
 msgstr "konnte Eingabedatei nicht öffnen: %s\n"
 
-#: pg_backup_archiver.c:1481
+#: pg_backup_archiver.c:1484
 #, c-format
 msgid "could not read input file: %s\n"
 msgstr "konnte nicht aus Eingabedatei lesen: %s\n"
 
-#: pg_backup_archiver.c:1483
+#: pg_backup_archiver.c:1486
 #, c-format
 msgid "input file is too short (read %d, expected 5)\n"
 msgstr "Eingabedatei ist zu kurz (gelesen: %d, erwartet: 5)\n"
 
-#: pg_backup_archiver.c:1528
+#: pg_backup_archiver.c:1531
 msgid "input file does not appear to be a valid archive (too short?)\n"
 msgstr "Eingabedatei scheint kein gültiges Archiv zu sein (zu kurz?)\n"
 
-#: pg_backup_archiver.c:1531
+#: pg_backup_archiver.c:1534
 msgid "input file does not appear to be a valid archive\n"
 msgstr "Eingabedatei scheint kein gültiges Archiv zu sein\n"
 
-#: pg_backup_archiver.c:1550
+#: pg_backup_archiver.c:1553
 #, c-format
 msgid "read %d bytes into lookahead buffer\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1556
+#: pg_backup_archiver.c:1559
 #, c-format
 msgid "could not close the input file after reading header: %s\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1573
+#: pg_backup_archiver.c:1576
 #, c-format
 msgid "allocating AH for %s, format %d\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1623
+#: pg_backup_archiver.c:1626
 #, c-format
 msgid "archive format is %d\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1651
+#: pg_backup_archiver.c:1654
 #, c-format
 msgid "unrecognized file format '%d'\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1765
+#: pg_backup_archiver.c:1768
 msgid "failed sanity check (bad entry id) - perhaps a corrupt TOC\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1797
+#: pg_backup_archiver.c:1800
 #, c-format
 msgid "read dependency for %s -> %s\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1961
+#: pg_backup_archiver.c:1819
+#, c-format
+msgid "read TOC entry %d (id %d) for %s %s\n"
+msgstr ""
+
+#: pg_backup_archiver.c:1964
 msgid ""
 "WARNING: requested compression not available in this installation - archive "
 "will be uncompressed\n"
 msgstr ""
 
-#: pg_backup_archiver.c:1994
+#: pg_backup_archiver.c:1997
 msgid "did not find magic string in file header\n"
 msgstr ""
 
-#: pg_backup_archiver.c:2008
+#: pg_backup_archiver.c:2011
 #, c-format
 msgid "unsupported version (%d.%d) in file header\n"
 msgstr ""
 
-#: pg_backup_archiver.c:2013
+#: pg_backup_archiver.c:2016
 #, c-format
 msgid "sanity check on integer size (%d) failed\n"
 msgstr ""
 
-#: pg_backup_archiver.c:2016
+#: pg_backup_archiver.c:2019
 msgid ""
 "WARNING: archive was made on a machine with larger integers, some operations "
 "may fail\n"
 msgstr ""
 
-#: pg_backup_archiver.c:2021
+#: pg_backup_archiver.c:2024
 #, c-format
 msgid "expected format (%d) differs from format found in file (%d)\n"
 msgstr ""
+"erwartetes Format (%d) ist nicht das gleiche wie das in der Datei gefundene "
+"(%d)\n"
 
-#: pg_backup_archiver.c:2037
+#: pg_backup_archiver.c:2040
 msgid ""
 "WARNING: archive is compressed, but this installation does not support "
 "compression - no data will be available\n"
 msgstr ""
 
-#: pg_backup_archiver.c:2055
-msgid "WARNING: bad creation date in header\n"
-msgstr ""
+#: pg_backup_archiver.c:2058
+msgid "WARNING: invalid creation date in header\n"
+msgstr "WARNUNG: ungültiges Erstellungsdatum im Kopf\n"
 
-#: pg_backup_custom.c:183
-#, c-format
-msgid "could not open archive file %s: %s\n"
+#: pg_backup_custom.c:105
+msgid "custom archiver"
 msgstr ""
 
-#: pg_backup_custom.c:196
+#: pg_backup_custom.c:183 pg_backup_custom.c:196
 #, c-format
-msgid "could not open archive file %s: %s"
-msgstr ""
+msgid "could not open archive file %s: %s\n"
+msgstr "konnte Archivdatei %s nicht öffnen: %s\n"
 
 #: pg_backup_custom.c:389
 msgid "invalid OID for BLOB\n"
@@ -917,7 +1217,7 @@ msgstr ""
 #: pg_backup_custom.c:550 pg_backup_custom.c:907
 #, c-format
 msgid "could not initialize compression library: %s\n"
-msgstr ""
+msgstr "konnte Komprimierungsbibliothek nicht initialisieren: %s\n"
 
 #: pg_backup_custom.c:572 pg_backup_custom.c:696
 #, c-format
@@ -932,7 +1232,7 @@ msgstr ""
 #: pg_backup_custom.c:724
 #, c-format
 msgid "could not write byte: %s\n"
-msgstr ""
+msgstr "konnte Byte nicht schreiben: %s\n"
 
 #: pg_backup_custom.c:767 pg_backup_files.c:418
 #, c-format
@@ -942,7 +1242,7 @@ msgstr ""
 #: pg_backup_custom.c:837
 #, c-format
 msgid "could not close archive file: %s\n"
-msgstr ""
+msgstr "konnte Archivdatei nicht schließen: %s\n"
 
 #: pg_backup_custom.c:860
 msgid "WARNING: ftell mismatch with filePos - filePos used\n"
@@ -966,142 +1266,181 @@ msgstr ""
 msgid "could not close compression stream: %s\n"
 msgstr ""
 
-#: pg_backup_db.c:131
+#: pg_backup_db.c:40
+msgid "archiver (db)"
+msgstr "Archivierer (DB)"
+
+#: pg_backup_db.c:130
 #, c-format
 msgid "unable to parse version string \"%s\"\n"
 msgstr ""
 
-#: pg_backup_db.c:156
+#: pg_backup_db.c:155
 #, c-format
 msgid "could not get version from server: %s"
 msgstr "konnte Version des Servers nicht ermitteln: %s"
 
-#: pg_backup_db.c:168
+#: pg_backup_db.c:167
 #, c-format
 msgid "server version: %s, %s version: %s\n"
-msgstr ""
+msgstr "Version des Servers: %s, Version vom %s: %s\n"
 
-#: pg_backup_db.c:171
+# XXX  bessere Übersetzung von mismatch?
+#: pg_backup_db.c:170
 msgid "proceeding despite version mismatch\n"
-msgstr ""
+msgstr "Fortsetzung trotz unterschiedlicher Versionen\n"
 
-#: pg_backup_db.c:173
+#: pg_backup_db.c:172
 msgid ""
 "aborting because of version mismatch  (Use the -i option to proceed "
 "anyway.)\n"
 msgstr ""
+"Abbruch wegen unterschiedlicher Versionen  (Verwenden Sie die Option -i um "
+"trotzdem fortzusetzen.)\n"
 
-#: pg_backup_db.c:194
+#: pg_backup_db.c:193
 #, c-format
 msgid "null result checking superuser status of %s\n"
 msgstr ""
 
-#: pg_backup_db.c:197
+#: pg_backup_db.c:196
 #, c-format
 msgid "could not check superuser status of %s: %s"
 msgstr ""
 
-#: pg_backup_db.c:282 pg_backup_db.c:315 pg_backup_db.c:374 pg_backup_db.c:403
+#: pg_backup_db.c:277
+#, c-format
+msgid "connecting to database %s as user %s\n"
+msgstr "verbinde mit Datenbank %s als Benutzer %s\n"
+
+#: pg_backup_db.c:281 pg_backup_db.c:314 pg_backup_db.c:373 pg_backup_db.c:402
 msgid "Password: "
 msgstr "Paßwort: "
 
-#: pg_backup_db.c:294
+#: pg_backup_db.c:293
 msgid "failed to reconnect to database\n"
 msgstr ""
 
-#: pg_backup_db.c:318
+#: pg_backup_db.c:317
 #, c-format
 msgid "could not reconnect to database: %s"
 msgstr ""
 
-#: pg_backup_db.c:350
-msgid "already connected to database\n"
-msgstr ""
+#: pg_backup_db.c:349
+msgid "already connected to a database\n"
+msgstr "bereits mit einer Datenbank verbunden\n"
 
-#: pg_backup_db.c:393
+#: pg_backup_db.c:392
 msgid "failed to connect to database\n"
-msgstr ""
+msgstr "Verbinden zur Datenbank schlug fehl\n"
 
-#: pg_backup_db.c:412
+#: pg_backup_db.c:411
 #, c-format
 msgid "connection to database \"%s\" failed: %s"
 msgstr ""
 
-#: pg_backup_db.c:452
+#: pg_backup_db.c:451
 #, c-format
-msgid "%s: no result from backend\n"
-msgstr ""
+msgid "%s: no result from server\n"
+msgstr "%s: kein Ergebnis vom Server\n"
 
-#: pg_backup_db.c:459
+#: pg_backup_db.c:458
 msgid "COPY command executed in non-primary connection\n"
 msgstr ""
 
-#: pg_backup_db.c:464
+#: pg_backup_db.c:463
 #, c-format
 msgid "%s: %s"
 msgstr "%s: %s"
 
-#: pg_backup_db.c:547
+#: pg_backup_db.c:546
 msgid "error returned by PQputline\n"
-msgstr ""
+msgstr "Fehler in PQputline\n"
 
-#: pg_backup_db.c:559
+#: pg_backup_db.c:558
 msgid "error returned by PQendcopy\n"
-msgstr ""
+msgstr "Fehler in PQendcopy\n"
 
-#: pg_backup_db.c:608
+#: pg_backup_db.c:607
 msgid "could not execute query"
 msgstr "konnte Abfrage nicht ausführen"
 
-#: pg_backup_db.c:698
+#: pg_backup_db.c:697
 #, c-format
 msgid "could not find oid columns of table \"%s\": %s"
+msgstr "konnte die OID-Spalten der Tabelle »%s« nicht finden: %s"
+
+#: pg_backup_db.c:703
+#, c-format
+msgid "no OID type columns in table %s\n"
+msgstr "keine Spalten vom Typ OID in Tabelle %s\n"
+
+#: pg_backup_db.c:712
+#, c-format
+msgid "fixing BLOB cross-references for %s.%s\n"
 msgstr ""
 
-#: pg_backup_db.c:733
+#: pg_backup_db.c:727
+#, c-format
+msgid "SQL: %s\n"
+msgstr "SQL: %s\n"
+
+#: pg_backup_db.c:732
 #, c-format
 msgid "could not update column \"%s\" of table \"%s\": %s"
 msgstr ""
 
-#: pg_backup_db.c:738
+#: pg_backup_db.c:737
 #, c-format
 msgid "error while updating column \"%s\" of table \"%s\": %s"
 msgstr ""
 
-#: pg_backup_db.c:764
+#: pg_backup_db.c:759
+msgid "creating table for BLOB cross-references\n"
+msgstr ""
+
+#: pg_backup_db.c:763
 msgid "could not create BLOB cross reference table"
 msgstr ""
 
-#: pg_backup_db.c:769
+#: pg_backup_db.c:768
 msgid "could not create index on BLOB cross reference table"
 msgstr ""
 
-#: pg_backup_db.c:779
+#: pg_backup_db.c:778
 msgid "could not create BLOB cross reference entry"
 msgstr ""
 
-#: pg_backup_db.c:789
+#: pg_backup_db.c:788
 msgid "could not start database transaction"
-msgstr ""
+msgstr "konnte Datenbanktransaktion nicht starten"
 
-#: pg_backup_db.c:801
+#: pg_backup_db.c:800
 msgid "could not start transaction for BLOB cross references"
 msgstr ""
 
-#: pg_backup_db.c:812
+#: pg_backup_db.c:811
 msgid "could not commit database transaction"
-msgstr ""
+msgstr "konnte Datenbanktransaktion nicht beenden"
 
-#: pg_backup_db.c:823
+#: pg_backup_db.c:822
 msgid "could not commit transaction for BLOB cross references"
 msgstr ""
 
+#: pg_backup_files.c:77
+msgid "file archiver"
+msgstr "Datei-Archivierer"
+
 #: pg_backup_files.c:122
 msgid ""
 "WARNING:\n"
-"  This format is for demonstration purposes, it is not intended for\n"
+"  This format is for demonstration purposes; it is not intended for\n"
 "  normal use. Files will be written in the current working directory.\n"
 msgstr ""
+"WARNUNG:\n"
+"  Dieses Format ist für Demonstrationszwecke; es ist nicht für den\n"
+"  normalen Gebrauch.  Dateien werden in das aktuelle Verzeichnis\n"
+"  geschrieben.\n"
 
 #: pg_backup_files.c:248
 msgid "could not open data file for output\n"
@@ -1155,6 +1494,10 @@ msgstr ""
 msgid "this format cannot be read\n"
 msgstr "dieses Format kann nicht gelesen werden\n"
 
+#: pg_backup_tar.c:104
+msgid "tar archiver"
+msgstr "Tar-Archivierer"
+
 #: pg_backup_tar.c:176
 #, c-format
 msgid "could not open TOC file for output: %s\n"
@@ -1217,6 +1560,11 @@ msgid ""
 "at position %d\n"
 msgstr ""
 
+#: pg_backup_tar.c:718
+#, c-format
+msgid "restoring BLOB oid %u\n"
+msgstr ""
+
 #: pg_backup_tar.c:857
 msgid "could not write null block at end of tar archive\n"
 msgstr ""
@@ -1240,11 +1588,26 @@ msgstr ""
 msgid "could not output padding at end of tar member\n"
 msgstr ""
 
+#: pg_backup_tar.c:1091
+#, c-format
+msgid "moving from position %d (%x) to next member at file position %d (%x)\n"
+msgstr ""
+
+#: pg_backup_tar.c:1099
+#, c-format
+msgid "now at file position %d (%x)\n"
+msgstr ""
+
 #: pg_backup_tar.c:1107 pg_backup_tar.c:1134
 #, c-format
 msgid "could not find header for file %s in tar archive\n"
 msgstr ""
 
+#: pg_backup_tar.c:1118
+#, c-format
+msgid "skipping tar member %s\n"
+msgstr ""
+
 #: pg_backup_tar.c:1122
 #, c-format
 msgid ""
@@ -1262,6 +1625,11 @@ msgstr ""
 msgid "incomplete tar header found (%d bytes)\n"
 msgstr ""
 
+#: pg_backup_tar.c:1205
+#, c-format
+msgid "TOC Entry %s at %d (length %d, checksum %d)\n"
+msgstr ""
+
 #: pg_backup_tar.c:1209
 #, c-format
 msgid ""
@@ -1352,7 +1720,8 @@ msgstr ""
 
 #: pg_restore.c:418
 msgid "If no input file name is supplied, then standard input is used.\n"
-msgstr "Wenn keine Eingabedatei angegeben ist, wird die Standardeingabe verwendet.\n"
+msgstr ""
+"Wenn keine Eingabedatei angegeben ist, wird die Standardeingabe verwendet.\n"
 
 #: pg_restore.c:419
 msgid "Report bugs to <pgsql-bugs@postgresql.org>."
diff --git a/src/bin/pg_dump/nls.mk b/src/bin/pg_dump/nls.mk
index d8155094bb19a93c5e43375eca99e80378dd6360..581e3d9c0421788eee17f12b29dad4fa0006cfc9 100644
--- a/src/bin/pg_dump/nls.mk
+++ b/src/bin/pg_dump/nls.mk
@@ -1,8 +1,8 @@
-# $Header: /cvsroot/pgsql/src/bin/pg_dump/nls.mk,v 1.1 2001/06/27 21:21:37 petere Exp $
+# $Header: /cvsroot/pgsql/src/bin/pg_dump/nls.mk,v 1.2 2001/07/03 20:21:48 petere Exp $
 CATALOG_NAME	:= pg_dump
 AVAIL_LANGUAGES	:= de
 GETTEXT_FILES	:= pg_dump.c common.c pg_backup_archiver.c pg_backup_custom.c \
                    pg_backup_db.c pg_backup_files.c pg_backup_null.c \
                    pg_backup_tar.c pg_restore.c
 GETTEXT_TRIGGERS:= write_msg:2 die_horribly:3 exit_horribly:3 simple_prompt \
-                   ExecuteSqlCommand:3
+                   ExecuteSqlCommand:3 ahlog:3
diff --git a/src/bin/pg_dump/pg_backup_archiver.c b/src/bin/pg_dump/pg_backup_archiver.c
index ed7a4841bbf1b34c872bae0a25a533419d473237..eea98ca7e5caaf084876be6fb0b93a499df3f70d 100644
--- a/src/bin/pg_dump/pg_backup_archiver.c
+++ b/src/bin/pg_dump/pg_backup_archiver.c
@@ -15,7 +15,7 @@
  *
  *
  * IDENTIFICATION
- *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.28 2001/06/27 21:21:37 petere Exp $
+ *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.29 2001/07/03 20:21:48 petere Exp $
  *
  * Modifications - 28-Jun-2000 - pjw@rhyme.com.au
  *
@@ -91,7 +91,7 @@ static void _fixupOidInfo(TocEntry *te);
 static Oid _findMaxOID(const char *((*deps)[]));
 
 const char *progname;
-static char *modulename = "archiver";
+static char *modulename = gettext_noop("archiver");
 
 static void _write_msg(const char *modulename, const char *fmt, va_list ap);
 static void _die_horribly(ArchiveHandle *AH, const char *modulename, const char *fmt, va_list ap);
@@ -170,7 +170,7 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 	 */
 	if (ropt->useDB)
 	{
-		ahlog(AH, 1, "Connecting to database for restore\n");
+		ahlog(AH, 1, "connecting to database for restore\n");
 		if (AH->version < K_VERS_1_3)
 			die_horribly(AH, modulename, "direct database connections are not supported in pre-1.3 archives\n");
 
@@ -219,7 +219,7 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 		if (impliedDataOnly)
 		{
 			ropt->dataOnly = impliedDataOnly;
-			ahlog(AH, 1, "Implied data-only restore\n");
+			ahlog(AH, 1, "implied data-only restore\n");
 		}
 	}
 
@@ -247,8 +247,9 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 		{
 			reqs = _tocEntryRequired(te, ropt);
 			if (((reqs & 1) != 0) && te->dropStmt)
-			{					/* We want the schema */
-				ahlog(AH, 1, "Dropping %s %s\n", te->desc, te->name);
+			{
+				/* We want the schema */
+				ahlog(AH, 1, "dropping %s %s\n", te->desc, te->name);
 				/* Reconnect if necessary */
 				_reconnectAsOwner(AH, "-", te);
 				/* Drop it */
@@ -284,14 +285,14 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 			/* Reconnect if necessary */
 			_reconnectAsOwner(AH, "-", te);
 
-			ahlog(AH, 1, "Creating %s %s\n", te->desc, te->name);
+			ahlog(AH, 1, "creating %s %s\n", te->desc, te->name);
 			_printTocEntry(AH, te, ropt, false);
 			defnDumped = true;
 
 			/* If we created a DB, connect to it... */
 			if (strcmp(te->desc, "DATABASE") == 0)
 			{
-				ahlog(AH, 1, "Connecting to new DB '%s' as %s\n", te->name, te->owner);
+				ahlog(AH, 1, "connecting to new database %s as user %s\n", te->name, te->owner);
 				_reconnectAsUser(AH, te->name, te->owner);
 			}
 		}	
@@ -346,7 +347,7 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 						 */
 						_reconnectAsOwner(AH, "-", te);
 
-						ahlog(AH, 1, "Restoring data for %s \n", te->name);
+						ahlog(AH, 1, "restoring data for table %s\n", te->name);
 
 						/*
 						 * If we have a copy statement, use it. As of V1.3, these
@@ -367,7 +368,7 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 				}
 			} else if (!defnDumped) {
 				/* If we haven't already dumped the defn part, do so now */ 
-				ahlog(AH, 1, "Executing %s %s\n", te->desc, te->name);
+				ahlog(AH, 1, "executing %s %s\n", te->desc, te->name);
 				_printTocEntry(AH, te, ropt, false);
 			}
 		}
@@ -391,18 +392,18 @@ RestoreArchive(Archive *AHX, RestoreOptions *ropt)
 			if (strcmp(te->desc, "TABLE DATA") == 0)
 			{
 
-				ahlog(AH, 2, "Checking if we loaded %s\n", te->name);
+				ahlog(AH, 2, "checking whether we loaded %s\n", te->name);
 
 				reqs = _tocEntryRequired(te, ropt);
 
 				if ((reqs & 2) != 0)	/* We loaded the data */
 				{
-					ahlog(AH, 1, "Fixing up BLOB ref for %s\n", te->name);
+					ahlog(AH, 1, "fixing up BLOB reference for %s\n", te->name);
 					FixupBlobRefs(AH, te->name);
 				}
 			}
 			else
-				ahlog(AH, 2, "Ignoring BLOB xrefs for %s %s\n", te->desc, te->name);
+				ahlog(AH, 2, "ignoring BLOB cross-references for %s %s\n", te->desc, te->name);
 
 			te = te->next;
 		}
@@ -489,7 +490,7 @@ _disableTriggersIfNecessary(ArchiveHandle *AH, TocEntry *te, RestoreOptions *rop
 		}
 	}
 
-	ahlog(AH, 1, "Disabling triggers\n");
+	ahlog(AH, 1, "disabling triggers\n");
 
 	/*
 	 * Disable them. This is a hack. Needs to be done via an appropriate
@@ -549,7 +550,7 @@ _enableTriggersIfNecessary(ArchiveHandle *AH, TocEntry *te, RestoreOptions *ropt
 		}
 	}
 
-	ahlog(AH, 1, "Enabling triggers\n");
+	ahlog(AH, 1, "enabling triggers\n");
 
 	/*
 	 * Enable them. This is a hack. Needs to be done via an appropriate
@@ -752,14 +753,14 @@ EndRestoreBlobs(ArchiveHandle *AH)
 {
 	if (AH->txActive)
 	{
-		ahlog(AH, 2, "Committing BLOB transactions\n");
+		ahlog(AH, 2, "committing BLOB transactions\n");
 		CommitTransaction(AH);
 	}
 
 	if (AH->blobTxActive)
 		CommitTransactionXref(AH);
 
-	ahlog(AH, 1, "Restored %d BLOBs\n", AH->blobCount);
+	ahlog(AH, 1, "restored %d BLOBs\n", AH->blobCount);
 }
 
 
@@ -769,7 +770,7 @@ EndRestoreBlobs(ArchiveHandle *AH)
 void
 StartRestoreBlob(ArchiveHandle *AH, Oid oid)
 {
-	int			loOid;
+	Oid			loOid;
 
 	AH->blobCount++;
 
@@ -787,7 +788,7 @@ StartRestoreBlob(ArchiveHandle *AH, Oid oid)
 	 */
 	if (!AH->txActive)
 	{
-		ahlog(AH, 2, "Starting BLOB transactions\n");
+		ahlog(AH, 2, "starting BLOB transactions\n");
 		StartTransaction(AH);
 	}
 	if (!AH->blobTxActive)
@@ -797,7 +798,7 @@ StartRestoreBlob(ArchiveHandle *AH, Oid oid)
 	if (loOid == 0)
 		die_horribly(AH, modulename, "could not create BLOB\n");
 
-	ahlog(AH, 2, "Restoring BLOB oid %d as %d\n", oid, loOid);
+	ahlog(AH, 2, "restoring BLOB oid %u as %u\n", oid, loOid);
 
 	InsertBlobXref(AH, oid, loOid);
 
@@ -819,7 +820,7 @@ EndRestoreBlob(ArchiveHandle *AH, Oid oid)
 	 */
 	if (((AH->blobCount / BLOB_BATCH_SIZE) * BLOB_BATCH_SIZE) == AH->blobCount)
 	{
-		ahlog(AH, 2, "Committing BLOB transactions\n");
+		ahlog(AH, 2, "committing BLOB transactions\n");
 		CommitTransaction(AH);
 		CommitTransactionXref(AH);
 	}
@@ -1166,7 +1167,7 @@ ahlog(ArchiveHandle *AH, int level, const char *fmt,...)
 		return;
 
 	va_start(ap, fmt);
-	vfprintf(stderr, fmt, ap);
+	_write_msg(NULL, fmt, ap);
 	va_end(ap);
 }
 
@@ -1193,7 +1194,7 @@ ahwrite(const void *ptr, size_t size, size_t nmemb, ArchiveHandle *AH)
 	if (AH->writingBlob)
 	{
 		res = lo_write(AH->connection, AH->loFd, (void *) ptr, size * nmemb);
-		ahlog(AH, 5, "Wrote %d bytes of BLOB data (result = %d)\n", size * nmemb, res);
+		ahlog(AH, 5, "wrote %d bytes of BLOB data (result = %d)\n", size * nmemb, res);
 		if (res < size * nmemb)
 			die_horribly(AH, modulename, "could not write to large object (result: %d, expected: %d)\n",
 						 res, size * nmemb);
@@ -1239,7 +1240,7 @@ static void
 _write_msg(const char *modulename, const char *fmt, va_list ap)
 {
 	if (modulename)
-		fprintf(stderr, "%s[%s]: ", progname, gettext(modulename));
+		fprintf(stderr, "%s: [%s] ", progname, gettext(modulename));
 	else
 		fprintf(stderr, "%s: ", progname);
 	vfprintf(stderr, gettext(fmt), ap);
@@ -1260,6 +1261,8 @@ static void
 _die_horribly(ArchiveHandle *AH, const char *modulename, const char *fmt, va_list ap)
 {
 	_write_msg(modulename, fmt, ap);
+	if (AH->public.verbose)
+		write_msg(NULL, "*** aborted because of error\n");
 
 	if (AH)
 		if (AH->connection)
@@ -1813,7 +1816,7 @@ ReadToc(ArchiveHandle *AH)
 		if (AH->ReadExtraTocPtr)
 			(*AH->ReadExtraTocPtr) (AH, te);
 
-		ahlog(AH, 3, "Read TOC entry %d (id %d) for %s %s\n", i, te->id, te->desc, te->name);
+		ahlog(AH, 3, "read TOC entry %d (id %d) for %s %s\n", i, te->id, te->desc, te->name);
 
 		te->prev = AH->toc->prev;
 		AH->toc->prev->next = te;
@@ -2052,7 +2055,7 @@ ReadHead(ArchiveHandle *AH)
 		AH->createDate = mktime(&crtm);
 
 		if (AH->createDate == (time_t) -1)
-			write_msg(modulename, "WARNING: bad creation date in header\n");
+			write_msg(modulename, "WARNING: invalid creation date in header\n");
 	}
 
 }
diff --git a/src/bin/pg_dump/pg_backup_archiver.h b/src/bin/pg_dump/pg_backup_archiver.h
index 0d5dcda4dec9de2d72f54790e942dab4ebb60ce8..16a1c06dfe6ebea7b0e93c3248f3f64de97479a7 100644
--- a/src/bin/pg_dump/pg_backup_archiver.h
+++ b/src/bin/pg_dump/pg_backup_archiver.h
@@ -17,7 +17,7 @@
  *
  *
  * IDENTIFICATION
- *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.h,v 1.35 2001/06/27 21:21:37 petere Exp $
+ *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_archiver.h,v 1.36 2001/07/03 20:21:48 petere Exp $
  *
  * Modifications - 28-Jun-2000 - pjw@rhyme.com.au
  *	-	Initial version.
@@ -316,8 +316,8 @@ extern char *ConnectedUser(ArchiveHandle *AH);
 extern int	ConnectedUserIsSuperuser(ArchiveHandle *AH);
 
 int			ahwrite(const void *ptr, size_t size, size_t nmemb, ArchiveHandle *AH);
-int			ahprintf(ArchiveHandle *AH, const char *fmt,...);
+int			ahprintf(ArchiveHandle *AH, const char *fmt,...) __attribute__((format(printf,2,3)));
 
-void		ahlog(ArchiveHandle *AH, int level, const char *fmt,...);
+void		ahlog(ArchiveHandle *AH, int level, const char *fmt,...) __attribute__((format(printf,3,4)));
 
 #endif
diff --git a/src/bin/pg_dump/pg_backup_custom.c b/src/bin/pg_dump/pg_backup_custom.c
index 00120d3039f7ec9aa67ed33415c0d0c8b551eecb..9de3e1b4a3dc8b1a7e5b58ef761c0ee9d5ae7db7 100644
--- a/src/bin/pg_dump/pg_backup_custom.c
+++ b/src/bin/pg_dump/pg_backup_custom.c
@@ -19,7 +19,7 @@
  *
  *
  * IDENTIFICATION
- *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_custom.c,v 1.12 2001/06/27 21:21:37 petere Exp $
+ *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_custom.c,v 1.13 2001/07/03 20:21:48 petere Exp $
  *
  * Modifications - 28-Jun-2000 - pjw@rhyme.com.au
  *
@@ -102,7 +102,7 @@ static void _EndDataCompressor(ArchiveHandle *AH, TocEntry *te);
 static int	_getFilePos(ArchiveHandle *AH, lclContext *ctx);
 static int	_DoDeflate(ArchiveHandle *AH, lclContext *ctx, int flush);
 
-static char *modulename = "custom archiver";
+static char *modulename = gettext_noop("custom archiver");
 
 
 
@@ -193,7 +193,7 @@ InitArchiveFmt_Custom(ArchiveHandle *AH)
 		else
 			AH->FH = stdin;
 		if (!AH->FH)
-			die_horribly(AH, modulename, "could not open archive file %s: %s", AH->fSpec, strerror(errno));
+			die_horribly(AH, modulename, "could not open archive file %s: %s\n", AH->fSpec, strerror(errno));
 
 		ctx->hasSeek = (fseek(AH->FH, 0, SEEK_CUR) == 0);
 
diff --git a/src/bin/pg_dump/pg_backup_db.c b/src/bin/pg_dump/pg_backup_db.c
index d3962b6db2193396b840168ceef40e87cee1c1d7..51a05646cd1e097588da295e33df06dcdb0fe0ce 100644
--- a/src/bin/pg_dump/pg_backup_db.c
+++ b/src/bin/pg_dump/pg_backup_db.c
@@ -5,7 +5,7 @@
  *	Implements the basic DB functions used by the archiver.
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.20 2001/06/27 21:21:37 petere Exp $
+ *	  $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.21 2001/07/03 20:21:48 petere Exp $
  *
  * NOTES
  *
@@ -20,7 +20,6 @@
  *-------------------------------------------------------------------------
  */
 
-#include "pg_dump.h"
 #include "pg_backup.h"
 #include "pg_backup_archiver.h"
 #include "pg_backup_db.h"
@@ -38,7 +37,7 @@
 #include "strdup.h"
 #endif
 
-static const char *modulename = "archiver (db)";
+static const char *modulename = gettext_noop("archiver (db)");
 
 static void _check_database_version(ArchiveHandle *AH, bool ignoreVersion);
 static PGconn *_connectDB(ArchiveHandle *AH, const char *newdbname, char *newUser);
@@ -275,7 +274,7 @@ _connectDB(ArchiveHandle *AH, const char *reqdb, char *requser)
 	else
 		newuser = (char *) requser;
 
-	ahlog(AH, 1, "Connecting to %s as %s\n", newdb, newuser);
+	ahlog(AH, 1, "connecting to database %s as user %s\n", newdb, newuser);
 
 	if (AH->requirePassword)
 	{
@@ -347,7 +346,7 @@ ConnectDatabase(Archive *AHX,
 	bool		need_pass = false;
 
 	if (AH->connection)
-		die_horribly(AH, modulename, "already connected to database\n");
+		die_horribly(AH, modulename, "already connected to a database\n");
 
 	if (!dbname && !(dbname = getenv("PGDATABASE")))
 		die_horribly(AH, modulename, "no database name specified\n");
@@ -449,7 +448,7 @@ _executeSqlCommand(ArchiveHandle *AH, PGconn *conn, PQExpBuffer qry, char *desc)
 	/* fprintf(stderr, "Executing: '%s'\n\n", qry->data); */
 	res = PQexec(conn, qry->data);
 	if (!res)
-		die_horribly(AH, modulename, "%s: no result from backend\n", desc);
+		die_horribly(AH, modulename, "%s: no result from server\n", desc);
 
 	if (PQresultStatus(res) != PGRES_COMMAND_OK && PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
@@ -701,7 +700,7 @@ FixupBlobRefs(ArchiveHandle *AH, char *tablename)
 	if ((n = PQntuples(res)) == 0)
 	{
 		/* We're done */
-		ahlog(AH, 1, "No OID attributes in table %s\n", tablename);
+		ahlog(AH, 1, "no OID type columns in table %s\n", tablename);
 		PQclear(res);
 		return;
 	}
@@ -710,7 +709,7 @@ FixupBlobRefs(ArchiveHandle *AH, char *tablename)
 	{
 		attr = PQgetvalue(res, i, 0);
 
-		ahlog(AH, 1, " - %s.%s\n", tablename, attr);
+		ahlog(AH, 1, "fixing BLOB cross-references for %s.%s\n", tablename, attr);
 
 		resetPQExpBuffer(tblQry);
 
@@ -725,7 +724,7 @@ FixupBlobRefs(ArchiveHandle *AH, char *tablename)
 				  "(select * from %s x where x.oldOid = \"%s\".\"%s\");",
 						  BLOB_XREF_TABLE, tablename, attr);
 
-		ahlog(AH, 10, " - sql:\n%s\n", tblQry->data);
+		ahlog(AH, 10, "SQL: %s\n", tblQry->data);
 
 		uRes = PQexec(AH->blobConnection, tblQry->data);
 		if (!uRes)
@@ -757,7 +756,7 @@ CreateBlobXrefTable(ArchiveHandle *AH)
 	if (!AH->blobConnection)
 		AH->blobConnection = _connectDB(AH, NULL, NULL);
 
-	ahlog(AH, 1, "Creating table for BLOBS xrefs\n");
+	ahlog(AH, 1, "creating table for BLOB cross-references\n");
 
 	appendPQExpBuffer(qry, "Create Temporary Table %s(oldOid oid, newOid oid);", BLOB_XREF_TABLE);
 
diff --git a/src/bin/pg_dump/pg_backup_files.c b/src/bin/pg_dump/pg_backup_files.c
index 2bbf68cb650d750a77e60adfe5eab09ee00ea65c..47a224fb89fea3b7d845d5d1274244d12a94905b 100644
--- a/src/bin/pg_dump/pg_backup_files.c
+++ b/src/bin/pg_dump/pg_backup_files.c
@@ -20,7 +20,7 @@
  *
  *
  * IDENTIFICATION
- *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_files.c,v 1.11 2001/06/27 21:21:37 petere Exp $
+ *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_files.c,v 1.12 2001/07/03 20:21:48 petere Exp $
  *
  * Modifications - 28-Jun-2000 - pjw@rhyme.com.au
  *
@@ -74,7 +74,7 @@ typedef struct
 	char	   *filename;
 } lclTocEntry;
 
-static char *modulename = "file archiver";
+static char *modulename = gettext_noop("file archiver");
 static void _LoadBlobs(ArchiveHandle *AH, RestoreOptions *ropt);
 static void _getBlobTocEntry(ArchiveHandle *AH, int *oid, char *fname);
 
@@ -120,7 +120,7 @@ InitArchiveFmt_Files(ArchiveHandle *AH)
 	{
 
 		write_msg(modulename, "WARNING:\n"
-				  "  This format is for demonstration purposes, it is not intended for\n"
+				  "  This format is for demonstration purposes; it is not intended for\n"
 				  "  normal use. Files will be written in the current working directory.\n");
 
 		if (AH->fSpec && strcmp(AH->fSpec, "") != 0)
diff --git a/src/bin/pg_dump/pg_backup_tar.c b/src/bin/pg_dump/pg_backup_tar.c
index 97001c27f67309bd4059ed32c6a45636bac1ac82..f75dca1474b42794be3714c238601bcf27274a30 100644
--- a/src/bin/pg_dump/pg_backup_tar.c
+++ b/src/bin/pg_dump/pg_backup_tar.c
@@ -16,7 +16,7 @@
  *
  *
  * IDENTIFICATION
- *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_tar.c,v 1.16 2001/06/27 21:21:37 petere Exp $
+ *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_backup_tar.c,v 1.17 2001/07/03 20:21:48 petere Exp $
  *
  * Modifications - 28-Jun-2000 - pjw@rhyme.com.au
  *
@@ -101,7 +101,7 @@ typedef struct
 	char	   *filename;
 } lclTocEntry;
 
-static char *modulename = "tar archiver";
+static char *modulename = gettext_noop("tar archiver");
 
 static void _LoadBlobs(ArchiveHandle *AH, RestoreOptions *ropt);
 
@@ -698,7 +698,7 @@ _PrintTocData(ArchiveHandle *AH, TocEntry *te, RestoreOptions *ropt)
 static void
 _LoadBlobs(ArchiveHandle *AH, RestoreOptions *ropt)
 {
-	int			oid;
+	Oid			oid;
 	lclContext *ctx = (lclContext *) AH->formatData;
 	TAR_MEMBER *th;
 	int			cnt;
@@ -711,11 +711,11 @@ _LoadBlobs(ArchiveHandle *AH, RestoreOptions *ropt)
 	{
 		ctx->FH = th;
 
-		oid = atoi(&th->targetFile[5]);
+		oid = (Oid)strtoul(&th->targetFile[5], NULL, 10);
 
 		if (strncmp(th->targetFile, "blob_", 5) == 0 && oid != 0)
 		{
-			ahlog(AH, 1, " - Restoring BLOB oid %d\n", oid);
+			ahlog(AH, 1, "restoring BLOB oid %u\n", oid);
 
 			StartRestoreBlob(AH, oid);
 
@@ -1088,7 +1088,7 @@ _tarPositionTo(ArchiveHandle *AH, const char *filename)
 	/* Go to end of current file, if any */
 	if (ctx->tarFHpos != 0)
 	{
-		ahlog(AH, 4, "Moving from %d (%x) to next member at file position %d (%x)\n",
+		ahlog(AH, 4, "moving from position %d (%x) to next member at file position %d (%x)\n",
 			  ctx->tarFHpos, ctx->tarFHpos,
 			  ctx->tarNextMember, ctx->tarNextMember);
 
@@ -1096,7 +1096,7 @@ _tarPositionTo(ArchiveHandle *AH, const char *filename)
 			_tarReadRaw(AH, &c, 1, NULL, ctx->tarFH);
 	}
 
-	ahlog(AH, 4, "Now at file position %d (%x)\n", ctx->tarFHpos, ctx->tarFHpos);
+	ahlog(AH, 4, "now at file position %d (%x)\n", ctx->tarFHpos, ctx->tarFHpos);
 
 	/* We are at the start of the file. or at the next member */
 
@@ -1115,7 +1115,7 @@ _tarPositionTo(ArchiveHandle *AH, const char *filename)
 
 	while (filename != NULL && strcmp(th->targetFile, filename) != 0)
 	{
-		ahlog(AH, 4, "Skipping member %s\n", th->targetFile);
+		ahlog(AH, 4, "skipping tar member %s\n", th->targetFile);
 
 		id = atoi(th->targetFile);
 		if ((TocIDRequired(AH, id, AH->ropt) & 2) != 0)
@@ -1202,7 +1202,7 @@ _tarGetHeader(ArchiveHandle *AH, TAR_MEMBER *th)
 	sscanf(&h[124], "%12o", &len);
 	sscanf(&h[148], "%8o", &sum);
 
-	ahlog(AH, 3, "TOC Entry %s at %d (len=%d, chk=%d)\n", &name[0], hPos, len, sum);
+	ahlog(AH, 3, "TOC Entry %s at %d (length %d, checksum %d)\n", &name[0], hPos, len, sum);
 
 	if (chk != sum)
 		die_horribly(AH, modulename,
diff --git a/src/bin/pg_dump/pg_dump.c b/src/bin/pg_dump/pg_dump.c
index 6d5d75410a9172db21575a8b780e0332299474ff..a73bb7b5c8b5b3849af714985fe6b56d7bfc16b7 100644
--- a/src/bin/pg_dump/pg_dump.c
+++ b/src/bin/pg_dump/pg_dump.c
@@ -22,7 +22,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_dump.c,v 1.212 2001/06/27 21:21:37 petere Exp $
+ *	  $Header: /cvsroot/pgsql/src/bin/pg_dump/pg_dump.c,v 1.213 2001/07/03 20:21:49 petere Exp $
  *
  * Modifications - 6/10/96 - dave@bensoft.com - version 1.13.dhb
  *
@@ -314,10 +314,12 @@ help(const char *progname)
 }
 
 
-static void
-exit_nicely(PGconn *conn)
+void
+exit_nicely(void)
 {
-	PQfinish(conn);
+	PQfinish(g_conn);
+	if (g_verbose)
+		write_msg(NULL, "*** aborted because of error\n");
 	exit(1);
 }
 
@@ -344,7 +346,7 @@ dumpClasses_nodumpData(Archive *fout, char *oid, void *dctxv)
 	char		copybuf[COPYBUFSIZ];
 
 	if (g_verbose)
-		fprintf(stderr, "%s dumping out the contents of table %s\n", g_comment_start, classname);
+		write_msg(NULL, "dumping out the contents of table %s\n", classname);
 
 	if (oids == true)
 	{
@@ -381,7 +383,7 @@ dumpClasses_nodumpData(Archive *fout, char *oid, void *dctxv)
 				  classname);
 		write_msg(NULL, "Error message from server: %s", PQerrorMessage(g_conn));
 		write_msg(NULL, "The command was: %s\n", query);
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	else
 	{
@@ -392,7 +394,7 @@ dumpClasses_nodumpData(Archive *fout, char *oid, void *dctxv)
 			write_msg(NULL, "The server returned status %d when %d was expected.\n", 
 					  PQresultStatus(res), PGRES_COPY_OUT);
 			write_msg(NULL, "The command was: %s\n", query);
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 		else
 		{
@@ -478,7 +480,7 @@ dumpClasses_nodumpData(Archive *fout, char *oid, void *dctxv)
 			write_msg(NULL, "Error message from server: %s", PQerrorMessage(g_conn));
 			write_msg(NULL, "The command was: %s\n", query);
 			PQclear(res);
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 	}
 
@@ -510,7 +512,7 @@ dumpClasses_dumpData(Archive *fout, char *oid, void *dctxv)
 		write_msg(NULL, "dumpClasses(): SQL command failed\n");
 		write_msg(NULL, "Error message from server: %s", PQerrorMessage(g_conn));
 		write_msg(NULL, "The command was: %s\n", q->data);
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	for (tuple = 0; tuple < PQntuples(res); tuple++)
 	{
@@ -623,18 +625,12 @@ dumpClasses(const TableInfo *tblinfo, const int numTables, Archive *fout,
 {
 
 	int			i;
-	char	   *all_only;
 	DataDumperPtr dumpFn;
 	DumpContext *dumpCtx;
 	char	   *oidsPart;
 	char		copyBuf[512];
 	char	   *copyStmt;
 
-	if (onlytable == NULL || (strlen(onlytable) == 0))
-		all_only = "all";
-	else
-		all_only = "only";
-
 	if (oids == true)
 		oidsPart = "WITH OIDS ";
 	else
@@ -642,12 +638,12 @@ dumpClasses(const TableInfo *tblinfo, const int numTables, Archive *fout,
 
 
 	if (g_verbose)
-		fprintf(stderr, "%s preparing to dump out the contents of %s %d table%s/sequence%s %s\n",
-				g_comment_start, all_only,
-		 (onlytable == NULL || (strlen(onlytable) == 0)) ? numTables : 1,
-			  (onlytable == NULL || (strlen(onlytable) == 0)) ? "s" : "",
-			  (onlytable == NULL || (strlen(onlytable) == 0)) ? "s" : "",
-				g_comment_end);
+	{
+		if (onlytable == NULL || (strlen(onlytable) == 0))
+			write_msg(NULL, "preparing to dump the contents of all %d tables/sequences\n", numTables);
+		else
+			write_msg(NULL, "preparing to dump the contents of only one table/sequence\n");
+	}
 
 	for (i = 0; i < numTables; i++)
 	{
@@ -663,10 +659,11 @@ dumpClasses(const TableInfo *tblinfo, const int numTables, Archive *fout,
 		if (!onlytable || (strcmp(classname, onlytable) == 0) || (strlen(onlytable) == 0))
 		{
 			if (g_verbose)
-				fprintf(stderr, "%s preparing to dump out the contents of Table '%s' %s\n",
-						g_comment_start, classname, g_comment_end);
+				write_msg(NULL, "preparing to dump the contents of table %s\n", classname);
 
-			/* becomeUser(fout, tblinfo[i].usename); */
+#if 0
+			becomeUser(fout, tblinfo[i].usename);
+#endif
 
 			dumpCtx = (DumpContext *) malloc(sizeof(DumpContext));
 			dumpCtx->tblinfo = (TableInfo *) tblinfo;
@@ -921,7 +918,7 @@ main(int argc, char **argv)
 
 			case 'u':
 				force_password = true;
-				username = simple_prompt("Username: ", 100, true);
+				username = simple_prompt("User name: ", 100, true);
 				break;
 
 			case 'U':
@@ -981,7 +978,7 @@ main(int argc, char **argv)
 
 	if (dataOnly && schemaOnly)
 	{
-		write_msg(NULL, "'Schema only' and 'data only' are incompatible options.\n");
+		write_msg(NULL, "The options \"schema only\" (-s) and \"data only\" (-a) cannot be used together.\n");
 		exit(1);
 	}
 
@@ -1086,8 +1083,7 @@ main(int argc, char **argv)
 		setMaxOid(g_fout);
 
 	if (g_verbose)
-		fprintf(stderr, "%s last builtin oid is %u %s\n",
-				g_comment_start, g_last_builtin_oid, g_comment_end);
+		write_msg(NULL, "last built-in oid is %u\n", g_last_builtin_oid);
 	tblinfo = dumpSchema(g_fout, &numTables, tablename, aclsSkip, oids, schemaOnly, dataOnly);
 
 	if (!schemaOnly)
@@ -1163,7 +1159,7 @@ dumpDatabase(Archive *AH)
 	int			i_dba;
 
 	if (g_verbose)
-		fprintf(stderr, "%s saving database definition\n", g_comment_start);
+		write_msg(NULL, "saving database definition\n");
 
 	/* Get the dba */
 	appendPQExpBuffer(dbQry, "select (select usename from pg_user where datdba = usesysid) as dba from pg_database"
@@ -1177,7 +1173,7 @@ dumpDatabase(Archive *AH)
 		write_msg(NULL, "SQL command failed\n");
 		write_msg(NULL, "Error message from server: %s", PQerrorMessage(g_conn));
 		write_msg(NULL, "The command was: %s\n", dbQry->data);
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -1185,14 +1181,14 @@ dumpDatabase(Archive *AH)
 	if (ntups <= 0)
 	{
 		write_msg(NULL, "missing pg_database entry for database \"%s\"\n", PQdb(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	if (ntups != 1)
 	{
 		write_msg(NULL, "query returned more than one (%d) pg_database entry for database \"%s\"\n",
 				  ntups, PQdb(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	appendPQExpBuffer(creaQry, "Create Database \"%s\";\n", PQdb(g_conn));
@@ -1232,7 +1228,7 @@ dumpBlobs(Archive *AH, char *junkOid, void *junkVal)
 	int			blobOid;
 
 	if (g_verbose)
-		fprintf(stderr, "%s saving BLOBs\n", g_comment_start);
+		write_msg(NULL, "saving BLOBs\n");
 
 	/* Cursor to get all BLOB tables */
 	if (AH->remoteVersion >= 70100)
@@ -1246,7 +1242,7 @@ dumpBlobs(Archive *AH, char *junkOid, void *junkVal)
 	if (!res || PQresultStatus(res) != PGRES_COMMAND_OK)
 	{
 		write_msg(NULL, "dumpBlobs(): cursor declaration failed: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	/* Fetch for cursor */
@@ -1262,7 +1258,7 @@ dumpBlobs(Archive *AH, char *junkOid, void *junkVal)
 		{
 			write_msg(NULL, "dumpBlobs(): fetch from cursor failed: %s",
 					  PQerrorMessage(g_conn));
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 
 		/* Process the tuples, if any */
@@ -1275,7 +1271,7 @@ dumpBlobs(Archive *AH, char *junkOid, void *junkVal)
 			{
 				write_msg(NULL, "dumpBlobs(): could not open large object: %s",
 						  PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			StartBlob(AH, blobOid);
@@ -1288,7 +1284,7 @@ dumpBlobs(Archive *AH, char *junkOid, void *junkVal)
 				{
 					write_msg(NULL, "dumpBlobs(): error reading large object: %s",
 							  PQerrorMessage(g_conn));
-					exit_nicely(g_conn);
+					exit_nicely();
 				}
 
 				WriteData(AH, buf, cnt);
@@ -1372,7 +1368,7 @@ getTypes(int *numTypes)
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "query to obtain list of data types failed: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -1490,7 +1486,7 @@ getOperators(int *numOprs)
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "query to obtain list of operators failed: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -1853,9 +1849,9 @@ getAggregates(int *numAggs)
 	if (!res ||
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
-		write_msg(NULL, "query to obtain list of aggregate functions failed: %s\n",
+		write_msg(NULL, "query to obtain list of aggregate functions failed: %s",
 				  PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -1956,7 +1952,7 @@ getFuncs(int *numFuncs)
 	{
 		write_msg(NULL, "query to obtain list of functions failed: %s",
 				  PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -2004,7 +2000,7 @@ getFuncs(int *numFuncs)
 		{
 			write_msg(NULL, "failed sanity check: function %s has more than %d (namely %d) arguments\n",
 					  finfo[i].proname, FUNC_MAX_ARGS, finfo[i].nargs);
-			exit(1);
+			exit_nicely();
 		}
 		parseNumericArray(PQgetvalue(res, i, i_proargtypes),
 						  finfo[i].argtypes,
@@ -2099,7 +2095,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 	{
 		write_msg(NULL, "query to obtain list of tables failed: %s",
 				  PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -2150,7 +2146,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			{
 				write_msg(NULL, "query to obtain definition of view \"%s\" failed: %s",
 						  tblinfo[i].relname, PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			if (PQntuples(res2) != 1)
@@ -2161,14 +2157,14 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 				else
 					write_msg(NULL, "query to obtain definition of view \"%s\" returned more than one definition\n",
 							tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			if (PQgetisnull(res2, 0, 1))
 			{
 				write_msg(NULL, "query to obtain definition of view \"%s\" returned NULL oid\n",
 						  tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			tblinfo[i].viewdef = strdup(PQgetvalue(res2, 0, 0));
@@ -2178,7 +2174,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			{
 				write_msg(NULL, "definition of view \"%s\" appears to be empty (length zero)\n",
 						  tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 		}
 		else
@@ -2201,10 +2197,8 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			int			i2;
 
 			if (g_verbose)
-				fprintf(stderr, "%s finding CHECK constraints for relation: '%s' %s\n",
-						g_comment_start,
-						tblinfo[i].relname,
-						g_comment_end);
+				write_msg(NULL, "finding CHECK constraints for table %s\n",
+						  tblinfo[i].relname);
 
 			resetPQExpBuffer(query);
 			appendPQExpBuffer(query, "SELECT rcname, rcsrc from pg_relcheck "
@@ -2225,7 +2219,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 				PQresultStatus(res2) != PGRES_TUPLES_OK)
 			{
 				write_msg(NULL, "query to obtain check constraints failed: %s", PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 			ntups2 = PQntuples(res2);
 			if (ntups2 > tblinfo[i].ncheck)
@@ -2233,7 +2227,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 				write_msg(NULL, "expected %d check constraints on table \"%s\" but found %d\n",
 						  tblinfo[i].ncheck, tblinfo[i].relname, ntups2);
 				write_msg(NULL, "(The system catalogs might be corrupted.)\n");
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			/* Set ncheck to the number of *non-inherited* CHECK constraints */
@@ -2275,14 +2269,14 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			{
 				write_msg(NULL, "query to obtain primary key of table \"%s\" failed: %s",
 						  tblinfo[i].relname, PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			if (PQntuples(res2) > 1)
 			{
 				write_msg(NULL, "query to obtain primary key of table \"%s\" produced more than one result\n",
 						tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			if (PQntuples(res2) == 1)
@@ -2332,7 +2326,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			{
 				write_msg(NULL, "query to obtain name of primary key of table \"%s\" failed: %s",
 						  tblinfo[i].relname, PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			n = PQntuples(res2);
@@ -2340,7 +2334,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			{
 				write_msg(NULL, "query to obtain name of primary key of table \"%s\" did not return exactly one result\n",
 						  tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			/* Sanity check on LOJ */
@@ -2348,7 +2342,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			{
 				write_msg(NULL, "name of primary key of table \"%s\" returned NULL value\n",
 						  tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			tblinfo[i].primary_key_name =
@@ -2356,7 +2350,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			if (tblinfo[i].primary_key_name == NULL)
 			{
 				write_msg(NULL, "out of memory\n");
-				exit(1);
+				exit_nicely();
 			}
 		}
 		else
@@ -2382,10 +2376,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 			int			i2;
 
 			if (g_verbose)
-				fprintf(stderr, "%s finding Triggers for relation: '%s' %s\n",
-						g_comment_start,
-						tblinfo[i].relname,
-						g_comment_end);
+				write_msg(NULL, "finding triggers for table %s\n", tblinfo[i].relname);
 
 			resetPQExpBuffer(query);
 			appendPQExpBuffer(query,
@@ -2402,14 +2393,14 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 				PQresultStatus(res2) != PGRES_TUPLES_OK)
 			{
 				write_msg(NULL, "query to obtain list of triggers failed: %s", PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 			ntups2 = PQntuples(res2);
 			if (ntups2 != tblinfo[i].ntrig)
 			{
 				write_msg(NULL, "expected %d triggers on table \"%s\" but found %d\n",
 						  tblinfo[i].ntrig, tblinfo[i].relname, ntups2);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 			i_tgname = PQfnumber(res2, "tgname");
 			i_tgfoid = PQfnumber(res2, "tgfoid");
@@ -2489,7 +2480,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 					{
 						write_msg(NULL, "query to obtain procedure name for trigger \"%s\" failed: %s",
 								  tgname, PQerrorMessage(g_conn));
-						exit_nicely(g_conn);
+						exit_nicely();
 					}
 
 					/* Sanity: Check we got only one tuple */
@@ -2498,7 +2489,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 					{
 						write_msg(NULL, "query to obtain procedure name for trigger \"%s\" did not return exactly one result\n",
 								  tgname);
-						exit_nicely(g_conn);
+						exit_nicely();
 					}
 
 					tgfunc = strdup(PQgetvalue(r, 0, PQfnumber(r, "proname")));
@@ -2561,7 +2552,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 						{
 							write_msg(NULL, "query produced NULL referenced table name for trigger \"%s\" on table \"%s\" (oid was %s)\n",
 									  tgname, tblinfo[i].relname, tgconstrrelid);
-							exit_nicely(g_conn);
+							exit_nicely();
 						}
 
 						appendPQExpBuffer(query, " FROM %s",
@@ -2593,7 +2584,7 @@ getTables(int *numTables, FuncInfo *finfo, int numFuncs)
 									  PQgetvalue(res2, i2, i_tgargs),
 									  tgname,
 									  tblinfo[i].relname);
-							exit_nicely(g_conn);
+							exit_nicely();
 						}
 						p++;
 						if (*p == '\\')
@@ -2679,7 +2670,7 @@ getInherits(int *numInherits)
 	{
 		write_msg(NULL, "query to obtain inheritance relationships failed: %s",
 				  PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -2741,10 +2732,8 @@ getTableAttrs(TableInfo *tblinfo, int numTables)
 		 * later
 		 */
 		if (g_verbose)
-			fprintf(stderr, "%s finding the attrs and types for table: '%s' %s\n",
-					g_comment_start,
-					tblinfo[i].relname,
-					g_comment_end);
+			write_msg(NULL, "finding the columns and types for table %s\n",
+					  tblinfo[i].relname);
 
 		resetPQExpBuffer(q);
 
@@ -2781,7 +2770,7 @@ getTableAttrs(TableInfo *tblinfo, int numTables)
 			PQresultStatus(res) != PGRES_TUPLES_OK)
 		{
 			write_msg(NULL, "query to get table columns failed: %s", PQerrorMessage(g_conn));
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 
 		ntups = PQntuples(res);
@@ -2814,7 +2803,7 @@ getTableAttrs(TableInfo *tblinfo, int numTables)
 			{
 				write_msg(NULL, "query produced NULL name for data type of column %d of table %s\n",
 						  j+1, tblinfo[i].relname);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			tblinfo[i].attoids[j] = strdup(PQgetvalue(res, j, i_attoid));
@@ -2834,10 +2823,8 @@ getTableAttrs(TableInfo *tblinfo, int numTables)
 				int			numAttr;
 
 				if (g_verbose)
-					fprintf(stderr, "%s finding DEFAULT expression for attr: '%s' %s\n",
-							g_comment_start,
-							tblinfo[i].attnames[j],
-							g_comment_end);
+					write_msg(NULL, "finding DEFAULT expression for column %s\n",
+							  tblinfo[i].attnames[j]);
 
 				resetPQExpBuffer(q);
 				appendPQExpBuffer(q, "SELECT adsrc from pg_attrdef "
@@ -2849,7 +2836,7 @@ getTableAttrs(TableInfo *tblinfo, int numTables)
 				{
 					write_msg(NULL, "query to get column default value failed: %s",
 							  PQerrorMessage(g_conn));
-					exit_nicely(g_conn);
+					exit_nicely();
 				}
 
 				/* Sanity: Check we got only one tuple */
@@ -2858,7 +2845,7 @@ getTableAttrs(TableInfo *tblinfo, int numTables)
 				{
 					write_msg(NULL, "query to get default value for column \"%s\" returned %d rows; expected 1\n",
 							  tblinfo[i].attnames[j], numAttr);
-					exit_nicely(g_conn);
+					exit_nicely();
 				}
 
 				tblinfo[i].adef_expr[j] = strdup(PQgetvalue(res2, 0, PQfnumber(res2, "adsrc")));
@@ -2930,7 +2917,7 @@ getIndexes(int *numIndexes)
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "query to obtain list of indexes failed: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	ntups = PQntuples(res);
@@ -3011,7 +2998,7 @@ dumpComment(Archive *fout, const char *target, const char *oid)
 	{
 		write_msg(NULL, "query to get comment on oid %s failed: %s",
 				   oid, PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	/*** If a comment exists, build COMMENT ON statement ***/
@@ -3066,7 +3053,7 @@ dumpDBComment(Archive *fout)
 	{
 		write_msg(NULL, "query to get database oid failed: %s",
 				   PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	/*** If a comment exists, build COMMENT ON statement ***/
@@ -3164,7 +3151,7 @@ dumpTypes(Archive *fout, FuncInfo *finfo, int numFuncs,
 			elemType = findTypeByOid(tinfo, numTypes, tinfo[i].typelem, zeroAsOpaque);
 			if (elemType == NULL)
 			{
-				write_msg(NULL, "Notice: array type %s - type for elements (oid %s) is not dumped.\n",
+				write_msg(NULL, "notice: array type %s - type for elements (oid %s) is not dumped\n",
 						  tinfo[i].typname, tinfo[i].typelem);
 				resetPQExpBuffer(q);
 				resetPQExpBuffer(delq);
@@ -3233,7 +3220,7 @@ dumpProcLangs(Archive *fout, FuncInfo *finfo, int numFuncs,
 	{
 		write_msg(NULL, "query to obtain list of procedural languages failed: %s",
 				   PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	ntups = PQntuples(res);
 
@@ -3261,7 +3248,7 @@ dumpProcLangs(Archive *fout, FuncInfo *finfo, int numFuncs,
 		{
 			write_msg(NULL, "handler procedure for procedural language %s not found\n",
 					   PQgetvalue(res, i, i_lanname));
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 
 		dumpOneFunc(fout, finfo, fidx, tinfo, numTypes);
@@ -3350,14 +3337,14 @@ dumpOneFunc(Archive *fout, FuncInfo *finfo, int i,
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "query to get name of procedural language failed: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	nlangs = PQntuples(res);
 
 	if (nlangs != 1)
 	{
 		write_msg(NULL, "procedural language for function %s not found\n", finfo[i].proname);
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	i_lanname = PQfnumber(res, "lanname");
@@ -3398,10 +3385,10 @@ dumpOneFunc(Archive *fout, FuncInfo *finfo, int i,
 		typname = findTypeByOid(tinfo, numTypes, finfo[i].argtypes[j], zeroAsOpaque);
 		if (typname == NULL)
 		{
-			write_msg(NULL, "Notice: function \"%s\" not dumped\n",
-					   finfo[i].proname);
+			write_msg(NULL, "WARNING: function \"%s\" not dumped\n",
+					  finfo[i].proname);
 
-			write_msg(NULL, "Reason: data type name of argument %d (oid %s) not found\n",
+			write_msg(NULL, "reason: data type name of argument %d (oid %s) not found\n",
 					   j, finfo[i].argtypes[j]);
 			resetPQExpBuffer(q);
 			resetPQExpBuffer(fn);
@@ -3427,11 +3414,11 @@ dumpOneFunc(Archive *fout, FuncInfo *finfo, int i,
 
 	if (rettypename == NULL)
 	{
-		write_msg(NULL, "Notice: function \"%s\" not dumped\n",
-				   finfo[i].proname);
+		write_msg(NULL, "WARNING: function \"%s\" not dumped\n",
+				  finfo[i].proname);
 
-		write_msg(NULL, "Reason: name of return data type (oid %s) not found\n",
-				   finfo[i].prorettype);
+		write_msg(NULL, "reason: name of return data type (oid %s) not found\n",
+				  finfo[i].prorettype);
 		resetPQExpBuffer(q);
 		resetPQExpBuffer(fn);
 		resetPQExpBuffer(delqry);
@@ -3491,12 +3478,6 @@ void
 dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 		 TypeInfo *tinfo, int numTypes)
 {
-#define OPR_NOTICE(arg) {\
-		fprintf(stderr, "Notice: operator \"%s\"(oid %s) is not dumped.\n",oprinfo[i].oprname, oprinfo[i].oid);\
-	fprintf(stderr, "Reason: " CppAsString(arg));\
-	fprintf (stderr, " (oid %s) not found.\n",oprinfo[i].arg);\
-	}
-
 	int			i;
 	PQExpBuffer q = createPQExpBuffer();
 	PQExpBuffer delq = createPQExpBuffer();
@@ -3544,7 +3525,10 @@ dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 								 oprinfo[i].oprleft, zeroAsOpaque);
 			if (name == NULL)
 			{
-				OPR_NOTICE(oprleft);
+				write_msg(NULL, "WARNING: operator \"%s\" (oid %s) not dumped\n",
+						  oprinfo[i].oprname, oprinfo[i].oid);
+				write_msg(NULL, "reason: oprleft (oid %s) not found\n",
+						  oprinfo[i].oprleft);
 				continue;
 			}
 			appendPQExpBuffer(leftarg, ",\n\tLEFTARG = %s ", name);
@@ -3557,7 +3541,10 @@ dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 								 oprinfo[i].oprright, zeroAsOpaque);
 			if (name == NULL)
 			{
-				OPR_NOTICE(oprright);
+				write_msg(NULL, "WARNING: operator \"%s\" (oid %s) not dumped\n",
+						  oprinfo[i].oprname, oprinfo[i].oid);
+				write_msg(NULL, "reason: oprright (oid %s) not found\n",
+						  oprinfo[i].oprright);
 				continue;
 			}
 			appendPQExpBuffer(rightarg, ",\n\tRIGHTARG = %s ", name);
@@ -3568,7 +3555,10 @@ dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 			name = findOprByOid(oprinfo, numOperators, oprinfo[i].oprcom);
 			if (name == NULL)
 			{
-				OPR_NOTICE(oprcom);
+				write_msg(NULL, "WARNING: operator \"%s\" (oid %s) not dumped\n",
+						  oprinfo[i].oprname, oprinfo[i].oid);
+				write_msg(NULL, "reason: oprcom (oid %s) not found\n",
+						  oprinfo[i].oprcom);
 				continue;
 			}
 			appendPQExpBuffer(commutator, ",\n\tCOMMUTATOR = %s ", name);
@@ -3579,7 +3569,10 @@ dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 			name = findOprByOid(oprinfo, numOperators, oprinfo[i].oprnegate);
 			if (name == NULL)
 			{
-				OPR_NOTICE(oprnegate);
+				write_msg(NULL, "WARNING: operator \"%s\" (oid %s) not dumped\n",
+						  oprinfo[i].oprname, oprinfo[i].oid);
+				write_msg(NULL, "reason: oprnegate (oid %s) not found\n",
+						  oprinfo[i].oprnegate);
 				continue;
 			}
 			appendPQExpBuffer(negator, ",\n\tNEGATOR = %s ", name);
@@ -3596,7 +3589,10 @@ dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 			name = findOprByOid(oprinfo, numOperators, oprinfo[i].oprlsortop);
 			if (name == NULL)
 			{
-				OPR_NOTICE(oprlsortop);
+				write_msg(NULL, "WARNING: operator \"%s\" (oid %s) not dumped\n",
+						  oprinfo[i].oprname, oprinfo[i].oid);
+				write_msg(NULL, "reason: oprlsortop (oid %s) not found\n",
+						  oprinfo[i].oprlsortop);
 				continue;
 			}
 			appendPQExpBuffer(sort1, ",\n\tSORT1 = %s ", name);
@@ -3607,7 +3603,10 @@ dumpOprs(Archive *fout, OprInfo *oprinfo, int numOperators,
 			name = findOprByOid(oprinfo, numOperators, oprinfo[i].oprrsortop);
 			if (name == NULL)
 			{
-				OPR_NOTICE(oprrsortop);
+				write_msg(NULL, "WARNING: operator \"%s\" (oid %s) not dumped\n",
+						  oprinfo[i].oprname, oprinfo[i].oid);
+				write_msg(NULL, "reason: oprrsortop (oid %s) not found\n",
+						  oprinfo[i].oprrsortop);
 				continue;
 			}
 			appendPQExpBuffer(sort2, ",\n\tSORT2 = %s ", name);
@@ -3649,16 +3648,6 @@ void
 dumpAggs(Archive *fout, AggInfo *agginfo, int numAggs,
 		 TypeInfo *tinfo, int numTypes)
 {
-#define AGG_NOTICE(arg) {\
-		resetPQExpBuffer(q);\
-		appendPQExpBuffer(q, "-- Notice: aggregate \"%s\"(oid %s) is not dumped.\n",agginfo[i].aggname, agginfo[i].oid);\
-		appendPQExpBuffer(q, "-- Reason: " CppAsString(arg) );\
-		appendPQExpBuffer(q, " (oid %s) not found.\n",agginfo[i].arg);\
-		fprintf(stderr, q->data);\
-		ArchiveEntry(fout, agginfo[i].oid, aggSig->data, "WARNING", NULL,\
-					q->data, "" /* Del */, "", agginfo[i].usename, NULL, NULL);\
-	}
-
 	int			i;
 	PQExpBuffer q = createPQExpBuffer();
 	PQExpBuffer delq = createPQExpBuffer();
@@ -3681,11 +3670,12 @@ dumpAggs(Archive *fout, AggInfo *agginfo, int numAggs,
 
 		if (!agginfo[i].convertok)
 		{
+			write_msg(NULL, "WARNING: aggregate function %s could not be dumped correctly for this database version; ignored\n",
+					  aggSig->data);
+
 			resetPQExpBuffer(q);
-			appendPQExpBuffer(q, "-- WARNING: Aggregate %s could not be dumped correctly for this database version - ignored\n",
+			appendPQExpBuffer(q, "-- WARNING: aggregate function %s could not be dumped correctly for this database version; ignored\n",
 									aggSig->data);
-			fprintf(stderr, q->data);
-
 			ArchiveEntry(fout, agginfo[i].oid, aggSig->data, "WARNING", NULL,
 					q->data, "" /* Del */, "", agginfo[i].usename, NULL, NULL);
 			continue;
@@ -3694,7 +3684,16 @@ dumpAggs(Archive *fout, AggInfo *agginfo, int numAggs,
 		name = findTypeByOid(tinfo, numTypes, agginfo[i].aggbasetype, zeroAsAny + useBaseTypeName);
 		if (name == NULL)
 		{
-			AGG_NOTICE(aggbasetype);
+			write_msg(NULL, "WARNING: aggregate function \"%s\" (oid %s) not dumped\n",
+					  agginfo[i].aggname, agginfo[i].oid);
+			write_msg(NULL, "reason: aggbasetype (oid %s) not found\n",
+					  agginfo[i].aggbasetype);
+
+			resetPQExpBuffer(q);
+			appendPQExpBuffer(q, "-- WARNING: aggregate function \"%s\" (oid %s) not dumped\n", agginfo[i].aggname, agginfo[i].oid);
+			appendPQExpBuffer(q, "-- reason: aggbasetype (oid %s) not found\n", agginfo[i].aggbasetype);
+			ArchiveEntry(fout, agginfo[i].oid, aggSig->data, "WARNING", NULL,
+						 q->data, "" /* Del */, "", agginfo[i].usename, NULL, NULL);
 			continue;
 		}
 		appendPQExpBuffer(details, "BASETYPE = %s, ", name);
@@ -3702,7 +3701,16 @@ dumpAggs(Archive *fout, AggInfo *agginfo, int numAggs,
 		name = findTypeByOid(tinfo, numTypes, agginfo[i].aggtranstype, zeroAsOpaque + useBaseTypeName);
 		if (name == NULL)
 		{
-			AGG_NOTICE(aggtranstype);
+			write_msg(NULL, "WARNING: aggregate function \"%s\" (oid %s) not dumped\n",
+					  agginfo[i].aggname, agginfo[i].oid);
+			write_msg(NULL, "reason: aggtranstype (oid %s) not found\n",
+					  agginfo[i].aggtranstype);
+
+			resetPQExpBuffer(q);
+			appendPQExpBuffer(q, "-- WARNING: aggregate function \"%s\" (oid %s) not dumped\n", agginfo[i].aggname, agginfo[i].oid);
+			appendPQExpBuffer(q, "-- reason: aggtranstype (oid %s) not found\n", agginfo[i].aggtranstype);
+			ArchiveEntry(fout, agginfo[i].oid, aggSig->data, "WARNING", NULL,
+						 q->data, "" /* Del */, "", agginfo[i].usename, NULL, NULL);
 			continue;
 		}
 		appendPQExpBuffer(details,
@@ -3859,9 +3867,9 @@ dumpACL(Archive *fout, TableInfo tbinfo)
 		eqpos = strchr(tok, '=');
 		if (!eqpos)
 		{
-			fprintf(stderr, "Could not parse ACL list ('%s') for '%s'...Exiting!\n",
-					acls, tbinfo.relname);
-			exit_nicely(g_conn);
+			write_msg(NULL, "could not parse ACL list ('%s') for relation %s\n",
+					  acls, tbinfo.relname);
+			exit_nicely();
 		}
 
 		/*
@@ -4102,7 +4110,7 @@ dumpTables(Archive *fout, TableInfo *tblinfo, int numTables,
 					{
 						write_msg(NULL, "dumpTables(): failed sanity check, could not find index (%s) for primary key constraint\n",
 								   tblinfo[i].pkIndexOid);
-						exit_nicely(g_conn);
+						exit_nicely();
 					}
 
 					consDef = getPKconstraint(&tblinfo[i], &indinfo[k]);
@@ -4226,7 +4234,7 @@ getAttrName(int attrnum, TableInfo *tblInfo)
 	}
 	write_msg(NULL, "getAttrName(): invalid column number %d for table %s\n",
 			   attrnum, tblInfo->relname);
-	exit_nicely(g_conn);
+	exit_nicely();
 	return NULL;				/* keep compiler quiet */
 }
 
@@ -4262,29 +4270,29 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 		{
 			write_msg(NULL, "dumpIndexes(): failed sanity check, table %s was not found\n",
 					   indinfo[i].indrelname);
-			exit(1);
+			exit_nicely();
 		}
 
 		/* Handle PK indexes */
 		if (strcmp(indinfo[i].indisprimary, "t") == 0)
 		{
-/*
- *			***PK: Enable this code when ALTER TABLE supports PK constraints. ***
- *
- *			PQExpBuffer consDef = getPKconstraint(&tblinfo[tableInd], &indinfo[i]);
- *
- *			resetPQExpBuffer(attlist);
- *
- *			appendPQExpBuffer(attlist, "Alter Table %s Add %s;",
- *								fmtId(tblinfo[tableInd].relname, force_quotes),
- *								consDef->data);
- *
- *			ArchiveEntry(fout, indinfo[i].oid, tblinfo[tableInd].primary_key_name, "CONSTRAINT", NULL,
- *							attlist->data, "",
- *							"", tblinfo[tableInd].usename, NULL, NULL);
- *
- *			destroyPQExpBuffer(consDef);
- */
+#if 0
+			/* PK: Enable this code when ALTER TABLE supports PK constraints. */
+
+			PQExpBuffer consDef = getPKconstraint(&tblinfo[tableInd], &indinfo[i]);
+
+			resetPQExpBuffer(attlist);
+
+			appendPQExpBuffer(attlist, "Alter Table %s Add %s;",
+							  fmtId(tblinfo[tableInd].relname, force_quotes),
+							  consDef->data);
+
+			ArchiveEntry(fout, indinfo[i].oid, tblinfo[tableInd].primary_key_name,
+						 "CONSTRAINT", NULL, attlist->data, "",
+						 "", tblinfo[tableInd].usename, NULL, NULL);
+
+			destroyPQExpBuffer(consDef);
+#endif
 
 			/*
 			 * Don't need to do anything else for this system-generated
@@ -4316,7 +4324,7 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 			{
 				write_msg(NULL, "query to get function name of oid %s failed: %s",
 						  indinfo[i].indproc, PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			/* Sanity: Check we got only one tuple */
@@ -4325,7 +4333,7 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 			{
 				write_msg(NULL, "query to get function name of oid %s returned %d rows; expected 1\n",
 						  indinfo[i].indproc, numFuncs);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			funcname = strdup(PQgetvalue(res, 0, PQfnumber(res, "proname")));
@@ -4350,7 +4358,7 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 			{
 				write_msg(NULL, "query to get operator class name of oid %u failed: %s",
 						  indclass, PQerrorMessage(g_conn));
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			/* Sanity: Check we got only one tuple */
@@ -4359,7 +4367,7 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 			{
 				write_msg(NULL, "query to get operator class name of oid %u returned %d rows; expected 1\n",
 						  indclass, numRows);
-				exit_nicely(g_conn);
+				exit_nicely();
 			}
 
 			classname[nclass] = strdup(PQgetvalue(res, 0, PQfnumber(res, "opcname")));
@@ -4370,7 +4378,7 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 		{
 			write_msg(NULL, "There must be exactly one OpClass for functional index \"%s\".\n",
 					  indinfo[i].indexrelname);
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 
 		/* convert attribute numbers into attribute list */
@@ -4394,7 +4402,7 @@ dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 				{
 					write_msg(NULL, "no operator class found for column \"%s\" of index \"%s\"\n",
 							attname, indinfo[i].indexrelname);
-					exit_nicely(g_conn);
+					exit_nicely();
 				}
 				resetPQExpBuffer(id1);
 				resetPQExpBuffer(id2);
@@ -4535,7 +4543,7 @@ setMaxOid(Archive *fout)
 		PQresultStatus(res) != PGRES_COMMAND_OK)
 	{
 		write_msg(NULL, "could not create pgdump_oid table: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	PQclear(res);
 	res = PQexec(g_conn, "INSERT INTO pgdump_oid VALUES (0)");
@@ -4543,13 +4551,13 @@ setMaxOid(Archive *fout)
 		PQresultStatus(res) != PGRES_COMMAND_OK)
 	{
 		write_msg(NULL, "could not insert into pgdump_oid table: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	max_oid = atol(PQoidStatus(res));
 	if (max_oid == 0)
 	{
 		write_msg(NULL, "inserted invalid oid\n");
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	PQclear(res);
 	res = PQexec(g_conn, "DROP TABLE pgdump_oid;");
@@ -4557,12 +4565,11 @@ setMaxOid(Archive *fout)
 		PQresultStatus(res) != PGRES_COMMAND_OK)
 	{
 		write_msg(NULL, "could not drop pgdump_oid table: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	PQclear(res);
 	if (g_verbose)
-		fprintf(stderr, "%s maximum system oid is %u %s\n",
-				g_comment_start, max_oid, g_comment_end);
+		write_msg(NULL, "maximum system oid is %u\n", max_oid);
 	snprintf(sql, 1024,
 			 "CREATE TEMPORARY TABLE pgdump_oid (dummy int4);\n"
 			 "COPY pgdump_oid WITH OIDS FROM stdin;\n"
@@ -4597,18 +4604,18 @@ findLastBuiltinOid_V71(const char *dbname)
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "error in finding the last system oid: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	ntups = PQntuples(res);
 	if (ntups < 1)
 	{
 		write_msg(NULL, "missing pg_database entry for this database\n");
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	if (ntups > 1)
 	{
 		write_msg(NULL, "found more than one pg_database entry for this database\n");
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	last_oid = atooid(PQgetvalue(res, 0, PQfnumber(res, "datlastsysoid")));
 	PQclear(res);
@@ -4635,18 +4642,18 @@ findLastBuiltinOid_V70(void)
 		PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "error in finding the template1 database: %s", PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	ntups = PQntuples(res);
 	if (ntups < 1)
 	{
 		write_msg(NULL, "could not find template1 database entry in the pg_database table\n");
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	if (ntups > 1)
 	{
 		write_msg(NULL, "found more than one template1 database entry in the pg_database table\n");
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 	last_oid = atooid(PQgetvalue(res, 0, PQfnumber(res, "oid")));
 	PQclear(res);
@@ -4677,21 +4684,21 @@ dumpSequence(Archive *fout, TableInfo tbinfo, const bool schemaOnly, const bool
 	if (!res || PQresultStatus(res) != PGRES_TUPLES_OK)
 	{
 		write_msg(NULL, "query to get data of sequence \"%s\" failed: %s", tbinfo.relname, PQerrorMessage(g_conn));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	if (PQntuples(res) != 1)
 	{
 		write_msg(NULL, "query to get data of sequence \"%s\" returned %d rows (expected 1)\n",
 				   tbinfo.relname, PQntuples(res));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 	if (strcmp(PQgetvalue(res, 0, 0), tbinfo.relname) != 0)
 	{
 		write_msg(NULL, "query to get data of sequence \"%s\" returned name \"%s\"\n",
 				   tbinfo.relname, PQgetvalue(res, 0, 0));
-		exit_nicely(g_conn);
+		exit_nicely();
 	}
 
 
@@ -4764,8 +4771,7 @@ dumpTriggers(Archive *fout, const char *tablename,
 				j;
 
 	if (g_verbose)
-		fprintf(stderr, "%s dumping out triggers %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "dumping out triggers\n");
 
 	for (i = 0; i < numTables; i++)
 	{
@@ -4799,8 +4805,7 @@ dumpRules(Archive *fout, const char *tablename,
 	int			i_rulename;
 
 	if (g_verbose)
-		fprintf(stderr, "%s dumping out rules %s\n",
-				g_comment_start, g_comment_end);
+		write_msg(NULL, "dumping out rules\n");
 
 	/*
 	 * For each table we dump
@@ -4834,7 +4839,7 @@ dumpRules(Archive *fout, const char *tablename,
 		{
 			write_msg(NULL, "query to get rules associated with table \"%s\" failed: %s",
 					   tblinfo[t].relname, PQerrorMessage(g_conn));
-			exit_nicely(g_conn);
+			exit_nicely();
 		}
 
 		nrules = PQntuples(res);
diff --git a/src/bin/pg_dump/pg_dump.h b/src/bin/pg_dump/pg_dump.h
index 749408338508d43e83e1410a3e4e78216295902e..a1a3bebd3955f08010640fe8411e587b00c76410 100644
--- a/src/bin/pg_dump/pg_dump.h
+++ b/src/bin/pg_dump/pg_dump.h
@@ -6,7 +6,7 @@
  * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
  *
- * $Id: pg_dump.h,v 1.64 2001/06/27 21:21:37 petere Exp $
+ * $Id: pg_dump.h,v 1.65 2001/07/03 20:21:50 petere Exp $
  *
  * Modifications - 6/12/96 - dave@bensoft.com - version 1.13.dhb.2
  *
@@ -275,5 +275,6 @@ extern void dumpTables(Archive *fout, TableInfo *tbinfo, int numTables,
 extern void dumpIndexes(Archive *fout, IndInfo *indinfo, int numIndexes,
 			TableInfo *tbinfo, int numTables, const char *tablename);
 extern const char *fmtId(const char *identifier, bool force_quotes);
+extern void exit_nicely(void);
 
 #endif	 /* PG_DUMP_H */
diff --git a/src/bin/pg_dump/pg_restore.c b/src/bin/pg_dump/pg_restore.c
index a058f069f2a3055ff6bf1785377380d3fe638657..50eac5c30421960ea82ad3ce36ad356353dde9c1 100644
--- a/src/bin/pg_dump/pg_restore.c
+++ b/src/bin/pg_dump/pg_restore.c
@@ -34,7 +34,7 @@
  *
  *
  * IDENTIFICATION
- *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_restore.c,v 1.21 2001/06/27 21:21:37 petere Exp $
+ *		$Header: /cvsroot/pgsql/src/bin/pg_dump/pg_restore.c,v 1.22 2001/07/03 20:21:50 petere Exp $
  *
  * Modifications - 28-Jun-2000 - pjw@rhyme.com.au
  *
@@ -248,7 +248,7 @@ main(int argc, char **argv)
 
 			case 'u':
 				opts->requirePassword = true;
-				opts->username = simple_prompt("Username: ", 100, true);
+				opts->username = simple_prompt("User name: ", 100, true);
 				break;
 
 			case 'U':
diff --git a/src/include/c.h b/src/include/c.h
index 51727b42db2535269bf24f451777091c732e43d1..2b6a9e0d7f09a372528281ad0024179308f017aa 100644
--- a/src/include/c.h
+++ b/src/include/c.h
@@ -12,7 +12,7 @@
  * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
  *
- * $Id: c.h,v 1.95 2001/06/03 14:53:56 petere Exp $
+ * $Id: c.h,v 1.96 2001/07/03 20:21:50 petere Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -73,6 +73,8 @@
 #else
 #define gettext(x) (x)
 #endif
+#define gettext_noop(x) (x)
+
 
 /* ----------------------------------------------------------------
  *				Section 1: hacks to cope with non-ANSI C compilers