fix io.directories.search -- doens't call link-info twice on every file now
parent
74ac35f432
commit
0759ddcfca
|
@ -6,15 +6,20 @@ sequences system vocabs.loader locals math namespaces
|
||||||
sorting assocs calendar threads ;
|
sorting assocs calendar threads ;
|
||||||
IN: io.directories.search
|
IN: io.directories.search
|
||||||
|
|
||||||
|
: qualified-directory-entries ( path -- seq )
|
||||||
|
dup directory-entries
|
||||||
|
[ [ append-path ] change-name ] with map ;
|
||||||
|
|
||||||
|
: qualified-directory-files ( path -- seq )
|
||||||
|
dup directory-files [ append-path ] with map ;
|
||||||
|
|
||||||
<PRIVATE
|
<PRIVATE
|
||||||
|
|
||||||
TUPLE: directory-iterator path bfs queue ;
|
TUPLE: directory-iterator path bfs queue ;
|
||||||
|
|
||||||
: qualified-directory ( path -- seq )
|
|
||||||
dup directory-files [ append-path ] with map ;
|
|
||||||
|
|
||||||
: push-directory ( path iter -- )
|
: push-directory ( path iter -- )
|
||||||
[ qualified-directory ] dip '[
|
[ dup directory-entry? [ name>> ] when ] dip
|
||||||
|
[ qualified-directory-entries ] dip '[
|
||||||
_ [ queue>> ] [ bfs>> ] bi
|
_ [ queue>> ] [ bfs>> ] bi
|
||||||
[ push-front ] [ push-back ] if
|
[ push-front ] [ push-back ] if
|
||||||
] each ;
|
] each ;
|
||||||
|
@ -25,8 +30,9 @@ TUPLE: directory-iterator path bfs queue ;
|
||||||
|
|
||||||
: next-file ( iter -- file/f )
|
: next-file ( iter -- file/f )
|
||||||
dup queue>> deque-empty? [ drop f ] [
|
dup queue>> deque-empty? [ drop f ] [
|
||||||
dup queue>> pop-back dup link-info directory?
|
dup queue>> pop-back dup directory?
|
||||||
[ over push-directory next-file ] [ nip ] if
|
[ over push-directory next-file ]
|
||||||
|
[ nip name>> ] if
|
||||||
] if ;
|
] if ;
|
||||||
|
|
||||||
:: iterate-directory ( iter quot: ( obj -- ? ) -- obj )
|
:: iterate-directory ( iter quot: ( obj -- ? ) -- obj )
|
||||||
|
@ -70,14 +76,6 @@ ERROR: file-not-found ;
|
||||||
: find-all-in-directories ( directories bfs? quot: ( obj -- ? ) -- paths/f )
|
: find-all-in-directories ( directories bfs? quot: ( obj -- ? ) -- paths/f )
|
||||||
'[ _ _ find-all-files ] map concat ; inline
|
'[ _ _ find-all-files ] map concat ; inline
|
||||||
|
|
||||||
: qualified-directory-entries ( path -- seq )
|
|
||||||
directory-entries
|
|
||||||
current-directory get '[ [ _ prepend-path ] change-name ] map ;
|
|
||||||
|
|
||||||
: qualified-directory-files ( path -- seq )
|
|
||||||
directory-files
|
|
||||||
current-directory get '[ _ prepend-path ] map ;
|
|
||||||
|
|
||||||
: with-qualified-directory-files ( path quot -- )
|
: with-qualified-directory-files ( path quot -- )
|
||||||
'[ "" qualified-directory-files @ ] with-directory ; inline
|
'[ "" qualified-directory-files @ ] with-directory ; inline
|
||||||
|
|
||||||
|
@ -93,7 +91,7 @@ ERROR: file-not-found ;
|
||||||
[ name>> dup ] [ directory? ] bi [
|
[ name>> dup ] [ directory? ] bi [
|
||||||
directory-size
|
directory-size
|
||||||
] [
|
] [
|
||||||
[ link-info size-on-disk>> ] [ drop 0 ] recover
|
[ link-info size-on-disk>> ] [ 2drop 0 ] recover
|
||||||
] if ;
|
] if ;
|
||||||
|
|
||||||
: directory-usage ( path -- assoc )
|
: directory-usage ( path -- assoc )
|
||||||
|
|
Loading…
Reference in New Issue