123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372 |
- {
- *********************************************************************
- $Id$
- Copyright (C) 1997, 1998 Gertjan Schouten
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
- 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. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- *********************************************************************
- System Utilities For Free Pascal
- }
- { PChar functions }
- type
- pbyte = ^byte;
- CharArray = array[0..0] of char;
- { StrLen returns the length of Str ( terminator not included ) }
- function StrLen(Str: PChar): cardinal;
- begin
- result := 0;
- if Str <> nil then begin
- while CharArray(Str^)[result] <> #0 do
- result := result + 1;
- end ;
- end ;
- { StrEnd returns a pointer to the last character (terminator) of Str }
- function StrEnd(Str: PChar): PChar;
- begin
- result := Str;
- if Str <> nil then begin
- while result^ <> #0 do
- result := result + 1;
- end ;
- end ;
- { StrMove copies Count bytes from source to dest, source and dest may overlap. }
- function StrMove(Dest, Source: PChar; Count: cardinal): PChar;
- begin
- result := Dest;
- if (Dest <> nil) and (Source <> nil) and (Count > 0) then
- move(Source^, Dest^, Count);
- end ;
- { StrCopy copies StrLen(Source) characters from Source to Dest and returns Dest }
- function StrCopy(Dest, Source: PChar): PChar;
- begin
- result := StrMove(Dest, Source, 1 + StrLen(Source)); { copy nul character too ! }
- end ;
- { StrECopy copies StrLen(Source) characters from Source to Dest and returns StrEnd(Dest) }
- function StrECopy(Dest, Source: PChar): PChar;
- begin
- StrMove(Dest, Source, 1 + StrLen(Source));
- result := StrEnd(Dest);
- end ;
- { StrLCopy copies MaxLen or less characters from Source to Dest and returns Dest }
- function StrLCopy(Dest, Source: PChar; MaxLen: cardinal): PChar;
- var count: cardinal;
- begin
- result := Dest;
- if result <> Nil then begin
- count := StrLen(Source);
- if count > MaxLen then
- count := MaxLen;
- StrMove(Dest, Source, count);
- CharArray(result^)[Count] := #0; { terminate ! }
- end ;
- end ;
- { StrPCopy copies the pascal string Source to Dest and returns Dest }
- function StrPCopy(Dest: PChar; Source: string): PChar;
- begin
- result := StrMove(Dest, PChar(@Source[1]), length(Source));
- end ;
- { StrPLCopy copies MaxLen or less characters from the pascal string
- Source to Dest and returns Dest }
- function StrPLCopy(Dest: PChar; Source: string; MaxLen: cardinal): PChar;
- var Count: cardinal;
- begin
- result := Dest;
- if (Result <> Nil) and (MaxLen <> 0) then begin
- Count := Length(Source);
- if Count > MaxLen then
- Count := MaxLen;
- StrMove(Dest, PChar(@Source[1]), Count);
- CharArray(result^)[Count] := #0; { terminate ! }
- end ;
- end ;
- { StrCat concatenates Dest and Source and returns Dest }
- function StrCat(Dest, Source: PChar): PChar;
- begin
- result := Dest;
- StrMove(StrEnd(Dest), Source, 1 + StrLen(Source)); { include #0 }
- end ;
- { StrLCat concatenates Dest and MaxLen - StrLen(Dest) (or less) characters
- from Source, and returns Dest }
- function StrLCat(Dest, Source: PChar; MaxLen: cardinal): PChar;
- var Count: cardinal; P: PChar;
- begin
- result := Dest;
- if (Dest <> nil) and (MaxLen <> 0) then begin
- P := StrEnd(Dest);
- Count := StrLen(Source);
- if Count > MaxLen - (P - Dest) then
- Count := MaxLen - (P - Dest);
- if Count <> 0 then begin
- StrMove(P, Source, Count);
- CharArray(p^)[Count] := #0; { terminate Dest }
- end ;
- end ;
- end ;
- { StrComp returns 0 if Str1 and Str2 are equal,
- a value less than 0 in case Str1 < Str2
- and a value greater than 0 in case Str1 > Str2 }
- function StrComp(Str1, Str2: PChar): integer;
- begin
- result := 0;
- if (Str1 <> Nil) and (Str2 <> Nil) then begin
- while result = 0 do begin
- result := byte(Str1^) - byte(Str2^);
- if (Str1^ = #0) or (Str2^ = #0) then break;
- Str1 := Str1 + 1;
- Str2 := Str2 + 1;
- end ;
- end ;
- end ;
- { StrIComp returns 0 if Str1 and Str2 are equal,
- a value less than 0 in case Str1 < Str2
- and a value greater than 0 in case Str1 > Str2;
- comparison is case insensitive }
- function StrIComp(Str1, Str2: PChar): integer;
- var Chr1, Chr2: byte;
- begin
- result := 0;
- if (Str1 <> Nil) and (Str2 <> Nil) then begin
- while result = 0 do begin
- Chr1 := byte(Str1^);
- Chr2 := byte(Str2^);
- if Chr1 in [97..122] then Chr1 := Chr1 - 32;
- if Chr2 in [97..122] then Chr2 := Chr2 - 32;
- result := Chr1 - Chr2;
- if (Chr1 = 0) or (Chr2 = 0) then break;
- Str1 := Str1 + 1;
- Str2 := Str2 + 1;
- end ;
- end ;
- end ;
- { StrLComp returns 0 if Str1 and Str2 are equal,
- a value less than 0 in case Str1 < Str2
- and a value greater than 0 in case Str1 > Str2;
- MaxLen or less characters are compared }
- function StrLComp(Str1, Str2: PChar; MaxLen: cardinal): integer;
- var I: integer;
- begin
- result := 0;
- if (Str1 <> Nil) and (Str2 <> Nil) then begin
- I := 0;
- while (I < MaxLen) and (result = 0) do begin
- result := byte(Str1^) - byte(Str2^);
- if (Str1^ = #0) or (Str2^ = #0) then break;
- Str1 := Str1 + 1;
- Str2 := Str2 + 1;
- I := I + 1;
- end ;
- end ;
- end ;
- { StrLIComp returns 0 if Str1 and Str2 are equal,
- a value less than 0 in case Str1 < Str2
- and a value greater than 0 in case Str1 > Str2;
- comparison is case insensitive and MaxLen or less characters are compared }
- function StrLIComp(Str1, Str2: PChar; MaxLen: cardinal): integer;
- var Chr1, Chr2: byte; I: integer;
- begin
- result := 0;
- if (Str1 <> Nil) and (Str2 <> Nil) then begin
- I := 0;
- while (I < MaxLen) and (result = 0) do begin
- Chr1 := byte(Str1^);
- Chr2 := byte(Str2^);
- if Chr1 in [97..122] then Chr1 := Chr1 - 32;
- if Chr2 in [97..122] then Chr2 := Chr2 - 32;
- result := Chr1 - Chr2;
- if (Chr1 = 0) or (Chr2 = 0) then break;
- Str1 := Str1 + 1;
- Str2 := Str2 + 1;
- I := I + 1;
- end ;
- end ;
- end ;
- { StrScan returns a PChar to the first character Chr in Str }
- function StrScan(Str: PChar; Chr: char): PChar;
- var P: PChar;
- begin
- result := Nil;
- if Str <> Nil then begin
- P := Str;
- while (P^ <> #0) and (P^ <> Chr) do
- P := P + 1;
- if P^ = Chr then result := P;
- end ;
- end ;
- { StrRScan returns a PChar to the last character Chr in Str }
- function StrRScan(Str: PChar; Chr: char): PChar;
- var P: PChar;
- begin
- result := Nil;
- if Str <> Nil then begin
- P := StrEnd(Str);
- While (P^ <> Chr) and (P <> Str) do
- P := P - 1;
- If P^ = Chr then result := P;
- end ;
- end ;
- { StrPos returns a PChar to the first occurance of Str2 contained in Str1
- if no occurance can be found StrPos returns Nil }
- function StrPos(Str1, Str2: PChar): PChar;
- var E: PChar; Count1, Count2: Cardinal;
- begin
- Count1 := StrLen(Str1);
- Count2 := StrLen(Str2);
- if (Str1 <> Nil) and (Str2 <> Nil) and (Count1 > 0) and (Count1 >= Count2) then begin
- E := Str1 + 1 + Count1 - Count2;
- result := Str1;
- While result <> E do begin
- if StrLComp(result, Str2, Count2) = 0 then
- exit;
- result := result + 1;
- end ;
- end ;
- result := Nil;
- end ;
- { StrUpper converts all lowercase characters in Str to uppercase }
- function StrUpper(Str: PChar): PChar;
- begin
- Result := Str;
- if Str <> Nil then begin
- While Str^ <> #0 do begin
- if Str^ in ['a'..'z'] then
- dec(byte(Str^), 32);
- Str := Str + 1;
- end ;
- end ;
- end ;
- { StrLower converts all uppercase characters in Str to lowercase }
- function StrLower(Str: PChar): PChar;
- begin
- Result := Str;
- if Str <> Nil then begin
- While Str^ <> #0 do begin
- if Str^ in ['A'..'Z'] then
- inc(byte(Str^), 32);
- Str := Str + 1;
- end ;
- end ;
- end ;
- { StrPas converts a PChar to a pascal string }
- function StrPas(Str: PChar): string;
- begin
- SetLength(result, StrLen(Str));
- Move(Str^, result[1], Length(result));
- end ;
- { StrAlloc allocates a buffer of Size + 4
- the size of the allocated buffer is stored at result - 4
- StrDispose should be used to destroy the buffer }
- function StrAlloc(Size: cardinal): PChar;
- var Temp: pointer;
- begin
- GetMem(Temp, Size + SizeOf(cardinal));
- Move(Size, Temp^, SizeOf(cardinal));
- pbyte(Temp + SizeOf(cardinal))^ := 0;
- result := PChar(Temp + SizeOf(cardinal));
- end ;
- { StrBufSize returns the amount of memory allocated for pchar Str allocated with StrAlloc }
- function StrBufSize(var Str: PChar): cardinal;
- begin
- if Str <> Nil then
- result := Cardinal(pointer(Str - SizeOf(cardinal))^)
- else
- result := 0;
- end ;
- { StrNew creates an exact copy of Str }
- function StrNew(Str: PChar): PChar;
- begin
- if Str <> Nil then begin
- result := StrAlloc(1 + StrLen(Str));
- StrCopy(result, Str);
- end
- else result := Nil;
- end ;
- { StrDispose clears the memory allocated with StrAlloc }
- procedure StrDispose(var Str: PChar);
- var Size: cardinal;
- begin
- if (Str <> Nil) then begin
- Str := PChar(Str - SizeOf(cardinal));
- Move(Str^, Size, SizeOf(cardinal));
- FreeMem(Str, Size + SizeOf(cardinal));
- Str := Nil;
- end ;
- end ;
- {
- $Log$
- Revision 1.2 1998-09-16 08:28:40 michael
- Update from gertjan Schouten, plus small fix for linux
- 1998/08/26 Gertjan
- Most functions rewritten in pascal.
- Revision 1.1 1998/04/10 15:17:46 michael
- + Initial implementation; Donated by Gertjan Schouten
- His file was split into several files, to keep it a little bit structured.
- }
|