diff options
author | jonas <jonas@3ad0048d-3df7-0310-abae-a5850022a9f2> | 2015-01-21 23:28:34 +0000 |
---|---|---|
committer | jonas <jonas@3ad0048d-3df7-0310-abae-a5850022a9f2> | 2015-01-21 23:28:34 +0000 |
commit | 1903b037de2fb3e75826406b46f055acb70963fa (patch) | |
tree | 604cd8b790fe14e5fbe441d4cd647c80d2a36a9a /compiler/jvm/dbgjasm.pas | |
parent | ad1141d52f8353457053b925cd674fe1d5c4eafc (diff) | |
parent | 953d907e4d6c3a5c2f8aaee6e5e4f73c55ce5985 (diff) | |
download | fpc-blocks.tar.gz |
* synchronised with trunk till r29513blocks
git-svn-id: http://svn.freepascal.org/svn/fpc/branches/blocks@29516 3ad0048d-3df7-0310-abae-a5850022a9f2
Diffstat (limited to 'compiler/jvm/dbgjasm.pas')
-rw-r--r-- | compiler/jvm/dbgjasm.pas | 44 |
1 files changed, 38 insertions, 6 deletions
diff --git a/compiler/jvm/dbgjasm.pas b/compiler/jvm/dbgjasm.pas index 2b76bbc1ca..40c971ad74 100644 --- a/compiler/jvm/dbgjasm.pas +++ b/compiler/jvm/dbgjasm.pas @@ -38,9 +38,10 @@ interface TDebugInfoJasmin=class(TDebugInfo) protected fcurrprocstart, + fcurrprocafterstart, fcurrprocend: tasmsymbol; - procedure appendsym_localsym(list: TAsmList; sym: tabstractnormalvarsym); + procedure appendsym_localsym(list: TAsmList; sym: tabstractnormalvarsym; startlab: tasmsymbol); procedure appendsym_paravar(list:TAsmList;sym:tparavarsym);override; procedure appendsym_localvar(list:TAsmList;sym:tlocalvarsym);override; @@ -65,7 +66,7 @@ implementation TDebugInfoJasmin ****************************************************************************} - procedure TDebugInfoJasmin.appendsym_localsym(list: TAsmList; sym: tabstractnormalvarsym); + procedure TDebugInfoJasmin.appendsym_localsym(list: TAsmList; sym: tabstractnormalvarsym; startlab: tasmsymbol); var jvar: tai_jvar; proc: tprocdef; @@ -75,20 +76,20 @@ implementation if not(sym.localloc.loc in [LOC_REFERENCE,LOC_CREFERENCE]) then exit; proc:=tprocdef(sym.owner.defowner); - jvar:=tai_jvar.create(sym.localloc.reference.offset,jvmmangledbasename(sym,true),fcurrprocstart,fcurrprocend); + jvar:=tai_jvar.create(sym.localloc.reference.offset,jvmmangledbasename(sym,true),startlab,fcurrprocend); tcpuprocdef(proc).exprasmlist.InsertAfter(jvar,proc.procstarttai); end; procedure TDebugInfoJasmin.appendsym_paravar(list: TAsmList; sym: tparavarsym); begin - appendsym_localsym(list,sym); + appendsym_localsym(list,sym,fcurrprocstart); end; procedure TDebugInfoJasmin.appendsym_localvar(list: TAsmList; sym: tlocalvarsym); begin - appendsym_localsym(list,sym); + appendsym_localsym(list,sym,fcurrprocafterstart); end; @@ -100,7 +101,11 @@ implementation procedure TDebugInfoJasmin.appendprocdef(list: TAsmList; def: tprocdef); var procstartlabel, - procendlabel : tasmlabel; + procendlabel, + afterprocstartlabel : tasmlabel; + hp, + afterproccodestart : tai; + instrcount : longint; begin { insert debug information for local variables and parameters, but only for routines implemented in the Pascal code } @@ -113,6 +118,33 @@ implementation tcpuprocdef(def).exprasmlist.insertbefore(tai_label.create(procendlabel),def.procendtai); fcurrprocstart:=procstartlabel; + { set the start label for local variables after the first instruction, + because javac's code completion support assumes that all info at + bytecode position 0 is for parameters } + instrcount:=0; + afterproccodestart:=def.procstarttai; + while assigned(afterproccodestart.next) do + begin + afterproccodestart:=tai(afterproccodestart.next); + if (afterproccodestart.typ=ait_instruction) then + break; + end; + { must be followed by at least one more instruction } + hp:=tai(afterproccodestart.next); + while assigned(hp) do + begin + if hp.typ=ait_instruction then + break; + hp:=tai(hp.next); + end; + if assigned(hp) then + begin + current_asmdata.getlabel(afterprocstartlabel,alt_dbgtype); + tcpuprocdef(def).exprasmlist.insertafter(tai_label.create(afterprocstartlabel),afterproccodestart); + fcurrprocafterstart:=afterprocstartlabel; + end + else + fcurrprocafterstart:=procstartlabel; fcurrprocend:=procendlabel; write_symtable_parasyms(list,def.paras); |