LibreOffice
LibreOffice 6.4 SDK C/C++ API Reference
file.h
Go to the documentation of this file.
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
5  * This Source Code Form is subject to the terms of the Mozilla Public
6  * License, v. 2.0. If a copy of the MPL was not distributed with this
7  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
11  * Licensed to the Apache Software Foundation (ASF) under one or more
12  * contributor license agreements. See the NOTICE file distributed
13  * with this work for additional information regarding copyright
14  * ownership. The ASF licenses this file to you under the Apache
15  * License, Version 2.0 (the "License"); you may not use this file
16  * except in compliance with the License. You may obtain a copy of
17  * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18  */
19 
20 #ifndef INCLUDED_OSL_FILE_H
21 #define INCLUDED_OSL_FILE_H
22 
23 #include "sal/config.h"
24 
25 #include "osl/time.h"
26 #include "rtl/ustring.h"
27 #include "sal/saldllapi.h"
28 
29 #ifdef __cplusplus
30 extern "C" {
31 #endif
32 
84 /* Error codes according to errno */
85 typedef enum {
138 
139 typedef void *oslDirectory;
140 typedef void *oslDirectoryItem;
141 
166  rtl_uString *pustrDirectoryURL, oslDirectory *pDirectory);
167 
198  oslDirectory Directory,
199  oslDirectoryItem *pItem,
200  sal_uInt32 uHint
201  );
202 
217  oslDirectory Directory);
218 
254  rtl_uString *pustrFileURL,
255  oslDirectoryItem *pItem
256  );
257 
274  oslDirectoryItem Item );
275 
276 
295  oslDirectoryItem Item );
296 
316  oslDirectoryItem pItemA,
317  oslDirectoryItem pItemB );
318 
324 typedef enum {
325  osl_File_Type_Directory, /*< directory */
326  osl_File_Type_Volume, /*< volume (e.g. C:, A:) */
327  osl_File_Type_Regular, /*< regular file */
328  osl_File_Type_Fifo, /*< named pipe */
329  osl_File_Type_Socket, /*< socket */
330  osl_File_Type_Link, /*< file link */
331  osl_File_Type_Special, /*< special device file */
332  osl_File_Type_Unknown /*< unknown file type */
341 #define osl_File_Attribute_ReadOnly 0x00000001
342 #define osl_File_Attribute_Hidden 0x00000002
343 #define osl_File_Attribute_Executable 0x00000010
344 #define osl_File_Attribute_GrpWrite 0x00000020
345 #define osl_File_Attribute_GrpRead 0x00000040
346 #define osl_File_Attribute_GrpExe 0x00000080
347 #define osl_File_Attribute_OwnWrite 0x00000100
348 #define osl_File_Attribute_OwnRead 0x00000200
349 #define osl_File_Attribute_OwnExe 0x00000400
350 #define osl_File_Attribute_OthWrite 0x00000800
351 #define osl_File_Attribute_OthRead 0x00001000
352 #define osl_File_Attribute_OthExe 0x00002000
353 
360 #define osl_FileStatus_Mask_Type 0x00000001
361 #define osl_FileStatus_Mask_Attributes 0x00000002
362 #define osl_FileStatus_Mask_CreationTime 0x00000010
363 #define osl_FileStatus_Mask_AccessTime 0x00000020
364 #define osl_FileStatus_Mask_ModifyTime 0x00000040
365 #define osl_FileStatus_Mask_FileSize 0x00000080
366 #define osl_FileStatus_Mask_FileName 0x00000100
367 #define osl_FileStatus_Mask_FileURL 0x00000200
368 #define osl_FileStatus_Mask_LinkTargetURL 0x00000400
369 #define osl_FileStatus_Mask_All 0x7FFFFFFF
370 #define osl_FileStatus_Mask_Validate 0x80000000
371 
378 typedef struct _oslFileStatus {
380  sal_uInt32 uStructSize;
382  sal_uInt32 uValidFields;
386  sal_uInt64 uAttributes;
396  sal_uInt64 uFileSize;
399  rtl_uString *ustrFileName;
402  rtl_uString *ustrFileURL;
406  rtl_uString *ustrLinkTargetURL;
408 
448  oslDirectoryItem Item, oslFileStatus *pStatus, sal_uInt32 uFieldMask );
449 
450 typedef void *oslVolumeDeviceHandle;
451 
470  oslVolumeDeviceHandle Handle );
471 
490  oslVolumeDeviceHandle Handle );
491 
517  oslVolumeDeviceHandle Handle, rtl_uString **ppustrDirectoryURL);
518 
524 #define osl_Volume_Attribute_Removeable 0x00000001L
525 #define osl_Volume_Attribute_Remote 0x00000002L
526 #define osl_Volume_Attribute_CompactDisc 0x00000004L
527 #define osl_Volume_Attribute_FixedDisk 0x00000008L
528 #define osl_Volume_Attribute_RAMDisk 0x00000010L
529 #define osl_Volume_Attribute_FloppyDisk 0x00000020L
530 
531 #define osl_Volume_Attribute_Case_Is_Preserved 0x00000040L
532 #define osl_Volume_Attribute_Case_Sensitive 0x00000080L
533 
542 #define osl_VolumeInfo_Mask_Attributes 0x00000001L
543 #define osl_VolumeInfo_Mask_TotalSpace 0x00000002L
544 #define osl_VolumeInfo_Mask_UsedSpace 0x00000004L
545 #define osl_VolumeInfo_Mask_FreeSpace 0x00000008L
546 #define osl_VolumeInfo_Mask_MaxNameLength 0x00000010L
547 #define osl_VolumeInfo_Mask_MaxPathLength 0x00000020L
548 #define osl_VolumeInfo_Mask_FileSystemName 0x00000040L
549 #define osl_VolumeInfo_Mask_DeviceHandle 0x00000080L
550 #define osl_VolumeInfo_Mask_FileSystemCaseHandling 0x00000100L
551 
560 typedef struct _oslVolumeInfo {
563  sal_uInt32 uStructSize;
565  sal_uInt32 uValidFields;
567  sal_uInt32 uAttributes;
569  sal_uInt64 uTotalSpace;
571  sal_uInt64 uUsedSpace;
573  sal_uInt64 uFreeSpace;
575  sal_uInt32 uMaxNameLength;
577  sal_uInt32 uMaxPathLength;
581  rtl_uString *ustrFileSystemName;
586 
622  rtl_uString *pustrDirectoryURL,
623  oslVolumeInfo *pInfo,
624  sal_uInt32 uFieldMask );
625 
626 typedef void *oslFileHandle;
627 
628 /* Open flags */
629 
630 #define osl_File_OpenFlag_Read 0x00000001L
631 #define osl_File_OpenFlag_Write 0x00000002L
632 #define osl_File_OpenFlag_Create 0x00000004L
633 #define osl_File_OpenFlag_NoLock 0x00000008L
634 /* larger bit-fields reserved for internal use cf. detail/file.h */
635 
690  rtl_uString *pustrFileURL, oslFileHandle *pHandle, sal_uInt32 uFlags );
691 
692 #define osl_Pos_Absolut 1
693 #define osl_Pos_Current 2
694 #define osl_Pos_End 3
695 
721  oslFileHandle Handle, sal_uInt32 uHow, sal_Int64 uPos );
722 
742  oslFileHandle Handle, sal_uInt64 *pPos );
743 
766  oslFileHandle Handle, sal_uInt64 uSize );
767 
789  oslFileHandle Handle, sal_uInt64 *pSize );
790 
797 #define osl_File_MapFlag_RandomAccess ((sal_uInt32)(0x1))
798 
809 #define osl_File_MapFlag_WillNeed ((sal_uInt32)(0x2))
810 
852  oslFileHandle Handle,
853  void** ppAddr,
854  sal_uInt64 uLength,
855  sal_uInt64 uOffset,
856  sal_uInt32 uFlags
857 );
858 
859 
860 #ifndef ANDROID
861 
874  void* pAddr,
875  sal_uInt64 uLength
876 );
877 
878 #endif
879 
892  oslFileHandle Handle,
893  void* pAddr,
894  sal_uInt64 uLength
895 );
896 
931  oslFileHandle Handle, void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64 *pBytesRead );
932 
957  oslFileHandle Handle, sal_Bool *pIsEOF );
958 
995  oslFileHandle Handle, const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64 *pBytesWritten );
996 
1029  oslFileHandle Handle,
1030  sal_uInt64 uOffset,
1031  void* pBuffer,
1032  sal_uInt64 uBytesRequested,
1033  sal_uInt64* pBytesRead
1034 );
1035 
1071  oslFileHandle Handle,
1072  sal_uInt64 uOffset,
1073  const void* pBuffer,
1074  sal_uInt64 uBytesToWrite,
1075  sal_uInt64* pBytesWritten
1076 );
1077 
1104  oslFileHandle Handle, sal_Sequence** ppSequence );
1105 
1128 
1145 
1171 SAL_DLLPUBLIC oslFileError SAL_CALL osl_createDirectory( rtl_uString* pustrDirectoryURL );
1172 
1188  rtl_uString * url, sal_uInt32 flags);
1189 
1215 SAL_DLLPUBLIC oslFileError SAL_CALL osl_removeDirectory( rtl_uString* pustrDirectoryURL );
1216 
1232 typedef void (SAL_CALL *oslDirectoryCreationCallbackFunc)(void* pData, rtl_uString* aDirectoryUrl);
1233 
1278  rtl_uString* aDirectoryUrl,
1279  oslDirectoryCreationCallbackFunc aDirectoryCreationCallbackFunc,
1280  void* pData);
1281 
1309  rtl_uString* pustrFileURL );
1310 
1338  rtl_uString* pustrSourceFileURL, rtl_uString *pustrDestFileURL );
1339 
1365  rtl_uString* pustrSourceFileURL, rtl_uString *pustrDestFileURL );
1366 
1387  rtl_uString *pustrRequestedURL, rtl_uString **ppustrValidURL);
1388 
1423  rtl_uString* pustrBaseDirectoryURL,
1424  rtl_uString *pustrRelativeFileURL,
1425  rtl_uString **ppustrAbsoluteFileURL );
1426 
1441  rtl_uString *pustrSystemPath, rtl_uString **ppustrFileURL);
1442 
1474  rtl_uString *pustrFileName, rtl_uString *pustrSearchPath, rtl_uString **ppustrFileURL );
1475 
1490  rtl_uString *pustrFileURL, rtl_uString **ppustrSystemPath);
1491 
1503 typedef sal_uInt32 (SAL_CALL *oslCalcTextWidthFunc)( rtl_uString *ustrText );
1504 
1525  rtl_uString *ustrSystemPath,
1526  rtl_uString **pustrCompacted,
1527  sal_uInt32 uMaxWidth,
1528  oslCalcTextWidthFunc pCalcWidth );
1529 
1544  rtl_uString *pustrFileURL, sal_uInt64 uAttributes );
1545 
1567  rtl_uString *pustrFileURL,
1568  const TimeValue *aCreationTime,
1569  const TimeValue *aLastAccessTime,
1570  const TimeValue *aLastWriteTime);
1571 
1581  rtl_uString **pustrTempDirURL );
1582 
1633  rtl_uString* pustrDirectoryURL,
1634  oslFileHandle* pHandle,
1635  rtl_uString** ppustrTempFileURL);
1636 
1665 SAL_DLLPUBLIC oslFileError SAL_CALL osl_replaceFile(rtl_uString* pustrSourceFileURL,
1666  rtl_uString* pustrDestFileURL);
1667 
1668 #ifdef __cplusplus
1669 }
1670 #endif
1671 
1672 #endif // INCLUDED_OSL_FILE_H
1673 
1674 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
osl_File_E_NXIO
@ osl_File_E_NXIO
Definition: file.h:92
oslFileHandle
void * oslFileHandle
Definition: file.h:626
osl_File_Type_Fifo
@ osl_File_Type_Fifo
Definition: file.h:328
osl_createDirectory
SAL_DLLPUBLIC oslFileError osl_createDirectory(rtl_uString *pustrDirectoryURL)
Create a directory.
osl_File_E_NFILE
@ osl_File_E_NFILE
Definition: file.h:108
_oslFileStatus
Structure containing information about files and directories.
Definition: file.h:378
osl_openDirectory
SAL_DLLPUBLIC oslFileError osl_openDirectory(rtl_uString *pustrDirectoryURL, oslDirectory *pDirectory)
Open a directory for enumerating its contents.
osl_File_E_FORCE_EQUAL_SIZE
@ osl_File_E_FORCE_EQUAL_SIZE
Definition: file.h:136
osl_getTempDirURL
SAL_DLLPUBLIC oslFileError osl_getTempDirURL(rtl_uString **pustrTempDirURL)
Retrieves the file URL of the system's temporary directory path.
_oslVolumeInfo::uMaxPathLength
sal_uInt32 uMaxPathLength
Maximum length of a full qualified path in system notation.
Definition: file.h:577
osl_File_E_invalidError
@ osl_File_E_invalidError
Definition: file.h:131
oslDirectoryCreationCallbackFunc
void(* oslDirectoryCreationCallbackFunc)(void *pData, rtl_uString *aDirectoryUrl)
Function pointer representing a function that will be called by osl_createDirectoryPath if a director...
Definition: file.h:1232
oslVolumeInfo
struct _oslVolumeInfo oslVolumeInfo
Structure containing information about volumes.
_oslVolumeInfo::uTotalSpace
sal_uInt64 uTotalSpace
Total available space on the volume for the current process/user.
Definition: file.h:569
osl_setFileAttributes
SAL_DLLPUBLIC oslFileError osl_setFileAttributes(rtl_uString *pustrFileURL, sal_uInt64 uAttributes)
Set file attributes.
osl_File_E_ISDIR
@ osl_File_E_ISDIR
Definition: file.h:106
osl_File_E_OVERFLOW
@ osl_File_E_OVERFLOW
Definition: file.h:129
osl_File_Type_Special
@ osl_File_Type_Special
Definition: file.h:331
osl_File_E_NOTEMPTY
@ osl_File_E_NOTEMPTY
Definition: file.h:123
osl_File_E_DEADLK
@ osl_File_E_DEADLK
Definition: file.h:119
osl_File_E_RANGE
@ osl_File_E_RANGE
Definition: file.h:118
osl_File_E_LOOP
@ osl_File_E_LOOP
Definition: file.h:124
osl_File_E_NETWORK
@ osl_File_E_NETWORK
Definition: file.h:133
osl_File_E_NOLCK
@ osl_File_E_NOLCK
Definition: file.h:121
osl_File_E_NOEXEC
@ osl_File_E_NOEXEC
Definition: file.h:94
osl_readFile
SAL_DLLPUBLIC oslFileError osl_readFile(oslFileHandle Handle, void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64 *pBytesRead)
Read a number of bytes from a file.
osl_removeFile
SAL_DLLPUBLIC oslFileError osl_removeFile(rtl_uString *pustrFileURL)
Remove a regular file.
osl_File_E_DOM
@ osl_File_E_DOM
Definition: file.h:117
osl_File_E_ROFS
@ osl_File_E_ROFS
Definition: file.h:114
saldllapi.h
oslFileType
oslFileType
Definition: file.h:324
osl_File_E_NAMETOOLONG
@ osl_File_E_NAMETOOLONG
Definition: file.h:120
_oslVolumeInfo::uMaxNameLength
sal_uInt32 uMaxNameLength
Maximum length of file name of a single item.
Definition: file.h:575
osl_File_E_CHILD
@ osl_File_E_CHILD
Definition: file.h:96
osl_File_E_FBIG
@ osl_File_E_FBIG
Definition: file.h:111
osl_setFileTime
SAL_DLLPUBLIC oslFileError osl_setFileTime(rtl_uString *pustrFileURL, const TimeValue *aCreationTime, const TimeValue *aLastAccessTime, const TimeValue *aLastWriteTime)
Set the file time.
oslDirectoryItem
void * oslDirectoryItem
Definition: file.h:140
time.h
_oslFileStatus::aAccessTime
TimeValue aAccessTime
Last access time in nanoseconds since 1/1/1970.
Definition: file.h:392
_oslFileStatus::uValidFields
sal_uInt32 uValidFields
Determines which members of the structure contain valid data.
Definition: file.h:382
osl_removeDirectory
SAL_DLLPUBLIC oslFileError osl_removeDirectory(rtl_uString *pustrDirectoryURL)
Remove an empty directory.
_oslVolumeInfo::uStructSize
sal_uInt32 uStructSize
Must be initialized with the size in bytes of the structure before passing it to any function.
Definition: file.h:563
osl_moveFile
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
@ osl_File_E_EXIST
Definition: file.h:102
osl_File_E_NOENT
@ osl_File_E_NOENT
Definition: file.h:88
osl_File_E_MLINK
@ osl_File_E_MLINK
Definition: file.h:115
osl_File_E_MFILE
@ osl_File_E_MFILE
Definition: file.h:109
osl_File_E_AGAIN
@ osl_File_E_AGAIN
Definition: file.h:97
osl_File_E_NODEV
@ osl_File_E_NODEV
Definition: file.h:104
_oslVolumeInfo::pDeviceHandle
oslVolumeDeviceHandle * pDeviceHandle
Pointer to handle the receives underlying device.
Definition: file.h:584
osl_getFilePos
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
@ osl_File_E_2BIG
Definition: file.h:93
osl_acquireDirectoryItem
SAL_DLLPUBLIC oslFileError osl_acquireDirectoryItem(oslDirectoryItem Item)
Increase the refcount of a directory item handle.
osl_File_Type_Volume
@ osl_File_Type_Volume
Definition: file.h:326
osl_getCanonicalName
SAL_DLLPUBLIC oslFileError osl_getCanonicalName(rtl_uString *pustrRequestedURL, rtl_uString **ppustrValidURL)
Determine a valid unused canonical name for a requested name.
_oslFileStatus::uStructSize
sal_uInt32 uStructSize
Must be initialized with the size in bytes of the structure before passing it to any function.
Definition: file.h:380
osl_File_E_TIMEDOUT
@ osl_File_E_TIMEDOUT
Definition: file.h:132
osl_writeFileAt
SAL_DLLPUBLIC oslFileError osl_writeFileAt(oslFileHandle Handle, sal_uInt64 uOffset, const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64 *pBytesWritten)
Write a number of bytes to a specified offset in a file.
sal_Bool
unsigned char sal_Bool
Definition: types.h:38
osl_copyFile
SAL_DLLPUBLIC oslFileError osl_copyFile(rtl_uString *pustrSourceFileURL, rtl_uString *pustrDestFileURL)
Copy a file to a new destination.
ustring.h
config.h
osl_unmapMappedFile
SAL_DLLPUBLIC oslFileError osl_unmapMappedFile(oslFileHandle Handle, void *pAddr, sal_uInt64 uLength)
Unmap a file segment from memory.
osl_mapFile
SAL_DLLPUBLIC oslFileError osl_mapFile(oslFileHandle Handle, void **ppAddr, sal_uInt64 uLength, sal_uInt64 uOffset, sal_uInt32 uFlags)
Map a shared file into memory.
_oslFileStatus::uAttributes
sal_uInt64 uAttributes
File attributes.
Definition: file.h:386
osl_File_E_IO
@ osl_File_E_IO
Definition: file.h:91
_oslFileStatus::ustrLinkTargetURL
rtl_uString * ustrLinkTargetURL
Full URL of the target file if the file itself is a link.
Definition: file.h:406
osl_File_E_SRCH
@ osl_File_E_SRCH
Definition: file.h:89
osl_closeDirectory
SAL_DLLPUBLIC oslFileError osl_closeDirectory(oslDirectory Directory)
Release a directory handle.
osl_getFileSize
SAL_DLLPUBLIC oslFileError osl_getFileSize(oslFileHandle Handle, sal_uInt64 *pSize)
Get the file size of an open file.
_oslFileStatus::aCreationTime
TimeValue aCreationTime
First creation time in nanoseconds since 1/1/1970.
Definition: file.h:389
osl_File_Type_Unknown
@ osl_File_Type_Unknown
Definition: file.h:332
_oslFileStatus::ustrFileName
rtl_uString * ustrFileName
Case correct name of the file.
Definition: file.h:399
osl_readLine
SAL_DLLPUBLIC oslFileError osl_readLine(oslFileHandle Handle, sal_Sequence **ppSequence)
Read a line from a file.
osl_File_E_INTR
@ osl_File_E_INTR
Definition: file.h:90
osl_isEndOfFile
SAL_DLLPUBLIC oslFileError osl_isEndOfFile(oslFileHandle Handle, sal_Bool *pIsEOF)
Test if the end of a file is reached.
osl_getNextDirectoryItem
SAL_DLLPUBLIC oslFileError osl_getNextDirectoryItem(oslDirectory Directory, oslDirectoryItem *pItem, sal_uInt32 uHint)
Retrieve the next item of a previously opened directory.
osl_getFileURLFromSystemPath
SAL_DLLPUBLIC oslFileError osl_getFileURLFromSystemPath(rtl_uString *pustrSystemPath, rtl_uString **ppustrFileURL)
Convert a system dependent path into a file URL.
_oslFileStatus::uFileSize
sal_uInt64 uFileSize
Size in bytes of the file.
Definition: file.h:396
_oslVolumeInfo::uValidFields
sal_uInt32 uValidFields
Determines which members of the structure contain valid data.
Definition: file.h:565
osl_File_E_NOTDIR
@ osl_File_E_NOTDIR
Definition: file.h:105
osl_setFileSize
SAL_DLLPUBLIC oslFileError osl_setFileSize(oslFileHandle Handle, sal_uInt64 uSize)
Set the file size of an open file.
osl_releaseDirectoryItem
SAL_DLLPUBLIC oslFileError osl_releaseDirectoryItem(oslDirectoryItem Item)
Decrease the refcount of a directory item handle.
osl_getDirectoryItem
SAL_DLLPUBLIC oslFileError osl_getDirectoryItem(rtl_uString *pustrFileURL, oslDirectoryItem *pItem)
Retrieve a single directory item.
osl_abbreviateSystemPath
SAL_DLLPUBLIC oslFileError osl_abbreviateSystemPath(rtl_uString *ustrSystemPath, rtl_uString **pustrCompacted, sal_uInt32 uMaxWidth, oslCalcTextWidthFunc pCalcWidth)
Abbreviate a system notation path.
osl_releaseVolumeDeviceHandle
SAL_DLLPUBLIC oslFileError osl_releaseVolumeDeviceHandle(oslVolumeDeviceHandle Handle)
Release a volume device handle.
osl_acquireVolumeDeviceHandle
SAL_DLLPUBLIC oslFileError osl_acquireVolumeDeviceHandle(oslVolumeDeviceHandle Handle)
Acquire a volume device handle.
SAL_DLLPUBLIC
#define SAL_DLLPUBLIC
Definition: saldllapi.h:30
_oslVolumeInfo::ustrFileSystemName
rtl_uString * ustrFileSystemName
Points to a string that receives the name of the file system type.
Definition: file.h:581
osl_getSystemPathFromFileURL
SAL_DLLPUBLIC oslFileError osl_getSystemPathFromFileURL(rtl_uString *pustrFileURL, rtl_uString **ppustrSystemPath)
Convert a file URL into a system dependent path.
osl_File_E_NOSYS
@ osl_File_E_NOSYS
Definition: file.h:122
osl_File_E_INVAL
@ osl_File_E_INVAL
Definition: file.h:107
_oslVolumeInfo
Structure containing information about volumes.
Definition: file.h:560
osl_File_E_ILSEQ
@ osl_File_E_ILSEQ
Definition: file.h:125
_oslVolumeInfo::uUsedSpace
sal_uInt64 uUsedSpace
Used space on the volume for the current process/user.
Definition: file.h:571
_oslFileStatus::ustrFileURL
rtl_uString * ustrFileURL
Full URL of the file.
Definition: file.h:402
_oslFileStatus::eType
oslFileType eType
The type of the file (file, directory, volume).
Definition: file.h:384
osl_File_E_None
@ osl_File_E_None
Definition: file.h:86
oslVolumeDeviceHandle
void * oslVolumeDeviceHandle
Definition: file.h:450
osl_unmapFile
SAL_DLLPUBLIC oslFileError osl_unmapFile(void *pAddr, sal_uInt64 uLength)
Unmap a shared file from memory.
osl_File_Type_Directory
@ osl_File_Type_Directory
Definition: file.h:325
osl_getAbsoluteFileURL
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.
osl_File_Type_Link
@ osl_File_Type_Link
Definition: file.h:330
osl_File_E_ACCES
@ osl_File_E_ACCES
Definition: file.h:99
osl_closeFile
SAL_DLLPUBLIC oslFileError osl_closeFile(oslFileHandle Handle)
Close an open file.
oslFileError
oslFileError
Definition: file.h:85
osl_File_E_NOMEM
@ osl_File_E_NOMEM
Definition: file.h:98
osl_writeFile
SAL_DLLPUBLIC oslFileError osl_writeFile(oslFileHandle Handle, const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64 *pBytesWritten)
Write a number of bytes to a file.
TimeValue
Definition: time.h:66
osl_getVolumeInformation
SAL_DLLPUBLIC oslFileError osl_getVolumeInformation(rtl_uString *pustrDirectoryURL, oslVolumeInfo *pInfo, sal_uInt32 uFieldMask)
Retrieve information about a volume.
SAL_WARN_UNUSED_RESULT
#define SAL_WARN_UNUSED_RESULT
Use this as markup for functions and methods whose return value must be checked.
Definition: types.h:302
osl_File_E_SPIPE
@ osl_File_E_SPIPE
Definition: file.h:113
osl_File_E_FAULT
@ osl_File_E_FAULT
Definition: file.h:100
osl_File_E_NOSPC
@ osl_File_E_NOSPC
Definition: file.h:112
osl_searchFileURL
SAL_DLLPUBLIC oslFileError osl_searchFileURL(rtl_uString *pustrFileName, rtl_uString *pustrSearchPath, rtl_uString **ppustrFileURL)
Search a full qualified system path or a file URL.
osl_setFilePos
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.
oslFileStatus
struct _oslFileStatus oslFileStatus
Structure containing information about files and directories.
osl_syncFile
SAL_DLLPUBLIC oslFileError osl_syncFile(oslFileHandle Handle)
Synchronize the memory representation of a file with that on the physical medium.
SAL_MAX_ENUM
#define SAL_MAX_ENUM
Definition: types.h:223
_sal_Sequence
This is the binary specification of a SAL sequence.
Definition: types.h:322
osl_File_E_BADF
@ osl_File_E_BADF
Definition: file.h:95
osl_createDirectoryPath
SAL_DLLPUBLIC oslFileError osl_createDirectoryPath(rtl_uString *aDirectoryUrl, oslDirectoryCreationCallbackFunc aDirectoryCreationCallbackFunc, void *pData)
Create a directory path.
osl_File_E_USERS
@ osl_File_E_USERS
Definition: file.h:128
osl_File_E_NOTREADY
@ osl_File_E_NOTREADY
Definition: file.h:130
oslDirectory
void * oslDirectory
Definition: file.h:139
osl_getFileStatus
SAL_DLLPUBLIC oslFileError osl_getFileStatus(oslDirectoryItem Item, oslFileStatus *pStatus, sal_uInt32 uFieldMask)
Retrieve information about a single file or directory.
osl_File_E_NOTTY
@ osl_File_E_NOTTY
Definition: file.h:110
osl_getVolumeDeviceMountPath
SAL_DLLPUBLIC oslFileError osl_getVolumeDeviceMountPath(oslVolumeDeviceHandle Handle, rtl_uString **ppustrDirectoryURL)
Get the full qualified URL where a device is mounted to.
_oslVolumeInfo::uAttributes
sal_uInt32 uAttributes
Attributes of the volume (remote and/or removable)
Definition: file.h:567
osl_File_E_BUSY
@ osl_File_E_BUSY
Definition: file.h:101
osl_File_Type_Regular
@ osl_File_Type_Regular
Definition: file.h:327
oslCalcTextWidthFunc
sal_uInt32(* oslCalcTextWidthFunc)(rtl_uString *ustrText)
Function pointer representing the function called back from osl_abbreviateSystemPath.
Definition: file.h:1503
osl_identicalDirectoryItem
SAL_DLLPUBLIC sal_Bool osl_identicalDirectoryItem(oslDirectoryItem pItemA, oslDirectoryItem pItemB)
Determine if two directory items point the same underlying file.
osl_File_E_MULTIHOP
@ osl_File_E_MULTIHOP
Definition: file.h:127
_oslFileStatus::aModifyTime
TimeValue aModifyTime
Last modify time in nanoseconds since 1/1/1970.
Definition: file.h:394
osl_File_E_XDEV
@ osl_File_E_XDEV
Definition: file.h:103
_oslVolumeInfo::uFreeSpace
sal_uInt64 uFreeSpace
Free space on the volume for the current process/user.
Definition: file.h:573
osl_File_E_PIPE
@ osl_File_E_PIPE
Definition: file.h:116
osl_File_E_PERM
@ osl_File_E_PERM
Definition: file.h:87
osl_createDirectoryWithFlags
SAL_DLLPUBLIC oslFileError osl_createDirectoryWithFlags(rtl_uString *url, sal_uInt32 flags)
Create a directory, passing flags.
osl_File_E_NOLINK
@ osl_File_E_NOLINK
Definition: file.h:126
osl_openFile
SAL_DLLPUBLIC oslFileError osl_openFile(rtl_uString *pustrFileURL, oslFileHandle *pHandle, sal_uInt32 uFlags)
Open a regular file.
osl_File_Type_Socket
@ osl_File_Type_Socket
Definition: file.h:329
osl_replaceFile
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).
osl_createTempFile
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...
osl_readFileAt
SAL_DLLPUBLIC oslFileError osl_readFileAt(oslFileHandle Handle, sal_uInt64 uOffset, void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64 *pBytesRead)
Read a number of bytes from a specified offset in a file.