| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050 | {****************************************************************************    $Id$                         Free Pascal Runtime-Library                              DOS unit for OS/2                   Copyright (c) 1997,1999-2000 by Daniel Mantione,                   member of the Free Pascal development team    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. ****************************************************************************}unit dos;{$ASMMODE ATT}{***************************************************************************}interface{***************************************************************************}{$PACKRECORDS 1}uses    strings;const   {Bit masks for CPU flags.}        fcarry      = $0001;        fparity     = $0004;        fauxiliary  = $0010;        fzero       = $0040;        fsign       = $0080;        foverflow   = $0800;        {Bit masks for file attributes.}        readonly    = $01;        hidden      = $02;        sysfile     = $04;        volumeid    = $08;        directory   = $10;        archive     = $20;        anyfile     = $3F;        fmclosed    = $D7B0;        fminput     = $D7B1;        fmoutput    = $D7B2;        fminout     = $D7B3;type    {Some string types:}        comstr=string;              {Filenames can be long in OS/2.}        pathstr=string;             {String for pathnames.}        dirstr=string;              {String for a directory}        namestr=string;             {String for a filename.}        extstr=string[40];          {String for an extension. Can be 253                                     characters long, in theory, but let's                                     say fourty will be enough.}        {Search record which is used by findfirst and findnext:}        searchrec=record            fill:array[1..21] of byte;            attr:byte;            time:longint;            size:longint;            name:string;            {Filenames can be long in OS/2!}        end;{$i filerec.inc}{$i textrec.inc}        {Data structure for the registers needed by msdos and intr:}       registers=record            case i:integer of                0:(ax,f1,bx,f2,cx,f3,dx,f4,bp,f5,si,f51,di,f6,ds,f7,es,                   f8,flags,fs,gs:word);                1:(al,ah,f9,f10,bl,bh,f11,f12,cl,ch,f13,f14,dl,dh:byte);                2:(eax,ebx,ecx,edx,ebp,esi,edi:longint);            end;        {Record for date and time:}        datetime=record            year,month,day,hour,min,sec:word;        end;        {Flags for the exec procedure:        Starting the program:        efwait:        Wait until program terminates.        efno_wait:     Don't wait until the program terminates. Does not work                       in dos, as DOS cannot multitask.        efoverlay:     Terminate this program, then execute the requested                       program. WARNING: Exit-procedures are not called!        efdebug:       Debug program. Details are unknown.        efsession:     Do not execute as child of this program. Use a seperate                       session instead.        efdetach:      Detached. Function unknown. Info wanted!        efpm:          Run as presentation manager program.        Determining the window state of the program:        efdefault:     Run the pm program in it's default situation.        efminimize:    Run the pm program minimized.        efmaximize:    Run the pm program maximized.        effullscreen:  Run the non-pm program fullscreen.        efwindowed:    Run the non-pm program in a window.        Other options are not implemented defined because lack of        knowledge abou what they do.}        type    execrunflags=(efwait,efno_wait,efoverlay,efdebug,efsession,                              efdetach,efpm);                execwinflags=(efdefault,efminimize,efmaximize,effullscreen,                              efwindowed);var doserror:integer;    dosexitcode:word;procedure getdate(var year,month,day,dayofweek:word);procedure gettime(var hour,minute,second,sec100:word);function dosversion:word;procedure setdate(year,month,day:word);procedure settime(hour,minute,second,sec100:word);procedure getcbreak(var breakvalue:boolean);procedure setcbreak(breakvalue:boolean);procedure getverify(var verify:boolean);procedure setverify(verify : boolean);function diskfree(drive:byte):longint;function disksize(drive:byte):longint;procedure findfirst(const path:pathstr;attr:word;var f:searchRec);procedure findnext(var f:searchRec);procedure findclose(var f:searchRec);{Is a dummy:}procedure swapvectors;{Not supported:procedure getintvec(intno:byte;var vector:pointer);procedure setintvec(intno:byte;vector:pointer);procedure keep(exitcode:word);}procedure msdos(var regs:registers);procedure intr(intno : byte;var regs:registers);procedure getfattr(var f;var attr:word);procedure setfattr(var f;attr:word);function fsearch(path:pathstr;dirlist:string):pathstr;procedure getftime(var f;var time:longint);procedure setftime(var f;time:longint);procedure packtime (var d:datetime; var time:longint);procedure unpacktime (time:longint; var d:datetime);function fexpand(const path:pathstr):pathstr;procedure fsplit(path:pathstr;var dir:dirstr;var name:namestr;                 var ext:extstr);procedure exec(const path:pathstr;const comline:comstr);function exec(path:pathstr;runflags:execrunflags;winflags:execwinflags;              const comline:comstr):longint;function envcount:longint;function envstr(index:longint) : string;function getenv(const envvar:string): string;implementationuses    doscalls;{Import syscall to call it nicely from assembler procedures.}procedure syscall;external name '___SYSCALL';function fsearch(path:pathstr;dirlist:string):pathstr;var i,p1:longint;    s:searchrec;    newdir:pathstr;    Handle: cardinal;    RC, Count: longint;    FStat: PFileFindBuf3;    ND: PathStr;begin    {No wildcards allowed in these things:}    if (pos('?',path)<>0) or (pos('*',path)<>0) then        fsearch:=''    else        begin            { allow slash as backslash }            for i:=1 to length(dirlist) do                if dirlist[i]='/' then dirlist[i]:='\';            repeat                p1:=pos(';',dirlist);                if p1<>0 then                    begin                        newdir:=copy(dirlist,1,p1-1);                        delete(dirlist,1,p1);                    end                else                    begin                        newdir:=dirlist;                        dirlist:='';                    end;                if (newdir<>'') and                 not (newdir[length(newdir)] in ['\',':']) then                    newdir:=newdir+'\';                if OS_Mode = osOS2 then                begin                 New (FStat);                 ND := NewDir + Path;                 Handle := $FFFFFFFF;                 Count := 1;                 RC := DosFindFirst (ND, Handle, $37, FStat, SizeOf (FStat^),                                                            Count, ilStandard);                 DosFindClose (Handle);                 Dispose (FStat);                end else                begin                 findfirst(newdir+path,anyfile,s);                 RC := DosError;                end;                if RC = 0 then                    newdir:=newdir+path                else                    newdir:='';            until (dirlist='') or (newdir<>'');            fsearch:=newdir;        end;end;procedure getftime(var f;var time:longint);begin    asm        {Load handle}        movl f,%ebx        movw (%ebx),%bx        {Get date}        movw $0x5700,%ax        call syscall        shll $16,%edx        movw %cx,%dx        movl time,%ebx        movl %edx,(%ebx)        xorb %ah,%ah        movw %ax,doserror    end;end;procedure setftime(var f;time : longint);begin    asm        {Load handle}        movl f,%ebx        movw (%ebx),%bx        movl time,%ecx        shldl $16,%ecx,%edx        {Set date}        movw $0x5701,%ax        call syscall        xorb %ah,%ah        movw %ax,doserror    end;end;procedure msdos(var regs:registers);{Not recommended for EMX. Only works in DOS mode, not in OS/2 mode.}begin    intr($21,regs);end;{$ASMMODE DIRECT}procedure intr(intno:byte;var regs:registers);{Not recommended for EMX. Only works in DOS mode, not in OS/2 mode.}begin    asm        .data    int86:        .byte        0xcd    int86_vec:        .byte        0x03        jmp        int86_retjmp        .text        movl        8(%ebp),%eax        movb        %al,int86_vec        movl        10(%ebp),%eax        {Do not use first int}        incl        %eax        incl        %eax        movl        4(%eax),%ebx        movl        8(%eax),%ecx        movl        12(%eax),%edx        movl        16(%eax),%ebp        movl        20(%eax),%esi        movl        24(%eax),%edi        movl        (%eax),%eax        jmp        int86    int86_retjmp:        pushf        pushl   %ebp        pushl       %eax        movl        %esp,%ebp        {Calc EBP new}        addl        $12,%ebp        movl        10(%ebp),%eax        {Do not use first int}        incl        %eax        incl        %eax        popl        (%eax)        movl        %ebx,4(%eax)        movl        %ecx,8(%eax)        movl        %edx,12(%eax)        {Restore EBP}        popl    %edx        movl    %edx,16(%eax)        movl        %esi,20(%eax)        movl        %edi,24(%eax)        {Ignore ES and DS}        popl        %ebx            {Flags.}        movl        %ebx,32(%eax)        {FS and GS too}    end;end;{$ASMMODE ATT}procedure exec(const path:pathstr;const comline:comstr);{Execute a program.}begin    dosexitcode:=exec(path,efwait,efdefault,comline);end;function exec(path:pathstr;runflags:execrunflags;winflags:execwinflags;              const comline:comstr):longint;{Execute a program. More suitable for OS/2 than the exec above.}{512 bytes should be enough to contain the command-line.}type    bytearray=array[0..8191] of byte;        Pbytearray=^bytearray;        execstruc=record            argofs,envofs,nameofs:pointer;            argseg,envseg,nameseg:word;            numarg,sizearg,            numenv,sizeenv:word;            mode1,mode2:byte;        end;var args:Pbytearray;    env:Pbytearray;    i,j:word;    es:execstruc;    esadr:pointer;    d:dirstr;    n:namestr;    e:extstr;begin    getmem(args,512);    getmem(env,8192);    j:=1;    {Now setup the arguments. The first argument should be the program     name without directory and extension.}    fsplit(path,d,n,e);    es.numarg:=1;    args^[0]:=$80;    for i:=1 to length(n) do        begin            args^[j]:=byte(n[i]);            inc(j);        end;    args^[j]:=0;    inc(j);    {Now do the real arguments.}    i:=1;    while i<=length(comline) do        begin            if comline[i]<>' ' then                begin                    {Commandline argument found. Copy it.}                    inc(es.numarg);                    args^[j]:=$80;                    inc(j);                    while (i<=length(comline)) and (comline[i]<>' ') do                        begin                            args^[j]:=byte(comline[i]);                            inc(j);                            inc(i);                        end;                    args^[j]:=0;                    inc(j);                end;            inc(i);        end;    args^[j]:=0;    inc(j);    {Commandline ready, now build the environment.     Oh boy, I always had the opinion that executing a program under Dos     was a hard job!}    {$ASMMODE DIRECT}    asm        movl env,%edi       {Setup destination pointer.}        movl _envc,%ecx     {Load number of arguments in edx.}        movl _environ,%esi  {Load env. strings.}        xorl %edx,%edx      {Count environment size.}    exa1:        lodsl               {Load a Pchar.}        xchgl %eax,%ebx    exa2:        movb (%ebx),%al     {Load a byte.}        incl %ebx           {Point to next byte.}        stosb               {Store it.}        incl %edx           {Increase counter.}        cmpb $0,%al         {Ready ?.}        jne exa2        loop exa1           {Next argument.}        stosb               {Store an extra 0 to finish. (AL is now 0).}        incl %edx        movl %edx,(24)es    {Store environment size.}    end;    {$ASMMODE ATT}    {Environtment ready, now set-up exec structure.}    es.argofs:=args;    es.envofs:=env;    asm        leal path,%esi        lodsb        movzbl %al,%eax        addl %eax,%esi        movb $0,(%esi)    end;    es.nameofs:=pointer(longint(@path)+1);    asm        movw %ss,es.argseg        movw %ss,es.envseg        movw %ss,es.nameseg    end;    es.sizearg:=j;    es.numenv:=0;    {Typecasting of sets in FPC is a bit hard.}    es.mode1:=byte(runflags);    es.mode2:=byte(winflags);    {Now exec the program.}    asm        leal es,%edx        mov $0x7f06,%ax        call syscall        xorl %edi,%edi        jnc .Lexprg1        xchgl %eax,%edi        xorl %eax,%eax        decl %eax    .Lexprg1:        movw %di,doserror        movl %eax,__RESULT    end;    freemem(args,512);    freemem(env,8192);    {Phew! That's it. This was the most sophisticated procedure to call     a system function I ever wrote!}end;function dosversion:word;assembler;{Returns DOS version in DOS and OS/2 version in OS/2}asm    movb $0x30,%ah    call syscallend;procedure getdate(var year,month,day,dayofweek:word);begin    asm        movb $0x2a,%ah        call syscall        xorb %ah,%ah        movl 20(%ebp),%edi        stosw        movl 16(%ebp),%edi        movb %dl,%al        stosw        movl 12(%ebp),%edi        movb %dh,%al        stosw        movl 8(%ebp),%edi        xchgw %ecx,%eax        stosw    end;end;procedure setdate(year,month,day : word);begin    {DOS only! You cannot change the system date in OS/2!}    asm        movw 8(%ebp),%cx        movb 10(%ebp),%dh        movb 12(%ebp),%dl        movb $0x2b,%ah        call syscall        xorb %ah,%ah        movw %ax,doserror    end;end;procedure gettime(var hour,minute,second,sec100:word);begin    asm        movb $0x2c,%ah        call syscall        xorb %ah,%ah        movl 20(%ebp),%edi        movb %dl,%al        stosw        movl 16(%ebp),%edi        movb %dh,%al        stosw        movl 12(%ebp),%edi        movb %cl,%al        stosw        movl 8(%ebp),%edi        movb %ch,%al        stosw    end;end;procedure settime(hour,minute,second,sec100:word);begin    asm        movb 8(%ebp),%ch        movb 10(%ebp),%cl        movb 12(%ebp),%dh        movb 14(%ebp),%dl        movb $0x2d,%ah        call syscall        xorb %ah,%ah        movw %ax,doserror    end;end;procedure getcbreak(var breakvalue:boolean);begin     {! Do not use in OS/2. Also not recommended in DOS. Use        signal handling instead.}    asm        movw $0x3300,%ax        call syscall        movl 8(%ebp),%eax        movb %dl,(%eax)    end;end;procedure setcbreak(breakvalue:boolean);begin    {! Do not use in OS/2. Also not recommended in DOS. Use       signal handling instead.}    asm        movb 8(%ebp),%dl        movw $0x3301,%ax        call syscall    end;end;procedure getverify(var verify:boolean);begin    {! Do not use in OS/2.}    asm        movb $0x54,%ah        call syscall        movl 8(%ebp),%edi        stosb    end;end;procedure setverify(verify:boolean);begin    {! Do not use in OS/2.}    asm        movb 8(%ebp),%al        movb $0x2e,%ah        call syscall    end;end;function diskfree(drive:byte):longint;var fi:TFSinfo;begin    if os_mode=osDOS then    {Function 36 is not supported in OS/2.}        asm            movb 8(%ebp),%dl            movb $0x36,%ah            call syscall            cmpw $-1,%ax            je .LDISKFREE1            mulw %cx            mulw %bx            shll $16,%edx            movw %ax,%dx            xchgl %edx,%eax            leave            ret         .LDISKFREE1:            cltd            leave            ret        end    else        {In OS/2, we use the filesystem information.}        begin            doserror:=dosqueryFSinfo(drive,1,FI,sizeof(FI));            if doserror=0 then                diskfree:=FI.free_clusters*FI.sectors_per_cluster*                 FI.bytes_per_sector            else                diskfree:=-1;        end;end;function disksize(drive:byte):longint;var fi:TFSinfo;begin    if os_mode=osDOS then        {Function 36 is not supported in OS/2.}        asm            movb 8(%ebp),%dl            movb $0x36,%ah            call syscall            movw %dx,%bx            cmpw $-1,%ax            je .LDISKSIZE1            mulw %cx            mulw %bx            shll $16,%edx            movw %ax,%dx            xchgl %edx,%eax            leave            ret        .LDISKSIZE1:            cltd            leave            ret        end    else        {In OS/2, we use the filesystem information.}        begin            doserror:=dosqueryFSinfo(drive,1,FI,sizeof(FI));            if doserror=0 then                disksize:=FI.total_clusters*FI.sectors_per_cluster*                 FI.bytes_per_sector            else                disksize:=-1;        end;end;procedure searchrec2dossearchrec(var f:searchrec);const   namesize=255;var l,i:longint;begin    l:=length(f.name);    for i:=1 to namesize do        f.name[i-1]:=f.name[i];    f.name[l]:=#0;end;procedure dossearchrec2searchrec(var f : searchrec);const namesize=255;var l,i : longint;begin    for i:=0 to namesize do        if f.name[i]=#0 then            begin                l:=i;                break;            end;    for i:=namesize-1 downto 0 do        f.name[i+1]:=f.name[i];    f.name[0]:=char(l);end;procedure findfirst(const path:pathstr;attr:word;var f:searchRec);    procedure _findfirst(path:pchar;attr:word;var f:searchrec);    begin        asm            movl 12(%esp),%edx            movw 16(%esp),%cx            {No need to set DTA in EMX. Just give a pointer in ESI.}            movl 18(%ebp),%esi            movb $0x4e,%ah            call syscall            jnc .LFF            movw %ax,doserror        .LFF:        end;    end;var path0:array[0..255] of char;begin    {No error.}    doserror:=0;    strPcopy(path0,path);    _findfirst(path0,attr,f);    dossearchrec2searchrec(f);end;procedure findnext(var f:searchRec);    procedure _findnext(var f : searchrec);    begin        asm            movl 12(%ebp),%esi            movb $0x4f,%ah            call syscall            jnc .LFN            movw %ax,doserror        .LFN:        end;    end;begin    {No error}    doserror:=0;    searchrec2dossearchrec(f);    _findnext(f);    dossearchrec2searchrec(f);end;procedure findclose(var f:searchRec);beginend;procedure swapvectors;{For TP compatibility, this exists.}beginend;type    PPchar=^Pchar;{$ASMMODE DIRECT}function envs:PPchar;assembler;asm    movl _environ,%eaxend ['EAX'];function envcount:longint;assembler;var hp : ppchar;asm    movl _envc,%eaxend ['EAX'];{$ASMMODE ATT}function envstr(index : longint) : string;var hp:PPchar;begin    if (index<=0) or (index>envcount) then        begin            envstr:='';            exit;        end;    hp:=PPchar(cardinal(envs)+4*(index-1));    envstr:=strpas(hp^);end;function getenv(const envvar : string) : string;var hs,_envvar : string;    eqpos,i : longint;begin    _envvar:=upcase(envvar);    getenv:='';    for i:=1 to envcount do        begin            hs:=envstr(i);            eqpos:=pos('=',hs);            if copy(hs,1,eqpos-1)=_envvar then                begin                    getenv:=copy(hs,eqpos+1,length(hs)-eqpos);                    exit;                end;        end;end;procedure fsplit(path:pathstr;var dir:dirstr;var name:namestr;                 var ext:extstr);var p1,i : longint;begin    {Get drive name}    p1:=pos(':',path);    if p1>0 then        begin            dir:=path[1]+':';            delete(path,1,p1);        end    else        dir:='';    { split the path and the name, there are no more path informtions }    { if path contains no backslashes                                 }    while true do        begin            p1:=pos('\',path);            if p1=0 then                p1:=pos('/',path);            if p1=0 then                break;            dir:=dir+copy(path,1,p1);              delete(path,1,p1);        end;    {Try to find an extension.}    ext:='';    for i:=length(path) downto 1 do        if path[i]='.' then            begin                ext:=copy(path,i,high(extstr));                delete(path,i,length(path)-i+1);                break;            end;    name:=path;end;function fexpand(const path:pathstr):pathstr;    function get_current_drive:byte;assembler;    asm        movb $0x19,%ah        call syscall    end;var s,pa:string;    i,j:longint;begin    getdir(0,s);    pa:=upcase(path);    {Allow slash as backslash}    for i:=1 to length(pa) do        if pa[i]='/' then            pa[i]:='\';    if (length(pa)>1) and (pa[1] in ['A'..'Z']) and (pa[2]=':') then        begin            {We must get the right directory}            getdir(byte(pa[1])-byte('A')+1,s);            if (byte(pa[0])>2) and (pa[3]<>'\') then                if pa[1]=s[1] then                    pa:=s+'\'+copy (pa,3,length(pa))                else                    pa:=pa[1]+':\'+copy (pa,3,length(pa))        end    else        if pa[1]='\' then            pa:=s[1]+':'+pa        else if s[0]=#3 then            pa:=s+pa        else            pa:=s+'\'+pa;    {First remove all references to '\.\'}    i:=pos('\.\',pa);    while i<>0 do        begin            delete(pa,i,2);            i:=pos('\.\',pa);        end;    {Now remove also all references to '\..\' + of course previous dirs..}    repeat        i:=pos('\..\',pa);        if i<>0 then            begin                j:=i-1;                while (j>1) and (pa[j]<>'\') do                    dec(j);                delete (pa,j,i-j+3);            end;    until i=0;    {Remove End . and \}    if (length(pa)>0) and (pa[length(pa)]='.') then        dec(byte(pa[0]));    if (length(pa)>0) and (pa[length(pa)]='\') then        dec(byte(pa[0]));    fexpand:=pa;end;procedure packtime(var d:datetime;var time:longint);var zs:longint;begin    time:=-1980;    time:=time+d.year and 127;    time:=time shl 4;    time:=time+d.month;    time:=time shl 5;    time:=time+d.day;    time:=time shl 16;    zs:=d.hour;    zs:=zs shl 6;    zs:=zs+d.min;    zs:=zs shl 5;    zs:=zs+d.sec div 2;    time:=time+(zs and $ffff);end;procedure unpacktime (time:longint;var d:datetime);begin    d.sec:=(time and 31) * 2;    time:=time shr 5;    d.min:=time and 63;    time:=time shr 6;    d.hour:=time and 31;    time:=time shr 5;    d.day:=time and 31;    time:=time shr 5;    d.month:=time and 15;    time:=time shr 4;    d.year:=time+1980;end;procedure getfattr(var f;var attr : word);assembler;asm    movw $0x4300,%ax    movl f,%edx    {addl $filerec.name,%edx Doesn't work!!}    addl $60,%edx    call syscall    movl attr,%ebx    movw %cx,(%ebx)end;procedure setfattr(var f;attr : word);assembler;asm    movw $0x4301,%ax    movl f,%edx    {addl $filerec.name,%edx Doesn't work!!}    addl $60,%edx    movw attr,%cx    call syscallend;end.{  $Log$  Revision 1.19  2000-01-09 20:51:03  hajny    * FPK changed to FPC  Revision 1.18  2000/01/07 16:41:45  daniel    * copyright 2000  Revision 1.17  1999/10/13 12:21:56  daniel  * OS/2 compiler works again.  Revision 1.16  1999/09/13 18:21:02  hajny    * again didn't manage to read docu for DosFindFirst properly :-(  Revision 1.15  1999/09/13 17:56:26  hajny    * another correction to FSearch fix - mistyping  Revision 1.14  1999/09/13 17:35:15  hajny    * little addition/correction to FSearch fix  Revision 1.13  1999/09/09 09:20:43  hajny    * FSearch under OS/2 fixed  Revision 1.12  1999/01/22 16:25:58  pierre   + findclose added  Revision 1.11  1999/01/18 16:22:51  jonas    - removed "noattcdq" define  Revision 1.10  1998/12/10 16:05:39  daniel  * Fsearch bug fixed  Revision 1.9  1998/12/07 18:55:41  jonas    * fixed bug reported in the mailing list by Frank McCormick (fsearch: changed      "if p1 = 0" to "if p1 <> 0"  Revision 1.8  1998/10/16 14:18:02  daniel  * Updates  Revision 1.7  1998/07/08 14:44:11  daniel  + Added moucalls and viocalls written by Tomas Hajny.  + Final routines in doscalls implemented.  * Fixed bugs in dos.pas.  * Changed some old $ifdef FPK into $ifdef FPC.  - Removed go32 stuff from dos.pas.  - Removed '/' to '\' translation from system unit - EMX does this  automatically.}
 |