]> gitweb.factorcode.org Git - factor.git/blobdiff - extra/sets/extras/extras.factor
factor: trim using lists
[factor.git] / extra / sets / extras / extras.factor
index a96c5a938aae71aea9b5e58e2ab5fd02bc64de9c..a6ca1f974004b210670e3f1cf39939c8dc016911 100644 (file)
@@ -1,6 +1,7 @@
 ! Copyright (C) 2013 Doug Coleman.
 ! See http://factorcode.org/license.txt for BSD license.
-USING: kernel locals sequences sets ;
+USING: assocs hash-sets kernel sequences sequences.extras
+sets ;
 IN: sets.extras
 
 : setwise-xor ( seq1 seq2 -- set )
@@ -23,5 +24,16 @@ IN: sets.extras
     0 seq new-resizable :> accum
     seq [
         accum over visited ?adjoin
-        [ push ] [ remove! drop ] if
+        [ push ] [ remove-first! drop ] if
     ] each accum seq like ;
+
+: adjoin-at* ( value key assoc -- set )
+    [ [ HS{ } clone ] unless* [ adjoin ] keep dup ] change-at ;
+
+: mapped-set ( ... seq quot: ( ... elt -- ... newelt ) -- ... set )
+    over length <hash-set> [
+        '[ @ _ adjoin ] each
+    ] keep ; inline
+
+: unique-by ( seq quot: ( elt -- key ) -- seq' )
+    over length <hash-set> '[ @ _ ?adjoin ] filter ; inline