Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
74096ed1
Commit
74096ed1
authored
Feb 19, 2007
by
Magnus Hagander
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix pg_dump on win32 to properly dump files larger than 2Gb when using
binary dump formats.
parent
bc959b7b
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
59 additions
and
41 deletions
+59
-41
src/bin/pg_dump/pg_backup_archiver.c
src/bin/pg_dump/pg_backup_archiver.c
+14
-14
src/bin/pg_dump/pg_backup_archiver.h
src/bin/pg_dump/pg_backup_archiver.h
+4
-4
src/bin/pg_dump/pg_backup_custom.c
src/bin/pg_dump/pg_backup_custom.c
+9
-9
src/bin/pg_dump/pg_backup_files.c
src/bin/pg_dump/pg_backup_files.c
+2
-2
src/bin/pg_dump/pg_backup_tar.c
src/bin/pg_dump/pg_backup_tar.c
+11
-11
src/bin/pg_dump/pg_dump.h
src/bin/pg_dump/pg_dump.h
+19
-1
No files found.
src/bin/pg_dump/pg_backup_archiver.c
View file @
74096ed1
...
@@ -15,7 +15,7 @@
...
@@ -15,7 +15,7 @@
*
*
*
*
* IDENTIFICATION
* IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.14
1 2007/02/01 19:10:28 momjian
Exp $
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_archiver.c,v 1.14
2 2007/02/19 15:05:06 mha
Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -1311,24 +1311,24 @@ TocIDRequired(ArchiveHandle *AH, DumpId id, RestoreOptions *ropt)
...
@@ -1311,24 +1311,24 @@ TocIDRequired(ArchiveHandle *AH, DumpId id, RestoreOptions *ropt)
}
}
size_t
size_t
WriteOffset
(
ArchiveHandle
*
AH
,
off_t
o
,
int
wasSet
)
WriteOffset
(
ArchiveHandle
*
AH
,
pg
off_t
o
,
int
wasSet
)
{
{
int
off
;
int
off
;
/* Save the flag */
/* Save the flag */
(
*
AH
->
WriteBytePtr
)
(
AH
,
wasSet
);
(
*
AH
->
WriteBytePtr
)
(
AH
,
wasSet
);
/* Write out off_t smallest byte first, prevents endian mismatch */
/* Write out
pg
off_t smallest byte first, prevents endian mismatch */
for
(
off
=
0
;
off
<
sizeof
(
off_t
);
off
++
)
for
(
off
=
0
;
off
<
sizeof
(
pg
off_t
);
off
++
)
{
{
(
*
AH
->
WriteBytePtr
)
(
AH
,
o
&
0xFF
);
(
*
AH
->
WriteBytePtr
)
(
AH
,
o
&
0xFF
);
o
>>=
8
;
o
>>=
8
;
}
}
return
sizeof
(
off_t
)
+
1
;
return
sizeof
(
pg
off_t
)
+
1
;
}
}
int
int
ReadOffset
(
ArchiveHandle
*
AH
,
off_t
*
o
)
ReadOffset
(
ArchiveHandle
*
AH
,
pg
off_t
*
o
)
{
{
int
i
;
int
i
;
int
off
;
int
off
;
...
@@ -1348,8 +1348,8 @@ ReadOffset(ArchiveHandle *AH, off_t *o)
...
@@ -1348,8 +1348,8 @@ ReadOffset(ArchiveHandle *AH, off_t *o)
else
if
(
i
==
0
)
else
if
(
i
==
0
)
return
K_OFFSET_NO_DATA
;
return
K_OFFSET_NO_DATA
;
/* Cast to off_t because it was written as an int. */
/* Cast to
pg
off_t because it was written as an int. */
*
o
=
(
off_t
)
i
;
*
o
=
(
pg
off_t
)
i
;
return
K_OFFSET_POS_SET
;
return
K_OFFSET_POS_SET
;
}
}
...
@@ -1379,8 +1379,8 @@ ReadOffset(ArchiveHandle *AH, off_t *o)
...
@@ -1379,8 +1379,8 @@ ReadOffset(ArchiveHandle *AH, off_t *o)
*/
*/
for
(
off
=
0
;
off
<
AH
->
offSize
;
off
++
)
for
(
off
=
0
;
off
<
AH
->
offSize
;
off
++
)
{
{
if
(
off
<
sizeof
(
off_t
))
if
(
off
<
sizeof
(
pg
off_t
))
*
o
|=
((
off_t
)
((
*
AH
->
ReadBytePtr
)
(
AH
)))
<<
(
off
*
8
);
*
o
|=
((
pg
off_t
)
((
*
AH
->
ReadBytePtr
)
(
AH
)))
<<
(
off
*
8
);
else
else
{
{
if
((
*
AH
->
ReadBytePtr
)
(
AH
)
!=
0
)
if
((
*
AH
->
ReadBytePtr
)
(
AH
)
!=
0
)
...
@@ -1647,7 +1647,7 @@ _allocAH(const char *FileSpec, const ArchiveFormat fmt,
...
@@ -1647,7 +1647,7 @@ _allocAH(const char *FileSpec, const ArchiveFormat fmt,
AH
->
createDate
=
time
(
NULL
);
AH
->
createDate
=
time
(
NULL
);
AH
->
intSize
=
sizeof
(
int
);
AH
->
intSize
=
sizeof
(
int
);
AH
->
offSize
=
sizeof
(
off_t
);
AH
->
offSize
=
sizeof
(
pg
off_t
);
if
(
FileSpec
)
if
(
FileSpec
)
{
{
AH
->
fSpec
=
strdup
(
FileSpec
);
AH
->
fSpec
=
strdup
(
FileSpec
);
...
@@ -2768,11 +2768,11 @@ checkSeek(FILE *fp)
...
@@ -2768,11 +2768,11 @@ checkSeek(FILE *fp)
if
(
fseeko
(
fp
,
0
,
SEEK_CUR
)
!=
0
)
if
(
fseeko
(
fp
,
0
,
SEEK_CUR
)
!=
0
)
return
false
;
return
false
;
else
if
(
sizeof
(
off_t
)
>
sizeof
(
long
))
else
if
(
sizeof
(
pg
off_t
)
>
sizeof
(
long
))
/*
/*
* At this point, off_t is too large for long, so we return based on
* At this point,
pg
off_t is too large for long, so we return based on
* whether an off_t version of fseek is available.
* whether an
pg
off_t version of fseek is available.
*/
*/
#ifdef HAVE_FSEEKO
#ifdef HAVE_FSEEKO
return
true
;
return
true
;
...
...
src/bin/pg_dump/pg_backup_archiver.h
View file @
74096ed1
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
*
*
*
*
* IDENTIFICATION
* IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_archiver.h,v 1.7
4 2007/01/25 03:30:43 momjian
Exp $
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_archiver.h,v 1.7
5 2007/02/19 15:05:06 mha
Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -199,7 +199,7 @@ typedef struct _archiveHandle
...
@@ -199,7 +199,7 @@ typedef struct _archiveHandle
* format */
* format */
size_t
lookaheadSize
;
/* Size of allocated buffer */
size_t
lookaheadSize
;
/* Size of allocated buffer */
size_t
lookaheadLen
;
/* Length of data in lookahead */
size_t
lookaheadLen
;
/* Length of data in lookahead */
off_t
lookaheadPos
;
/* Current read position in lookahead buffer */
pg
off_t
lookaheadPos
;
/* Current read position in lookahead buffer */
ArchiveEntryPtr
ArchiveEntryPtr
;
/* Called for each metadata object */
ArchiveEntryPtr
ArchiveEntryPtr
;
/* Called for each metadata object */
StartDataPtr
StartDataPtr
;
/* Called when table data is about to be
StartDataPtr
StartDataPtr
;
/* Called when table data is about to be
...
@@ -332,8 +332,8 @@ extern int ReadInt(ArchiveHandle *AH);
...
@@ -332,8 +332,8 @@ extern int ReadInt(ArchiveHandle *AH);
extern
char
*
ReadStr
(
ArchiveHandle
*
AH
);
extern
char
*
ReadStr
(
ArchiveHandle
*
AH
);
extern
size_t
WriteStr
(
ArchiveHandle
*
AH
,
const
char
*
s
);
extern
size_t
WriteStr
(
ArchiveHandle
*
AH
,
const
char
*
s
);
int
ReadOffset
(
ArchiveHandle
*
,
off_t
*
);
int
ReadOffset
(
ArchiveHandle
*
,
pg
off_t
*
);
size_t
WriteOffset
(
ArchiveHandle
*
,
off_t
,
int
);
size_t
WriteOffset
(
ArchiveHandle
*
,
pg
off_t
,
int
);
extern
void
StartRestoreBlobs
(
ArchiveHandle
*
AH
);
extern
void
StartRestoreBlobs
(
ArchiveHandle
*
AH
);
extern
void
StartRestoreBlob
(
ArchiveHandle
*
AH
,
Oid
oid
);
extern
void
StartRestoreBlob
(
ArchiveHandle
*
AH
,
Oid
oid
);
...
...
src/bin/pg_dump/pg_backup_custom.c
View file @
74096ed1
...
@@ -19,7 +19,7 @@
...
@@ -19,7 +19,7 @@
*
*
*
*
* IDENTIFICATION
* IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_custom.c,v 1.3
6 2006/10/04 00:30:05 momjian
Exp $
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_custom.c,v 1.3
7 2007/02/19 15:05:06 mha
Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -70,14 +70,14 @@ typedef struct
...
@@ -70,14 +70,14 @@ typedef struct
char
*
zlibIn
;
char
*
zlibIn
;
size_t
inSize
;
size_t
inSize
;
int
hasSeek
;
int
hasSeek
;
off_t
filePos
;
pg
off_t
filePos
;
off_t
dataStart
;
pg
off_t
dataStart
;
}
lclContext
;
}
lclContext
;
typedef
struct
typedef
struct
{
{
int
dataState
;
int
dataState
;
off_t
dataPos
;
pg
off_t
dataPos
;
}
lclTocEntry
;
}
lclTocEntry
;
...
@@ -88,7 +88,7 @@ typedef struct
...
@@ -88,7 +88,7 @@ typedef struct
static
void
_readBlockHeader
(
ArchiveHandle
*
AH
,
int
*
type
,
int
*
id
);
static
void
_readBlockHeader
(
ArchiveHandle
*
AH
,
int
*
type
,
int
*
id
);
static
void
_StartDataCompressor
(
ArchiveHandle
*
AH
,
TocEntry
*
te
);
static
void
_StartDataCompressor
(
ArchiveHandle
*
AH
,
TocEntry
*
te
);
static
void
_EndDataCompressor
(
ArchiveHandle
*
AH
,
TocEntry
*
te
);
static
void
_EndDataCompressor
(
ArchiveHandle
*
AH
,
TocEntry
*
te
);
static
off_t
_getFilePos
(
ArchiveHandle
*
AH
,
lclContext
*
ctx
);
static
pg
off_t
_getFilePos
(
ArchiveHandle
*
AH
,
lclContext
*
ctx
);
static
int
_DoDeflate
(
ArchiveHandle
*
AH
,
lclContext
*
ctx
,
int
flush
);
static
int
_DoDeflate
(
ArchiveHandle
*
AH
,
lclContext
*
ctx
,
int
flush
);
static
char
*
modulename
=
gettext_noop
(
"custom archiver"
);
static
char
*
modulename
=
gettext_noop
(
"custom archiver"
);
...
@@ -791,7 +791,7 @@ static void
...
@@ -791,7 +791,7 @@ static void
_CloseArchive
(
ArchiveHandle
*
AH
)
_CloseArchive
(
ArchiveHandle
*
AH
)
{
{
lclContext
*
ctx
=
(
lclContext
*
)
AH
->
formatData
;
lclContext
*
ctx
=
(
lclContext
*
)
AH
->
formatData
;
off_t
tpos
;
pg
off_t
tpos
;
if
(
AH
->
mode
==
archModeWrite
)
if
(
AH
->
mode
==
archModeWrite
)
{
{
...
@@ -827,10 +827,10 @@ _CloseArchive(ArchiveHandle *AH)
...
@@ -827,10 +827,10 @@ _CloseArchive(ArchiveHandle *AH)
/*
/*
* Get the current position in the archive file.
* Get the current position in the archive file.
*/
*/
static
off_t
static
pg
off_t
_getFilePos
(
ArchiveHandle
*
AH
,
lclContext
*
ctx
)
_getFilePos
(
ArchiveHandle
*
AH
,
lclContext
*
ctx
)
{
{
off_t
pos
;
pg
off_t
pos
;
if
(
ctx
->
hasSeek
)
if
(
ctx
->
hasSeek
)
{
{
...
@@ -841,7 +841,7 @@ _getFilePos(ArchiveHandle *AH, lclContext *ctx)
...
@@ -841,7 +841,7 @@ _getFilePos(ArchiveHandle *AH, lclContext *ctx)
/*
/*
* Prior to 1.7 (pg7.3) we relied on the internally maintained
* Prior to 1.7 (pg7.3) we relied on the internally maintained
* pointer. Now we rely on off_t always. pos = ctx->filePos;
* pointer. Now we rely on
pg
off_t always. pos = ctx->filePos;
*/
*/
}
}
}
}
...
...
src/bin/pg_dump/pg_backup_files.c
View file @
74096ed1
...
@@ -20,7 +20,7 @@
...
@@ -20,7 +20,7 @@
*
*
*
*
* IDENTIFICATION
* IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_files.c,v 1.3
0 2007/02/08 11:10:27 petere
Exp $
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_files.c,v 1.3
1 2007/02/19 15:05:06 mha
Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -51,7 +51,7 @@ static void _EndBlobs(ArchiveHandle *AH, TocEntry *te);
...
@@ -51,7 +51,7 @@ static void _EndBlobs(ArchiveHandle *AH, TocEntry *te);
typedef
struct
typedef
struct
{
{
int
hasSeek
;
int
hasSeek
;
off_t
filePos
;
pg
off_t
filePos
;
FILE
*
blobToc
;
FILE
*
blobToc
;
}
lclContext
;
}
lclContext
;
...
...
src/bin/pg_dump/pg_backup_tar.c
View file @
74096ed1
...
@@ -16,7 +16,7 @@
...
@@ -16,7 +16,7 @@
*
*
*
*
* IDENTIFICATION
* IDENTIFICATION
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_tar.c,v 1.5
6 2006/11/01 15:59:26 tgl
Exp $
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_tar.c,v 1.5
7 2007/02/19 15:05:06 mha
Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -67,30 +67,30 @@ typedef struct
...
@@ -67,30 +67,30 @@ typedef struct
FILE
*
tmpFH
;
FILE
*
tmpFH
;
char
*
targetFile
;
char
*
targetFile
;
char
mode
;
char
mode
;
off_t
pos
;
pg
off_t
pos
;
off_t
fileLen
;
pg
off_t
fileLen
;
ArchiveHandle
*
AH
;
ArchiveHandle
*
AH
;
}
TAR_MEMBER
;
}
TAR_MEMBER
;
/*
/*
* Maximum file size for a tar member: The limit inherent in the
* Maximum file size for a tar member: The limit inherent in the
* format is 2^33-1 bytes (nearly 8 GB). But we don't want to exceed
* format is 2^33-1 bytes (nearly 8 GB). But we don't want to exceed
* what we can represent by an off_t.
* what we can represent by an
pg
off_t.
*/
*/
#ifdef INT64_IS_BUSTED
#ifdef INT64_IS_BUSTED
#define MAX_TAR_MEMBER_FILELEN INT_MAX
#define MAX_TAR_MEMBER_FILELEN INT_MAX
#else
#else
#define MAX_TAR_MEMBER_FILELEN (((int64) 1 << Min(33, sizeof(off_t)*8 - 1)) - 1)
#define MAX_TAR_MEMBER_FILELEN (((int64) 1 << Min(33, sizeof(
pg
off_t)*8 - 1)) - 1)
#endif
#endif
typedef
struct
typedef
struct
{
{
int
hasSeek
;
int
hasSeek
;
off_t
filePos
;
pg
off_t
filePos
;
TAR_MEMBER
*
blobToc
;
TAR_MEMBER
*
blobToc
;
FILE
*
tarFH
;
FILE
*
tarFH
;
off_t
tarFHpos
;
pg
off_t
tarFHpos
;
off_t
tarNextMember
;
pg
off_t
tarNextMember
;
TAR_MEMBER
*
FH
;
TAR_MEMBER
*
FH
;
int
isSpecialScript
;
int
isSpecialScript
;
TAR_MEMBER
*
scriptTH
;
TAR_MEMBER
*
scriptTH
;
...
@@ -1048,7 +1048,7 @@ _tarAddFile(ArchiveHandle *AH, TAR_MEMBER *th)
...
@@ -1048,7 +1048,7 @@ _tarAddFile(ArchiveHandle *AH, TAR_MEMBER *th)
FILE
*
tmp
=
th
->
tmpFH
;
/* Grab it for convenience */
FILE
*
tmp
=
th
->
tmpFH
;
/* Grab it for convenience */
char
buf
[
32768
];
char
buf
[
32768
];
size_t
cnt
;
size_t
cnt
;
off_t
len
=
0
;
pg
off_t
len
=
0
;
size_t
res
;
size_t
res
;
size_t
i
,
size_t
i
,
pad
;
pad
;
...
@@ -1061,7 +1061,7 @@ _tarAddFile(ArchiveHandle *AH, TAR_MEMBER *th)
...
@@ -1061,7 +1061,7 @@ _tarAddFile(ArchiveHandle *AH, TAR_MEMBER *th)
/*
/*
* Some compilers with throw a warning knowing this test can never be true
* Some compilers with throw a warning knowing this test can never be true
* because off_t can't exceed the compared maximum.
* because
pg
off_t can't exceed the compared maximum.
*/
*/
if
(
th
->
fileLen
>
MAX_TAR_MEMBER_FILELEN
)
if
(
th
->
fileLen
>
MAX_TAR_MEMBER_FILELEN
)
die_horribly
(
AH
,
modulename
,
"archive member too large for tar format
\n
"
);
die_horribly
(
AH
,
modulename
,
"archive member too large for tar format
\n
"
);
...
@@ -1197,7 +1197,7 @@ _tarGetHeader(ArchiveHandle *AH, TAR_MEMBER *th)
...
@@ -1197,7 +1197,7 @@ _tarGetHeader(ArchiveHandle *AH, TAR_MEMBER *th)
chk
;
chk
;
size_t
len
;
size_t
len
;
unsigned
long
ullen
;
unsigned
long
ullen
;
off_t
hPos
;
pg
off_t
hPos
;
bool
gotBlock
=
false
;
bool
gotBlock
=
false
;
while
(
!
gotBlock
)
while
(
!
gotBlock
)
...
...
src/bin/pg_dump/pg_dump.h
View file @
74096ed1
...
@@ -6,7 +6,7 @@
...
@@ -6,7 +6,7 @@
* Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
* Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
* Portions Copyright (c) 1994, Regents of the University of California
*
*
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.h,v 1.13
2 2007/01/23 17:54:50 tgl
Exp $
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.h,v 1.13
3 2007/02/19 15:05:06 mha
Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -16,6 +16,24 @@
...
@@ -16,6 +16,24 @@
#include "postgres_fe.h"
#include "postgres_fe.h"
/*
* WIN32 does not provide 64-bit off_t, but does provide the functions operating
* with 64-bit offsets.
*/
#ifdef WIN32
#define pgoff_t __int64
#undef fseeko
#undef ftello
#ifdef WIN32_ONLY_COMPILER
#define fseeko(stream, offset, origin) _fseeki64(stream, offset, origin)
#define ftello(stream) _ftelli64(stream)
#else
#define fseeko(stream, offset, origin) fseeko64(stream, offset, origin)
#define ftello(stream) ftello64(stream)
#endif
#else
#define pgoff_t off_t
#endif
/*
/*
* pg_dump uses two different mechanisms for identifying database objects:
* pg_dump uses two different mechanisms for identifying database objects:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment