{ This file is part of the Free Pascal Run time library. Copyright (c) 2010 by Florian Klaempfl This unit contain procedures specific for iso pascal mode. It should be platform independant. 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 iso7185; interface const MaxInt = MaxLongint; type Integer = Longint; Procedure Rewrite(var t : Text); Procedure Reset(var t : Text); Procedure Reset(var f : TypedFile); [INTERNPROC: fpc_in_Reset_TypedFile]; Procedure Rewrite(var f : TypedFile); [INTERNPROC: fpc_in_Rewrite_TypedFile]; Procedure Rewrite(var t : Text;const filename : string); Procedure Reset(var t : Text;const filename : string); Procedure Reset(var f : TypedFile;const filename : string); [INTERNPROC: fpc_in_Reset_TypedFile_Name]; Procedure Rewrite(var f : TypedFile;const filename : string); [INTERNPROC: fpc_in_Rewrite_TypedFile_Name]; Function Eof(Var t: Text): Boolean; Function Eof:Boolean; Function Eoln(Var t: Text): Boolean; Function Eoln:Boolean; Procedure Page; Procedure Page(Var t: Text); Procedure Get(Var t: Text); Procedure Put(Var t: Text); procedure Get; Procedure Put; Procedure Get(Var f: TypedFile); Procedure Put(Var f: TypedFile); Procedure Seek(var f:TypedFile;Pos:Int64); Function FilePos(var f:TypedFile):Int64; Function Eof(var f:TypedFile): Boolean; {$ifndef FPUNONE} {$ifdef FPC_CURRENCY_IS_INT64} function round(c : currency) : int64; {$ifndef cpujvm} function round(c : comp) : int64; {$else not cpujvm} function round_comp(c : comp) : int64; {$endif not cpujvm} {$endif FPC_CURRENCY_IS_INT64} function Round(d : ValReal) : int64; {$endif FPUNONE} implementation {$i isotmp.inc} {$i-} procedure DoAssign(var t : Text); {$ifndef FPC_HAS_FEATURE_RANDOM} const NextIndex : Word = 1; {$endif FPC_HAS_FEATURE_RANDOM} begin {$ifdef FPC_HAS_FEATURE_RANDOM} Assign(t,getTempDir+'fpc_'+HexStr(random(1000000000),8)+'.tmp'); {$else FPC_HAS_FEATURE_RANDOM} Assign(t,getTempDir+'fpc_'+HexStr(NextIndex,4)+'.tmp'); Inc(NextIndex); {$endif FPC_HAS_FEATURE_RANDOM} end; Procedure Rewrite(var t : Text);[IOCheck]; Begin { create file name? } if Textrec(t).mode=0 then DoAssign(t); System.Rewrite(t); End; Procedure Reset(var t : Text);[IOCheck]; Begin case Textrec(t).mode of { create file name? } 0: DoAssign(t); fmOutput: Write(t,#26); end; System.Reset(t); End; Procedure Rewrite(var t : Text;const filename : string);[IOCheck]; Begin { create file name? } if Textrec(t).mode=0 then Assign(t,filename); System.Rewrite(t); End; Procedure Reset(var t : Text;const filename : string);[IOCheck]; Begin case Textrec(t).mode of { create file name? } 0: Assign(t,filename); fmOutput: Write(t,#26); end; System.Reset(t); End; Function Eof(Var t: Text): Boolean;[IOCheck]; var OldCtrlZMarksEof : Boolean; Begin { not sure if this is correct, but we are always at eof when writing to a file } if TextRec(t).mode=fmOutput then Eof:=true else begin OldCtrlZMarksEof:=CtrlZMarksEOF; CtrlZMarksEof:=true; Eof:=System.Eof(t); CtrlZMarksEof:=OldCtrlZMarksEOF; end; end; Function Eof:Boolean; Begin Eof:=Eof(Input); End; Function Eoln(Var t: Text): Boolean;[IOCheck]; var OldCtrlZMarksEof : Boolean; Begin OldCtrlZMarksEof:=CtrlZMarksEOF; CtrlZMarksEof:=true; Eoln:=System.Eoln(t); CtrlZMarksEof:=OldCtrlZMarksEOF; end; Function Eoln:Boolean; Begin Eoln:=Eoln(Input); End; Procedure Page;[IOCheck]; begin Page(Output); end; Procedure Page(var t : Text);[IOCheck]; Begin write(#12); End; procedure Get(var t : Text);[IOCheck]; var c : AnsiChar; Begin Read(t,c); End; Procedure Put(var t : Text);[IOCheck]; type FileFunc = Procedure(var t : TextRec); begin inc(TextRec(t).BufPos); If TextRec(t).BufPos>=TextRec(t).BufSize Then FileFunc(TextRec(t).InOutFunc)(TextRec(t)); end; procedure Get;[IOCheck]; var c : AnsiChar; Begin Read(input,c); End; Procedure Put;[IOCheck]; type FileFunc = Procedure(var t : TextRec); begin inc(TextRec(Output).BufPos); If TextRec(Output).BufPos>=TextRec(Output).BufSize Then FileFunc(TextRec(Output).InOutFunc)(TextRec(Output)); end; procedure Get(var f:TypedFile);[IOCheck]; Begin if not(system.eof(f)) then BlockRead(f,(pbyte(@f)+sizeof(FileRec))^,1) else FileRec(f)._private[1]:=1; End; Procedure Put(var f:TypedFile);[IOCheck]; begin BlockWrite(f,(pbyte(@f)+sizeof(FileRec))^,1); end; Function Eof(var f:TypedFile): Boolean;[IOCheck]; Begin Eof:=FileRec(f)._private[1]=1; End; Procedure Seek(var f:TypedFile;Pos:Int64);[IOCheck]; Begin System.Seek(f,Pos); if (FileRec(f).mode=fmInOut) or (FileRec(f).mode=fmInput) then begin if FilePos(f)=0.0 then Round:=Trunc(c+0.5) else Round:=Trunc(c-0.5); end; {$ifndef cpujvm} function round(c : comp) : int64; begin if c>=0.0 then round:=Trunc(c+0.5) else round:=Trunc(c-0.5); end; {$else not cpujvm} function round_comp(c : comp) : int64; begin if c>=0.0 then round_comp:=Trunc(c+0.5) else round_comp:=Trunc(c-0.5); end; {$endif cpujvm} {$endif FPC_CURRENCY_IS_INT64} function Round(d : ValReal) : int64; begin if d>=0.0 then Round:=Trunc(d+0.5) else Round:=Trunc(d-0.5); end; {$endif FPUNONE} begin { we shouldn't do this because it might confuse user programs, but for now it is good enough to get pretty unique tmp file names } {$ifdef FPC_HAS_FEATURE_RANDOM} Randomize; {$endif FPC_HAS_FEATURE_RANDOM} { reset opens with read-only } Filemode:=0; end.