diff options
| author | Bruce Momjian | 2004-05-26 18:24:22 +0000 |
|---|---|---|
| committer | Bruce Momjian | 2004-05-26 18:24:22 +0000 |
| commit | 0d5364fd9835302e05be85e3e49c98326013a0f7 (patch) | |
| tree | bd95efb469efb8a683d3f4ede705d604fdf21490 | |
| parent | 480761925103dfdccd74dafa1db5f6875d8ad7cd (diff) | |
Fix problem with doing 7.0.X dumps on character varying[] fields.
Christopher Kings-Lynne
| -rw-r--r-- | src/bin/pg_dump/pg_dump.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/bin/pg_dump/pg_dump.c b/src/bin/pg_dump/pg_dump.c index c178baa4726..b95aba5e2f7 100644 --- a/src/bin/pg_dump/pg_dump.c +++ b/src/bin/pg_dump/pg_dump.c @@ -12,7 +12,7 @@ * by PostgreSQL * * IDENTIFICATION - * $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.371 2004/05/25 01:00:24 momjian Exp $ + * $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.372 2004/05/26 18:24:22 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -7722,8 +7722,16 @@ static char * myFormatType(const char *typname, int32 typmod) { char *result; + bool isarray = false; PQExpBuffer buf = createPQExpBuffer(); + /* Handle array types */ + if (typname[0] == '_') + { + isarray = true; + typname++; + } + /* Show lengths on bpchar and varchar */ if (!strcmp(typname, "bpchar")) { @@ -7767,6 +7775,10 @@ myFormatType(const char *typname, int32 typmod) else appendPQExpBuffer(buf, "%s", fmtId(typname)); + /* Append array qualifier for array types */ + if (isarray) + appendPQExpBuffer(buf, "[]"); + result = strdup(buf->data); destroyPQExpBuffer(buf); |
