--- gforth/see.fs 2008/07/15 16:11:49 1.65 +++ gforth/see.fs 2010/04/18 16:39:55 1.69 @@ -529,10 +529,10 @@ VARIABLE C-Pass ELSE 2drop THEN ; -[IFDEF] (does>) +[IFDEF] !does : c-does> \ end of create part - Display? IF S" DOES> " Com# .string THEN - maxaligned /does-handler + ; + Display? IF S" DOES> " Com# .string THEN ; +\ maxaligned /does-handler + ; \ !! no longer needed for non-cross stuff [THEN] [IFDEF] (compile) @@ -576,7 +576,7 @@ CREATE C-Table [IFDEF] (abort") ' (abort") A, ' c-abort" A, [THEN] \ only defined if compiler is loaded [IFDEF] (compile) ' (compile) A, ' c-(compile) A, [THEN] -[IFDEF] (does>) ' (does>) A, ' c-does> A, [THEN] +[IFDEF] !does ' !does A, ' c-does> A, [THEN] 0 , here 0 , avariable c-extender @@ -657,7 +657,7 @@ Defer xt-see-xt ( xt -- ) space ; Defer discode ( addr u -- ) \ gforth -\G hook for the disassembler: disassemble code at addr of length u +\G hook for the disassembler: disassemble u bytes of code at addr ' dump IS discode : next-head ( addr1 -- addr2 ) \ gforth @@ -706,6 +706,11 @@ Defer discode ( addr u -- ) \ gforth then over - discode ." end-code" cr ; +: seeabicode ( xt -- ) + dup s" ABI-Code" .defname + >body dup dup next-head + swap - discode + ." end-code" cr ; : seevar ( xt -- ) s" Variable" .defname cr ; : seeuser ( xt -- ) @@ -771,6 +776,9 @@ Defer discode ( addr u -- ) \ gforth [IFDEF] dofield: dofield: of seefield endof [THEN] +[IFDEF] doabicode: + doabicode: of seeabicode endof +[THEN] over of seecode endof \ direct threaded code words over >body of seecode endof \ indirect threaded code words 2drop abort" unknown word type"