GDAL
cpl_vsi.h
Go to the documentation of this file.
1/******************************************************************************
2 *
3 * Project: CPL - Common Portability Library
4 * Author: Frank Warmerdam, warmerdam@pobox.com
5 * Purpose: Include file defining Virtual File System (VSI) functions, a
6 * layer over POSIX file and other system services.
7 *
8 ******************************************************************************
9 * Copyright (c) 1998, Frank Warmerdam
10 * Copyright (c) 2008-2014, Even Rouault <even dot rouault at spatialys.com>
11 *
12 * SPDX-License-Identifier: MIT
13 ****************************************************************************/
14
15#ifndef CPL_VSI_H_INCLUDED
16#define CPL_VSI_H_INCLUDED
17
18#include "cpl_port.h"
19#include "cpl_progress.h"
20
21#include <stdbool.h>
22
23#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
24extern "C++"
25{
26#include <string>
27}
28#endif
29
48/* -------------------------------------------------------------------- */
49/* We need access to ``struct stat''. */
50/* -------------------------------------------------------------------- */
51
52/* Unix */
53#if !defined(_WIN32)
54#include <unistd.h>
55#endif
56
57/* Windows */
58#include <sys/stat.h>
59
61
63#ifdef ENABLE_EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
64#define EXPERIMENTAL_CPL_WARN_UNUSED_RESULT CPL_WARN_UNUSED_RESULT
65#else
66#define EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
67#endif
70/* ==================================================================== */
71/* stdio file access functions. These do not support large */
72/* files, and do not go through the virtualization API. */
73/* ==================================================================== */
74
77FILE CPL_DLL *VSIFOpen(const char *, const char *) CPL_WARN_UNUSED_RESULT;
78int CPL_DLL VSIFClose(FILE *);
79int CPL_DLL VSIFSeek(FILE *, long, int) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
80long CPL_DLL VSIFTell(FILE *) CPL_WARN_UNUSED_RESULT;
81void CPL_DLL VSIRewind(FILE *);
82void CPL_DLL VSIFFlush(FILE *);
83
84size_t CPL_DLL VSIFRead(void *, size_t, size_t,
85 FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
86size_t CPL_DLL VSIFWrite(const void *, size_t, size_t,
87 FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
88char CPL_DLL *VSIFGets(char *, int, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
89int CPL_DLL VSIFPuts(const char *, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
90int CPL_DLL VSIFPrintf(FILE *, CPL_FORMAT_STRING(const char *),
91 ...) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
93
94int CPL_DLL VSIFGetc(FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
95int CPL_DLL VSIFPutc(int, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
96int CPL_DLL VSIUngetc(int, FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
97int CPL_DLL VSIFEof(FILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
98
101/* ==================================================================== */
102/* VSIStat() related. */
103/* ==================================================================== */
104
106typedef struct stat VSIStatBuf;
107int CPL_DLL VSIStat(const char *, VSIStatBuf *) CPL_WARN_UNUSED_RESULT;
110#ifdef _WIN32
111#define VSI_ISLNK(x) (0) /* N/A on Windows */
112#define VSI_ISREG(x) ((x) & S_IFREG)
113#define VSI_ISDIR(x) ((x) & S_IFDIR)
114#define VSI_ISCHR(x) ((x) & S_IFCHR)
115#define VSI_ISBLK(x) (0) /* N/A on Windows */
116#else
118#define VSI_ISLNK(x) S_ISLNK(x)
120#define VSI_ISREG(x) S_ISREG(x)
122#define VSI_ISDIR(x) S_ISDIR(x)
124#define VSI_ISCHR(x) S_ISCHR(x)
125#define VSI_ISBLK(x) S_ISBLK(x)
127#endif
128
129/* ==================================================================== */
130/* 64bit stdio file access functions. If we have a big size */
131/* defined, then provide prototypes for the large file API, */
132/* otherwise redefine to use the regular api. */
133/* ==================================================================== */
134
138#define VSI_L_OFFSET_MAX GUINTBIG_MAX
139
142
143VSILFILE CPL_DLL *VSIFOpenL(const char *, const char *) CPL_WARN_UNUSED_RESULT;
144VSILFILE CPL_DLL *VSIFOpenExL(const char *, const char *,
146VSILFILE CPL_DLL *VSIFOpenEx2L(const char *, const char *, int,
148int CPL_DLL VSIFCloseL(VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
149int CPL_DLL VSIFSeekL(VSILFILE *, vsi_l_offset,
150 int) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
151#ifdef GDAL_COMPILATION
152#ifdef __cplusplus
153
156
157int VSIFSeekL(VSILFILE *, int &, int) = delete;
158int VSIFSeekL(VSILFILE *, const int &, int) = delete;
159int VSIFSeekL(VSILFILE *, unsigned &, int) = delete;
160int VSIFSeekL(VSILFILE *, const unsigned &, int) = delete;
161
162inline int VSIFSeekL(VSILFILE *f, int &&nOffset, int nWhence)
163{
164 return VSIFSeekL(f, static_cast<vsi_l_offset>(nOffset), nWhence);
165}
166
167template <typename T>
168inline std::enable_if_t<
169 std::is_same_v<T, uint64_t> && !std::is_same_v<uint64_t, vsi_l_offset>, int>
170VSIFSeekL(VSILFILE *f, T nOffset, int nWhence)
171{
172 return VSIFSeekL(f, static_cast<vsi_l_offset>(nOffset), nWhence);
173}
174
175template <typename T>
176inline std::enable_if_t<std::is_same_v<T, size_t> &&
177 !std::is_same_v<T, uint64_t> &&
178 !std::is_same_v<size_t, unsigned> &&
179 !std::is_same_v<size_t, vsi_l_offset>,
180 int>
181VSIFSeekL(VSILFILE *f, T, int) = delete;
182
184
186#endif
187#endif
189void CPL_DLL VSIRewindL(VSILFILE *);
190size_t CPL_DLL VSIFReadL(void *, size_t, size_t,
191 VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
192int CPL_DLL VSIFReadMultiRangeL(int nRanges, void **ppData,
193 const vsi_l_offset *panOffsets,
194 const size_t *panSizes,
195 VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
196size_t CPL_DLL VSIFWriteL(const void *, size_t, size_t,
197 VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
198void CPL_DLL VSIFClearErrL(VSILFILE *);
200int CPL_DLL VSIFEofL(VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
201int CPL_DLL VSIFTruncateL(VSILFILE *,
202 vsi_l_offset) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
203int CPL_DLL VSIFFlushL(VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
204int CPL_DLL VSIFPrintfL(VSILFILE *, CPL_FORMAT_STRING(const char *),
205 ...) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT
207int CPL_DLL VSIFPutcL(int, VSILFILE *) EXPERIMENTAL_CPL_WARN_UNUSED_RESULT;
208
216
218 vsi_l_offset nLength);
219
220int CPL_DLL VSIIngestFile(VSILFILE *fp, const char *pszFilename,
221 GByte **ppabyRet, vsi_l_offset *pnSize,
223
224int CPL_DLL VSIOverwriteFile(VSILFILE *fpTarget, const char *pszSourceFilename)
226
227#if defined(VSI_STAT64_T)
229typedef struct VSI_STAT64_T VSIStatBufL;
230#else
232#define VSIStatBufL VSIStatBuf
233#endif
234
235int CPL_DLL VSIStatL(const char *, VSIStatBufL *) CPL_WARN_UNUSED_RESULT;
236
238#define VSI_STAT_EXISTS_FLAG 0x1
240#define VSI_STAT_NATURE_FLAG 0x2
242#define VSI_STAT_SIZE_FLAG 0x4
244#define VSI_STAT_SET_ERROR_FLAG 0x8
248#define VSI_STAT_CACHE_ONLY 0x10
249
250int CPL_DLL VSIStatExL(const char *pszFilename, VSIStatBufL *psStatBuf,
251 int nFlags) CPL_WARN_UNUSED_RESULT;
252
253int CPL_DLL VSIIsCaseSensitiveFS(const char *pszFilename);
254
255int CPL_DLL VSISupportsSparseFiles(const char *pszPath);
256
257bool CPL_DLL VSIIsLocal(const char *pszPath);
258
259char CPL_DLL *VSIGetCanonicalFilename(const char *pszPath);
260
261bool CPL_DLL VSISupportsSequentialWrite(const char *pszPath,
262 bool bAllowLocalTempFile);
263
264bool CPL_DLL VSISupportsRandomWrite(const char *pszPath,
265 bool bAllowLocalTempFile);
266
267int CPL_DLL VSIHasOptimizedReadMultiRange(const char *pszPath);
268
269const char CPL_DLL *VSIGetActualURL(const char *pszFilename);
270
271char CPL_DLL *VSIGetSignedURL(const char *pszFilename,
272 CSLConstList papszOptions);
273
274const char CPL_DLL *VSIGetFileSystemOptions(const char *pszFilename);
275
276char CPL_DLL **VSIGetFileSystemsPrefixes(void);
277
279
280char CPL_DLL **
281VSIGetFileMetadata(const char *pszFilename, const char *pszDomain,
283
284int CPL_DLL VSISetFileMetadata(const char *pszFilename,
285 CSLConstList papszMetadata,
286 const char *pszDomain,
287 CSLConstList papszOptions);
288
289void CPL_DLL VSISetPathSpecificOption(const char *pszPathPrefix,
290 const char *pszKey, const char *pszValue);
291void CPL_DLL VSIClearPathSpecificOptions(const char *pszPathPrefix);
292const char CPL_DLL *VSIGetPathSpecificOption(const char *pszPath,
293 const char *pszKey,
294 const char *pszDefault);
295
296void CPL_DLL VSISetCredential(const char *pszPathPrefix, const char *pszKey,
297 const char *pszValue)
299 CPL_WARN_DEPRECATED("Use VSISetPathSpecificOption instead")
301 ;
302void CPL_DLL VSIClearCredentials(const char *pszPathPrefix)
304 CPL_WARN_DEPRECATED("Use VSIClearPathSpecificOptions instead")
306 ;
307const char CPL_DLL *VSIGetCredential(const char *pszPath, const char *pszKey,
308 const char *pszDefault)
310 CPL_WARN_DEPRECATED("Use VSIGetPathSpecificOption instead")
312 ;
313
314/* ==================================================================== */
315/* Memory allocation */
316/* ==================================================================== */
317
318void CPL_DLL *VSICalloc(size_t, size_t) CPL_WARN_UNUSED_RESULT;
319void CPL_DLL *VSIMalloc(size_t) CPL_WARN_UNUSED_RESULT;
320void CPL_DLL VSIFree(void *);
321void CPL_DLL *VSIRealloc(void *, size_t) CPL_WARN_UNUSED_RESULT;
322char CPL_DLL *VSIStrdup(const char *) CPL_WARN_UNUSED_RESULT;
323
324#if defined(__cplusplus)
325extern "C++"
326{
328 struct CPL_DLL VSIFreeReleaser
329 {
330 void operator()(void *p) const
331 {
332 VSIFree(p);
333 }
334 };
335
337}
338#endif
339
340void CPL_DLL *VSIMallocAligned(size_t nAlignment,
341 size_t nSize) CPL_WARN_UNUSED_RESULT;
342void CPL_DLL *VSIMallocAlignedAuto(size_t nSize) CPL_WARN_UNUSED_RESULT;
343void CPL_DLL VSIFreeAligned(void *ptr);
344
345void CPL_DLL *VSIMallocAlignedAutoVerbose(size_t nSize, const char *pszFile,
346 int nLine) CPL_WARN_UNUSED_RESULT;
348#define VSI_MALLOC_ALIGNED_AUTO_VERBOSE(size) \
349 VSIMallocAlignedAutoVerbose(size, __FILE__, __LINE__)
350
358void CPL_DLL *VSIMalloc2(size_t nSize1, size_t nSize2) CPL_WARN_UNUSED_RESULT;
359
368void CPL_DLL *VSIMalloc3(size_t nSize1, size_t nSize2,
369 size_t nSize3) CPL_WARN_UNUSED_RESULT;
370
372void CPL_DLL *VSIMallocVerbose(size_t nSize, const char *pszFile,
373 int nLine) CPL_WARN_UNUSED_RESULT;
375#define VSI_MALLOC_VERBOSE(size) VSIMallocVerbose(size, __FILE__, __LINE__)
376
378void CPL_DLL *VSIMalloc2Verbose(size_t nSize1, size_t nSize2,
379 const char *pszFile,
380 int nLine) CPL_WARN_UNUSED_RESULT;
382#define VSI_MALLOC2_VERBOSE(nSize1, nSize2) \
383 VSIMalloc2Verbose(nSize1, nSize2, __FILE__, __LINE__)
384
386void CPL_DLL *VSIMalloc3Verbose(size_t nSize1, size_t nSize2, size_t nSize3,
387 const char *pszFile,
388 int nLine) CPL_WARN_UNUSED_RESULT;
390#define VSI_MALLOC3_VERBOSE(nSize1, nSize2, nSize3) \
391 VSIMalloc3Verbose(nSize1, nSize2, nSize3, __FILE__, __LINE__)
392
394void CPL_DLL *VSICallocVerbose(size_t nCount, size_t nSize, const char *pszFile,
395 int nLine) CPL_WARN_UNUSED_RESULT;
397#define VSI_CALLOC_VERBOSE(nCount, nSize) \
398 VSICallocVerbose(nCount, nSize, __FILE__, __LINE__)
399
401void CPL_DLL *VSIReallocVerbose(void *pOldPtr, size_t nNewSize,
402 const char *pszFile,
403 int nLine) CPL_WARN_UNUSED_RESULT;
405#define VSI_REALLOC_VERBOSE(pOldPtr, nNewSize) \
406 VSIReallocVerbose(pOldPtr, nNewSize, __FILE__, __LINE__)
407
409char CPL_DLL *VSIStrdupVerbose(const char *pszStr, const char *pszFile,
410 int nLine) CPL_WARN_UNUSED_RESULT;
412#define VSI_STRDUP_VERBOSE(pszStr) VSIStrdupVerbose(pszStr, __FILE__, __LINE__)
413
414GIntBig CPL_DLL CPLGetPhysicalRAM(void);
415GIntBig CPL_DLL CPLGetUsablePhysicalRAM(void);
416
417/* ==================================================================== */
418/* Other... */
419/* ==================================================================== */
420
422#define CPLReadDir VSIReadDir
423char CPL_DLL **VSIReadDir(const char *);
424char CPL_DLL **VSIReadDirRecursive(const char *pszPath);
425char CPL_DLL **VSIReadDirEx(const char *pszPath, int nMaxFiles);
426char CPL_DLL **VSISiblingFiles(const char *pszPath);
427char CPL_DLL **VSIGlob(const char *pszPattern, const char *const *papszOptions,
428 GDALProgressFunc pProgressFunc, void *pProgressData);
429
430const char CPL_DLL *VSIGetDirectorySeparator(const char *pszPath);
431
433typedef struct VSIDIR VSIDIR;
434
435VSIDIR CPL_DLL *VSIOpenDir(const char *pszPath, int nRecurseDepth,
436 const char *const *papszOptions);
437
439typedef struct VSIDIREntry VSIDIREntry;
440
445{
447 char *pszName;
449 int nMode;
462
463#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
465 VSIDIREntry();
466 ~VSIDIREntry();
467 VSIDIREntry(const VSIDIREntry &);
468 VSIDIREntry &operator=(VSIDIREntry &) = delete;
470#endif
471};
472
473const VSIDIREntry CPL_DLL *VSIGetNextDirEntry(VSIDIR *dir);
474void CPL_DLL VSICloseDir(VSIDIR *dir);
475
476int CPL_DLL VSIMkdir(const char *pszPathname, long mode);
477int CPL_DLL VSIMkdirRecursive(const char *pszPathname, long mode);
478int CPL_DLL VSIRmdir(const char *pszDirname);
479int CPL_DLL VSIRmdirRecursive(const char *pszDirname);
480int CPL_DLL VSIUnlink(const char *pszFilename);
481int CPL_DLL *VSIUnlinkBatch(CSLConstList papszFiles);
482int CPL_DLL VSIRename(const char *oldpath, const char *newpath);
483int CPL_DLL VSIMove(const char *oldpath, const char *newpath,
484 const char *const *papszOptions,
485 GDALProgressFunc pProgressFunc, void *pProgressData);
486int CPL_DLL VSICopyFile(const char *pszSource, const char *pszTarget,
487 VSILFILE *fpSource, vsi_l_offset nSourceSize,
488 const char *const *papszOptions,
489 GDALProgressFunc pProgressFunc, void *pProgressData);
490int CPL_DLL VSICopyFileRestartable(const char *pszSource, const char *pszTarget,
491 const char *pszInputPayload,
492 char **ppszOutputPayload,
493 const char *const *papszOptions,
494 GDALProgressFunc pProgressFunc,
495 void *pProgressData);
496int CPL_DLL VSISync(const char *pszSource, const char *pszTarget,
497 const char *const *papszOptions,
498 GDALProgressFunc pProgressFunc, void *pProgressData,
499 char ***ppapszOutputs);
500
502 const char *pszFilename, int *pbNonSequentialUploadSupported,
503 int *pbParallelUploadSupported, int *pbAbortSupported,
504 size_t *pnMinPartSize, size_t *pnMaxPartSize, int *pnMaxPartCount);
505
506char CPL_DLL *VSIMultipartUploadStart(const char *pszFilename,
507 CSLConstList papszOptions);
508char CPL_DLL *VSIMultipartUploadAddPart(const char *pszFilename,
509 const char *pszUploadId,
510 int nPartNumber,
511 vsi_l_offset nFileOffset,
512 const void *pData, size_t nDataLength,
513 CSLConstList papszOptions);
514int CPL_DLL VSIMultipartUploadEnd(const char *pszFilename,
515 const char *pszUploadId, size_t nPartIdsCount,
516 const char *const *apszPartIds,
517 vsi_l_offset nTotalSize,
518 CSLConstList papszOptions);
519int CPL_DLL VSIMultipartUploadAbort(const char *pszFilename,
520 const char *pszUploadId,
521 CSLConstList papszOptions);
522
523int CPL_DLL VSIAbortPendingUploads(const char *pszFilename);
524
525char CPL_DLL *VSIStrerror(int);
526GIntBig CPL_DLL VSIGetDiskFreeSpace(const char *pszDirname);
527
528void CPL_DLL VSINetworkStatsReset(void);
529char CPL_DLL *VSINetworkStatsGetAsSerializedJSON(char **papszOptions);
530
531#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
532extern "C++"
533{
534 std::string CPL_DLL VSIURIToVSIPath(const std::string &osURI);
535}
536#endif
537
538/* ==================================================================== */
539/* Install special file access handlers. */
540/* ==================================================================== */
541void CPL_DLL VSIInstallMemFileHandler(void);
543void CPL_DLL VSIInstallLargeFileHandler(void);
545void CPL_DLL VSIInstallSubFileHandler(void);
547void CPL_DLL VSICurlClearCache(void);
548void CPL_DLL VSICurlPartialClearCache(const char *pszFilenamePrefix);
550void VSIInstallS3FileHandler(void);
552void VSIInstallGSFileHandler(void);
557void VSIInstallOSSFileHandler(void);
561void VSIInstall7zFileHandler(void); /* No reason to export that */
562void VSIInstallRarFileHandler(void); /* No reason to export that */
563void VSIInstallGZipFileHandler(void); /* No reason to export that */
564void VSIInstallZipFileHandler(void); /* No reason to export that */
565void VSIInstallStdinHandler(void); /* No reason to export that */
566void VSIInstallHdfsHandler(void); /* No reason to export that */
567void VSIInstallWebHdfsHandler(void); /* No reason to export that */
568void VSIInstallStdoutHandler(void); /* No reason to export that */
569void CPL_DLL VSIInstallSparseFileHandler(void);
570void VSIInstallTarFileHandler(void); /* No reason to export that */
571void VSIInstallCachedFileHandler(void); /* No reason to export that */
572void CPL_DLL VSIInstallCryptFileHandler(void);
573void CPL_DLL VSISetCryptKey(const GByte *pabyKey, int nKeySize);
575void CPL_DLL VSICleanupFileManager(void);
578bool CPL_DLL VSIDuplicateFileSystemHandler(const char *pszSourceFSName,
579 const char *pszNewFSName);
580
581VSILFILE CPL_DLL *
582VSIFileFromMemBuffer(const char *pszFilename, GByte *pabyData,
583 vsi_l_offset nDataLength,
584 int bTakeOwnership) CPL_WARN_UNUSED_RESULT;
585GByte CPL_DLL *VSIGetMemFileBuffer(const char *pszFilename,
586 vsi_l_offset *pnDataLength,
587 int bUnlinkAndSeize);
588
589const char CPL_DLL *VSIMemGenerateHiddenFilename(const char *pszFilename);
590
592typedef size_t (*VSIWriteFunction)(const void *ptr, size_t size, size_t nmemb,
593 FILE *stream);
594void CPL_DLL VSIStdoutSetRedirection(VSIWriteFunction pFct, FILE *stream);
595
600typedef int (*VSIFilesystemPluginStatCallback)(void *pUserData,
601 const char *pszFilename,
602 VSIStatBufL *pStatBuf,
603 int nFlags);
608typedef int (*VSIFilesystemPluginUnlinkCallback)(void *pUserData,
609 const char *pszFilename);
614typedef int (*VSIFilesystemPluginRenameCallback)(void *pUserData,
615 const char *oldpath,
616 const char *newpath);
621typedef int (*VSIFilesystemPluginMkdirCallback)(void *pUserData,
622 const char *pszDirname,
623 long nMode);
628typedef int (*VSIFilesystemPluginRmdirCallback)(void *pUserData,
629 const char *pszDirname);
634typedef char **(*VSIFilesystemPluginReadDirCallback)(void *pUserData,
635 const char *pszDirname,
636 int nMaxFiles);
646typedef char **(*VSIFilesystemPluginSiblingFilesCallback)(
647 void *pUserData, const char *pszDirname);
654typedef void *(*VSIFilesystemPluginOpenCallback)(void *pUserData,
655 const char *pszFilename,
656 const char *pszAccess);
666typedef int (*VSIFilesystemPluginSeekCallback)(void *pFile,
667 vsi_l_offset nOffset,
668 int nWhence);
674typedef size_t (*VSIFilesystemPluginReadCallback)(void *pFile, void *pBuffer,
675 size_t nSize, size_t nCount);
682 void *pFile, int nRanges, void **ppData, const vsi_l_offset *panOffsets,
683 const size_t *panSizes);
689 void *pFile, vsi_l_offset nOffset, vsi_l_offset nLength);
694typedef int (*VSIFilesystemPluginEofCallback)(void *pFile);
699typedef size_t (*VSIFilesystemPluginWriteCallback)(void *pFile,
700 const void *pBuffer,
701 size_t nSize, size_t nCount);
706typedef int (*VSIFilesystemPluginFlushCallback)(void *pFile);
710typedef int (*VSIFilesystemPluginTruncateCallback)(void *pFile,
711 vsi_l_offset nNewSize);
716typedef int (*VSIFilesystemPluginCloseCallback)(void *pFile);
717
733 void *pFile, int nRanges, const vsi_l_offset *panOffsets,
734 const size_t *panSizes);
735
740typedef int (*VSIFilesystemPluginErrorCallback)(void *pFile);
741
746typedef void (*VSIFilesystemPluginClearErrCallback)(void *pFile);
747
803
811
818
825int CPL_DLL VSIInstallPluginHandler(
826 const char *pszPrefix, const VSIFilesystemPluginCallbacksStruct *poCb);
827
837int CPL_DLL VSIRemovePluginHandler(const char *pszPrefix);
838
839/* ==================================================================== */
840/* Time querying. */
841/* ==================================================================== */
842
844unsigned long CPL_DLL VSITime(unsigned long *);
845const char CPL_DLL *VSICTime(unsigned long);
846struct tm CPL_DLL *VSIGMTime(const time_t *pnTime, struct tm *poBrokenTime);
847struct tm CPL_DLL *VSILocalTime(const time_t *pnTime, struct tm *poBrokenTime);
851/* -------------------------------------------------------------------- */
852/* the following can be turned on for detailed logging of */
853/* almost all IO calls. */
854/* -------------------------------------------------------------------- */
855#ifdef VSI_DEBUG
856
857#ifndef DEBUG
858#define DEBUG
859#endif
860
861#include "cpl_error.h"
862
863#define VSIDebug4(f, a1, a2, a3, a4) CPLDebug("VSI", f, a1, a2, a3, a4);
864#define VSIDebug3(f, a1, a2, a3) CPLDebug("VSI", f, a1, a2, a3);
865#define VSIDebug2(f, a1, a2) CPLDebug("VSI", f, a1, a2);
866#define VSIDebug1(f, a1) CPLDebug("VSI", f, a1);
867#else
868#define VSIDebug4(f, a1, a2, a3, a4) \
869 { \
870 }
871#define VSIDebug3(f, a1, a2, a3) \
872 { \
873 }
874#define VSIDebug2(f, a1, a2) \
875 { \
876 }
877#define VSIDebug1(f, a1) \
878 { \
879 }
880#endif
884
885#endif /* ndef CPL_VSI_H_INCLUDED */
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:198
#define CPL_C_END
Macro to end a block of C symbols.
Definition cpl_port.h:279
#define CPL_C_START
Macro to start a block of C symbols.
Definition cpl_port.h:275
#define CPL_FORMAT_STRING(arg)
Macro into which to wrap the format argument of a printf-like function.
Definition cpl_port.h:1025
#define CPL_PRINT_FUNC_FORMAT(format_idx, arg_idx)
Tag a function to have printf() formatting.
Definition cpl_port.h:1009
char ** CSLConstList
Type of a constant null-terminated list of nul terminated strings.
Definition cpl_port.h:1252
#define CPL_WARN_UNUSED_RESULT
Qualifier to warn when the return value of a function is not used.
Definition cpl_port.h:1035
unsigned char GByte
Unsigned byte type.
Definition cpl_port.h:165
long long GIntBig
Large signed integer type (generally 64-bit integer type).
Definition cpl_port.h:195
#define VSIStatBufL
Type for VSIStatL()
Definition cpl_vsi.h:232
void * VSICallocVerbose(size_t nCount, size_t nSize, const char *pszFile, int nLine)
VSICallocVerbose.
Definition cpl_vsisimple.cpp:1204
int VSISetFileMetadata(const char *pszFilename, CSLConstList papszMetadata, const char *pszDomain, CSLConstList papszOptions)
Set metadata on files.
Definition cpl_vsil.cpp:1755
int * VSIUnlinkBatch(CSLConstList papszFiles)
Delete several files, possibly in a batch.
Definition cpl_vsil.cpp:764
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:3659
void VSINetworkStatsReset(void)
Clear network related statistics.
Definition cpl_vsil_curl.cpp:6717
void VSIInstallCachedFileHandler(void)
Install /vsicached? file system handler.
Definition cpl_vsil_cache.cpp:741
size_t(* VSIWriteFunction)(const void *ptr, size_t size, size_t nmemb, FILE *stream)
Callback used by VSIStdoutSetRedirection()
Definition cpl_vsi.h:592
void VSIInstallS3StreamingFileHandler(void)
Install /vsis3_streaming/ Amazon S3 file system handler (requires libcurl).
Definition cpl_vsil_curl_streaming.cpp:2131
std::string VSIURIToVSIPath(const std::string &osURI)
Return a VSI compatible path from a URI / URL.
Definition cpl_vsil.cpp:4537
char ** VSISiblingFiles(const char *pszPath)
Return related filenames.
Definition cpl_vsil.cpp:133
int VSIFFlushL(VSILFILE *)
Flush pending writes to disk.
Definition cpl_vsil.cpp:3119
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:681
const char * VSIGetDirectorySeparator(const char *pszPath)
Return the directory separator for the specified path.
Definition cpl_vsil.cpp:421
vsi_l_offset VSIFTellL(VSILFILE *)
Tell current file offset.
Definition cpl_vsil.cpp:3050
int VSIRename(const char *oldpath, const char *newpath)
Rename a file.
Definition cpl_vsil.cpp:814
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:4019
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:963
size_t VSIFWriteL(const void *, size_t, size_t, VSILFILE *)
Write bytes to file.
Definition cpl_vsil.cpp:3238
VSIRangeStatus
Range status.
Definition cpl_vsi.h:211
@ VSI_RANGE_STATUS_DATA
Data present.
Definition cpl_vsi.h:213
@ VSI_RANGE_STATUS_HOLE
Hole.
Definition cpl_vsi.h:214
@ VSI_RANGE_STATUS_UNKNOWN
Unknown.
Definition cpl_vsi.h:212
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:1343
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:674
void VSIInstallStdinHandler(void)
Install /vsistdin/ file system handler.
Definition cpl_vsil_stdin.cpp:673
bool VSISupportsRandomWrite(const char *pszPath, bool bAllowLocalTempFile)
Returns if the filesystem supports random write.
Definition cpl_vsil.cpp:1917
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:3402
void * VSICalloc(size_t, size_t)
Analog of calloc().
Definition cpl_vsisimple.cpp:434
vsi_l_offset(* VSIFilesystemPluginTellCallback)(void *pFile)
Return current position in handle.
Definition cpl_vsi.h:661
int VSIIsCaseSensitiveFS(const char *pszFilename)
Returns if the filenames of the filesystem are case sensitive.
Definition cpl_vsil.cpp:1788
void VSIInstallGZipFileHandler(void)
Install GZip file system handler.
Definition cpl_vsil_gzip.cpp:3284
void * VSIMalloc2Verbose(size_t nSize1, size_t nSize2, const char *pszFile, int nLine)
VSIMalloc2Verbose.
Definition cpl_vsisimple.cpp:1155
void VSIFClearErrL(VSILFILE *)
Reset the error and end-of-file indicators.
Definition cpl_vsil.cpp:3364
int VSIHasOptimizedReadMultiRange(const char *pszPath)
Returns if the filesystem supports efficient multi-range reading.
Definition cpl_vsil.cpp:1941
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:732
char **(* VSIFilesystemPluginReadDirCallback)(void *pUserData, const char *pszDirname, int nMaxFiles)
List directory content.
Definition cpl_vsi.h:634
void VSIFreeFilesystemPluginCallbacksStruct(VSIFilesystemPluginCallbacksStruct *poCb)
free resources allocated by VSIAllocFilesystemPluginCallbacksStruct
Definition cpl_vsil_plugin.cpp:506
int(* VSIFilesystemPluginRenameCallback)(void *pUserData, const char *oldpath, const char *newpath)
Rename handle.
Definition cpl_vsi.h:614
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:4056
int VSIRemovePluginHandler(const char *pszPrefix)
Unregister a handler previously installed with VSIInstallPluginHandler() on the given prefix.
Definition cpl_vsil_plugin.cpp:493
void VSIInstallCurlFileHandler(void)
Install /vsicurl/ HTTP/FTP file system handler (requires libcurl)
Definition cpl_vsil_curl.cpp:6624
void * VSIMallocVerbose(size_t nSize, const char *pszFile, int nLine)
VSIMallocVerbose.
Definition cpl_vsisimple.cpp:1138
void VSIInstallWebHdfsHandler(void)
Install /vsiwebhdfs/ WebHDFS (Hadoop File System) REST API file system handler (requires libcurl)
Definition cpl_vsil_webhdfs.cpp:1203
bool VSISupportsSequentialWrite(const char *pszPath, bool bAllowLocalTempFile)
Returns if the filesystem supports sequential write.
Definition cpl_vsil.cpp:1893
int VSIFErrorL(VSILFILE *)
Test the error indicator.
Definition cpl_vsil.cpp:3329
void VSIInstallS3FileHandler(void)
Install /vsis3/ Amazon S3 file system handler (requires libcurl)
Definition cpl_vsil_s3.cpp:5448
void VSIInstallHdfsHandler(void)
Install /vsihdfs/ file system handler (requires JVM and HDFS support)
Definition cpl_vsil_hdfs.cpp:465
void VSIInstallCryptFileHandler(void)
Install /vsicrypt/ encrypted file system handler (requires libcrypto++)
Definition cpl_vsil_crypt.cpp:2042
char ** VSIGetFileSystemsPrefixes(void)
Return the list of prefixes for virtual file system handlers currently registered.
Definition cpl_vsil.cpp:3976
int VSIOverwriteFile(VSILFILE *fpTarget, const char *pszSourceFilename)
Overwrite an existing file with content from another one.
Definition cpl_vsil.cpp:3867
void VSIInstallSwiftStreamingFileHandler(void)
Install /vsiswift_streaming/ OpenStack Swif Object Storage (Swift) file system handler (requires libc...
Definition cpl_vsil_curl_streaming.cpp:2213
void VSISetCryptKey(const GByte *pabyKey, int nKeySize)
Installs the encryption/decryption key.
Definition cpl_vsil_crypt.cpp:189
void * VSIMallocAlignedAutoVerbose(size_t nSize, const char *pszFile, int nLine)
See VSIMallocAlignedAuto()
Definition cpl_vsisimple.cpp:959
void VSIInstallStdoutHandler(void)
Install /vsistdout/ file system handler.
Definition cpl_vsil_stdout.cpp:448
int VSIMkdirRecursive(const char *pszPathname, long mode)
Create a directory and all its ancestors.
Definition cpl_vsil.cpp:645
void VSIInstallMemFileHandler(void)
Install "memory" file system handler.
Definition cpl_vsi_mem.cpp:1158
int VSIFPutcL(int, VSILFILE *)
Write a single byte to the file.
Definition cpl_vsil.cpp:3609
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:1162
void * VSIMalloc2(size_t nSize1, size_t nSize2)
VSIMalloc2 allocates (nSize1 * nSize2) bytes.
Definition cpl_vsisimple.cpp:1116
int(* VSIFilesystemPluginCloseCallback)(void *pFile)
Close file handle.
Definition cpl_vsi.h:716
struct VSIDIR VSIDIR
Opaque type for a directory iterator.
Definition cpl_vsi.h:433
void VSICurlClearCache(void)
Clean local cache associated with /vsicurl/ (and related file systems)
Definition cpl_vsil_curl.cpp:6649
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:6694
int VSIIngestFile(VSILFILE *fp, const char *pszFilename, GByte **ppabyRet, vsi_l_offset *pnSize, GIntBig nMaxSize)
Ingest a file into memory.
Definition cpl_vsil.cpp:3693
VSILFILE * VSIFOpenExL(const char *, const char *, int)
Open/create file.
Definition cpl_vsil.cpp:2818
int VSISupportsSparseFiles(const char *pszPath)
Returns if the filesystem supports sparse files.
Definition cpl_vsil.cpp:1816
int VSIMultipartUploadAbort(const char *pszFilename, const char *pszUploadId, CSLConstList papszOptions)
Aborts a multi-part file upload.
Definition cpl_vsil.cpp:1378
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:1306
int(* VSIFilesystemPluginMkdirCallback)(void *pUserData, const char *pszDirname, long nMode)
Create Directory.
Definition cpl_vsi.h:621
void * VSIRealloc(void *, size_t)
Analog of realloc().
Definition cpl_vsisimple.cpp:680
int(* VSIFilesystemPluginTruncateCallback)(void *pFile, vsi_l_offset nNewSize)
Truncate handle.
Definition cpl_vsi.h:710
VSIFilesystemPluginCallbacksStruct * VSIAllocFilesystemPluginCallbacksStruct(void)
return a VSIFilesystemPluginCallbacksStruct to be populated at runtime with handler callbacks
Definition cpl_vsil_plugin.cpp:500
size_t(* VSIFilesystemPluginWriteCallback)(void *pFile, const void *pBuffer, size_t nSize, size_t nCount)
Write bytes at current offset.
Definition cpl_vsi.h:699
char **(* VSIFilesystemPluginSiblingFilesCallback)(void *pUserData, const char *pszDirname)
List related files.
Definition cpl_vsi.h:646
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:1219
void VSICloseDir(VSIDIR *dir)
Close a directory.
Definition cpl_vsil.cpp:599
int VSIUnlink(const char *pszFilename)
Delete a file.
Definition cpl_vsil.cpp:733
void * VSIMalloc3(size_t nSize1, size_t nSize2, size_t nSize3)
VSIMalloc3 allocates (nSize1 * nSize2 * nSize3) bytes.
Definition cpl_vsisimple.cpp:1129
int VSIFCloseL(VSILFILE *)
Close file.
Definition cpl_vsil.cpp:2951
VSIDIR * VSIOpenDir(const char *pszPath, int nRecurseDepth, const char *const *papszOptions)
Open a directory to read its entries.
Definition cpl_vsil.cpp:542
GByte * VSIGetMemFileBuffer(const char *pszFilename, vsi_l_offset *pnDataLength, int bUnlinkAndSeize)
Fetch buffer underlying memory file.
Definition cpl_vsi_mem.cpp:1279
void VSIInstallSwiftFileHandler(void)
Install /vsiswift/ OpenStack Swif Object Storage (Swift) file system handler (requires libcurl)
Definition cpl_vsil_swift.cpp:739
void VSIInstallZipFileHandler(void)
Install ZIP file system handler.
Definition cpl_vsil_gzip.cpp:4927
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:4124
VSIRangeStatus(* VSIFilesystemPluginGetRangeStatusCallback)(void *pFile, vsi_l_offset nOffset, vsi_l_offset nLength)
Get empty ranges.
Definition cpl_vsi.h:688
void * VSIFGetNativeFileDescriptorL(VSILFILE *)
Returns the "native" file descriptor for the virtual handle.
Definition cpl_vsil.cpp:3938
char * VSIGetCanonicalFilename(const char *pszPath)
Returns the canonical filename.
Definition cpl_vsil.cpp:1869
int(* VSIFilesystemPluginSeekCallback)(void *pFile, vsi_l_offset nOffset, int nWhence)
Seek to position in handle.
Definition cpl_vsi.h:666
void VSIClearCredentials(const char *pszPathPrefix)
Clear path specific options set with VSISetPathSpecificOption()
Definition cpl_vsil.cpp:4083
int(* VSIFilesystemPluginStatCallback)(void *pUserData, const char *pszFilename, VSIStatBufL *pStatBuf, int nFlags)
Return information about a handle.
Definition cpl_vsi.h:600
void VSIInstallOSSStreamingFileHandler(void)
Install /vsiaz_streaming/ Alibaba Cloud Object Storage Service (OSS) (requires libcurl)
Definition cpl_vsil_curl_streaming.cpp:2192
char ** VSIReadDirEx(const char *pszPath, int nMaxFiles)
Read names in a directory.
Definition cpl_vsil.cpp:105
void * VSIMallocAligned(size_t nAlignment, size_t nSize)
Allocates a buffer with an alignment constraint.
Definition cpl_vsisimple.cpp:897
char * VSIGetSignedURL(const char *pszFilename, CSLConstList papszOptions)
Returns a signed URL of a supplied filename.
Definition cpl_vsil.cpp:2012
void(* VSIFilesystemPluginClearErrCallback)(void *pFile)
Clear error and end-of-file flags.
Definition cpl_vsi.h:746
int VSIInstallPluginHandler(const char *pszPrefix, const VSIFilesystemPluginCallbacksStruct *poCb)
register a handler on the given prefix.
Definition cpl_vsil_plugin.cpp:483
const char * VSIGetActualURL(const char *pszFilename)
Returns the actual URL of a supplied filename.
Definition cpl_vsil.cpp:1969
int VSIRmdirRecursive(const char *pszDirname)
Delete a directory recursively.
Definition cpl_vsil.cpp:1532
int VSIMkdir(const char *pszPathname, long mode)
Create a directory.
Definition cpl_vsil.cpp:624
void * VSIReallocVerbose(void *pOldPtr, size_t nNewSize, const char *pszFile, int nLine)
VSIReallocVerbose.
Definition cpl_vsisimple.cpp:1223
void *(* VSIFilesystemPluginOpenCallback)(void *pUserData, const char *pszFilename, const char *pszAccess)
Open a handle.
Definition cpl_vsi.h:654
size_t VSIFReadL(void *, size_t, size_t, VSILFILE *)
Read bytes from file.
Definition cpl_vsil.cpp:3151
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:3207
void VSIInstallCurlStreamingFileHandler(void)
Install /vsicurl_streaming/ HTTP/FTP file system handler (requires libcurl).
Definition cpl_vsil_curl_streaming.cpp:2111
char * VSIStrdup(const char *)
Analog of strdup().
Definition cpl_vsisimple.cpp:1001
VSILFILE * VSIFOpenL(const char *, const char *)
Open file.
Definition cpl_vsil.cpp:2048
int VSIFEofL(VSILFILE *)
Test for end of file.
Definition cpl_vsil.cpp:3282
void VSIInstallSparseFileHandler(void)
Install /vsisparse/ virtual file handler.
Definition cpl_vsil_sparsefile.cpp:580
char ** VSIGlob(const char *pszPattern, const char *const *papszOptions, GDALProgressFunc pProgressFunc, void *pProgressData)
Return a list of file and directory names matching a pattern that can contain wildcards.
Definition cpl_vsil.cpp:290
void VSIInstallSubFileHandler(void)
Install /vsisubfile/ virtual file handler.
Definition cpl_vsil_subfile.cpp:500
void VSIRewindL(VSILFILE *)
Rewind the file pointer to the beginning of the file.
Definition cpl_vsil.cpp:3070
char ** VSIReadDir(const char *)
Read names in a directory.
Definition cpl_vsil.cpp:72
void * VSIMalloc3Verbose(size_t nSize1, size_t nSize2, size_t nSize3, const char *pszFile, int nLine)
VSIMalloc3Verbose.
Definition cpl_vsisimple.cpp:1179
int(* VSIFilesystemPluginUnlinkCallback)(void *pUserData, const char *pszFilename)
Remove handle by name.
Definition cpl_vsi.h:608
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:1364
bool VSIDuplicateFileSystemHandler(const char *pszSourceFSName, const char *pszNewFSName)
Duplicate an existing file system handler.
Definition cpl_vsil.cpp:4183
void VSIInstallADLSFileHandler(void)
Install /vsiaz/ Microsoft Azure Data Lake Storage Gen2 file system handler (requires libcurl)
Definition cpl_vsil_adls.cpp:2189
GIntBig CPLGetUsablePhysicalRAM(void)
Return the total physical RAM, usable by a process, in bytes.
Definition cpl_vsisimple.cpp:1618
int VSIStatL(const char *, VSIStatBufL *)
Get filesystem object info.
Definition cpl_vsil.cpp:1568
char ** VSIReadDirRecursive(const char *pszPath)
Read names in a directory recursively.
Definition cpl_vsil.cpp:460
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:1056
void VSIInstallGSStreamingFileHandler(void)
Install /vsigs_streaming/ Google Cloud Storage file system handler (requires libcurl)
Definition cpl_vsil_curl_streaming.cpp:2151
int(* VSIFilesystemPluginEofCallback)(void *pFile)
Has end of file been reached.
Definition cpl_vsi.h:694
int VSIMove(const char *oldpath, const char *newpath, const char *const *papszOptions, GDALProgressFunc pProgressFunc, void *pProgressData)
Move (or rename) a file.
Definition cpl_vsil.cpp:848
int VSIFPrintfL(VSILFILE *, const char *,...)
Formatted write to file.
Definition cpl_vsil.cpp:3426
int VSIStatExL(const char *pszFilename, VSIStatBufL *psStatBuf, int nFlags)
Get filesystem object info.
Definition cpl_vsil.cpp:1607
char * VSINetworkStatsGetAsSerializedJSON(char **papszOptions)
Return network related statistics, as a JSON serialized object.
Definition cpl_vsil_curl.cpp:6816
void VSIInstallOSSFileHandler(void)
Install /vsioss/ Alibaba Cloud Object Storage Service (OSS) file system handler (requires libcurl)
Definition cpl_vsil_oss.cpp:319
GIntBig VSIGetDiskFreeSpace(const char *pszDirname)
Return free disk space available on the filesystem.
Definition cpl_vsil.cpp:3956
VSILFILE * VSIFOpenEx2L(const char *, const char *, int, CSLConstList)
Open/create file.
Definition cpl_vsil.cpp:2896
void VSIInstallTarFileHandler(void)
Install /vsitar/ file system handler.
Definition cpl_vsil_tar.cpp:625
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:3995
void VSIFreeAligned(void *ptr)
Free a buffer allocated with VSIMallocAligned().
Definition cpl_vsisimple.cpp:981
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:946
int VSIAbortPendingUploads(const char *pszFilename)
Abort all ongoing multi-part uploads.
Definition cpl_vsil.cpp:1480
void VSIStdoutSetRedirection(VSIWriteFunction pFct, FILE *stream)
Set an alternative write function and output file handle instead of fwrite() / stdout.
Definition cpl_vsil_stdout.cpp:42
const char * VSIGetPathSpecificOption(const char *pszPath, const char *pszKey, const char *pszDefault)
Get the value a path specific option.
Definition cpl_vsil.cpp:4143
void * VSIMalloc(size_t)
Analog of malloc().
Definition cpl_vsisimple.cpp:550
int VSIFSeekL(VSILFILE *, vsi_l_offset, int)
Seek to requested offset.
Definition cpl_vsil.cpp:3009
int(* VSIFilesystemPluginFlushCallback)(void *pFile)
Sync written bytes.
Definition cpl_vsi.h:706
VSILFILE * VSIFileFromMemBuffer(const char *pszFilename, GByte *pabyData, vsi_l_offset nDataLength, int bTakeOwnership)
Create memory "file" from a buffer.
Definition cpl_vsi_mem.cpp:1191
bool VSIIsLocal(const char *pszPath)
Returns if the file/filesystem is "local".
Definition cpl_vsil.cpp:1844
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:1357
int VSIRmdir(const char *pszDirname)
Delete a directory.
Definition cpl_vsil.cpp:1507
void VSIInstallAzureFileHandler(void)
Install /vsiaz/ Microsoft Azure Blob file system handler (requires libcurl)
Definition cpl_vsil_az.cpp:2616
void VSIFree(void *)
Analog of free() for data allocated with VSIMalloc(), VSICalloc(), VSIRealloc().
Definition cpl_vsisimple.cpp:833
char * VSIStrdupVerbose(const char *pszStr, const char *pszFile, int nLine)
VSIStrdupVerbose.
Definition cpl_vsisimple.cpp:1241
void VSIClearPathSpecificOptions(const char *pszPathPrefix)
Clear path specific options set with VSISetPathSpecificOption()
Definition cpl_vsil.cpp:4101
GUIntBig vsi_l_offset
Type for a file offset.
Definition cpl_vsi.h:136
const VSIDIREntry * VSIGetNextDirEntry(VSIDIR *dir)
Return the next entry of the directory.
Definition cpl_vsil.cpp:581
char * VSIMultipartUploadStart(const char *pszFilename, CSLConstList papszOptions)
Initiates the upload a (big) file in a piece-wise way.
Definition cpl_vsil.cpp:1268
void VSIInstallGSFileHandler(void)
Install /vsigs/ Google Cloud Storage file system handler (requires libcurl)
Definition cpl_vsil_gs.cpp:969
int(* VSIFilesystemPluginErrorCallback)(void *pFile)
Has a read error (non end-of-file related) has occurred?
Definition cpl_vsi.h:740
void VSIInstallAzureStreamingFileHandler(void)
Install /vsiaz_streaming/ Microsoft Azure Blob file system handler (requires libcurl)
Definition cpl_vsil_curl_streaming.cpp:2171
char ** VSIGetFileMetadata(const char *pszFilename, const char *pszDomain, CSLConstList papszOptions)
Get metadata on files.
Definition cpl_vsil.cpp:1685
int(* VSIFilesystemPluginRmdirCallback)(void *pUserData, const char *pszDirname)
Delete Directory.
Definition cpl_vsi.h:628
Directory entry.
Definition cpl_vsi.h:445
char * pszName
Filename.
Definition cpl_vsi.h:447
GIntBig nMTime
Last modification time (seconds since 1970/01/01)
Definition cpl_vsi.h:453
char bMTimeKnown
Whether nMTime is known: 0 = unknown, 1 = known.
Definition cpl_vsi.h:459
char bSizeKnown
Whether nSize is known: 0 = unknown, 1 = known.
Definition cpl_vsi.h:457
char bModeKnown
Whether nMode is known: 0 = unknown, 1 = known.
Definition cpl_vsi.h:455
char ** papszExtra
NULL-terminated list of extra properties.
Definition cpl_vsi.h:461
vsi_l_offset nSize
File size.
Definition cpl_vsi.h:451
int nMode
File mode.
Definition cpl_vsi.h:449
struct containing callbacks to used by the handler.
Definition cpl_vsi.h:756
VSIFilesystemPluginAdviseReadCallback advise_read
The following optional member has been added in GDAL 3.7:
Definition cpl_vsi.h:792
VSIFilesystemPluginWriteCallback write
write bytes to current position (w)
Definition cpl_vsi.h:782
size_t nBufferSize
buffer small reads (makes handler read only)
Definition cpl_vsi.h:786
VSIFilesystemPluginRenameCallback rename
rename handle ()
Definition cpl_vsi.h:764
VSIFilesystemPluginReadMultiRangeCallback read_multi_range
read multiple blocks ()
Definition cpl_vsi.h:776
VSIFilesystemPluginUnlinkCallback unlink
unlink handle by name ()
Definition cpl_vsi.h:763
VSIFilesystemPluginRmdirCallback rmdir
remove directory ()
Definition cpl_vsi.h:766
VSIFilesystemPluginClearErrCallback clear_err
clear error flags(r)
Definition cpl_vsi.h:795
size_t nCacheSize
max mem to use per file when buffering
Definition cpl_vsi.h:787
VSIFilesystemPluginEofCallback eof
has end of file been reached (r?)
Definition cpl_vsi.h:780
VSIFilesystemPluginSiblingFilesCallback sibling_files
list related files
Definition cpl_vsi.h:789
VSIFilesystemPluginOpenCallback open
open handle by name (rw)
Definition cpl_vsi.h:769
VSIFilesystemPluginSeekCallback seek
set current position of handle (rw)
Definition cpl_vsi.h:773
VSIFilesystemPluginGetRangeStatusCallback get_range_status
get range status ()
Definition cpl_vsi.h:778
VSIFilesystemPluginCloseCallback close
close handle (rw)
Definition cpl_vsi.h:785
VSIFilesystemPluginReadCallback read
read from current position (r)
Definition cpl_vsi.h:774
VSIFilesystemPluginFlushCallback flush
sync bytes (w)
Definition cpl_vsi.h:783
VSIFilesystemPluginReadDirCallback read_dir
list directory content (r?)
Definition cpl_vsi.h:768
void * pUserData
Optional opaque pointer passed back to filemanager callbacks (e.g.
Definition cpl_vsi.h:761
VSIFilesystemPluginErrorCallback error
has read error occurred (r)
Definition cpl_vsi.h:794
VSIFilesystemPluginTruncateCallback truncate
truncate handle (w?)
Definition cpl_vsi.h:784
VSIFilesystemPluginMkdirCallback mkdir
make directory ()
Definition cpl_vsi.h:765
VSIFilesystemPluginStatCallback stat
stat handle by name (rw)
Definition cpl_vsi.h:762
VSIFilesystemPluginTellCallback tell
get current position of handle (rw)
Definition cpl_vsi.h:771
Virtual file handle.
Definition cpl_vsi_virtual.h:48