| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418 |  {    $Id$    This unit handles symbols    Copyright (C) 1998-2000 by Daniel Mantione,     member of the Free Pascal development team    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. ****************************************************************************}{$ifdef TP}  {$N+,E+,F+}{$endif}unit symbols;interfaceuses    symtable,aasm,objects,cobjects,defs{$ifdef i386}        ,i386base{$endif}{$ifdef m68k}        ,m68k{$endif}{$ifdef alpha}        ,alpha{$endif};{Note: It is forbidden to add the symtablt unit. A symbol should not now in which symtable it is.}type    Ttypeprop=(sp_primary_typesym);        Ttypepropset=set of Ttypeprop;        Tpropprop=(ppo_indexed,ppo_defaultproperty,                   ppo_stored,ppo_published);        Tproppropset=set of Tpropprop;        Tvarprop=(vo_regable,vo_is_C_var,vo_is_external,vo_is_dll_var,                  vo_is_thread_var);        Tvarpropset=set of Tvarprop;        Plabelsym=^Tlabelsym;        Tlabelsym=object(Tsym)            lab:Pasmlabel;            defined:boolean;            constructor init(const n:string;l:Pasmlabel);            constructor load(var s:Tstream);            function mangledname:string;virtual;            procedure store(var s:Tstream);virtual;        end;{       Punitsym=^Tunitsym;        Tunitsym=object(Tsym)            unitsymtable : punitsymtable;            prevsym : punitsym;            refs : longint;            constructor init(const n : string;ref : punitsymtable);            constructor load(var s:Tstream);            destructor done;virtual;            procedure store(var s:Tstream);virtual;        end;}        Perrorsym=^Terrorsym;        Terrorsym=object(tsym)            constructor init;        end;        Pprocsym=^Tprocsym;        Tprocsym=object(Tsym)            definitions:Pobject;    {Is Pprocdef when procedure not                                     overloaded, or a Pcollection of                                     Pprocdef when it is overloaded.                                     Since most procedures are not                                     overloaded, this saves a lot of                                     memory.}            sub_of:Pprocsym;            _class:Pobjectdef;            constructor init(const n:string;Asub_of:Pprocsym);            constructor load(var s:Tstream);            procedure foreach(action:pointer);            procedure insert(def:Pdef);            function mangledname:string;virtual; {Causes internalerror.}            {Writes all declarations.}            procedure write_parameter_lists;            {Tests, if all procedures definitions are defined and not             just available as forward,}            procedure check_forward;            procedure store(var s:Tstream);virtual;            procedure deref;virtual;            procedure load_references;virtual;            function  write_references:boolean;virtual;            destructor done;virtual;        end;        Ptypesym=^Ttypesym;        Ttypesym=object(Tsym)            definition:Pdef;            forwardpointers:Pcollection;    {Contains the forwardpointers.}            properties:Ttypepropset;            synonym:Ptypesym;            constructor init(const n:string;d:Pdef);            constructor load(var s:Tstream);{           procedure addforwardpointer(p:Ppointerdef);}            procedure deref;virtual;            procedure store(var s:Tstream);virtual;            procedure load_references;virtual;            procedure updateforwarddef(p:pdef);            function  write_references:boolean;virtual;            destructor done;virtual;        end;        Psyssym=^Tsyssym;        Tsyssym=object(Tsym)            number:longint;            constructor init(const n:string;l:longint);            constructor load(var s:Tstream);            procedure store(var s:Tstream);virtual;        end;        Pmacrosym=^Tmacrosym;        Tmacrosym=object(Tsym)            defined:boolean;            buftext:Pchar;            buflen:longint;            {Macros aren't written to PPU files !}            constructor init(const n:string);            destructor done;virtual;        end;        Penumsym=^Tenumsym;        Tenumsym=object(tsym)            value:longint;            definition:Penumdef;            nextenum:Penumsym;            constructor init(const n:string;def:Penumdef;v:longint);            constructor load(var s:Tstream);            procedure store(var s:Tstream);virtual;            procedure deref;virtual;            procedure order;        end;        Pprogramsym=^Tprogramsym;        Tprogramsym=object(Tsym)        end;        Pvarsym=^Tvarsym;        Tvarsym=object(tsym)            address:longint;            localvarsym:Pvarsym;            islocalcopy:boolean;            definition:Pdef;            refs:longint;            properties:Tvarpropset;            objprop:Tobjpropset;            _mangledname:Pstring;            reg:Tregister;  {If reg<>R_NO, then the variable is an register                             variable }            constructor init(const n:string;p:Pdef);            constructor init_dll(const n:string;p:Pdef);            constructor init_C(const n,mangled:string;p:Pdef);            constructor load(var s:Tstream);            procedure concatdata(const n:string;len:longint);            procedure deref;virtual;            function getsize:longint;virtual;            function mangledname:string;virtual;            procedure insert_in_data;virtual;            procedure setmangledname(const s:string);            procedure store(var s:Tstream);virtual;            destructor done;virtual;        end;        Pparamsym=^Tparamsym;        Tparamsym=object(Tvarsym)            varspez:Tvarspez;            pushaddress:longint;            constructor init(const n:string;p:Pdef;vs:Tvarspez);            function getsize:longint;virtual;            function getpushsize:longint;virtual;            procedure insert_in_data;virtual;        end;        Ptypedconstsym=^Ttypedconstsym;        Ttypedconstsym=object(Tsym)            prefix:Pstring;            definition:Pdef;            is_really_const:boolean;            constructor init(const n:string;p:Pdef;really_const:boolean);            constructor load(var s:Tstream);            destructor done;virtual;            function mangledname:string;virtual;            procedure store(var s:Tstream);virtual;            procedure deref;virtual;            function getsize:longint;            procedure insert_in_data;virtual;        end;        Tconsttype=(constord,conststring,constreal,constbool,                    constint,constchar,constset,constnil);        Pconstsym=^Tconstsym;        Tconstsym=object(Tsym)           definition:Pdef;           consttype:Tconsttype;           value,len:longint;   {Len is needed for string length.}           constructor init(const n:string;t:Tconsttype;v:longint);           constructor init_def(const n:string;t:Tconsttype;v:longint;                                def:Pdef);           constructor init_string(const n:string;t:Tconsttype;                                   str:Pchar;l:longint);           constructor load(var s:Tstream);           procedure deref;virtual;           procedure store(var s:Tstream);virtual;           destructor done;virtual;        end;        absolutetyp = (tovar,toasm,toaddr);        Pabsolutesym = ^tabsolutesym;        Tabsolutesym = object(tvarsym)            abstyp:absolutetyp;            absseg:boolean;            ref:Psym;            asmname:Pstring;            constructor load(var s:Tstream);            procedure deref;virtual;            function mangledname : string;virtual;            procedure store(var s:Tstream);virtual;        end;        Pfuncretsym=^Tfuncretsym;        Tfuncretsym=object(tsym)            funcretprocinfo : pointer{ should be pprocinfo};            funcretdef:Pdef;            address:longint;            constructor init(const n:string;approcinfo:pointer{pprocinfo});            constructor load(var s:Tstream);            procedure insert_in_data;virtual;            procedure store(var s:Tstream);virtual;            procedure deref;virtual;        end;        Ppropertysym=^Tpropertysym;        Tpropertysym=object(Tsym)            properties:Tproppropset;            definition:Pdef;            readaccesssym,writeaccesssym,storedsym:Psym;            readaccessdef,writeaccessdef,storeddef:Pdef;            index,default:longint;            constructor load(var s:Tstream);            function getsize:longint;virtual;            procedure store(var s:Tstream);virtual;            procedure deref;virtual;        end;var current_object_option:Tobjpropset;    current_type_option:Ttypepropset;implementationuses    callspec,verbose,globals,systems,globtype;{****************************************************************************                                 Tlabelsym****************************************************************************}constructor Tlabelsym.init(const n:string;l:Pasmlabel);begin    inherited init(n);    lab:=l;    defined:=false;end;constructor Tlabelsym.load(var s:Tstream);begin    inherited load(s);    defined:=true;end;function Tlabelsym.mangledname:string;begin    mangledname:=lab^.name;end;procedure Tlabelsym.store(var s:Tstream);begin    inherited store(s);{   current_ppu^.writeentry(iblabelsym);}end;{****************************************************************************                                  Terrorsym****************************************************************************}constructor terrorsym.init;begin    inherited init('');end;{****************************************************************************                                  Tprocsym****************************************************************************}constructor Tprocsym.init(const n:string;Asub_of:Pprocsym);begin    inherited init(n);    sub_of:=Asub_of;end;constructor Tprocsym.load(var s:Tstream);begin    inherited load(s);{   definition:=Pprocdef(readdefref);}end;procedure Tprocsym.foreach(action:pointer);begin    if definitions<>nil then        begin            if typeof(definitions^)=typeof(Tcollection) then                Pcollection(definitions)^.foreach(action)            else                callpointerlocal(action,previousframepointer,definitions);        end;end;procedure Tprocsym.insert(def:Pdef);var c:Pcollection;begin    if definitions=nil then        definitions:=def    else        if typeof(definitions^)=typeof(Tcollection) then            Pcollection(def)^.insert(def)        else            begin                c:=new(Pcollection,init(8,4));                c^.insert(definitions);                definitions:=c;            end;end;function Tprocsym.mangledname:string;begin    internalerror($99080201);end;procedure Tprocsym.write_parameter_lists;{var    p:Pprocdef;}begin(*  p:=definition;    while assigned(p) do        begin            {Force the error to be printed.}            verbose.message1(sym_b_param_list,name+p^.demangled_paras);            p:=p^.nextoverloaded;        end;*)end;procedure tprocsym.check_forward;{var    pd:Pprocdef;}begin(*  pd:=definition;    while assigned(pd) do        begin            if pd^.forwarddef then                begin                    if assigned(pd^._class) then                        messagepos1(fileinfo,sym_e_forward_not_resolved,                         pd^._class^.objname^+'.'+name+                         demangledparas(pd^.demangled_paras))                    else                        messagepos1(fileinfo,sym_e_forward_not_resolved,                         name+pd^.demangled_paras);                    {Turn futher error messages off.}                    pd^.forwarddef:=false;                end;                pd:=pd^.nextoverloaded;        end;*)end;procedure tprocsym.deref;{var    t:ttoken;    last:Pprocdef;}begin(*    resolvedef(pdef(definition));    if (definition^.options and pooperator) <> 0 then        begin            last:=definition;            while assigned(last^.nextoverloaded) do                last:=last^.nextoverloaded;            for t:=first_overloaded to last_overloaded do                if (name=overloaded_names[t]) then                    begin                        if assigned(overloaded_operators[t]) then                            last^.nextoverloaded:=overloaded_operators[t]^.definition;                        overloaded_operators[t]:=@self;                    end;        end;*)end;procedure Tprocsym.store(var s:Tstream);begin    inherited store(s);{   writedefref(pdef(definition));    current_ppu^.writeentry(ibprocsym);}end;procedure tprocsym.load_references;begin    inherited load_references;end;function Tprocsym.write_references:boolean;{var    prdef:Pprocdef;}begin(*  write_references:=false;    if not inherited write_references then        exit;    write_references:=true;    prdef:=definition;    while assigned(prdef) and (prdef^.owner=definition^.owner) do        begin            prdef^.write_references;            prdef:=prdef^.nextoverloaded;        end;*)end;destructor Tprocsym.done;begin    {Don't check if errors !!}    if errorcount=0 then        check_forward;    inherited done;end;{****************************************************************************                                  Ttypesym****************************************************************************}constructor Ttypesym.init(const n:string;d:Pdef);begin    inherited init(n);    definition:=d;    if assigned(definition) then        begin            if definition^.sym<>nil then                begin                    definition^.sym:=@self;                    properties:=[sp_primary_typesym];                end            else                begin                    synonym:=Ptypesym(definition^.sym)^.synonym;                    Ptypesym(definition^.sym)^.synonym:=@self;                end;        end;end;constructor Ttypesym.load(var s:Tstream);begin    inherited load(s);{   definition:=readdefref;}end;{procedure Ttypesym.addforwardpointer(p:Ppointerdef);begin    if forwardpointers=nil then        new(forwardpointers,init(8,4));    forwardpointers^.insert(p);end;}procedure ttypesym.deref;begin(*  resolvedef(definition);    if assigned(definition) then        begin            if properties=sp_primary_typesym then                begin                    if definition^.sym<>@self then                        synonym:=definition^.sym;                    definition^.sym:=@self;                end            else                begin                    if assigned(definition^.sym) then                        begin                            synonym:=definition^.sym^.synonym;                            if definition^.sym<>@self then                                definition^.sym^.synonym:=@self;                        end                    else                        definition^.sym:=@self;                end;            if (definition^.deftype=recorddef) and             assigned(precdef(definition)^.symtable) and             (definition^.sym=@self) then                precdef(definition)^.symtable^.name:=stringdup('record '+name);        end;*)end;procedure ttypesym.store(var s:Tstream);begin    inherited store(s);{   writedefref(definition);    current_ppu^.writeentry(ibtypesym);}end;procedure ttypesym.load_references;begin    inherited load_references;{   if typeof(definition^)=typeof(Trecorddef) then       Precdef(definition)^.symtable^.load_browser;    if typeof(definition^)=typeof(Tobjectdef) then       Pobjectdef(definition)^.publicsyms^.load_browser;}end;function ttypesym.write_references : boolean;begin(*  if not inherited write_references then    {Write address of this symbol if record or object     even if no real refs are there     because we need it for the symtable }    if (definition^.deftype=recorddef) or     (definition^.deftype=objectdef) then        begin            writesymref(@self);            current_ppu^.writeentry(ibsymref);        end;    write_references:=true;    if (definition^.deftype=recorddef) then        precdef(definition)^.symtable^.write_browser;    if (definition^.deftype=objectdef) then        pobjectdef(definition)^.publicsyms^.write_browser;*)end;procedure ttypesym.updateforwarddef(p:pdef);var i:word;begin    if definition<>nil then        internalerror($99080203)    else        definition:=p;    properties:=current_type_option;    fileinfo:=tokenpos;    if assigned(definition) and not(assigned(definition^.sym)) then        definition^.sym:=@self;    {Update all forwardpointers to this definition.}{   for i:=1 to forwardpointers^.count do        Ppointerdef(forwardpointers^.at(i))^.definition:=definition;}    forwardpointers^.deleteall;    dispose(forwardpointers,done);    forwardpointers:=nil;end;destructor Ttypesym.done;var prevsym:Ptypesym;begin    if assigned(definition) then        begin            prevsym:=Ptypesym(definition^.sym);            if prevsym=@self then                definition^.sym:=synonym;            while assigned(prevsym) do                begin                    if (prevsym^.synonym=@self) then                        begin                            prevsym^.synonym:=synonym;                            break;                     end;                    prevsym:=prevsym^.synonym;                end;           end;    synonym:=nil;    definition:=nil;    inherited done;end;{****************************************************************************                                  Tsyssym****************************************************************************}constructor Tsyssym.init(const n:string;l:longint);begin    inherited init(n);    number:=l;end;constructor Tsyssym.load(var s:Tstream);begin     inherited load(s);{    number:=readlong;}end;procedure tsyssym.store(var s:Tstream);begin    Tsym.store(s);{   writelong(number);    current_ppu^.writeentry(ibsyssym);}end;{****************************************************************************                                  Tenumsym****************************************************************************}constructor Tenumsym.init(const n:string;def:Penumdef;v:longint);begin    inherited init(n);    definition:=def;    value:=v;    if def^.minval>v then        def^.setmin(v);    if def^.maxval<v then        def^.setmax(v);    order;end;constructor Tenumsym.load(var s:Tstream);begin    inherited load(s);{   definition:=Penumdef(readdefref);    value:=readlong;}end;procedure Tenumsym.deref;begin{   resolvedef(pdef(definition));    order;}end;procedure Tenumsym.order;var i:word;label   inserted;begin    {Keep the enum symbols ordered by value...}    with definition^.symbols^ do        begin            {Most of the time, enums are defined in order, so we count down.}            for i:=count-1 downto 0 do                begin                    if Penumsym(at(i))^.value<value then                        begin                            atinsert(i+1,@self);                            {We have to use goto to keep the                             code efficient :( }                            goto inserted;                        end;                end;            atinsert(0,@self);        inserted:        end;end;procedure Tenumsym.store(var s:Tstream);begin    inherited store(s);(*  writedefref(definition);    writelong(value);    current_ppu^.writeentry(ibenumsym);*)end;{****************************************************************************                                  Tmacrosym****************************************************************************}constructor Tmacrosym.init(const n:string);begin    inherited init(n);    defined:=true;end;destructor Tmacrosym.done;begin    if assigned(buftext) then        freemem(buftext,buflen);    inherited done;end;{****************************************************************************                                  Tprogramsym****************************************************************************}{****************************************************************************                                    Tvarsym****************************************************************************}constructor Tvarsym.init(const n:string;p:Pdef);begin    inherited init(n);    definition:=p;    {Can we load the value into a register ? }    if dp_regable in p^.properties then        include(properties,vo_regable);    reg:=R_NO;end;constructor Tvarsym.init_dll(const n:string;p:Pdef);begin    init(n,p);    include(properties,vo_is_dll_var);end;constructor Tvarsym.init_C(const n,mangled:string;p:Pdef);begin    init(n,p);    include(properties,vo_is_C_var);    setmangledname(mangled);end;procedure Tvarsym.concatdata(const n:string;len:longint);beginend;constructor Tvarsym.load(var s:Tstream);begin    inherited load(s);    reg:=R_NO;{   if read_member then        address:=readlong    else        address:=0;    definition:=readdefref;    var_options:=readbyte;    if (var_options and vo_is_C_var)<>0 then        setmangledname(readstring);}end;function Tvarsym.getsize:longint;begin    if definition<>nil then        getsize:=definition^.size    else        getsize:=0;end;procedure Tvarsym.deref;begin{   resolvedef(definition);}end;procedure Tvarsym.store(var s:Tstream);begin(*  inherited store(s);    if read_member then        writelong(address);    writedefref(definition);    { symbols which are load are never candidates for a register,      turn of the regable }    writebyte(var_options and (not vo_regable));    if (var_options and vo_is_C_var)<>0 then        writestring(mangledname);    current_ppu^.writeentry(ibvarsym);*)end;procedure Tvarsym.setmangledname(const s:string);begin    _mangledname:=stringdup(s);end;function Tvarsym.mangledname:string;var prefix:string;begin    if assigned(_mangledname) then        mangledname:=_mangledname^    else        mangledname:=owner^.varsymprefix+name;end;procedure Tvarsym.insert_in_data;var l,ali,modulo:longint;    storefilepos:Tfileposinfo;begin    if (vo_is_external in properties) then        begin            {Handle static variables of objects especially }            if read_member and (sp_static in objprop) then                begin                    {The data field is generated in parser.pas                     with a tobject_FIELDNAME variable, so we do                     not need to do it in this procedure.}                    {This symbol can't be loaded to a register.}                    exclude(properties,vo_regable);                end            else                if not(read_member) then                    begin                        storefilepos:=aktfilepos;                        aktfilepos:=tokenpos;                        if (vo_is_thread_var in properties) then                            l:=4                        else                            l:=getsize;                        address:=owner^.varsymtodata(@self,l);                        aktfilepos:=storefilepos;                    end;        end;end;destructor Tvarsym.done;begin    disposestr(_mangledname);    inherited done;end;{****************************************************************************                                Tparamsym****************************************************************************}constructor Tparamsym.init(const n:string;p:Pdef;vs:Tvarspez);begin    inherited init(n,p);    varspez:=vs;end;function Tparamsym.getsize:longint;begin    if (definition<>nil) and (varspez=vs_value) then        getsize:=definition^.size    else        getsize:=0;end;function Tparamsym.getpushsize:longint;begin    if assigned(definition) then        begin            case varspez of                vs_var:                    getpushsize:=target_os.size_of_pointer;                vs_value,vs_const:                     if dp_pointer_param in definition^.properties then                         getpushsize:=target_os.size_of_pointer                     else                         getpushsize:=definition^.size;            end;        end    else        getpushsize:=0;end;procedure Tparamsym.insert_in_data;var storefilepos:Tfileposinfo;begin    storefilepos:=aktfilepos;    {Handle static variables of objects especially }    if read_member and (sp_static in objprop) then        begin            {The data field is generated in parser.pas             with a tobject_FIELDNAME variable, so we do             not need to do it in this procedure.}            {This symbol can't be loaded to a register.}            exclude(properties,vo_regable);        end    else        if not(read_member) then            pushaddress:=owner^.varsymtodata(@self,getpushsize);        if (varspez=vs_var) then            address:=0        else if (varspez=vs_value) then            if dp_pointer_param in definition^.properties then                begin                    {Allocate local space.}                    address:=owner^.datasize;                    inc(owner^.datasize,getsize);                end            else                address:=pushaddress        else            {vs_const}            if dp_pointer_param in definition^.properties then                address:=0            else                address:=pushaddress;    aktfilepos:=storefilepos;end;{****************************************************************************                             Ttypedconstsym*****************************************************************************}constructor Ttypedconstsym.init(const n:string;p:Pdef;really_const:boolean);begin   inherited init(n);   definition:=p;   is_really_const:=really_const;   prefix:=stringdup(procprefix);end;constructor Ttypedconstsym.load(var s:Tstream);begin    inherited load(s);(*  definition:=readdefref;{$ifdef DELPHI_CONST_IN_RODATA}    is_really_const:=boolean(readbyte);{$else DELPHI_CONST_IN_RODATA}    is_really_const:=false;{$endif DELPHI_CONST_IN_RODATA}    prefix:=stringdup(readstring);*)end;procedure Ttypedconstsym.deref;begin{   resolvedef(definition);}end;function Ttypedconstsym.mangledname:string;begin    mangledname:='TC_'+prefix^+'_'+name;end;function Ttypedconstsym.getsize:longint;begin    if assigned(definition) then        getsize:=definition^.size    else        getsize:=0;end;procedure Ttypedconstsym.store(var s:Tstream);begin   inherited store(s);(*   writedefref(definition);   writestring(prefix^);{$ifdef DELPHI_CONST_IN_RODATA}   writebyte(byte(is_really_const));{$endif DELPHI_CONST_IN_RODATA}   current_ppu^.writeentry(ibtypedconstsym);*)end;{ for most symbol types ther is nothing to do at all }procedure Ttypedconstsym.insert_in_data;var constsegment:Paasmoutput;    l,ali,modulo:longint;    storefilepos:Tfileposinfo;begin    storefilepos:=aktfilepos;    aktfilepos:=tokenpos;    owner^.tconstsymtodata(@self,getsize);    aktfilepos:=storefilepos;end;destructor Ttypedconstsym.done;begin    stringdispose(prefix);    inherited done;end;{****************************************************************************                                  TCONSTSYM****************************************************************************}constructor Tconstsym.init(const n : string;t : tconsttype;v : longint);begin    inherited init(n);    consttype:=t;    value:=v;end;constructor Tconstsym.init_def(const n:string;t:Tconsttype;                               v:longint;def:Pdef);begin    inherited init(n);    consttype:=t;    value:=v;    definition:=def;end;constructor Tconstsym.init_string(const n:string;t:Tconsttype;str:Pchar;l:longint);begin    inherited init(n);    consttype:=t;    value:=longint(str);    len:=l;end;constructor Tconstsym.load(var s:Tstream);var pd:Pbestreal;    ps:Pnormalset;begin    inherited load(s);(*  consttype:=tconsttype(readbyte);    case consttype of      constint,      constbool,      constchar : value:=readlong;      constord :        begin          definition:=readdefref;          value:=readlong;        end;      conststring :        begin          len:=readlong;          getmem(pchar(value),len+1);          current_ppu^.getdata(pchar(value)^,len);        end;      constreal :        begin          new(pd);          pd^:=readreal;          value:=longint(pd);        end;      constset :        begin          definition:=readdefref;          new(ps);          readnormalset(ps^);          value:=longint(ps);        end;      constnil : ;      else        Message1(unit_f_ppu_invalid_entry,tostr(ord(consttype)));   end;*)end;procedure Tconstsym.deref;begin{   if consttype in [constord,constset] then        resolvedef(pdef(definition));}end;procedure Tconstsym.store(var s:Tstream);begin(*  inherited store(s);    writebyte(byte(consttype));    case consttype of      constnil : ;      constint,      constbool,      constchar :        writelong(value);      constord :        begin          writedefref(definition);          writelong(value);        end;      conststring :        begin          writelong(len);          current_ppu^.putdata(pchar(value)^,len);        end;      constreal :        writereal(pbestreal(value)^);      constset :        begin          writedefref(definition);          writenormalset(pointer(value)^);        end;    else      internalerror(13);    end;    current_ppu^.writeentry(ibconstsym);*)end;destructor Tconstsym.done;begin    case consttype of        conststring:            freemem(Pchar(value),len+1);        constreal:            dispose(Pbestreal(value));        constset:            dispose(Pnormalset(value));    end;    inherited done;end;{****************************************************************************                                Tabsolutesym****************************************************************************}constructor Tabsolutesym.load(var s:Tstream);begin    inherited load(s);(*  typ:=absolutesym;    abstyp:=absolutetyp(readbyte);    case abstyp of      tovar :        begin          asmname:=stringdup(readstring);          ref:=srsym;        end;      toasm :        asmname:=stringdup(readstring);      toaddr :        begin          address:=readlong;          absseg:=boolean(readbyte);        end;    end;*)end;procedure tabsolutesym.store(var s:Tstream);begin    inherited store(s);(*  writebyte(byte(varspez));    if read_member then      writelong(address);    writedefref(definition);    writebyte(var_options and (not vo_regable));    writebyte(byte(abstyp));    case abstyp of      tovar :        writestring(ref^.name);      toasm :        writestring(asmname^);      toaddr :        begin          writelong(address);          writebyte(byte(absseg));        end;    end;    current_ppu^.writeentry(ibabsolutesym);*)end;procedure tabsolutesym.deref;begin(*  resolvedef(definition);    if (abstyp=tovar) and (asmname<>nil) then        begin            { search previous loaded symtables }            getsym(asmname^,false);            if not(assigned(srsym)) then            getsymonlyin(owner,asmname^);            if not(assigned(srsym)) then                srsym:=generrorsym;            ref:=srsym;            stringdispose(asmname);       end;*)end;function Tabsolutesym.mangledname : string;begin    case abstyp of        tovar :            mangledname:=ref^.mangledname;        toasm :            mangledname:=asmname^;        toaddr :            mangledname:='$'+tostr(address);        else            internalerror(10002);    end;end;{****************************************************************************                                  Tfuncretsym****************************************************************************}constructor Tfuncretsym.init(const n:string;approcinfo:pointer{pprocinfo});begin    inherited init(n);    funcretprocinfo:=approcinfo;{   funcretdef:=Pprocinfo(approcinfo)^.retdef;}    { address valid for ret in param only }    { otherwise set by insert             }{   address:=pprocinfo(approcinfo)^.retoffset;}end;constructor Tfuncretsym.load(var s:Tstream);begin    inherited load(s);{   funcretdef:=readdefref;    address:=readlong;    funcretprocinfo:=nil;    typ:=funcretsym;}end;procedure Tfuncretsym.store(var s:Tstream);begin     (*      Normally all references are      transfered to the function symbol itself !! PM *)    inherited store(s);{   writedefref(funcretdef);    writelong(address);    current_ppu^.writeentry(ibfuncretsym);}end;procedure Tfuncretsym.deref;begin    {resolvedef(funcretdef);}end;procedure Tfuncretsym.insert_in_data;var l:longint;begin    {Allocate space in local if ret in acc or in fpu.}{   if dp_ret_in_acc in procinfo.retdef^.properties     or (procinfo.retdef^.deftype=floatdef) then        begin            l:=funcretdef^.size;            adress:=owner^.varsymtodata('',l);            procinfo.retoffset:=-owner^.datasize;        end;}end;constructor tpropertysym.load(var s:Tstream);begin    inherited load(s);(*  proptype:=readdefref;    options:=readlong;    index:=readlong;    default:=readlong;    { it's hack ... }    readaccesssym:=psym(stringdup(readstring));    writeaccesssym:=psym(stringdup(readstring));    storedsym:=psym(stringdup(readstring));    { now the defs: }    readaccessdef:=readdefref;    writeaccessdef:=readdefref;    storeddef:=readdefref;*)end;procedure Tpropertysym.deref;begin(*  resolvedef(proptype);    resolvedef(readaccessdef);    resolvedef(writeaccessdef);    resolvedef(storeddef);    { solve the hack we did in load: }    if pstring(readaccesssym)^<>'' then      begin         srsym:=search_class_member(pobjectdef(owner^.defowner),pstring(readaccesssym)^);         if not(assigned(srsym)) then           srsym:=generrorsym;      end    else      srsym:=nil;    stringdispose(pstring(readaccesssym));    readaccesssym:=srsym;    if pstring(writeaccesssym)^<>'' then      begin         srsym:=search_class_member(pobjectdef(owner^.defowner),pstring(writeaccesssym)^);         if not(assigned(srsym)) then           srsym:=generrorsym;      end    else      srsym:=nil;    stringdispose(pstring(writeaccesssym));    writeaccesssym:=srsym;    if pstring(storedsym)^<>'' then      begin         srsym:=search_class_member(pobjectdef(owner^.defowner),pstring(storedsym)^);         if not(assigned(srsym)) then           srsym:=generrorsym;      end    else      srsym:=nil;    stringdispose(pstring(storedsym));    storedsym:=srsym;*)end;function Tpropertysym.getsize:longint;begin    getsize:=0;end;procedure Tpropertysym.store(var s:Tstream);begin    Tsym.store(s);(*  writedefref(proptype);    writelong(options);    writelong(index);    writelong(default);    if assigned(readaccesssym) then        writestring(readaccesssym^.name)    else        writestring('');    if assigned(writeaccesssym) then      writestring(writeaccesssym^.name)    else      writestring('');    if assigned(storedsym) then      writestring(storedsym^.name)    else      writestring('');    writedefref(readaccessdef);    writedefref(writeaccessdef);    writedefref(storeddef);    current_ppu^.writeentry(ibpropertysym);*)end;end.
 |