! Copyright (C) 2008, 2010 Slava Pestov. ! See http://factorcode.org/license.txt for BSD license. USING: math sequences kernel namespaces accessors biassocs compiler.cfg compiler.cfg.instructions compiler.cfg.registers compiler.cfg.hats compiler.cfg.predecessors compiler.cfg.stacks.local compiler.cfg.stacks.height compiler.cfg.stacks.global compiler.cfg.stacks.finalize ; IN: compiler.cfg.stacks : begin-stack-analysis ( -- ) locs>vregs set H{ } clone ds-heights set H{ } clone rs-heights set H{ } clone peek-sets set H{ } clone replace-sets set H{ } clone kill-sets set current-height new current-height set ; : end-stack-analysis ( -- ) cfg get compute-global-sets finalize-stack-shuffling drop ; : ds-drop ( -- ) -1 inc-d ; : ds-peek ( -- vreg ) D 0 peek-loc ; : ds-pop ( -- vreg ) ds-peek ds-drop ; : ds-push ( vreg -- ) 1 inc-d D 0 replace-loc ; : ds-load ( n -- vregs ) dup 0 = [ drop f ] [ [ iota [ peek-loc ] map ] [ neg inc-d ] bi ] if ; : ds-store ( vregs -- ) [ [ length inc-d ] [ [ replace-loc ] each-index ] bi ] unless-empty ; : rs-drop ( -- ) -1 inc-r ; : rs-load ( n -- vregs ) dup 0 = [ drop f ] [ [ [ peek-loc ] map ] [ neg inc-r ] bi ] if ; : rs-store ( vregs -- ) [ [ length inc-r ] [ [ replace-loc ] each-index ] bi ] unless-empty ; : (2inputs) ( -- vreg1 vreg2 ) D 1 peek-loc D 0 peek-loc ; : 2inputs ( -- vreg1 vreg2 ) (2inputs) -2 inc-d ; : (3inputs) ( -- vreg1 vreg2 vreg3 ) D 2 peek-loc D 1 peek-loc D 0 peek-loc ; : 3inputs ( -- vreg1 vreg2 vreg3 ) (3inputs) -3 inc-d ; ! adjust-d/adjust-r: these are called when other instructions which ! internally adjust the stack height are emitted, such as ##call and ! ##alien-invoke : adjust-d ( n -- ) current-height get [ + ] change-d drop ; : adjust-r ( n -- ) current-height get [ + ] change-r drop ;