From 7eefdfa79bec067f9af2c02a0cbdae16536133a3 Mon Sep 17 00:00:00 2001 From: Sam Anklesaria Date: Sat, 9 May 2009 08:02:35 -0500 Subject: [PATCH] file-trees: file? restriction blocking selected --- extra/file-trees/file-trees.factor | 10 ++++---- extra/file-trees/file-trees.factor copy | 34 +++++++++++++++++++++++++ 2 files changed, 39 insertions(+), 5 deletions(-) create mode 100644 extra/file-trees/file-trees.factor copy diff --git a/extra/file-trees/file-trees.factor b/extra/file-trees/file-trees.factor index 52b1de7f96..90916baa56 100644 --- a/extra/file-trees/file-trees.factor +++ b/extra/file-trees/file-trees.factor @@ -1,5 +1,5 @@ USING: accessors arrays delegate delegate.protocols -io.pathnames kernel locals models.arrow namespaces prettyprint sequences +io.pathnames kernel locals sequences ui.frp vectors make ; IN: file-trees @@ -12,6 +12,8 @@ M: walkable-vector set-nth [ vector>> set-nth ] 3keep nip TUPLE: tree node comment children ; CONSULT: sequence-protocol tree children>> ; +: file? ( tree -- ? ) children>> [ node>> ".." = not ] filter empty? ; + : ( {start,comment} -- tree ) first2 walkable-vector new vector new >>vector [ tree boa dup children>> ] [ ".." -rot tree boa ] 2bi swap (>>father) ; @@ -26,7 +28,6 @@ DEFER: (tree-insert) path-rest [ path-head tree-insert ] unless-empty ] if* ; -! Use an accumulator for this : add-paths ( pathseq -- {{name,path}} ) "" [ [ "/" glue dup ] keep swap 2array , ] [ reduce drop ] f make ; @@ -35,6 +36,5 @@ DEFER: (tree-insert) : ( tree-model -- table ) [ node>> 1array ] >>quot - [ selected-value>> [ dup [ first ] when ] ] - [ swap >>model ] bi - [ dup comment>> 2array ] >>val-quot ; \ No newline at end of file + [ selected-value>> ] + [ swap >>model ] bi ; \ No newline at end of file diff --git a/extra/file-trees/file-trees.factor copy b/extra/file-trees/file-trees.factor copy new file mode 100644 index 0000000000..e3324d9834 --- /dev/null +++ b/extra/file-trees/file-trees.factor copy @@ -0,0 +1,34 @@ +USING: accessors arrays delegate delegate.protocols +io.pathnames kernel locals namespaces prettyprint sequences +ui.frp vectors ; +IN: file-trees + +! There should be optional extra information you can provide +TUPLE: tree node children ; +CONSULT: sequence-protocol tree children>> ; + +: ( start -- tree ) V{ } clone + [ tree boa dup children>> ] [ ".." swap tree boa ] bi swap push ; + +DEFER: (tree-insert) + +: tree-insert ( path tree -- ) [ unclip ] [ children>> ] bi* (tree-insert) ; +:: (tree-insert) ( path-rest path-head tree-children -- ) + tree-children [ node>> path-head node>> = ] find nip + [ path-rest swap tree-insert ] + [ + path-head tree-children push + path-rest [ path-head tree-insert ] unless-empty + ] if* ; + +: create-tree ( file-list -- tree ) [ path-components ] map + t [ [ tree-insert ] curry each ] keep ; + +: find-path ( tree -- string ) dup node>> tuck t = + [ 2drop f ] [ children>> first find-path "/" glue ] if ; + +: ( tree-model -- table ) + [ node>> 1array ] >>quot + [ selected-value>> ] + [ swap >>model ] bi + [ find-path ] >>val-quot ; \ No newline at end of file