|
LibreOffice
LibreOffice 25.8 SDK C/C++ API Reference
|
Go to the documentation of this file.
24 #ifndef INCLUDED_OSL_FILE_HXX
25 #define INCLUDED_OSL_FILE_HXX
39 namespace rtl {
class ByteSequence; }
171 return static_cast< RC >(
osl_getAbsoluteFileURL( ustrBaseDirectoryURL.pData, ustrRelativeFileURL.pData, &ustrAbsoluteFileURL.pData ) );
241 return static_cast< RC >(
osl_searchFileURL( ustrFileName.pData, ustrSearchPath.pData, &ustrFileURL.pData ) );
310 rtl_uString* pustr_dir_url = pustrDirectoryURL ? pustrDirectoryURL->pData : NULL;
311 rtl_uString** ppustr_tmp_file_url = pustrTempFileURL ? &pustrTempFileURL->pData : NULL;
344 _aHandle = rDevice._aHandle;
374 _aHandle = newHandle;
673 memset(&_aStatus, 0,
sizeof(_aStatus));
712 "no FileStatus Type determined");
769 "no FileStatus Attributes determined");
784 "no FileStatus CreationTime determined");
799 "no FileStatus AccessTime determined");
814 "no FileStatus ModifyTime determined");
828 "no FileStatus FileSize determined");
842 "no FileStatus FileName determined");
859 "no FileStatus FileURL determined");
875 "no FileStatus LinkTargetURL determined");
913 File( const ::rtl::OUString& ustrFileURL ): _pData( NULL ), _aPath( ustrFileURL ) {}
976 return static_cast< RC >(
osl_openFile( _aPath.pData, &_pData, uFlags ) );
1002 return static_cast< RC >( Error );
1149 RC read(
void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64& rBytesRead )
1151 return static_cast< RC >(
osl_readFile( _pData, pBuffer, uBytesRequested, &rBytesRead ) );
1187 RC write(
const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64& rBytesWritten)
1189 return static_cast< RC >(
osl_writeFile( _pData, pBuffer, uBytesToWrite, &rBytesWritten ) );
1242 SAL_WARN_IF(!_pData,
"sal.osl",
"File::sync(): File not open");
1271 static RC copy( const ::rtl::OUString& ustrSourceFileURL, const ::rtl::OUString& ustrDestFileURL )
1273 return static_cast< RC >(
osl_copyFile( ustrSourceFileURL.pData, ustrDestFileURL.pData ) );
1299 static RC move( const ::rtl::OUString& ustrSourceFileURL, const ::rtl::OUString& ustrDestFileURL )
1301 return static_cast< RC >(
osl_moveFile( ustrSourceFileURL.pData, ustrDestFileURL.pData ) );
1332 const ::rtl::OUString& ustrDestFileURL)
1334 return static_cast<RC>(
osl_replaceFile(ustrSourceFileURL.pData, ustrDestFileURL.pData));
1410 const ::rtl::OUString& ustrFileURL,
1419 &rLastWriteTime ) );
1472 _pData = rItem._pData;
1488 return _pData != NULL;
1529 rItem._pData = NULL;
1568 return static_cast< RC >(
osl_getFileStatus( _pData, &rStatus._aStatus, rStatus._nMask ) );
1660 Directory( const ::rtl::OUString& strPath ): _pData( NULL ), _aPath( strPath )
1736 return static_cast< RC >( Error );
1789 rItem._pData = NULL;
1861 const ::rtl::OUString& ustrDirectoryURL,
1864 return static_cast< RC >(
1894 static RC remove( const ::rtl::OUString& ustrDirectoryURL )
1936 const ::rtl::OUString& aDirectoryUrl,
1940 aDirectoryUrl.pData,
1942 aDirectoryCreationObserver));
1948 #endif // INCLUDED_OSL_FILE_HXX
@ osl_File_E_NXIO
Definition: file.h:96
void * oslFileHandle
Definition: file.h:630
~File()
Destructor.
Definition: file.hxx:918
sal_uInt64 uFreeSpace
Free space on the volume for the current process/user.
Definition: file.h:577
static RC remove(const ::rtl::OUString &ustrFileURL)
Remove a regular file.
Definition: file.hxx:1363
@ osl_File_Type_Fifo
Definition: file.h:332
@ E_NOENT
no such file or directory
Definition: file.hxx:59
@ E_NOMEM
no memory available
Definition: file.hxx:69
@ E_MFILE
process has too many distinct files open
Definition: file.hxx:80
Definition: socket_decl.hxx:198
VolumeDevice & operator=(const VolumeDevice &rDevice)
Assignment operator.
Definition: file.hxx:364
@ E_2BIG
argument list too long
Definition: file.hxx:64
bool getRemoveableFlag() const
Check the removable flag.
Definition: file.hxx:469
@ osl_File_E_NFILE
Definition: file.h:112
Time since Jan-01-1970.
Definition: time.h:76
The FileStatus class.
Definition: file.hxx:638
SAL_DLLPUBLIC oslFileError osl_openDirectory(rtl_uString *pustrDirectoryURL, oslDirectory *pDirectory)
Open a directory for enumerating its contents.
static RC move(const ::rtl::OUString &ustrSourceFileURL, const ::rtl::OUString &ustrDestFileURL)
Move a file or directory to a new destination or renames it.
Definition: file.hxx:1299
SAL_DLLPUBLIC oslFileError osl_getTempDirURL(rtl_uString **pustrTempDirURL)
Retrieves the file URL of the system's temporary directory path.
VolumeDevice(const VolumeDevice &rDevice)
Copy constructor.
Definition: file.hxx:342
@ osl_File_E_invalidError
Definition: file.h:135
Base class for all File System specific objects.
Definition: file.hxx:53
#define osl_FileStatus_Mask_Type
Definition: file.h:364
struct _oslVolumeInfo oslVolumeInfo
Structure containing information about volumes.
#define SAL_INFO_IF(condition, area, stream)
Produce log entry from stream in the given log area if condition is true.
Definition: log.hxx:353
static RC getTempDirURL(::rtl::OUString &ustrTempDirURL)
Retrieves the file URL of the system's temporary directory path.
Definition: file.hxx:253
SAL_DLLPUBLIC oslFileError osl_setFileAttributes(rtl_uString *pustrFileURL, sal_uInt64 uAttributes)
Set file attributes.
Definition: condition.hxx:31
@ osl_File_E_ISDIR
Definition: file.h:110
@ osl_File_E_OVERFLOW
Definition: file.h:133
@ osl_File_Type_Special
Definition: file.h:335
@ osl_File_E_NOTEMPTY
Definition: file.h:127
#define osl_Volume_Attribute_RAMDisk
Definition: file.h:532
void onDirectoryCreated(void *pData, rtl_uString *aDirectoryUrl)
Definition: file.hxx:1625
@ osl_File_E_DEADLK
Definition: file.h:123
@ E_INVAL
invalid argument to library function
Definition: file.hxx:78
@ osl_File_E_RANGE
Definition: file.h:122
@ osl_File_E_LOOP
Definition: file.h:128
FileStatus(sal_uInt32 nMask)
Constructor.
Definition: file.hxx:670
@ osl_File_E_NETWORK
Definition: file.h:137
RC close()
Close an open file.
Definition: file.hxx:992
RC
Definition: file.hxx:56
Structure containing information about files and directories.
Definition: file.h:382
Main goals and usage hints.
static RC remove(const ::rtl::OUString &ustrDirectoryURL)
Remove an empty directory.
Definition: file.hxx:1894
@ osl_File_E_NOLCK
Definition: file.h:125
@ osl_File_E_NOEXEC
Definition: file.h:98
SAL_DLLPUBLIC oslFileError osl_readFile(oslFileHandle Handle, void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64 *pBytesRead)
Read a number of bytes from a file.
#define osl_Volume_Attribute_Case_Is_Preserved
Definition: file.h:535
bool isLink() const
Is it a link?
Definition: file.hxx:754
sal_uInt32 uValidFields
Determines which members of the structure contain valid data.
Definition: file.h:386
This String class provides base functionality for C++ like Unicode character array handling.
Definition: ustring.hxx:172
virtual void DirectoryCreated(const rtl::OUString &aDirectoryUrl)=0
This method will be called when a new directory has been created and needs to be overwritten by deriv...
static RC createTempFile(::rtl::OUString *pustrDirectoryURL, oslFileHandle *pHandle, ::rtl::OUString *pustrTempFileURL)
Creates a temporary file in the directory provided by the caller or the directory returned by getTemp...
Definition: file.hxx:305
SAL_DLLPUBLIC oslFileError osl_removeFile(rtl_uString *pustrFileURL)
Remove a regular file.
sal_uInt32 uStructSize
Must be initialized with the size in bytes of the structure before passing it to any function.
Definition: file.h:567
@ osl_File_E_DOM
Definition: file.h:121
sal_uInt32 getMaxPathLength() const
Determine the maximal length of a path name.
Definition: file.hxx:573
RC getNextItem(DirectoryItem &rItem, sal_uInt32 nHint=0)
Retrieve the next item of a previously opened directory.
Definition: file.hxx:1784
@ osl_File_E_ROFS
Definition: file.h:118
~VolumeInfo()
Definition: file.hxx:436
@ osl_File_E_NAMETOOLONG
Definition: file.h:124
@ E_SPIPE
invalid seek operation (such as on pipe)
Definition: file.hxx:84
@ osl_File_E_CHILD
Definition: file.h:100
bool getFixedDiskFlag() const
Check the fixed disk flag.
Definition: file.hxx:502
#define osl_FileStatus_Mask_CreationTime
Definition: file.h:366
static RC getCanonicalName(const ::rtl::OUString &ustrRequestedURL, ::rtl::OUString &ustrValidURL)
Determine a valid unused canonical name for a requested name.
Definition: file.hxx:130
@ osl_File_E_FBIG
Definition: file.h:115
SAL_DLLPUBLIC oslFileError osl_setFileTime(rtl_uString *pustrFileURL, const TimeValue *aCreationTime, const TimeValue *aLastAccessTime, const TimeValue *aLastWriteTime)
Set the file time.
#define osl_FileStatus_Mask_Attributes
Definition: file.h:365
RC reset()
Resets the directory item enumeration to the beginning.
Definition: file.hxx:1756
void * oslDirectoryItem
Definition: file.h:144
RC sync() const
Synchronize the memory representation of a file with that on the physical medium.
Definition: file.hxx:1240
oslVolumeDeviceHandle * pDeviceHandle
Pointer to handle the receives underlying device.
Definition: file.h:588
bool getFloppyDiskFlag() const
Check the floppy disc flag.
Definition: file.hxx:491
bool isCaseSensitiveFileSystem() const
Return whether the file system is case sensitive or case insensitive.
Definition: file.hxx:609
~DirectoryItem()
Destructor.
Definition: file.hxx:1456
@ E_FAULT
bad address; an invalid pointer detected
Definition: file.hxx:71
@ E_NOTREADY
device not ready
Definition: file.hxx:101
The directory class object provides an enumeration of DirectoryItems.
Definition: file.hxx:1637
#define osl_Volume_Attribute_CompactDisc
Definition: file.h:530
sal_uInt32 uStructSize
Must be initialized with the size in bytes of the structure before passing it to any function.
Definition: file.h:384
bool isCasePreservingFileSystem() const
Return whether the file system preserves the case of file and directory names or not.
Definition: file.hxx:621
@ Regular
Definition: file.hxx:657
SAL_DLLPUBLIC oslFileError osl_removeDirectory(rtl_uString *pustrDirectoryURL)
Remove an empty directory.
@ E_EXIST
file exists where should only be created
Definition: file.hxx:73
SAL_DLLPUBLIC oslFileError osl_moveFile(rtl_uString *pustrSourceFileURL, rtl_uString *pustrDestFileURL)
Move a file or directory to a new destination or renames it.
@ osl_File_E_EXIST
Definition: file.h:106
@ osl_File_E_NOENT
Definition: file.h:92
@ osl_File_E_MLINK
Definition: file.h:119
@ osl_File_E_MFILE
Definition: file.h:113
sal_uInt64 uAttributes
File attributes.
Definition: file.h:390
sal_uInt32 uMaxNameLength
Maximum length of file name of a single item.
Definition: file.h:579
@ E_MLINK
too many links to file
Definition: file.hxx:86
bool isDirectory() const
Is it a directory? This method returns True for both directories, and volumes.
Definition: file.hxx:726
@ osl_File_E_AGAIN
Definition: file.h:101
static RC get(const ::rtl::OUString &ustrFileURL, DirectoryItem &rItem)
Retrieve a single directory item.
Definition: file.hxx:1524
DirectoryItem & operator=(const DirectoryItem &rItem)
Assignment operator.
Definition: file.hxx:1465
@ osl_File_E_NODEV
Definition: file.h:108
TimeValue aCreationTime
First creation time in nanoseconds since 1/1/1970.
Definition: file.h:393
~VolumeDevice()
Destructor.
Definition: file.hxx:352
@ E_IO
I/O error occurred.
Definition: file.hxx:62
sal_uInt64 getUsedSpace() const
Determine the used space of a volume device.
Definition: file.hxx:549
SAL_DLLPUBLIC oslFileError osl_getFilePos(oslFileHandle Handle, sal_uInt64 *pPos)
Retrieve the current position of the internal pointer of an open file.
@ osl_File_E_2BIG
Definition: file.h:97
bool isIdenticalTo(const DirectoryItem &pOther)
Determine if a directory item point the same underlying file.
Definition: file.hxx:1586
TimeValue aAccessTime
Last access time in nanoseconds since 1/1/1970.
Definition: file.h:396
SAL_DLLPUBLIC oslFileError osl_acquireDirectoryItem(oslDirectoryItem Item)
Increase the refcount of a directory item handle.
@ osl_File_Type_Volume
Definition: file.h:330
SAL_DLLPUBLIC oslFileError osl_getCanonicalName(rtl_uString *pustrRequestedURL, rtl_uString **ppustrValidURL)
Determine a valid unused canonical name for a requested name.
@ osl_File_E_TIMEDOUT
Definition: file.h:136
RC readLine(::rtl::ByteSequence &aSeq)
Read a line from a file.
Definition: file.hxx:1216
@ E_DEADLK
deadlock avoided
Definition: file.hxx:90
unsigned char sal_Bool
Definition: types.h:38
SAL_DLLPUBLIC oslFileError osl_copyFile(rtl_uString *pustrSourceFileURL, rtl_uString *pustrDestFileURL)
Copy a file to a new destination.
VolumeDevice getDeviceHandle() const
Get the volume device handle.
Definition: file.hxx:598
#define osl_Volume_Attribute_Removeable
Definition: file.h:528
@ E_ILSEQ
invalid or incomplete byte sequence of multibyte char found
Definition: file.hxx:96
RC read(void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64 &rBytesRead)
Read a number of bytes from a file.
Definition: file.hxx:1149
@ E_RANGE
range error (mathematical error)
Definition: file.hxx:89
sal_uInt64 uFileSize
Size in bytes of the file.
Definition: file.h:400
sal_uInt32 uValidFields
Determines which members of the structure contain valid data.
Definition: file.h:569
@ osl_File_E_IO
Definition: file.h:95
@ E_PERM
operation not permitted
Definition: file.hxx:58
@ osl_File_E_SRCH
Definition: file.h:93
Type
Definition: file.hxx:654
SAL_DLLPUBLIC oslFileError osl_closeDirectory(oslDirectory Directory)
Release a directory handle.
SAL_DLLPUBLIC oslFileError osl_getFileSize(oslFileHandle Handle, sal_uInt64 *pSize)
Get the file size of an open file.
#define osl_Volume_Attribute_Remote
Definition: file.h:529
@ E_USERS
file quote system is confused as there are too many users
Definition: file.hxx:99
RC setSize(sal_uInt64 uSize)
Set the file size of an open file.
Definition: file.hxx:1089
rtl_uString * ustrFileSystemName
Points to a string that receives the name of the file system type.
Definition: file.h:585
SAL_DLLPUBLIC void rtl_uString_release(rtl_uString *str) SAL_THROW_EXTERN_C() SAL_HOT
Decrement the reference count of a string.
@ osl_File_Type_Unknown
Definition: file.h:336
::rtl::OUString getFileSystemName() const
Determine the name of the volume device's File System.
Definition: file.hxx:585
sal_uInt64 getFileSize() const
Get the size of the file.
Definition: file.hxx:824
#define osl_Volume_Attribute_FixedDisk
Definition: file.h:531
@ E_ACCES
file permissions do not allow operation
Definition: file.hxx:70
SAL_DLLPUBLIC oslFileError osl_readLine(oslFileHandle Handle, sal_Sequence **ppSequence)
Read a line from a file.
@ osl_File_E_INTR
Definition: file.h:94
SAL_DLLPUBLIC oslFileError osl_isEndOfFile(oslFileHandle Handle, sal_Bool *pIsEOF)
Test if the end of a file is reached.
RC write(const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64 &rBytesWritten)
Write a number of bytes to a file.
Definition: file.hxx:1187
#define osl_Volume_Attribute_Case_Sensitive
Definition: file.h:536
::rtl::OUString getFileName() const
Get the file name.
Definition: file.hxx:838
@ E_CHILD
there are no child processes
Definition: file.hxx:67
DirectoryItem(const DirectoryItem &rItem)
Copy constructor.
Definition: file.hxx:1447
@ E_LOOP
too many levels of symbolic links found during name lookup
Definition: file.hxx:95
::rtl::OUString getLinkTargetURL() const
Get the link target URL.
Definition: file.hxx:871
static RC replace(const ::rtl::OUString &ustrSourceFileURL, const ::rtl::OUString &ustrDestFileURL)
Move a file to a new destination or rename it, taking old file's identity (if exists).
Definition: file.hxx:1331
SAL_DLLPUBLIC oslFileError osl_getNextDirectoryItem(oslDirectory Directory, oslDirectoryItem *pItem, sal_uInt32 uHint)
Retrieve the next item of a previously opened directory.
SAL_DLLPUBLIC oslFileError osl_getFileURLFromSystemPath(rtl_uString *pustrSystemPath, rtl_uString **ppustrFileURL)
Convert a system dependent path into a file URL.
@ E_NOTDIR
file isn't a directory where one is needed
Definition: file.hxx:76
rtl::OUString getMountPath()
Get the full qualified URL where a device is mounted to.
Definition: file.hxx:384
oslFileType eType
The type of the file (file, directory, volume).
Definition: file.h:388
#define osl_Volume_Attribute_FloppyDisk
Definition: file.h:533
@ E_SRCH
no process matches the PID
Definition: file.hxx:60
@ osl_File_E_NOTDIR
Definition: file.h:109
rtl_uString * ustrLinkTargetURL
Full URL of the target file if the file itself is a link.
Definition: file.h:410
SAL_DLLPUBLIC oslFileError osl_setFileSize(oslFileHandle Handle, sal_uInt64 uSize)
Set the file size of an open file.
SAL_DLLPUBLIC oslFileError osl_releaseDirectoryItem(oslDirectoryItem Item)
Decrease the refcount of a directory item handle.
SAL_DLLPUBLIC oslFileError osl_getDirectoryItem(rtl_uString *pustrFileURL, oslDirectoryItem *pItem)
Retrieve a single directory item.
@ E_None
on success
Definition: file.hxx:57
SAL_DLLPUBLIC oslFileError osl_releaseVolumeDeviceHandle(oslVolumeDeviceHandle Handle)
Release a volume device handle.
Definition: bootstrap.hxx:34
#define osl_FileStatus_Mask_FileURL
Definition: file.h:371
SAL_DLLPUBLIC oslFileError osl_acquireVolumeDeviceHandle(oslVolumeDeviceHandle Handle)
Acquire a volume device handle.
sal_uInt32 getMaxNameLength() const
Determine the maximal length of a file name.
Definition: file.hxx:561
RC getPos(sal_uInt64 &uPos)
Retrieve the current position of the internal pointer of an open file.
Definition: file.hxx:1041
@ E_NOTEMPTY
directory not empty
Definition: file.hxx:94
SAL_DLLPUBLIC oslFileError osl_getSystemPathFromFileURL(rtl_uString *pustrFileURL, rtl_uString **ppustrSystemPath)
Convert a file URL into a system dependent path.
@ E_NOSPC
no space left on device, write failed
Definition: file.hxx:83
@ osl_File_E_NOSYS
Definition: file.h:126
@ osl_File_E_INVAL
Definition: file.h:111
rtl_uString * ustrFileName
Case correct name of the file.
Definition: file.h:403
@ E_NETWORK
Definition: file.hxx:104
The file class object provides access to file contents and attributes.
Definition: file.hxx:891
virtual ~DirectoryCreationObserver()
Definition: file.hxx:1608
@ osl_File_E_ILSEQ
Definition: file.h:129
static RC setTime(const ::rtl::OUString &ustrFileURL, const TimeValue &rCreationTime, const TimeValue &rLastAccessTime, const TimeValue &rLastWriteTime)
Set the file time.
Definition: file.hxx:1409
TimeValue getAccessTime() const
Get the file access time.
Definition: file.hxx:795
#define osl_FileStatus_Mask_FileSize
Definition: file.h:369
::rtl::OUString getFileURL() const
Get the URL of the file.
Definition: file.hxx:855
C++ class representing a SAL byte sequence.
Definition: byteseq.h:170
@ osl_File_E_None
Definition: file.h:90
RC getSize(sal_uInt64 &rSize)
Get the file size of an open file.
Definition: file.hxx:1113
void * oslVolumeDeviceHandle
Definition: file.h:454
@ Volume
Definition: file.hxx:656
#define osl_File_OpenFlag_Write
Definition: file.h:635
static RC getSystemPathFromFileURL(const ::rtl::OUString &ustrFileURL, ::rtl::OUString &ustrSystemPath)
Convert a file URL into a system dependent path.
Definition: file.hxx:188
@ E_NOSYS
function not implemented
Definition: file.hxx:93
~Directory()
Destructor.
Definition: file.hxx:1667
@ Fifo
Definition: file.hxx:658
@ osl_File_Type_Directory
Definition: file.h:329
sal_uInt64 getAttributes() const
Get the file attributes.
Definition: file.hxx:765
SAL_DLLPUBLIC oslFileError osl_getAbsoluteFileURL(rtl_uString *pustrBaseDirectoryURL, rtl_uString *pustrRelativeFileURL, rtl_uString **ppustrAbsoluteFileURL)
Convert a path relative to a given directory into an full qualified file URL.
static RC getVolumeInfo(const ::rtl::OUString &ustrDirectoryURL, VolumeInfo &rInfo)
Retrieve information about a volume.
Definition: file.hxx:1825
@ osl_File_Type_Link
Definition: file.h:334
The VolumeInfo class.
Definition: file.hxx:406
static RC getAbsoluteFileURL(const ::rtl::OUString &ustrBaseDirectoryURL, const ::rtl::OUString &ustrRelativeFileURL, ::rtl::OUString &ustrAbsoluteFileURL)
Convert a path relative to a given directory into an full qualified file URL.
Definition: file.hxx:169
@ osl_File_E_ACCES
Definition: file.h:103
@ E_NOTTY
inappropriate I/O control operation
Definition: file.hxx:81
@ E_NAMETOOLONG
filename too long
Definition: file.hxx:91
SAL_DLLPUBLIC oslFileError osl_closeFile(oslFileHandle Handle)
Close an open file.
oslFileError
Definition: file.h:89
@ E_AGAIN
resource temp unavailable, try again later
Definition: file.hxx:68
Structure containing information about volumes.
Definition: file.h:564
@ osl_File_E_NOMEM
Definition: file.h:102
@ E_OVERFLOW
value too large for defined data type
Definition: file.hxx:100
SAL_DLLPUBLIC oslFileError osl_writeFile(oslFileHandle Handle, const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64 *pBytesWritten)
Write a number of bytes to a file.
@ E_FBIG
file too large
Definition: file.hxx:82
#define osl_FileStatus_Mask_ModifyTime
Definition: file.h:368
bool isValid(sal_uInt32 nMask) const
Check if specified fields are valid.
Definition: file.hxx:698
SAL_DLLPUBLIC oslFileError osl_getVolumeInformation(rtl_uString *pustrDirectoryURL, oslVolumeInfo *pInfo, sal_uInt32 uFieldMask)
Retrieve information about a volume.
~FileStatus()
Destructor.
Definition: file.hxx:679
@ E_BUSY
resource busy
Definition: file.hxx:72
sal_uInt64 uUsedSpace
Used space on the volume for the current process/user.
Definition: file.h:575
sal_uInt64 getTotalSpace() const
Determine the total space of a volume device.
Definition: file.hxx:525
rtl_uString * ustrFileURL
Full URL of the file.
Definition: file.h:406
#define SAL_WARN_UNUSED_RESULT
Use this as markup for functions and methods whose return value must be used.
Definition: types.h:288
@ osl_File_E_SPIPE
Definition: file.h:117
bool isRegular() const
Is it a regular file?
Definition: file.hxx:741
@ osl_File_E_FAULT
Definition: file.h:104
@ E_NOLINK
link has been severed
Definition: file.hxx:97
@ E_NODEV
wrong device type specified
Definition: file.hxx:75
VolumeDevice()
Constructor.
Definition: file.hxx:332
@ osl_File_E_NOSPC
Definition: file.h:116
@ Unknown
Definition: file.hxx:662
SAL_DLLPUBLIC oslFileError osl_searchFileURL(rtl_uString *pustrFileName, rtl_uString *pustrSearchPath, rtl_uString **ppustrFileURL)
Search a full qualified system path or a file URL.
RC open()
Open a directory for enumerating its contents.
Definition: file.hxx:1698
@ E_NOLCK
no locks available
Definition: file.hxx:92
SAL_WARN_UNUSED_RESULT SAL_DLLPUBLIC oslFileError osl_setFilePos(oslFileHandle Handle, sal_uInt32 uHow, sal_Int64 uPos)
Set the internal position pointer of an open file.
@ E_ISDIR
file is a directory, invalid operation
Definition: file.hxx:77
SAL_WARN_UNUSED_RESULT RC setPos(sal_uInt32 uHow, sal_Int64 uPos)
Set the internal position pointer of an open file.
Definition: file.hxx:1021
bool getRemoteFlag() const
Check the remote flag.
Definition: file.hxx:459
SAL_DLLPUBLIC oslFileError osl_syncFile(oslFileHandle Handle)
Synchronize the memory representation of a file with that on the physical medium.
This is the binary specification of a SAL sequence.
Definition: types.h:322
@ osl_File_E_BADF
Definition: file.h:99
@ E_NOEXEC
invalid executable file format
Definition: file.hxx:65
bool getCompactDiscFlag() const
Check the compact disc flag.
Definition: file.hxx:480
SAL_DLLPUBLIC oslFileError osl_createDirectoryPath(rtl_uString *aDirectoryUrl, oslDirectoryCreationCallbackFunc aDirectoryCreationCallbackFunc, void *pData)
Create a directory path.
@ E_DOM
domain error (mathematical error)
Definition: file.hxx:88
@ osl_File_E_USERS
Definition: file.h:132
@ osl_File_E_NOTREADY
Definition: file.h:134
#define osl_FileStatus_Mask_AccessTime
Definition: file.h:367
@ Special
Definition: file.hxx:661
static RC setAttributes(const ::rtl::OUString &ustrFileURL, sal_uInt64 uAttributes)
Set file attributes.
Definition: file.hxx:1383
sal_uInt64 getFreeSpace() const
Determine the free space of a volume device.
Definition: file.hxx:537
bool isOpen()
Query if directory is open.
Definition: file.hxx:1713
RC getFileStatus(FileStatus &rStatus)
Retrieve information about a single file or directory.
Definition: file.hxx:1566
@ Link
Definition: file.hxx:660
void * oslDirectory
Definition: file.h:143
#define SAL_WARN_IF(condition, area, stream)
Produce warning entry from stream in the given log area if condition is true.
Definition: log.hxx:373
#define SAL_DELETED_FUNCTION
short-circuit extra-verbose API namespaces
Definition: types.h:396
rtl::OUString getURL() const
Obtain the URL.
Definition: file.hxx:930
bool isValid(sal_uInt32 nMask) const
Check if specified fields are valid.
Definition: file.hxx:449
TimeValue aModifyTime
Last modify time in nanoseconds since 1/1/1970.
Definition: file.h:398
#define osl_FileStatus_Mask_LinkTargetURL
Definition: file.h:372
RC open(sal_uInt32 uFlags)
Open a regular file.
Definition: file.hxx:974
@ E_PIPE
broken pipe; no process reading from other end of pipe
Definition: file.hxx:87
SAL_DLLPUBLIC oslFileError osl_getFileStatus(oslDirectoryItem Item, oslFileStatus *pStatus, sal_uInt32 uFieldMask)
Retrieve information about a single file or directory.
@ E_NXIO
no such device or address
Definition: file.hxx:63
#define osl_FileStatus_Mask_FileName
Definition: file.h:370
Base class for observers of directory creation notifications.
Definition: file.hxx:1606
@ osl_File_E_NOTTY
Definition: file.h:114
static RC createPath(const ::rtl::OUString &aDirectoryUrl, DirectoryCreationObserver *aDirectoryCreationObserver=NULL)
Create a directory path.
Definition: file.hxx:1935
RC close()
Close a directory.
Definition: file.hxx:1726
SAL_DLLPUBLIC oslFileError osl_getVolumeDeviceMountPath(oslVolumeDeviceHandle Handle, rtl_uString **ppustrDirectoryURL)
Get the full qualified URL where a device is mounted to.
static RC searchFileURL(const ::rtl::OUString &ustrFileName, const ::rtl::OUString &ustrSearchPath, ::rtl::OUString &ustrFileURL)
Search a full qualified system path or a file URL.
Definition: file.hxx:239
File(const ::rtl::OUString &ustrFileURL)
Constructor.
Definition: file.hxx:913
static RC copy(const ::rtl::OUString &ustrSourceFileURL, const ::rtl::OUString &ustrDestFileURL)
Copy a file to a new destination.
Definition: file.hxx:1271
static RC getFileURLFromSystemPath(const ::rtl::OUString &ustrSystemPath, ::rtl::OUString &ustrFileURL)
Convert a system dependent path into a file URL.
Definition: file.hxx:207
TimeValue getModifyTime() const
Get the file modification time.
Definition: file.hxx:810
@ osl_File_E_BUSY
Definition: file.h:105
DirectoryItem()
Constructor.
Definition: file.hxx:1440
@ osl_File_Type_Regular
Definition: file.h:331
@ E_invalidError
unmapped error: always last entry in enum!
Definition: file.hxx:102
TimeValue getCreationTime() const
Get the creation time of this file.
Definition: file.hxx:780
@ E_TIMEDOUT
socket operation timed out
Definition: file.hxx:103
SAL_DLLPUBLIC sal_Bool osl_identicalDirectoryItem(oslDirectoryItem pItemA, oslDirectoryItem pItemB)
Determine if two directory items point the same underlying file.
@ osl_File_E_MULTIHOP
Definition: file.h:131
@ osl_File_E_XDEV
Definition: file.h:107
bool getRAMDiskFlag() const
Check the RAM disk flag.
Definition: file.hxx:513
static RC create(const ::rtl::OUString &ustrDirectoryURL, sal_uInt32 flags=osl_File_OpenFlag_Read|osl_File_OpenFlag_Write)
Create a directory.
Definition: file.hxx:1860
rtl::OUString getURL() const
Obtain the URL.
Definition: file.hxx:1679
@ E_BADF
bad file descriptor
Definition: file.hxx:66
The VolumeDevice class.
Definition: file.hxx:324
VolumeInfo(sal_uInt32 nMask)
Constructor.
Definition: file.hxx:428
@ osl_File_E_PIPE
Definition: file.h:120
@ E_NFILE
too many distinct file openings
Definition: file.hxx:79
@ E_XDEV
improper link across file systems detected
Definition: file.hxx:74
@ osl_File_E_PERM
Definition: file.h:91
SAL_DLLPUBLIC oslFileError osl_createDirectoryWithFlags(rtl_uString *url, sal_uInt32 flags)
Create a directory, passing flags.
@ E_MULTIHOP
remote resource is not directly available
Definition: file.hxx:98
@ E_ROFS
illegal modification to read-only filesystem
Definition: file.hxx:85
sal_uInt32 uMaxPathLength
Maximum length of a full qualified path in system notation.
Definition: file.h:581
RC isEndOfFile(sal_Bool *pIsEOF)
Test if the end of a file is reached.
Definition: file.hxx:1067
#define osl_File_OpenFlag_Read
Definition: file.h:634
bool is()
Check for validity of this instance.
Definition: file.hxx:1486
Directory(const ::rtl::OUString &strPath)
Constructor.
Definition: file.hxx:1660
The directory item class object provides access to file status information.
Definition: file.hxx:1432
sal_uInt32 uAttributes
Attributes of the volume (remote and/or removable)
Definition: file.h:571
@ osl_File_E_NOLINK
Definition: file.h:130
sal_uInt64 uTotalSpace
Total available space on the volume for the current process/user.
Definition: file.h:573
SAL_DLLPUBLIC oslFileError osl_openFile(rtl_uString *pustrFileURL, oslFileHandle *pHandle, sal_uInt32 uFlags)
Open a regular file.
@ osl_File_Type_Socket
Definition: file.h:333
@ E_INTR
function call was interrupted
Definition: file.hxx:61
SAL_DLLPUBLIC oslFileError osl_replaceFile(rtl_uString *pustrSourceFileURL, rtl_uString *pustrDestFileURL)
Move a file to a new destination or rename it, taking old file's identity (if exists).
SAL_DLLPUBLIC oslFileError osl_createTempFile(rtl_uString *pustrDirectoryURL, oslFileHandle *pHandle, rtl_uString **ppustrTempFileURL)
Creates a temporary file in the directory provided by the caller or the directory returned by osl_get...
Type getFileType() const
Get the file type.
Definition: file.hxx:708