| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516 | {    This file is part of the Free Pascal run time library.    Copyright (c) 1999-2000 by the Free Pascal development team    This unit makes Free Pascal as much as possible Delphi compatible    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. **********************************************************************}{$Mode ObjFpc}{$I-}{$ifndef Unix}  {$S-}{$endif}unit objpas;  interface    { first, in object pascal, the integer type must be redefined }    const       MaxInt  = MaxLongint;    type       Integer  = longint;       PInteger = ^Integer;       { Ansistring are the default }       PString = PAnsiString;       { array types }       IntegerArray  = array[0..$effffff] of Integer;       TIntegerArray = IntegerArray;       PIntegerArray = ^IntegerArray;       PointerArray  = array [0..512*1024*1024-2] of Pointer;       TPointerArray = PointerArray;       PPointerArray = ^PointerArray;       TBoundArray = array of integer;{****************************************************************************                             Compatibility routines.****************************************************************************}    { Untyped file support }     Procedure AssignFile(Var f:File;const Name:string);     Procedure AssignFile(Var f:File;p:pchar);     Procedure AssignFile(Var f:File;c:char);     Procedure CloseFile(Var f:File);     { Text file support }     Procedure AssignFile(Var t:Text;const s:string);     Procedure AssignFile(Var t:Text;p:pchar);     Procedure AssignFile(Var t:Text;c:char);     Procedure CloseFile(Var t:Text);     { Typed file supoort }     Procedure AssignFile(Var f:TypedFile;const Name:string);     Procedure AssignFile(Var f:TypedFile;p:pchar);     Procedure AssignFile(Var f:TypedFile;c:char);     { ParamStr should return also an ansistring }     Function ParamStr(Param : Integer) : Ansistring;{****************************************************************************                             Resource strings.****************************************************************************}   type     TResourceIterator = Function (Name,Value : AnsiString; Hash : Longint; arg:pointer) : AnsiString;   Function Hash(S : AnsiString) : LongWord;   Procedure ResetResourceTables;   Procedure FinalizeResourceTables;   Procedure SetResourceStrings (SetFunction :  TResourceIterator;arg:pointer);   Procedure SetUnitResourceStrings (const UnitName:string;SetFunction :  TResourceIterator;arg:pointer);{$ifndef RESSTRSECTIONS}   Function ResourceStringTableCount : Longint;   Function ResourceStringCount(TableIndex : longint) : longint;   Function GetResourceStringName(TableIndex,StringIndex : Longint) : Ansistring;   Function GetResourceStringHash(TableIndex,StringIndex : Longint) : Longint;   Function GetResourceStringDefaultValue(TableIndex,StringIndex : Longint) : AnsiString;   Function GetResourceStringCurrentValue(TableIndex,StringIndex : Longint) : AnsiString;   Function SetResourceStringValue(TableIndex,StringIndex : longint; Value : Ansistring) : Boolean;{$endif RESSTRSECTIONS}   { Delphi compatibility }   type     PResStringRec=^AnsiString;     TResStringRec=AnsiString;   Function LoadResString(p:PResStringRec):AnsiString;  implementation{****************************************************************************                             Compatibility routines.****************************************************************************}{ Untyped file support }Procedure AssignFile(Var f:File;const Name:string);begin  System.Assign (F,Name);end;Procedure AssignFile(Var f:File;p:pchar);begin  System.Assign (F,P);end;Procedure AssignFile(Var f:File;c:char);begin  System.Assign (F,C);end;Procedure CloseFile(Var f:File); [IOCheck];begin  { Catch Runtime error/Exception }  System.Close(f);end;{ Text file support }Procedure AssignFile(Var t:Text;const s:string);begin  System.Assign (T,S);end;Procedure AssignFile(Var t:Text;p:pchar);begin  System.Assign (T,P);end;Procedure AssignFile(Var t:Text;c:char);begin  System.Assign (T,C);end;Procedure CloseFile(Var t:Text); [IOCheck];begin  { Catch Runtime error/Exception }  System.Close(T);end;{ Typed file support }Procedure AssignFile(Var f:TypedFile;const Name:string);begin  system.Assign(F,Name);end;Procedure AssignFile(Var f:TypedFile;p:pchar);begin  system.Assign (F,p);end;Procedure AssignFile(Var f:TypedFile;c:char);begin  system.Assign (F,C);end;Function ParamStr(Param : Integer) : Ansistring;Var Len : longint;begin{  Paramstr(0) should return the name of the binary.  Since this functionality is included in the system unit,  we fetch it from there.  Normally, pathnames are less than 255 chars anyway,  so this will work correct in 99% of all cases.  In time, the system unit should get a GetExeName call.}  if (Param=0) then    Result:=System.Paramstr(0)  else if (Param>0) and (Param<argc) then    begin    Len:=0;    While Argv[Param][Len]<>#0 do      Inc(len);    SetLength(Result,Len);    If Len>0 then      Move(Argv[Param][0],Result[1],Len);    end  else    paramstr:='';end;{ ---------------------------------------------------------------------    ResourceString support  ---------------------------------------------------------------------}Function Hash(S : AnsiString) : LongWord;Var  thehash,g,I : LongWord;begin   thehash:=0;   For I:=1 to Length(S) do { 0 terminated }     begin     thehash:=thehash shl 4;     inc(theHash,Ord(S[i]));     g:=thehash and LongWord($f shl 28);     if g<>0 then       begin       thehash:=thehash xor (g shr 24);       thehash:=thehash xor g;       end;     end;   If theHash=0 then     Hash:=$ffffffff   else     Hash:=TheHash;end;{$ifdef RESSTRSECTIONS}Type  PResourceStringRecord = ^TResourceStringRecord;  TResourceStringRecord = Packed Record     Name,     CurrentValue,     DefaultValue : AnsiString;     HashValue    : LongWord;{$ifdef cpu64}     Dummy        : LongWord; // alignment{$endif cpu64}   end;   TResourceStringTableList = Packed Record     Count : ptrint;     Tables : Array[Word] of record       TableStart,       TableEnd   : PResourceStringRecord;     end;   end;Var  ResourceStringTable : TResourceStringTableList; External Name 'FPC_RESOURCESTRINGTABLES';Procedure SetResourceStrings (SetFunction :  TResourceIterator;arg:pointer);Var  ResStr : PResourceStringRecord;  i      : Longint;  s      : AnsiString;begin  With ResourceStringTable do    begin      For i:=0 to Count-1 do        begin          ResStr:=Tables[I].TableStart;          { Skip first entry (name of the Unit) }          inc(ResStr);          while ResStr<Tables[I].TableEnd do            begin              s:=SetFunction(ResStr^.Name,ResStr^.DefaultValue,ResStr^.HashValue,arg);              if s<>'' then                ResStr^.CurrentValue:=s;              inc(ResStr);            end;        end;    end;end;Procedure SetUnitResourceStrings (const UnitName:string;SetFunction :  TResourceIterator;arg:pointer);Var  ResStr : PResourceStringRecord;  i      : Longint;  s,  UpUnitName : AnsiString;begin  With ResourceStringTable do    begin      UpUnitName:=UpCase(UnitName);      For i:=0 to Count-1 do        begin          ResStr:=Tables[I].TableStart;          { Check name of the Unit }          if ResStr^.Name<>UpUnitName then            continue;          inc(ResStr);          while ResStr<Tables[I].TableEnd do            begin              s:=SetFunction(ResStr^.Name,ResStr^.DefaultValue,ResStr^.HashValue,arg);              if s<>'' then                ResStr^.CurrentValue:=s;              inc(ResStr);            end;        end;    end;end;Procedure ResetResourceTables;Var  ResStr : PResourceStringRecord;  i      : Longint;begin  With ResourceStringTable do    begin      For i:=0 to Count-1 do        begin          ResStr:=Tables[I].TableStart;          { Skip first entry (name of the Unit) }          inc(ResStr);          while ResStr<Tables[I].TableEnd do            begin              ResStr^.CurrentValue:=ResStr^.DefaultValue;              inc(ResStr);            end;        end;    end;end;Procedure FinalizeResourceTables;Var  ResStr : PResourceStringRecord;  i      : Longint;begin  With ResourceStringTable do    begin      For i:=0 to Count-1 do        begin          ResStr:=Tables[I].TableStart;          { Skip first entry (name of the Unit) }          inc(ResStr);          while ResStr<Tables[I].TableEnd do            begin              ResStr^.CurrentValue:='';              inc(ResStr);            end;        end;    end;end;{$else RESSTRSECTIONS}Type  PResourceStringRecord = ^TResourceStringRecord;  TResourceStringRecord = Packed Record     DefaultValue,     CurrentValue : AnsiString;     HashValue    : LongWord;     Name         : AnsiString;   end;   TResourceStringTable = Packed Record     Count : longint;     Resrec : Array[Word] of TResourceStringRecord;   end;   PResourceStringTable = ^TResourceStringTable;   TResourceTableList = Packed Record     Count : longint;     Tables : Array[Word] of PResourceStringTable;     end;Var  ResourceStringTable : TResourceTablelist; External Name 'FPC_RESOURCESTRINGTABLES';Function GetResourceString(Const TheTable: TResourceStringTable;Index : longint) : AnsiString;[Public,Alias : 'FPC_GETRESOURCESTRING'];begin  If (Index>=0) and (Index<TheTAble.Count) then     Result:=TheTable.ResRec[Index].CurrentValue  else     Result:='';end;Procedure SetResourceStrings (SetFunction :  TResourceIterator;arg:pointer);Var I,J : longint;begin  With ResourceStringTable do    For I:=0 to Count-1 do      With Tables[I]^ do         For J:=0 to Count-1 do           With ResRec[J] do             CurrentValue:=SetFunction(Name,DefaultValue,HashValue,arg);end;Procedure SetUnitResourceStrings (const UnitName:string;SetFunction :  TResourceIterator;arg:pointer);begin  SetResourceStrings (SetFunction,arg);end;Procedure ResetResourceTables;Var I,J : longint;begin  With ResourceStringTable do  For I:=0 to Count-1 do    With Tables[I]^ do        For J:=0 to Count-1 do          With ResRec[J] do            CurrentValue:=DefaultValue;end;Procedure FinalizeResourceTables;Var I,J : longint;begin  With ResourceStringTable do  For I:=0 to Count-1 do    With Tables[I]^ do        For J:=0 to Count-1 do          With ResRec[J] do            CurrentValue:='';end;Function ResourceStringTableCount : Longint;begin  Result:=ResourceStringTable.Count;end;Function CheckTableIndex (Index: longint) : Boolean;begin  Result:=(Index<ResourceStringTable.Count) and (Index>=0)end;Function CheckStringIndex (TableIndex,Index: longint) : Boolean;begin  Result:=(TableIndex<ResourceStringTable.Count) and (TableIndex>=0) and          (Index<ResourceStringTable.Tables[TableIndex]^.Count) and (Index>=0)end;Function ResourceStringCount(TableIndex : longint) : longint;begin  If not CheckTableIndex(TableIndex) then     Result:=-1  else    Result:=ResourceStringTable.Tables[TableIndex]^.Count;end;Function GetResourceStringName(TableIndex,StringIndex : Longint) : Ansistring;begin  If not CheckStringIndex(Tableindex,StringIndex) then    Result:=''  else    result:=ResourceStringTable.Tables[TableIndex]^.ResRec[StringIndex].Name;end;Function GetResourceStringHash(TableIndex,StringIndex : Longint) : Longint;begin  If not CheckStringIndex(Tableindex,StringIndex) then    Result:=0  else    result:=ResourceStringTable.Tables[TableIndex]^.ResRec[StringIndex].HashValue;end;Function GetResourceStringDefaultValue(TableIndex,StringIndex : Longint) : AnsiString;begin  If not CheckStringIndex(Tableindex,StringIndex) then    Result:=''  else    result:=ResourceStringTable.Tables[TableIndex]^.ResRec[StringIndex].DefaultValue;end;Function GetResourceStringCurrentValue(TableIndex,StringIndex : Longint) : AnsiString;begin  If not CheckStringIndex(Tableindex,StringIndex) then    Result:=''  else    result:=ResourceStringTable.Tables[TableIndex]^.ResRec[StringIndex].CurrentValue;end;Function SetResourceStringValue(TableIndex,StringIndex : longint; Value : Ansistring) : Boolean;begin  Result:=CheckStringIndex(Tableindex,StringIndex);  If Result then   ResourceStringTable.Tables[TableIndex]^.ResRec[StringIndex].CurrentValue:=Value;end;{$endif RESSTRSECTIONS}Function LoadResString(p:PResStringRec):AnsiString;begin  Result:=p^;end;Initialization{  ResetResourceTables;}finalization  FinalizeResourceTables;end.
 |