! Copyright (C) 2007 Chris Double, Doug Coleman. ! See http://factorcode.org/license.txt for BSD license. USING: accessors assocs combinators effects.parser generalizations kernel sequences sequences.generalizations ; IN: shuffle MACRO: shuffle-effect ( effect -- quot ) [ in>> H{ } zip-index-as ] [ out>> ] bi [ drop assoc-size '[ _ narray ] ] [ [ of '[ _ swap nth ] ] with map ] 2bi '[ @ _ cleave ] ; SYNTAX: shuffle( ")" parse-effect suffix! \ shuffle-effect suffix! ; : 2swap ( x y z t -- z t x y ) 2 2 mnswap ; inline : 2pick ( x y z t -- x y z t x y ) reach reach ; inline : 5roll ( a b c d e -- b c d e a ) [ roll ] dip swap ; inline : 6roll ( a b c d e f -- b c d e f a ) [ roll ] 2dip rot ; inline : 7roll ( a b c d e f g -- b c d e f g a ) [ roll ] 3dip roll ; inline : 8roll ( a b c d e f g h -- b c d e f g h a ) [ roll ] 4dip 5roll ; inline : 2reach ( w x y z -- w x y z w x ) reach reach ; inline : nipdd ( w x y z -- x y z ) roll drop ; inline