| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 | {    This file is part of the Free Pascal run time library.    Copyright (c) 1999-2000 by the Free Pascal development team.    Processor independent implementation for the system unit    (based on libc)    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. **********************************************************************}{****************************************************************************                               Primitives****************************************************************************}{$ifndef FPC_SYSTEM_HAS_MOVE}{$define FPC_SYSTEM_HAS_MOVE}procedure bcopy(const source;var dest;count:size_t); cdecl; external clib name 'bcopy';{ we need this separate move declaration because we can't add a "public, alias" to the above }procedure Move(const source;var dest;count:sizeint); [public, alias: 'FPC_MOVE'];{$ifdef SYSTEMINLINE}inline;{$endif}begin  if count <= 0 then    exit;  bcopy(source,dest,count);end;{$endif not FPC_SYSTEM_HAS_MOVE}{$ifndef FPC_SYSTEM_HAS_FILLCHAR}{$define FPC_SYSTEM_HAS_FILLCHAR}procedure memset(var x; value: byte; count: size_t); cdecl; external clib;Procedure FillChar(var x;count: sizeint;value:byte);{$ifdef SYSTEMINLINE}inline;{$endif}begin  if count <= 0 then    exit;  memset(x,value,count);end;{$endif FPC_SYSTEM_HAS_FILLCHAR}{$ifndef FPC_SYSTEM_HAS_INDEXBYTE}{$define FPC_SYSTEM_HAS_INDEXBYTE}{$ifdef LINUX}  {$define BUGGYMEMCHR}{$endif}function memchr(const buf; b: cint; len: size_t): pointer; cdecl; external clib;{$ifdef BUGGYMEMCHR}function rawmemchr(const buf; b: cint): pointer; cdecl; external clib;{$endif BUGGYMEMCHR}function IndexByte(Const buf;len:sizeint;b:byte):sizeint;{$ifdef SYSTEMINLINE}inline;{$endif}var  res: pointer;begin  if len = 0 then    exit(-1);  { simulate assembler implementations behaviour, which is expected }  { fpc_pchar_to_ansistr in astrings.inc (interpret values < 0 as   }  { unsigned)                                                       }{$ifdef BUGGYMEMCHR}  if len = -1 then    res := rawmemchr(buf,cint(b))  else{$endif BUGGYMEMCHR}    res := memchr(buf,cint(b),size_t(sizeuint(len)));  if (res <> nil) then    IndexByte := SizeInt(res-@buf)  else    IndexByte := -1;end;{$endif not FPC_SYSTEM_HAS_INDEXBYTE}{$ifndef FPC_SYSTEM_HAS_COMPAREBYTE}{$define FPC_SYSTEM_HAS_COMPAREBYTE}function memcmp_comparechar(Const buf1,buf2;len:size_t):cint; cdecl; external clib name 'memcmp';function CompareByte(Const buf1,buf2;len:sizeint):sizeint;{$ifdef SYSTEMINLINE}inline;{$endif}var  res: longint;begin  if len <= 0 then    exit(0);  res := memcmp_comparechar(buf1,buf2,len);  if res < 0 then    CompareByte := -1  else if res > 0 then    CompareByte := 1  else    CompareByte := 0;end;{$endif not FPC_SYSTEM_HAS_COMPAREBYTE}{$ifndef FPC_SYSTEM_HAS_COMPARECHAR0}{$define FPC_SYSTEM_HAS_COMPARECHAR0}function strncmp_comparechar0(Const buf1,buf2;len:size_t):longint; cdecl; external clib name 'strncmp';function CompareChar0(Const buf1,buf2;len:sizeint):sizeint;{$ifdef SYSTEMINLINE}inline;{$endif}begin  if len <= 0 then    exit(0);  CompareChar0:=strncmp_comparechar0(buf1,buf2,len);end;{$endif not FPC_SYSTEM_HAS_COMPARECHAR0}{$ifndef FPC_SYSTEM_HAS_FPC_PCHAR_LENGTH}{$define FPC_SYSTEM_HAS_FPC_PCHAR_LENGTH}function libc_pchar_length(p:pchar):size_t; cdecl; external clib name 'strlen';function fpc_pchar_length(p:pchar):sizeint;[public,alias:'FPC_PCHAR_LENGTH']; compilerproc;begin  if assigned(p) then    fpc_pchar_length:=libc_pchar_length(p)  else    fpc_pchar_length:=0;end;{$endif ndef FPC_SYSTEM_HAS_FPC_PCHAR_LENGTH}
 |