123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- {
- This file is part of the Free Pascal run time library.
- Copyright (c) 1999-2000 by Florian Klaempfl and Pavel Ozerski
- member of the Free Pascal development team.
- FPC Pascal system unit for the Win32 API.
- See the file COPYING.FPC, included in this distribution,
- for details about the copyright.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- **********************************************************************}
- {*****************************************************************************
- Directory Handling
- *****************************************************************************}
- Procedure MkDir(s: pchar;len:sizeuint);[IOCheck, public, alias : 'FPC_SYS_MKDIR'];
- var
- Rc : word;
- begin
- If not assigned(s) or (len=0) or (InOutRes <> 0) then
- exit;
- DoDirSeparators(s);
- Rc := DosCreateDir(s,nil);
- if Rc <> 0 then
- begin
- InOutRes := Rc;
- Errno2Inoutres;
- end;
- end;
- Procedure RmDir(s: pchar;len:sizeuint);[IOCheck, public, alias : 'FPC_SYS_RMDIR'];
- var
- Rc : word;
- begin
- if (len=1) and (s^ = '.' ) then
- InOutRes := 16;
- If not assigned(s) or (len=0) or (InOutRes <> 0) then
- exit;
- DoDirSeparators(s);
- Rc := DosDeleteDir(s);
- if Rc <> 0 then
- begin
- InOutRes := Rc;
- Errno2Inoutres;
- end;
- end;
- {$ASMMODE INTEL}
- Procedure ChDir(s: pchar;len:sizeuint);[IOCheck, public, alias : 'FPC_SYS_CHDIR'];
- var RC: cardinal;
- begin
- If not assigned(s) or (len=0) or (InOutRes <> 0) then
- exit;
- if (Len >= 2) and (S[1] = ':') then
- begin
- RC := DosSetDefaultDisk ((Ord (S [0]) and not ($20)) - $40);
- if RC <> 0 then
- InOutRes := RC
- else
- if Len > 2 then
- begin
- DoDirSeparators (s);
- RC := DosSetCurrentDir (s);
- if RC <> 0 then
- begin
- InOutRes := RC;
- Errno2InOutRes;
- end;
- end;
- end else begin
- DoDirSeparators (s);
- RC := DosSetCurrentDir (s);
- if RC <> 0 then
- begin
- InOutRes:= RC;
- Errno2InOutRes;
- end;
- end;
- end;
- {$ASMMODE ATT}
- procedure GetDir (DriveNr: byte; var Dir: ShortString);
- {Written by Michael Van Canneyt.}
- var sof: Pchar;
- i:byte;
- l,l2:cardinal;
- begin
- Dir [4] := #0;
- { Used in case the specified drive isn't available }
- sof:=pchar(@dir[4]);
- { dir[1..3] will contain '[drivenr]:\', but is not }
- { supplied by DOS, so we let dos string start at }
- { dir[4] }
- { Get dir from drivenr : 0=default, 1=A etc... }
- l:=255-3;
- InOutRes:=longint (DosQueryCurrentDir(DriveNr, sof^, l));
- {$WARNING Result code should be translated in some cases!}
- { Now Dir should be filled with directory in ASCIIZ, }
- { starting from dir[4] }
- dir[0]:=#3;
- dir[2]:=':';
- dir[3]:='\';
- i:=4;
- {Conversion to Pascal string }
- while (dir[i]<>#0) do
- begin
- { convert path name to DOS }
- if dir[i] in AllowDirectorySeparators then
- dir[i]:=DirectorySeparator;
- dir[0]:=char(i);
- inc(i);
- end;
- { upcase the string (FPC function) }
- if drivenr<>0 then { Drive was supplied. We know it }
- dir[1]:=chr(64+drivenr)
- else
- begin
- { We need to get the current drive from DOS function 19H }
- { because the drive was the default, which can be unknown }
- DosQueryCurrentDisk(l, l2);
- dir[1]:=chr(64+l);
- end;
- if not (FileNameCaseSensitive) then dir:=upcase(dir);
- end;
|