16#ifndef CPL_VSI_H_INCLUDED
17#define CPL_VSI_H_INCLUDED
20#include "cpl_progress.h"
57#ifdef ENABLE_EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
58#define EXPERIMENTAL_CPL_WARN_UNUSED_RESULT CPL_WARN_UNUSED_RESULT
60#define EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
72int CPL_DLL VSIFClose(FILE *);
73int CPL_DLL VSIFSeek(FILE *,
long,
int) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
75void CPL_DLL VSIRewind(FILE *);
76void CPL_DLL VSIFFlush(FILE *);
78size_t CPL_DLL VSIFRead(
void *,
size_t,
size_t,
79 FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
80size_t CPL_DLL VSIFWrite(
const void *,
size_t,
size_t,
81 FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
82char CPL_DLL *VSIFGets(
char *,
int, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
83int CPL_DLL VSIFPuts(
const char *, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
85 ...) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
88int CPL_DLL VSIFGetc(FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
89int CPL_DLL VSIFPutc(
int, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
90int CPL_DLL VSIUngetc(
int, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
91int CPL_DLL VSIFEof(FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
100typedef struct stat VSIStatBuf;
105#define VSI_ISLNK(x) (0)
106#define VSI_ISREG(x) ((x)&S_IFREG)
107#define VSI_ISDIR(x) ((x)&S_IFDIR)
108#define VSI_ISCHR(x) ((x)&S_IFCHR)
109#define VSI_ISBLK(x) (0)
112#define VSI_ISLNK(x) S_ISLNK(x)
114#define VSI_ISREG(x) S_ISREG(x)
116#define VSI_ISDIR(x) S_ISDIR(x)
118#define VSI_ISCHR(x) S_ISCHR(x)
119#define VSI_ISBLK(x) S_ISBLK(x)
132#define VSI_L_OFFSET_MAX GUINTBIG_MAX
144 int) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
147size_t CPL_DLL
VSIFReadL(
void *,
size_t,
size_t,
148 VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
151 const size_t *panSizes,
152 VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
153size_t CPL_DLL
VSIFWriteL(
const void *,
size_t,
size_t,
154 VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
162 ...) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
184#if defined(VSI_STAT64_T)
189#define VSIStatBufL VSIStatBuf
195#define VSI_STAT_EXISTS_FLAG 0x1
197#define VSI_STAT_NATURE_FLAG 0x2
199#define VSI_STAT_SIZE_FLAG 0x4
201#define VSI_STAT_SET_ERROR_FLAG 0x8
205#define VSI_STAT_CACHE_ONLY 0x10
219 bool bAllowLocalTempFile);
222 bool bAllowLocalTempFile);
243 const char *pszDomain,
247 const char *pszKey,
const char *pszValue);
251 const char *pszDefault);
254 const char *pszValue)
256 CPL_WARN_DEPRECATED(
"Use VSISetPathSpecificOption instead")
261 CPL_WARN_DEPRECATED(
"Use VSIClearPathSpecificOptions instead")
264const char CPL_DLL *
VSIGetCredential(
const char *pszPath,
const char *pszKey,
265 const char *pszDefault)
267 CPL_WARN_DEPRECATED(
"Use VSIGetPathSpecificOption instead")
281#if defined(__cplusplus) && defined(GDAL_COMPILATION)
285 struct CPL_DLL VSIFreeReleaser
287 void operator()(
void *p)
const
305#define VSI_MALLOC_ALIGNED_AUTO_VERBOSE(size) \
306 VSIMallocAlignedAutoVerbose(size, __FILE__, __LINE__)
325void CPL_DLL *
VSIMalloc3(
size_t nSize1,
size_t nSize2,
332#define VSI_MALLOC_VERBOSE(size) VSIMallocVerbose(size, __FILE__, __LINE__)
339#define VSI_MALLOC2_VERBOSE(nSize1, nSize2) \
340 VSIMalloc2Verbose(nSize1, nSize2, __FILE__, __LINE__)
347#define VSI_MALLOC3_VERBOSE(nSize1, nSize2, nSize3) \
348 VSIMalloc3Verbose(nSize1, nSize2, nSize3, __FILE__, __LINE__)
351void CPL_DLL *
VSICallocVerbose(
size_t nCount,
size_t nSize,
const char *pszFile,
354#define VSI_CALLOC_VERBOSE(nCount, nSize) \
355 VSICallocVerbose(nCount, nSize, __FILE__, __LINE__)
362#define VSI_REALLOC_VERBOSE(pOldPtr, nNewSize) \
363 VSIReallocVerbose(pOldPtr, nNewSize, __FILE__, __LINE__)
369#define VSI_STRDUP_VERBOSE(pszStr) VSIStrdupVerbose(pszStr, __FILE__, __LINE__)
379#define CPLReadDir VSIReadDir
382char CPL_DLL **
VSIReadDirEx(
const char *pszPath,
int nMaxFiles);
391 const char *
const *papszOptions);
418#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
431int CPL_DLL
VSIMkdir(
const char *pszPathname,
long mode);
433int CPL_DLL
VSIRmdir(
const char *pszDirname);
435int CPL_DLL
VSIUnlink(
const char *pszFilename);
437int CPL_DLL
VSIRename(
const char *oldpath,
const char *newpath);
438int CPL_DLL
VSICopyFile(
const char *pszSource,
const char *pszTarget,
440 const char *
const *papszOptions,
441 GDALProgressFunc pProgressFunc,
void *pProgressData);
443 const char *pszInputPayload,
444 char **ppszOutputPayload,
445 const char *
const *papszOptions,
446 GDALProgressFunc pProgressFunc,
447 void *pProgressData);
448int CPL_DLL
VSISync(
const char *pszSource,
const char *pszTarget,
449 const char *
const *papszOptions,
450 GDALProgressFunc pProgressFunc,
void *pProgressData,
451 char ***ppapszOutputs);
454 const char *pszFilename,
int *pbNonSequentialUploadSupported,
455 int *pbParallelUploadSupported,
int *pbAbortSupported,
456 size_t *pnMinPartSize,
size_t *pnMaxPartSize,
int *pnMaxPartCount);
461 const char *pszUploadId,
464 const void *pData,
size_t nDataLength,
467 const char *pszUploadId,
size_t nPartIdsCount,
468 const char *
const *apszPartIds,
472 const char *pszUploadId,
488void CPL_DLL VSIInstallLargeFileHandler(
void);
520void CPL_DLL VSICleanupFileManager(
void);
524 const char *pszNewFSName);
532 int bUnlinkAndSeize);
546 const char *pszFilename,
554 const char *pszFilename);
561 const char *newpath);
567 const char *pszDirname,
574 const char *pszDirname);
579typedef char **(*VSIFilesystemPluginReadDirCallback)(
void *pUserData,
580 const char *pszDirname,
591typedef char **(*VSIFilesystemPluginSiblingFilesCallback)(
592 void *pUserData,
const char *pszDirname);
599typedef void *(*VSIFilesystemPluginOpenCallback)(
void *pUserData,
600 const char *pszFilename,
601 const char *pszAccess);
620 size_t nSize,
size_t nCount);
627 void *pFile,
int nRanges,
void **ppData,
const vsi_l_offset *panOffsets,
628 const size_t *panSizes);
646 size_t nSize,
size_t nCount);
678 void *pFile,
int nRanges,
const vsi_l_offset *panOffsets,
679 const size_t *panSizes);
789unsigned long CPL_DLL VSITime(
unsigned long *);
790const char CPL_DLL *VSICTime(
unsigned long);
791struct tm CPL_DLL *VSIGMTime(
const time_t *pnTime,
struct tm *poBrokenTime);
792struct tm CPL_DLL *VSILocalTime(
const time_t *pnTime,
struct tm *poBrokenTime);
808#define VSIDebug4(f, a1, a2, a3, a4) CPLDebug("VSI", f, a1, a2, a3, a4);
809#define VSIDebug3(f, a1, a2, a3) CPLDebug("VSI", f, a1, a2, a3);
810#define VSIDebug2(f, a1, a2) CPLDebug("VSI", f, a1, a2);
811#define VSIDebug1(f, a1) CPLDebug("VSI", f, a1);
813#define VSIDebug4(f, a1, a2, a3, a4) \
816#define VSIDebug3(f, a1, a2, a3) \
819#define VSIDebug2(f, a1, a2) \
822#define VSIDebug1(f, a1) \
CPL error handling services.
Core portability definitions for CPL.
unsigned long long GUIntBig
Large unsigned integer type (generally 64-bit unsigned integer type).
Definition cpl_port.h:202
#define CPL_C_END
Macro to end a block of C symbols.
Definition cpl_port.h:283
#define CPL_C_START
Macro to start a block of C symbols.
Definition cpl_port.h:279
#define CPL_FORMAT_STRING(arg)
Macro into which to wrap the format argument of a printf-like function.
Definition cpl_port.h:954
#define CPL_PRINT_FUNC_FORMAT(format_idx, arg_idx)
Tag a function to have printf() formatting.
Definition cpl_port.h:938
char ** CSLConstList
Type of a constant null-terminated list of nul terminated strings.
Definition cpl_port.h:1179
#define CPL_WARN_UNUSED_RESULT
Qualifier to warn when the return value of a function is not used.
Definition cpl_port.h:964
unsigned char GByte
Unsigned byte type.
Definition cpl_port.h:169
long long GIntBig
Large signed integer type (generally 64-bit integer type).
Definition cpl_port.h:199
#define VSIStatBufL
Type for VSIStatL()
Definition cpl_vsi.h:189
void * VSICallocVerbose(size_t nCount, size_t nSize, const char *pszFile, int nLine)
VSICallocVerbose.
Definition cpl_vsisimple.cpp:1202
int VSISetFileMetadata(const char *pszFilename, CSLConstList papszMetadata, const char *pszDomain, CSLConstList papszOptions)
Set metadata on files.
Definition cpl_vsil.cpp:1335
int * VSIUnlinkBatch(CSLConstList papszFiles)
Delete several files, possibly in a batch.
Definition cpl_vsil.cpp:465
VSIRangeStatus VSIFGetRangeStatusL(VSILFILE *fp, vsi_l_offset nStart, vsi_l_offset nLength)
Return if a given file range contains data or holes filled with zeroes.
Definition cpl_vsil.cpp:3094
void VSINetworkStatsReset(void)
Clear network related statistics.
Definition cpl_vsil_curl.cpp:6303
void VSIInstallCachedFileHandler(void)
Install /vsicached? file system handler.
Definition cpl_vsil_cache.cpp:736
size_t(* VSIWriteFunction)(const void *ptr, size_t size, size_t nmemb, FILE *stream)
Callback used by VSIStdoutSetRedirection()
Definition cpl_vsi.h:537
void VSIInstallS3StreamingFileHandler(void)
Install /vsis3_streaming/ Amazon S3 file system handler (requires libcurl).
Definition cpl_vsil_curl_streaming.cpp:2127
char ** VSISiblingFiles(const char *pszPath)
Return related filenames.
Definition cpl_vsil.cpp:135
int VSIFFlushL(VSILFILE *)
Flush pending writes to disk.
Definition cpl_vsil.cpp:2622
int(* VSIFilesystemPluginReadMultiRangeCallback)(void *pFile, int nRanges, void **ppData, const vsi_l_offset *panOffsets, const size_t *panSizes)
Read from multiple offsets.
Definition cpl_vsi.h:626
const char * VSIGetDirectorySeparator(const char *pszPath)
Return the directory separator for the specified path.
Definition cpl_vsil.cpp:154
vsi_l_offset VSIFTellL(VSILFILE *)
Tell current file offset.
Definition cpl_vsil.cpp:2553
int VSIRename(const char *oldpath, const char *newpath)
Rename a file.
Definition cpl_vsil.cpp:509
void VSISetCredential(const char *pszPathPrefix, const char *pszKey, const char *pszValue)
Set a credential (or more generally an option related to a virtual file system) for a given path pref...
Definition cpl_vsil.cpp:3460
int VSICopyFile(const char *pszSource, const char *pszTarget, VSILFILE *fpSource, vsi_l_offset nSourceSize, const char *const *papszOptions, GDALProgressFunc pProgressFunc, void *pProgressData)
Copy a source file into a target file.
Definition cpl_vsil.cpp:551
size_t VSIFWriteL(const void *, size_t, size_t, VSILFILE *)
Write bytes to file.
Definition cpl_vsil.cpp:2786
VSIRangeStatus
Range status.
Definition cpl_vsi.h:168
@ VSI_RANGE_STATUS_DATA
Data present.
Definition cpl_vsi.h:170
@ VSI_RANGE_STATUS_HOLE
Hole.
Definition cpl_vsi.h:171
@ VSI_RANGE_STATUS_UNKNOWN
Unknown.
Definition cpl_vsi.h:169
int VSIMultipartUploadEnd(const char *pszFilename, const char *pszUploadId, size_t nPartIdsCount, const char *const *apszPartIds, vsi_l_offset nTotalSize, CSLConstList papszOptions)
Completes a multi-part file upload.
Definition cpl_vsil.cpp:932
size_t(* VSIFilesystemPluginReadCallback)(void *pFile, void *pBuffer, size_t nSize, size_t nCount)
Read data from current position, returns the number of blocks correctly read.
Definition cpl_vsi.h:619
void VSIInstallStdinHandler(void)
Install /vsistdin/ file system handler.
Definition cpl_vsil_stdin.cpp:682
bool VSISupportsRandomWrite(const char *pszPath, bool bAllowLocalTempFile)
Returns if the filesystem supports random write.
Definition cpl_vsil.cpp:1499
GIntBig CPLGetPhysicalRAM(void)
Return the total physical RAM in bytes.
Definition cpl_vsisimple.cpp:1385
int VSIFTruncateL(VSILFILE *, vsi_l_offset)
Truncate/expand the file to the specified size.
Definition cpl_vsil.cpp:2952
void * VSICalloc(size_t, size_t)
Analog of calloc().
Definition cpl_vsisimple.cpp:436
vsi_l_offset(* VSIFilesystemPluginTellCallback)(void *pFile)
Return current position in handle.
Definition cpl_vsi.h:606
int VSIIsCaseSensitiveFS(const char *pszFilename)
Returns if the filenames of the filesystem are case sensitive.
Definition cpl_vsil.cpp:1369
void VSIInstallGZipFileHandler(void)
Install GZip file system handler.
Definition cpl_vsil_gzip.cpp:3350
void * VSIMalloc2Verbose(size_t nSize1, size_t nSize2, const char *pszFile, int nLine)
VSIMalloc2Verbose.
Definition cpl_vsisimple.cpp:1153
void VSIFClearErrL(VSILFILE *)
Reset the error and end-of-file indicators.
Definition cpl_vsil.cpp:2912
int VSIHasOptimizedReadMultiRange(const char *pszPath)
Returns if the filesystem supports efficient multi-range reading.
Definition cpl_vsil.cpp:1524
void(* VSIFilesystemPluginAdviseReadCallback)(void *pFile, int nRanges, const vsi_l_offset *panOffsets, const size_t *panSizes)
This optional method is called when code plans to access soon one or several ranges in a file.
Definition cpl_vsi.h:677
char **(* VSIFilesystemPluginReadDirCallback)(void *pUserData, const char *pszDirname, int nMaxFiles)
List directory content.
Definition cpl_vsi.h:579
void VSIFreeFilesystemPluginCallbacksStruct(VSIFilesystemPluginCallbacksStruct *poCb)
free resources allocated by VSIAllocFilesystemPluginCallbacksStruct
Definition cpl_vsil_plugin.cpp:505
int(* VSIFilesystemPluginRenameCallback)(void *pUserData, const char *oldpath, const char *newpath)
Rename handle.
Definition cpl_vsi.h:559
void VSISetPathSpecificOption(const char *pszPathPrefix, const char *pszKey, const char *pszValue)
Set a path specific option for a given path prefix.
Definition cpl_vsil.cpp:3497
int VSIRemovePluginHandler(const char *pszPrefix)
Unregister a handler previously installed with VSIInstallPluginHandler() on the given prefix.
Definition cpl_vsil_plugin.cpp:492
void VSIInstallCurlFileHandler(void)
Install /vsicurl/ HTTP/FTP file system handler (requires libcurl)
Definition cpl_vsil_curl.cpp:6210
void * VSIMallocVerbose(size_t nSize, const char *pszFile, int nLine)
VSIMallocVerbose.
Definition cpl_vsisimple.cpp:1136
void VSIInstallWebHdfsHandler(void)
Install /vsiwebhdfs/ WebHDFS (Hadoop File System) REST API file system handler (requires libcurl)
Definition cpl_vsil_webhdfs.cpp:1191
bool VSISupportsSequentialWrite(const char *pszPath, bool bAllowLocalTempFile)
Returns if the filesystem supports sequential write.
Definition cpl_vsil.cpp:1475
int VSIFErrorL(VSILFILE *)
Test the error indicator.
Definition cpl_vsil.cpp:2877
void VSIInstallS3FileHandler(void)
Install /vsis3/ Amazon S3 file system handler (requires libcurl)
Definition cpl_vsil_s3.cpp:5163
void VSIInstallHdfsHandler(void)
Install /vsihdfs/ file system handler (requires JVM and HDFS support)
Definition cpl_vsil_hdfs.cpp:466
void VSIInstallCryptFileHandler(void)
Install /vsicrypt/ encrypted file system handler (requires libcrypto++)
Definition cpl_vsil_crypt.cpp:2067
char ** VSIGetFileSystemsPrefixes(void)
Return the list of prefixes for virtual file system handlers currently registered.
Definition cpl_vsil.cpp:3416
int VSIOverwriteFile(VSILFILE *fpTarget, const char *pszSourceFilename)
Overwrite an existing file with content from another one.
Definition cpl_vsil.cpp:3305
void VSIInstallSwiftStreamingFileHandler(void)
Install /vsiswift_streaming/ OpenStack Swif Object Storage (Swift) file system handler (requires libc...
Definition cpl_vsil_curl_streaming.cpp:2211
void VSISetCryptKey(const GByte *pabyKey, int nKeySize)
Installs the encryption/decryption key.
Definition cpl_vsil_crypt.cpp:188
void * VSIMallocAlignedAutoVerbose(size_t nSize, const char *pszFile, int nLine)
See VSIMallocAlignedAuto()
Definition cpl_vsisimple.cpp:956
void VSIInstallStdoutHandler(void)
Install /vsistdout/ file system handler.
Definition cpl_vsil_stdout.cpp:452
int VSIMkdirRecursive(const char *pszPathname, long mode)
Create a directory and all its ancestors.
Definition cpl_vsil.cpp:383
void VSIInstallMemFileHandler(void)
Install "memory" file system handler.
Definition cpl_vsi_mem.cpp:1168
int VSIFPutcL(int, VSILFILE *)
Write a single byte to the file.
Definition cpl_vsil.cpp:3042
int VSISync(const char *pszSource, const char *pszTarget, const char *const *papszOptions, GDALProgressFunc pProgressFunc, void *pProgressData, char ***ppapszOutputs)
Synchronize a source file/directory with a target file/directory.
Definition cpl_vsil.cpp:751
void * VSIMalloc2(size_t nSize1, size_t nSize2)
VSIMalloc2 allocates (nSize1 * nSize2) bytes.
Definition cpl_vsisimple.cpp:1114
int(* VSIFilesystemPluginCloseCallback)(void *pFile)
Close file handle.
Definition cpl_vsi.h:661
struct VSIDIR VSIDIR
Opaque type for a directory iterator.
Definition cpl_vsi.h:388
void VSICurlClearCache(void)
Clean local cache associated with /vsicurl/ (and related file systems)
Definition cpl_vsil_curl.cpp:6234
void VSICurlPartialClearCache(const char *pszFilenamePrefix)
Clean local cache associated with /vsicurl/ (and related file systems) for a given filename (and its ...
Definition cpl_vsil_curl.cpp:6280
int VSIIngestFile(VSILFILE *fp, const char *pszFilename, GByte **ppabyRet, vsi_l_offset *pnSize, GIntBig nMaxSize)
Ingest a file into memory.
Definition cpl_vsil.cpp:3129
VSILFILE * VSIFOpenExL(const char *, const char *, int)
Open/create file.
Definition cpl_vsil.cpp:2325
int VSISupportsSparseFiles(const char *pszPath)
Returns if the filesystem supports sparse files.
Definition cpl_vsil.cpp:1398
int VSIMultipartUploadAbort(const char *pszFilename, const char *pszUploadId, CSLConstList papszOptions)
Aborts a multi-part file upload.
Definition cpl_vsil.cpp:967
char * VSIMultipartUploadAddPart(const char *pszFilename, const char *pszUploadId, int nPartNumber, vsi_l_offset nFileOffset, const void *pData, size_t nDataLength, CSLConstList papszOptions)
Uploads a new part to a multi-part uploaded file.
Definition cpl_vsil.cpp:895
int(* VSIFilesystemPluginMkdirCallback)(void *pUserData, const char *pszDirname, long nMode)
Create Directory.
Definition cpl_vsi.h:566
void * VSIRealloc(void *, size_t)
Analog of realloc().
Definition cpl_vsisimple.cpp:679
int(* VSIFilesystemPluginTruncateCallback)(void *pFile, vsi_l_offset nNewSize)
Truncate handle.
Definition cpl_vsi.h:655
VSIFilesystemPluginCallbacksStruct * VSIAllocFilesystemPluginCallbacksStruct(void)
return a VSIFilesystemPluginCallbacksStruct to be populated at runtime with handler callbacks
Definition cpl_vsil_plugin.cpp:499
size_t(* VSIFilesystemPluginWriteCallback)(void *pFile, const void *pBuffer, size_t nSize, size_t nCount)
Write bytes at current offset.
Definition cpl_vsi.h:644
char **(* VSIFilesystemPluginSiblingFilesCallback)(void *pUserData, const char *pszDirname)
List related files.
Definition cpl_vsi.h:591
int VSIMultipartUploadGetCapabilities(const char *pszFilename, int *pbNonSequentialUploadSupported, int *pbParallelUploadSupported, int *pbAbortSupported, size_t *pnMinPartSize, size_t *pnMaxPartSize, int *pnMaxPartCount)
Return capabilities for multiple part file upload.
Definition cpl_vsil.cpp:808
void VSICloseDir(VSIDIR *dir)
Close a directory.
Definition cpl_vsil.cpp:336
int VSIUnlink(const char *pszFilename)
Delete a file.
Definition cpl_vsil.cpp:434
void * VSIMalloc3(size_t nSize1, size_t nSize2, size_t nSize3)
VSIMalloc3 allocates (nSize1 * nSize2 * nSize3) bytes.
Definition cpl_vsisimple.cpp:1127
int VSIFCloseL(VSILFILE *)
Close file.
Definition cpl_vsil.cpp:2454
VSIDIR * VSIOpenDir(const char *pszPath, int nRecurseDepth, const char *const *papszOptions)
Open a directory to read its entries.
Definition cpl_vsil.cpp:277
GByte * VSIGetMemFileBuffer(const char *pszFilename, vsi_l_offset *pnDataLength, int bUnlinkAndSeize)
Fetch buffer underlying memory file.
Definition cpl_vsi_mem.cpp:1286
void VSIInstallSwiftFileHandler(void)
Install /vsiswift/ OpenStack Swif Object Storage (Swift) file system handler (requires libcurl)
Definition cpl_vsil_swift.cpp:724
void VSIInstallZipFileHandler(void)
Install ZIP file system handler.
Definition cpl_vsil_gzip.cpp:4978
const char * VSIGetCredential(const char *pszPath, const char *pszKey, const char *pszDefault)
Get the value of a credential (or more generally an option related to a virtual file system) for a gi...
Definition cpl_vsil.cpp:3565
VSIRangeStatus(* VSIFilesystemPluginGetRangeStatusCallback)(void *pFile, vsi_l_offset nOffset, vsi_l_offset nLength)
Get empty ranges.
Definition cpl_vsi.h:633
void * VSIFGetNativeFileDescriptorL(VSILFILE *)
Returns the "native" file descriptor for the virtual handle.
Definition cpl_vsil.cpp:3376
char * VSIGetCanonicalFilename(const char *pszPath)
Returns the canonical filename.
Definition cpl_vsil.cpp:1451
int(* VSIFilesystemPluginSeekCallback)(void *pFile, vsi_l_offset nOffset, int nWhence)
Seek to position in handle.
Definition cpl_vsi.h:611
void VSIClearCredentials(const char *pszPathPrefix)
Clear path specific options set with VSISetPathSpecificOption()
Definition cpl_vsil.cpp:3524
int(* VSIFilesystemPluginStatCallback)(void *pUserData, const char *pszFilename, VSIStatBufL *pStatBuf, int nFlags)
Return information about a handle.
Definition cpl_vsi.h:545
void VSIInstallOSSStreamingFileHandler(void)
Install /vsiaz_streaming/ Alibaba Cloud Object Storage Service (OSS) (requires libcurl)
Definition cpl_vsil_curl_streaming.cpp:2190
char ** VSIReadDirEx(const char *pszPath, int nMaxFiles)
Read names in a directory.
Definition cpl_vsil.cpp:107
void * VSIMallocAligned(size_t nAlignment, size_t nSize)
Allocates a buffer with an alignment constraint.
Definition cpl_vsisimple.cpp:893
char * VSIGetSignedURL(const char *pszFilename, CSLConstList papszOptions)
Returns a signed URL of a supplied filename.
Definition cpl_vsil.cpp:1597
void(* VSIFilesystemPluginClearErrCallback)(void *pFile)
Clear error and end-of-file flags.
Definition cpl_vsi.h:691
int VSIInstallPluginHandler(const char *pszPrefix, const VSIFilesystemPluginCallbacksStruct *poCb)
register a handler on the given prefix.
Definition cpl_vsil_plugin.cpp:482
const char * VSIGetActualURL(const char *pszFilename)
Returns the actual URL of a supplied filename.
Definition cpl_vsil.cpp:1553
int VSIRmdirRecursive(const char *pszDirname)
Delete a directory recursively.
Definition cpl_vsil.cpp:1122
int VSIMkdir(const char *pszPathname, long mode)
Create a directory.
Definition cpl_vsil.cpp:361
void * VSIReallocVerbose(void *pOldPtr, size_t nNewSize, const char *pszFile, int nLine)
VSIReallocVerbose.
Definition cpl_vsisimple.cpp:1221
void *(* VSIFilesystemPluginOpenCallback)(void *pUserData, const char *pszFilename, const char *pszAccess)
Open a handle.
Definition cpl_vsi.h:599
size_t VSIFReadL(void *, size_t, size_t, VSILFILE *)
Read bytes from file.
Definition cpl_vsil.cpp:2676
int VSIFReadMultiRangeL(int nRanges, void **ppData, const vsi_l_offset *panOffsets, const size_t *panSizes, VSILFILE *)
Read several ranges of bytes from file.
Definition cpl_vsil.cpp:2734
void VSIInstallCurlStreamingFileHandler(void)
Install /vsicurl_streaming/ HTTP/FTP file system handler (requires libcurl).
Definition cpl_vsil_curl_streaming.cpp:2107
char * VSIStrdup(const char *)
Analog of strdup().
Definition cpl_vsisimple.cpp:999
VSILFILE * VSIFOpenL(const char *, const char *)
Open file.
Definition cpl_vsil.cpp:1634
int VSIFEofL(VSILFILE *)
Test for end of file.
Definition cpl_vsil.cpp:2830
void VSIInstallSparseFileHandler(void)
Install /vsisparse/ virtual file handler.
Definition cpl_vsil_sparsefile.cpp:582
void VSIInstallSubFileHandler(void)
Install /vsisubfile/ virtual file handler.
Definition cpl_vsil_subfile.cpp:515
void VSIRewindL(VSILFILE *)
Rewind the file pointer to the beginning of the file.
Definition cpl_vsil.cpp:2573
char ** VSIReadDir(const char *)
Read names in a directory.
Definition cpl_vsil.cpp:73
void * VSIMalloc3Verbose(size_t nSize1, size_t nSize2, size_t nSize3, const char *pszFile, int nLine)
VSIMalloc3Verbose.
Definition cpl_vsisimple.cpp:1177
int(* VSIFilesystemPluginUnlinkCallback)(void *pUserData, const char *pszFilename)
Remove handle by name.
Definition cpl_vsi.h:553
void VSIInstallRarFileHandler(void)
Install /vsirar/ RAR file system handler (requires libarchive)
Definition cpl_vsil_libarchive.cpp:49
char * VSIStrerror(int)
Return the error string corresponding to the error number.
Definition cpl_vsisimple.cpp:1362
bool VSIDuplicateFileSystemHandler(const char *pszSourceFSName, const char *pszNewFSName)
Duplicate an existing file system handler.
Definition cpl_vsil.cpp:3624
void VSIInstallADLSFileHandler(void)
Install /vsiaz/ Microsoft Azure Data Lake Storage Gen2 file system handler (requires libcurl)
Definition cpl_vsil_adls.cpp:2183
GIntBig CPLGetUsablePhysicalRAM(void)
Return the total physical RAM, usable by a process, in bytes.
Definition cpl_vsisimple.cpp:1611
int VSIStatL(const char *, VSIStatBufL *)
Get filesystem object info.
Definition cpl_vsil.cpp:1158
char ** VSIReadDirRecursive(const char *pszPath)
Read names in a directory recursively.
Definition cpl_vsil.cpp:194
int VSICopyFileRestartable(const char *pszSource, const char *pszTarget, const char *pszInputPayload, char **ppszOutputPayload, const char *const *papszOptions, GDALProgressFunc pProgressFunc, void *pProgressData)
Copy a source file into a target file in a way that can (potentially) be restarted.
Definition cpl_vsil.cpp:644
void VSIInstallGSStreamingFileHandler(void)
Install /vsigs_streaming/ Google Cloud Storage file system handler (requires libcurl)
Definition cpl_vsil_curl_streaming.cpp:2148
int(* VSIFilesystemPluginEofCallback)(void *pFile)
Has end of file been reached.
Definition cpl_vsi.h:639
int VSIFPrintfL(VSILFILE *, const char *,...)
Formatted write to file.
Definition cpl_vsil.cpp:2976
int VSIStatExL(const char *pszFilename, VSIStatBufL *psStatBuf, int nFlags)
Get filesystem object info.
Definition cpl_vsil.cpp:1198
char * VSINetworkStatsGetAsSerializedJSON(char **papszOptions)
Return network related statistics, as a JSON serialized object.
Definition cpl_vsil_curl.cpp:6402
void VSIInstallOSSFileHandler(void)
Install /vsioss/ Alibaba Cloud Object Storage Service (OSS) file system handler (requires libcurl)
Definition cpl_vsil_oss.cpp:322
GIntBig VSIGetDiskFreeSpace(const char *pszDirname)
Return free disk space available on the filesystem.
Definition cpl_vsil.cpp:3395
VSILFILE * VSIFOpenEx2L(const char *, const char *, int, CSLConstList)
Open/create file.
Definition cpl_vsil.cpp:2399
void VSIInstallTarFileHandler(void)
Install /vsitar/ file system handler.
Definition cpl_vsil_tar.cpp:655
void VSIInstall7zFileHandler(void)
Install /vsi7z/ 7zip file system handler (requires libarchive)
Definition cpl_vsil_libarchive.cpp:31
const char * VSIGetFileSystemOptions(const char *pszFilename)
Return the list of options associated with a virtual file system handler as a serialized XML string.
Definition cpl_vsil.cpp:3436
void VSIFreeAligned(void *ptr)
Free a buffer allocated with VSIMallocAligned().
Definition cpl_vsisimple.cpp:979
void * VSIMallocAlignedAuto(size_t nSize)
Allocates a buffer with an alignment constraint such that it can be used by the most demanding vector...
Definition cpl_vsisimple.cpp:943
int VSIAbortPendingUploads(const char *pszFilename)
Abort all ongoing multi-part uploads.
Definition cpl_vsil.cpp:1069
void VSIStdoutSetRedirection(VSIWriteFunction pFct, FILE *stream)
Set an alternative write function and output file handle instead of fwrite() / stdout.
Definition cpl_vsil_stdout.cpp:46
const char * VSIGetPathSpecificOption(const char *pszPath, const char *pszKey, const char *pszDefault)
Get the value a path specific option.
Definition cpl_vsil.cpp:3584
void * VSIMalloc(size_t)
Analog of malloc().
Definition cpl_vsisimple.cpp:552
int VSIFSeekL(VSILFILE *, vsi_l_offset, int)
Seek to requested offset.
Definition cpl_vsil.cpp:2512
int(* VSIFilesystemPluginFlushCallback)(void *pFile)
Sync written bytes.
Definition cpl_vsi.h:651
VSILFILE * VSIFileFromMemBuffer(const char *pszFilename, GByte *pabyData, vsi_l_offset nDataLength, int bTakeOwnership)
Create memory "file" from a buffer.
Definition cpl_vsi_mem.cpp:1201
bool VSIIsLocal(const char *pszPath)
Returns if the file/filesystem is "local".
Definition cpl_vsil.cpp:1426
const char * VSIMemGenerateHiddenFilename(const char *pszFilename)
Generates a unique filename that can be used with the /vsimem/ virtual file system.
Definition cpl_vsi_mem.cpp:1364
int VSIRmdir(const char *pszDirname)
Delete a directory.
Definition cpl_vsil.cpp:1096
void VSIInstallAzureFileHandler(void)
Install /vsiaz/ Microsoft Azure Blob file system handler (requires libcurl)
Definition cpl_vsil_az.cpp:2619
void VSIFree(void *)
Analog of free() for data allocated with VSIMalloc(), VSICalloc(), VSIRealloc()
Definition cpl_vsisimple.cpp:828
char * VSIStrdupVerbose(const char *pszStr, const char *pszFile, int nLine)
VSIStrdupVerbose.
Definition cpl_vsisimple.cpp:1239
void VSIClearPathSpecificOptions(const char *pszPathPrefix)
Clear path specific options set with VSISetPathSpecificOption()
Definition cpl_vsil.cpp:3542
GUIntBig vsi_l_offset
Type for a file offset.
Definition cpl_vsi.h:130
const VSIDIREntry * VSIGetNextDirEntry(VSIDIR *dir)
Return the next entry of the directory.
Definition cpl_vsil.cpp:317
char * VSIMultipartUploadStart(const char *pszFilename, CSLConstList papszOptions)
Initiates the upload a (big) file in a piece-wise way.
Definition cpl_vsil.cpp:857
void VSIInstallGSFileHandler(void)
Install /vsigs/ Google Cloud Storage file system handler (requires libcurl)
Definition cpl_vsil_gs.cpp:812
int(* VSIFilesystemPluginErrorCallback)(void *pFile)
Has a read error (non end-of-file related) has occurred?
Definition cpl_vsi.h:685
void VSIInstallAzureStreamingFileHandler(void)
Install /vsiaz_streaming/ Microsoft Azure Blob file system handler (requires libcurl)
Definition cpl_vsil_curl_streaming.cpp:2169
char ** VSIGetFileMetadata(const char *pszFilename, const char *pszDomain, CSLConstList papszOptions)
Get metadata on files.
Definition cpl_vsil.cpp:1265
int(* VSIFilesystemPluginRmdirCallback)(void *pUserData, const char *pszDirname)
Delete Directory.
Definition cpl_vsi.h:573
Directory entry.
Definition cpl_vsi.h:400
char * pszName
Filename.
Definition cpl_vsi.h:402
GIntBig nMTime
Last modification time (seconds since 1970/01/01)
Definition cpl_vsi.h:408
char bMTimeKnown
Whether nMTime is known: 0 = unknown, 1 = known.
Definition cpl_vsi.h:414
char bSizeKnown
Whether nSize is known: 0 = unknown, 1 = known.
Definition cpl_vsi.h:412
char bModeKnown
Whether nMode is known: 0 = unknown, 1 = known.
Definition cpl_vsi.h:410
char ** papszExtra
NULL-terminated list of extra properties.
Definition cpl_vsi.h:416
vsi_l_offset nSize
File size.
Definition cpl_vsi.h:406
int nMode
File mode.
Definition cpl_vsi.h:404
struct containing callbacks to used by the handler.
Definition cpl_vsi.h:701
VSIFilesystemPluginAdviseReadCallback advise_read
The following optional member has been added in GDAL 3.7:
Definition cpl_vsi.h:737
VSIFilesystemPluginWriteCallback write
write bytes to current position (w)
Definition cpl_vsi.h:727
size_t nBufferSize
buffer small reads (makes handler read only)
Definition cpl_vsi.h:731
VSIFilesystemPluginRenameCallback rename
rename handle ()
Definition cpl_vsi.h:709
VSIFilesystemPluginReadMultiRangeCallback read_multi_range
read multiple blocks ()
Definition cpl_vsi.h:721
VSIFilesystemPluginUnlinkCallback unlink
unlink handle by name ()
Definition cpl_vsi.h:708
VSIFilesystemPluginRmdirCallback rmdir
remove directory ()
Definition cpl_vsi.h:711
VSIFilesystemPluginClearErrCallback clear_err
clear error flags(r)
Definition cpl_vsi.h:740
size_t nCacheSize
max mem to use per file when buffering
Definition cpl_vsi.h:732
VSIFilesystemPluginEofCallback eof
has end of file been reached (r?)
Definition cpl_vsi.h:725
VSIFilesystemPluginSiblingFilesCallback sibling_files
list related files
Definition cpl_vsi.h:734
VSIFilesystemPluginOpenCallback open
open handle by name (rw)
Definition cpl_vsi.h:714
VSIFilesystemPluginSeekCallback seek
set current position of handle (rw)
Definition cpl_vsi.h:718
VSIFilesystemPluginGetRangeStatusCallback get_range_status
get range status ()
Definition cpl_vsi.h:723
VSIFilesystemPluginCloseCallback close
close handle (rw)
Definition cpl_vsi.h:730
VSIFilesystemPluginReadCallback read
read from current position (r)
Definition cpl_vsi.h:719
VSIFilesystemPluginFlushCallback flush
sync bytes (w)
Definition cpl_vsi.h:728
VSIFilesystemPluginReadDirCallback read_dir
list directory content (r?)
Definition cpl_vsi.h:713
void * pUserData
Optional opaque pointer passed back to filemanager callbacks (e.g.
Definition cpl_vsi.h:706
VSIFilesystemPluginErrorCallback error
has read error occurred (r)
Definition cpl_vsi.h:739
VSIFilesystemPluginTruncateCallback truncate
truncate handle (w?)
Definition cpl_vsi.h:729
VSIFilesystemPluginMkdirCallback mkdir
make directory ()
Definition cpl_vsi.h:710
VSIFilesystemPluginStatCallback stat
stat handle by name (rw)
Definition cpl_vsi.h:707
VSIFilesystemPluginTellCallback tell
get current position of handle (rw)
Definition cpl_vsi.h:716
Virtual file handle.
Definition cpl_vsi_virtual.h:47