123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- {
- Copyright (c) 1998-2002 by Florian Klaempfl
- This unit provides some help routines for symbol handling
- 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.
- ****************************************************************************
- }
- unit symutil;
- {$i fpcdefs.inc}
- interface
- uses
- symbase,symsym;
- function is_funcret_sym(p:TSymEntry):boolean;
- function equal_constsym(sym1,sym2:tconstsym; nanequal: boolean):boolean;
- implementation
- uses
- globtype,cpuinfo,constexp,
- symconst,widestr;
- function is_funcret_sym(p:TSymEntry):boolean;
- begin
- is_funcret_sym:=(p.typ in [absolutevarsym,localvarsym,paravarsym]) and
- (vo_is_funcret in tabstractvarsym(p).varoptions);
- end;
- function equal_constsym(sym1,sym2:tconstsym; nanequal: boolean):boolean;
- var
- p1,p2,pend : pchar;
- begin
- equal_constsym:=false;
- if sym1.consttyp<>sym2.consttyp then
- exit;
- case sym1.consttyp of
- constord :
- equal_constsym:=(sym1.value.valueord=sym2.value.valueord);
- constpointer :
- equal_constsym:=(sym1.value.valueordptr=sym2.value.valueordptr);
- conststring,constresourcestring :
- begin
- if sym1.value.len=sym2.value.len then
- begin
- p1:=pchar(sym1.value.valueptr);
- p2:=pchar(sym2.value.valueptr);
- pend:=p1+sym1.value.len;
- while (p1<pend) do
- begin
- if p1^<>p2^ then
- break;
- inc(p1);
- inc(p2);
- end;
- if (p1=pend) then
- equal_constsym:=true;
- end;
- end;
- constwstring :
- begin
- if (sym1.value.len=sym2.value.len) and
- (comparewidestrings(sym1.value.valueptr,sym2.value.valueptr)=0) then
- equal_constsym:=true;
- end;
- constreal :
- if nanequal then
- equal_constsym:=CompareByte(pbestreal(sym1.value.valueptr)^,pbestreal(sym2.value.valueptr)^,sizeof(pbestreal^))=0
- else
- equal_constsym:=pbestreal(sym1.value.valueptr)^=pbestreal(sym2.value.valueptr)^;
- constset :
- equal_constsym:=(pnormalset(sym1.value.valueptr)^=pnormalset(sym2.value.valueptr)^);
- constnil :
- equal_constsym:=true;
- end;
- end;
- end.
|