mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-13 11:59:19 +02:00
* patch for Dos.Exec and others from borsa77 at libero.it
git-svn-id: trunk@3930 -
This commit is contained in:
parent
50a8ef63a8
commit
1ecf556685
@ -181,27 +181,36 @@ var
|
|||||||
execblock : texecblock;
|
execblock : texecblock;
|
||||||
c,p : string;
|
c,p : string;
|
||||||
|
|
||||||
function paste_to_dos(src : string) : boolean;
|
function paste_to_dos(src : string;cr : boolean) : boolean;
|
||||||
var
|
var
|
||||||
c : array[0..255] of char;
|
c : pchar;
|
||||||
|
CLen : cardinal;
|
||||||
begin
|
begin
|
||||||
paste_to_dos:=false;
|
paste_to_dos:=false;
|
||||||
if current_dos_buffer_pos+length(src)+1>transfer_buffer+tb_size then
|
if current_dos_buffer_pos+length(src)+3>transfer_buffer+tb_size then
|
||||||
RunError(217);
|
RunError(217);
|
||||||
move(src[1],c[0],length(src));
|
getmem(c,length(src)+3);
|
||||||
c[length(src)]:=#0;
|
move(src[0],c^,length(src)+1);
|
||||||
seg_move(get_ds,longint(@c),dosmemselector,current_dos_buffer_pos,length(src)+1);
|
if cr then
|
||||||
current_dos_buffer_pos:=current_dos_buffer_pos+length(src)+1;
|
begin
|
||||||
|
c[length(src)+1]:=#13;
|
||||||
|
c[length(src)+2]:=#0;
|
||||||
|
end
|
||||||
|
else
|
||||||
|
c[length(src)+1]:=#0;
|
||||||
|
CLen := StrLen (C) + 1;
|
||||||
|
seg_move(get_ds,longint(c),dosmemselector,current_dos_buffer_pos,CLen);
|
||||||
|
current_dos_buffer_pos:=current_dos_buffer_pos+CLen;
|
||||||
|
freemem(c,length(src)+3);
|
||||||
paste_to_dos:=true;
|
paste_to_dos:=true;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
begin
|
begin
|
||||||
{ create command line }
|
{ create command line }
|
||||||
move(comline[0],c[1],length(comline)+1);
|
c:=comline;
|
||||||
c[length(comline)+2]:=#13;
|
|
||||||
c[0]:=char(length(comline)+2);
|
|
||||||
{ create path }
|
{ create path }
|
||||||
p:=path;
|
p:=path;
|
||||||
|
{ allow slash as backslash }
|
||||||
for i:=1 to length(p) do
|
for i:=1 to length(p) do
|
||||||
if p[i]='/' then
|
if p[i]='/' then
|
||||||
p[i]:='\';
|
p[i]:='\';
|
||||||
@ -214,13 +223,13 @@ begin
|
|||||||
current_dos_buffer_pos:=la_env;
|
current_dos_buffer_pos:=la_env;
|
||||||
{ copy environment }
|
{ copy environment }
|
||||||
for i:=1 to envcount do
|
for i:=1 to envcount do
|
||||||
paste_to_dos(envstr(i));
|
paste_to_dos(envstr(i),false);
|
||||||
paste_to_dos(''); { adds a double zero at the end }
|
paste_to_dos(chr(0),false); { adds a double zero at the end }
|
||||||
{ allow slash as backslash }
|
{ allow slash as backslash }
|
||||||
la_p:=current_dos_buffer_pos;
|
la_p:=current_dos_buffer_pos;
|
||||||
paste_to_dos(p);
|
paste_to_dos(p,false);
|
||||||
la_c:=current_dos_buffer_pos;
|
la_c:=current_dos_buffer_pos;
|
||||||
paste_to_dos(c);
|
paste_to_dos(c,true);
|
||||||
la_e:=current_dos_buffer_pos;
|
la_e:=current_dos_buffer_pos;
|
||||||
fcb1_la:=la_e;
|
fcb1_la:=la_e;
|
||||||
la_e:=la_e+16;
|
la_e:=la_e+16;
|
||||||
@ -228,8 +237,9 @@ begin
|
|||||||
la_e:=la_e+16;
|
la_e:=la_e+16;
|
||||||
{ allocate FCB see dosexec code }
|
{ allocate FCB see dosexec code }
|
||||||
arg_ofs:=1;
|
arg_ofs:=1;
|
||||||
while (c[arg_ofs] in [' ',#9]) do
|
while (c[arg_ofs] in [' ',#9]) and
|
||||||
inc(arg_ofs);
|
(arg_ofs<length(c)) do
|
||||||
|
inc(arg_ofs);
|
||||||
dosregs.ax:=$2901;
|
dosregs.ax:=$2901;
|
||||||
dosregs.ds:=(la_c+arg_ofs) shr 4;
|
dosregs.ds:=(la_c+arg_ofs) shr 4;
|
||||||
dosregs.esi:=(la_c+arg_ofs) and 15;
|
dosregs.esi:=(la_c+arg_ofs) and 15;
|
||||||
@ -237,20 +247,11 @@ begin
|
|||||||
dosregs.edi:=fcb1_la and 15;
|
dosregs.edi:=fcb1_la and 15;
|
||||||
msdos(dosregs);
|
msdos(dosregs);
|
||||||
{ allocate second FCB see dosexec code }
|
{ allocate second FCB see dosexec code }
|
||||||
repeat
|
|
||||||
inc(arg_ofs);
|
|
||||||
until (c[arg_ofs] in [' ',#9,#13]);
|
|
||||||
if c[arg_ofs]<>#13 then
|
|
||||||
begin
|
|
||||||
repeat
|
|
||||||
inc(arg_ofs);
|
|
||||||
until not (c[arg_ofs] in [' ',#9]);
|
|
||||||
end;
|
|
||||||
dosregs.ax:=$2901;
|
dosregs.ax:=$2901;
|
||||||
dosregs.ds:=(la_c+arg_ofs) shr 4;
|
dosregs.ds:=(la_c+arg_ofs) shr 4;
|
||||||
dosregs.si:=(la_c+arg_ofs) and 15;
|
dosregs.esi:=(la_c+arg_ofs) and 15;
|
||||||
dosregs.es:=fcb2_la shr 4;
|
dosregs.es:=fcb2_la shr 4;
|
||||||
dosregs.di:=fcb2_la and 15;
|
dosregs.edi:=fcb2_la and 15;
|
||||||
msdos(dosregs);
|
msdos(dosregs);
|
||||||
with execblock do
|
with execblock do
|
||||||
begin
|
begin
|
||||||
@ -263,14 +264,14 @@ begin
|
|||||||
secondFCB.ofs:=fcb2_la and 15;
|
secondFCB.ofs:=fcb2_la and 15;
|
||||||
end;
|
end;
|
||||||
seg_move(get_ds,longint(@execblock),dosmemselector,la_e,sizeof(texecblock));
|
seg_move(get_ds,longint(@execblock),dosmemselector,la_e,sizeof(texecblock));
|
||||||
dosregs.edx:=la_p and 15;
|
dosregs.edx:=la_p and 15+1;
|
||||||
dosregs.ds:=la_p shr 4;
|
dosregs.ds:=la_p shr 4;
|
||||||
dosregs.ebx:=la_e and 15;
|
dosregs.ebx:=la_p and 15+la_e-la_p;
|
||||||
dosregs.es:=la_e shr 4;
|
dosregs.es:=la_p shr 4;
|
||||||
dosregs.ax:=$4b00;
|
dosregs.ax:=$4b00;
|
||||||
msdos(dosregs);
|
msdos(dosregs);
|
||||||
LoadDosError;
|
LoadDosError;
|
||||||
if DosError=0 then
|
if DosError<>0 then
|
||||||
begin
|
begin
|
||||||
dosregs.ax:=$4d00;
|
dosregs.ax:=$4d00;
|
||||||
msdos(dosregs);
|
msdos(dosregs);
|
||||||
@ -686,7 +687,7 @@ begin
|
|||||||
LoadDosError;
|
LoadDosError;
|
||||||
if DosError=0 then
|
if DosError=0 then
|
||||||
begin
|
begin
|
||||||
copyfromdos(c,255);
|
copyfromdos(c,256);
|
||||||
move(c[0],p[1],strlen(c));
|
move(c[0],p[1],strlen(c));
|
||||||
p[0]:=char(strlen(c));
|
p[0]:=char(strlen(c));
|
||||||
GetShortName:=true;
|
GetShortName:=true;
|
||||||
@ -714,7 +715,7 @@ begin
|
|||||||
LoadDosError;
|
LoadDosError;
|
||||||
if DosError=0 then
|
if DosError=0 then
|
||||||
begin
|
begin
|
||||||
copyfromdos(c,255);
|
copyfromdos(c,256);
|
||||||
move(c[0],p[1],strlen(c));
|
move(c[0],p[1],strlen(c));
|
||||||
p[0]:=char(strlen(c));
|
p[0]:=char(strlen(c));
|
||||||
GetLongName:=true;
|
GetLongName:=true;
|
||||||
@ -806,17 +807,15 @@ end;
|
|||||||
function envstr (Index: longint): string;
|
function envstr (Index: longint): string;
|
||||||
begin
|
begin
|
||||||
if (index<=0) or (index>envcount) then
|
if (index<=0) or (index>envcount) then
|
||||||
begin
|
envstr:=''
|
||||||
envstr:='';
|
else
|
||||||
exit;
|
envstr:=strpas(ppchar(pointer(envp)+SizeOf(PChar)*(index-1))^);
|
||||||
end;
|
|
||||||
envstr:=strpas(ppchar(pointer(envp)+4*(index-1))^);
|
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
|
||||||
Function GetEnv(envvar: string): string;
|
Function GetEnv(envvar: string): string;
|
||||||
var
|
var
|
||||||
hp : ppchar;
|
hp : ppchar;
|
||||||
hs : string;
|
hs : string;
|
||||||
eqpos : longint;
|
eqpos : longint;
|
||||||
begin
|
begin
|
||||||
@ -829,8 +828,8 @@ begin
|
|||||||
eqpos:=pos('=',hs);
|
eqpos:=pos('=',hs);
|
||||||
if upcase(copy(hs,1,eqpos-1))=envvar then
|
if upcase(copy(hs,1,eqpos-1))=envvar then
|
||||||
begin
|
begin
|
||||||
getenv:=copy(hs,eqpos+1,255);
|
getenv:=copy(hs,eqpos+1,length(hs)-eqpos);
|
||||||
exit;
|
break;
|
||||||
end;
|
end;
|
||||||
inc(hp);
|
inc(hp);
|
||||||
end;
|
end;
|
||||||
|
Loading…
Reference in New Issue
Block a user