]> gitweb.factorcode.org Git - factor.git/blobdiff - basis/shuffle/shuffle.factor
Merge branch 'master' of git://factorcode.org/git/factor
[factor.git] / basis / shuffle / shuffle.factor
index 10fb8b01ddb37fd8867a6ac5aa0d7a8d1779f5fe..6cae048d2764290f7ca9371725068f0fd894f95e 100644 (file)
@@ -1,9 +1,27 @@
 ! Copyright (C) 2007 Chris Double, Doug Coleman.
 ! See http://factorcode.org/license.txt for BSD license.
-USING: kernel generalizations ;
-
+USING: accessors assocs combinators effects.parser generalizations
+hashtables kernel locals locals.backend macros make math
+parser sequences ;
 IN: shuffle
 
+<PRIVATE
+
+: >index-assoc ( sequence -- assoc )
+    dup length zip >hashtable ;
+
+PRIVATE>
+
+MACRO: shuffle-effect ( effect -- )
+    [ out>> ] [ in>> >index-assoc ] bi
+    [
+        [ nip assoc-size , \ narray , ]
+        [ [ at \ swap \ nth [ ] 3sequence ] curry map , \ cleave , ] 2bi
+    ] [ ] make ;
+
+: shuffle(
+    ")" parse-effect parsed \ shuffle-effect parsed ; parsing
+
 : 2swap ( x y z t -- z t x y ) 2 2 mnswap ; inline
 
 : 4dup ( a b c d -- a b c d a b c d ) 4 ndup ; inline