summaryrefslogtreecommitdiff
path: root/contrib/btree_gist/sql/uuid.sql
diff options
context:
space:
mode:
authorMichael Paquier <michael@paquier.xyz>2023-04-12 09:09:58 +0900
committerMichael Paquier <michael@paquier.xyz>2023-04-12 09:09:58 +0900
commit34105eea62e1a607a30596840c7e6dd1cd3feb14 (patch)
treeb85ef9831b06d7879b946bb079a4682f8d02f0f7 /contrib/btree_gist/sql/uuid.sql
parent0cb01a04f60e000c437d82f5fe9928422831cdf7 (diff)
Fix detection of unseekable files for fseek() and ftello() with MSVC
Calling fseek() or ftello() on a handle to a non-seeking device such as a pipe or a communications device is not supported. Unfortunately, MSVC's flavor of these routines, _fseeki64() and _ftelli64(), do not return an error when given a pipe as handle. Some of the logic of pg_dump and restore relies on these routines to check if a handle is seekable, causing failures when passing the contents of pg_dump to pg_restore through a pipe, for example. This commit introduces wrappers for fseeko() and ftello() on MSVC so as any callers are able to properly detect the cases of non-seekable handles. This relies mainly on GetFileType(), sharing a bit of code with the MSVC port for fstat(). The code in charge of getting a file type is refactored into a new file called win32common.c, shared by win32stat.c and the new win32fseek.c. It includes the MSVC ports for fseeko() and ftello(). Like 765f5df, this is backpatched down to 14, where the fstat() implementation for MSVC is able to understand about files larger than 4GB in size. Using a TAP test for that is proving to be tricky as IPC::Run handles the pipes by itself, still I have been able to check the fix manually. Reported-by: Daniel Watzinger Author: Juan José Santamaría Flecha, Michael Paquier Discussion: https://postgr.es/m/CAC+AXB26a4EmxM2suXxPpJaGrqAdxracd7hskLg-zxtPB50h7A@mail.gmail.com Backpatch-through: 14
Diffstat (limited to 'contrib/btree_gist/sql/uuid.sql')
0 files changed, 0 insertions, 0 deletions