filutilh.inc 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. {
  2. This file is part of the Free Pascal run time library.
  3. Copyright (c) 1999-2000 by the Free Pascal development team
  4. File utility calls
  5. See the file COPYING.FPC, included in this distribution,
  6. for details about the copyright.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  10. **********************************************************************}
  11. Type
  12. // Some operating systems need FindHandle to be a Pointer
  13. {$if defined(unix) or defined(msdos) or defined(hasamiga) or defined(atari) or defined(win16)}
  14. {$define FINDHANDLE_IS_POINTER}
  15. {$endif}
  16. // Some operating systems need extra find data.
  17. {$if defined(Win32) or defined(WinCE) or defined(Win64)}
  18. {$define SEARCHREC_USEFINDDATA}
  19. {$define SYMLINKREC_USEFINDDATA}
  20. TFindData = TWin32FindDataW;
  21. {$endif}
  22. {$ifdef netware_clib}
  23. TFindData = TNetwareFindData;
  24. {$define SEARCHREC_USEFINDDATA}
  25. {$endif}
  26. {$ifdef netware_libc}
  27. TFindData = TNetwareLibcFindData;
  28. {$define SEARCHREC_USEFINDDATA}
  29. {$endif}
  30. {$ifdef MacOS}
  31. TFindData = TMacOSFindData;
  32. {$define SEARCHREC_USEFINDDATA}
  33. {$endif}
  34. {$ifdef nativent}
  35. TFindData = TNativeNTFindData;
  36. {$define SEARCHREC_USEFINDDATA}
  37. {$endif}
  38. // The actual unicode search record
  39. { TUnicodeSearchRec }
  40. TUnicodeSearchRec = Record
  41. Time : Int64;
  42. Size : Int64;
  43. Attr : Longint;
  44. Name : UnicodeString;
  45. ExcludeAttr : Longint;
  46. FindHandle : {$ifdef FINDHANDLE_IS_POINTER}Pointer{$else}THandle{$endif};
  47. {$ifdef unix}
  48. Mode : TMode;
  49. {$endif unix}
  50. {$ifdef SEARCHREC_USEFINDDATA}
  51. FindData : TFindData;
  52. {$endif}
  53. private
  54. function GetTimeStamp: TDateTime;
  55. function GetTimeStampUTC: TDateTime;
  56. public
  57. Function IsDirectory : Boolean; inline;
  58. function IsCurrentOrParentDir: Boolean; inline;
  59. property TimeStamp: TDateTime read GetTimeStamp;
  60. property TimeStampUTC: TDateTime read GetTimeStampUTC;
  61. end;
  62. { TRawbyteSearchRec }
  63. TRawbyteSearchRec = Record
  64. Time : Int64;
  65. Size : Int64;
  66. Attr : Longint;
  67. Name : RawByteString;
  68. ExcludeAttr : Longint;
  69. FindHandle : {$ifdef FINDHANDLE_IS_POINTER}Pointer{$else}THandle{$endif};
  70. {$ifdef unix}
  71. Mode : TMode;
  72. {$endif unix}
  73. {$IFDEF SEARCHREC_USEFINDDATA}
  74. FindData : TFindData;
  75. {$ENDIF}
  76. private
  77. function GetTimeStamp: TDateTime;
  78. function GetTimeStampUTC: TDateTime;
  79. public
  80. Function IsDirectory : Boolean; inline;
  81. function IsCurrentOrParentDir: Boolean; inline;
  82. property TimeStamp: TDateTime read GetTimeStamp;
  83. property TimeStampUTC: TDateTime read GetTimeStampUTC;
  84. end;
  85. {$IFDEF FPC_UNICODE_RTL}
  86. TSearchRec = TUnicodeSearchRec;
  87. {$ELSE}
  88. TSearchRec = TRawbyteSearchRec;
  89. {$ENDIF}
  90. TUnicodeSymLinkRec = Record
  91. TargetName : UnicodeString;
  92. Attr : Longint;
  93. Size : Int64;
  94. {$ifdef unix}
  95. Mode : TMode;
  96. {$endif unix}
  97. {$ifdef SYMLINKREC_USEFINDDATA}
  98. FindData : TFindData;
  99. {$endif}
  100. private
  101. function GetTimeStamp: TDateTime;
  102. public
  103. property TimeStamp: TDateTime read GetTimeStamp;
  104. end;
  105. TRawbyteSymLinkRec = Record
  106. TargetName : RawByteString;
  107. Size : Int64;
  108. Attr : Longint;
  109. {$ifdef unix}
  110. Mode : TMode;
  111. {$endif unix}
  112. {$IFDEF SYMLINKREC_USEFINDDATA}
  113. FindData : TFindData;
  114. {$ENDIF}
  115. private
  116. function GetTimeStamp: TDateTime;
  117. public
  118. property TimeStamp: TDateTime read GetTimeStamp;
  119. end;
  120. {$IFDEF FPC_UNICODE_RTL}
  121. TSymLinkRec = TUnicodeSymLinkRec;
  122. {$ELSE}
  123. TSymLinkRec = TRawbyteSymLinkRec;
  124. {$ENDIF}
  125. Const
  126. { File attributes }
  127. faReadOnly = $00000001;
  128. faHidden = $00000002 platform;
  129. faSysFile = $00000004 platform;
  130. faVolumeId = $00000008 platform deprecated;
  131. faDirectory = $00000010;
  132. faArchive = $00000020;
  133. faNormal = $00000080;
  134. faTemporary = $00000100 platform;
  135. faSymLink = $00000400 platform;
  136. faCompressed = $00000800 platform;
  137. faEncrypted = $00004000 platform;
  138. faVirtual = $00010000 platform;
  139. faAnyFile = $000001FF;
  140. { File open modes }
  141. fmOpenRead = $0000;
  142. fmOpenWrite = $0001;
  143. fmOpenReadWrite = $0002;
  144. { Share modes}
  145. fmShareCompat = $0000;
  146. fmShareExclusive = $0010;
  147. fmShareDenyWrite = $0020;
  148. fmShareDenyRead = $0030;
  149. fmShareDenyNone = $0040;
  150. { File seek origins }
  151. fsFromBeginning = 0;
  152. fsFromCurrent = 1;
  153. fsFromEnd = 2;
  154. { File errors }
  155. feInvalidHandle = THandle(-1); //return value on FileOpen error
  156. Type
  157. TFileSearchOption = (sfoImplicitCurrentDir,sfoStripQuotes);
  158. TFileSearchOptions = set of TFileSearchOption;
  159. Function FileOpen (Const FileName : unicodestring; Mode : Integer) : THandle;
  160. Function FileCreate (Const FileName : UnicodeString) : THandle;
  161. Function FileCreate (Const FileName : UnicodeString; Rights : Integer) : THandle;
  162. Function FileCreate (Const FileName : UnicodeString; ShareMode : Integer; Rights : Integer) : THandle;
  163. {$IFNDEF FPUNONE}
  164. Function FileAge (Const FileName : UnicodeString): Int64;
  165. {$ENDIF}
  166. Function FileExists (Const FileName : UnicodeString; FollowLink : Boolean = True) : Boolean;
  167. Function DirectoryExists (Const Directory : UnicodeString; FollowLink : Boolean = True) : Boolean;
  168. Function FileSetDate (Const FileName : UnicodeString;Age : Int64) : Longint;
  169. Function FileGetAttr (Const FileName : UnicodeString) : Longint;
  170. Function FileSetAttr (Const Filename : UnicodeString; Attr: longint) : Longint;
  171. Function DeleteFile (Const FileName : UnicodeString) : Boolean;
  172. Function RenameFile (Const OldName, NewName : UnicodeString) : Boolean;
  173. Function FindFirst (Const Path : UnicodeString; Attr : Longint; out Rslt : TUnicodeSearchRec) : Longint;
  174. Function FindNext (Var Rslt : TUnicodeSearchRec) : Longint;
  175. Procedure FindClose (Var F : TUnicodeSearchrec);
  176. Function FileSearch (Const Name, DirList : UnicodeString; Options : TFileSearchoptions = [sfoImplicitCurrentDir]) : UnicodeString;
  177. Function FileSearch (Const Name, DirList : UnicodeString; ImplicitCurrentDir : Boolean) : UnicodeString;
  178. Function ExeSearch (Const Name : UnicodeString; Const DirList : UnicodeString = '') : UnicodeString;
  179. Function FileIsReadOnly(const FileName : UnicodeString): Boolean;
  180. function FileAge(const FileName: UnicodeString; out FileDateTime: TDateTime; FollowLink: Boolean = True): Boolean;
  181. function FileAgeUTC(const FileName: UnicodeString; out FileDateTimeUTC: TDateTime; FollowLink: Boolean = True): Boolean;
  182. function FileGetSymLinkTarget(const FileName: UnicodeString; out SymLinkRec: TUnicodeSymLinkRec): Boolean;
  183. function FileGetSymLinkTarget(const FileName: UnicodeString; out TargetName: UnicodeString): Boolean; inline;
  184. Function FileOpen (Const FileName : RawByteString; Mode : Integer) : THandle;
  185. Function FileCreate (Const FileName : RawByteString) : THandle;
  186. Function FileCreate (Const FileName : RawByteString; Rights : Integer) : THandle;
  187. Function FileCreate (Const FileName : RawByteString; ShareMode : Integer; Rights : Integer) : THandle;
  188. Function FileExists (Const FileName : RawByteString; FollowLink : Boolean = True) : Boolean;
  189. Function DirectoryExists (Const Directory : RawByteString; FollowLink: Boolean = True) : Boolean;
  190. Function FileSetDate (Const FileName : RawByteString;Age : Int64) : Longint;
  191. Function FileGetAttr (Const FileName : RawByteString) : Longint;
  192. Function FileSetAttr (Const Filename : RawByteString; Attr: longint) : Longint;
  193. Function DeleteFile (Const FileName : RawByteString) : Boolean;
  194. Function RenameFile (Const OldName, NewName : RawByteString) : Boolean;
  195. Function FindFirst (Const Path : RawByteString; Attr : Longint; out Rslt : TRawByteSearchRec) : Longint;
  196. Function FileSearch (Const Name, DirList : RawByteString; Options : TFileSearchoptions = [sfoImplicitCurrentDir]) : RawByteString;
  197. Function FileSearch (Const Name, DirList : RawByteString; ImplicitCurrentDir : Boolean) : RawByteString;
  198. Function ExeSearch (Const Name : RawByteString; Const DirList : RawByteString = '') : RawByteString;
  199. Function FileIsReadOnly(const FileName: RawByteString): Boolean;
  200. function FileAge(const FileName: RawByteString; out FileDateTime: TDateTime; FollowLink: Boolean = True): Boolean;
  201. function FileAgeUTC(const FileName: RawByteString; out FileDateTimeUTC: TDateTime; FollowLink: Boolean = True): Boolean;
  202. {$ifndef FPUNONE}
  203. Function FileAge (Const FileName : RawByteString): Int64;
  204. {$endif}
  205. function FileGetSymLinkTarget(const FileName: RawByteString; out SymLinkRec: TRawbyteSymLinkRec): Boolean;
  206. function FileGetSymLinkTarget(const FileName: RawByteString; out TargetName: RawByteString): Boolean; inline;
  207. Function FileRead (Handle : THandle; out Buffer; Count : longint) : Longint;
  208. Function FileWrite (Handle : THandle; const Buffer; Count : Longint) : Longint;
  209. Function FileSeek (Handle : THandle; FOffset, Origin: Longint) : Longint;
  210. Function FileSeek (Handle : THandle; FOffset: Int64; Origin: Longint) : Int64;
  211. function FileFlush(Handle: THandle): Boolean;
  212. Procedure FileClose (Handle : THandle);
  213. Function FileTruncate (Handle : THandle;Size: Int64) : boolean;
  214. Function FindNext (Var Rslt : TRawByteSearchRec) : Longint;
  215. Procedure FindClose (Var F : TRawByteSearchrec);
  216. Function FileGetDate (Handle : THandle) : Int64;
  217. Function FileSetDate (Handle : THandle;Age : Int64) : Longint;
  218. Function GetFileHandle(var f : File):THandle;
  219. Function GetFileHandle(var f : Text):THandle;
  220. Function GetFileContents(Const aFileName : RawByteString) : TBytes;
  221. Function GetFileContents(Const aFileName : UnicodeString) : TBytes;
  222. Function GetFileContents(Const aHandle : THandle) : TBytes;
  223. Function GetFileAsString(Const aFileName : RawByteString) : RawByteString;
  224. Function GetFileAsString(Const aFileName : RawByteString; aEncoding : TEncoding) : RawByteString;
  225. Function GetFileAsString(Const aFileName : UnicodeString) : UnicodeString;
  226. Function GetFileAsString(Const aFileName : UnicodeString; aEncoding : TEncoding) : UnicodeString;