DirectoryContents.st
author Claus Gittinger <cg@exept.de>
Mon, 04 Jun 2007 21:44:03 +0200
changeset 1885 4d424e94093c
parent 1575 4c4042cd577f
child 1919 d52cda5ce0e7
permissions -rw-r--r--
oops
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     1
"
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     2
 COPYRIGHT (c) 1997 by eXept Software AG
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     3
              All Rights Reserved
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     4
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     5
 This software is furnished under a license and may be used
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    10
 hereby transferred.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    11
"
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    12
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    13
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    14
904
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
    15
"{ Package: 'stx:libbasic2' }"
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
    16
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    17
Object subclass:#DirectoryContents
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
    18
	instanceVariableNames:'directory timeStamp contents'
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    19
	classVariableNames:'CachedDirectories LockSema ReadersList'
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    20
	poolDictionaries:''
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    21
	category:'System-Support'
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    22
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    23
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    24
Object subclass:#DirectoryContentsItem
1099
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
    25
	instanceVariableNames:'info fileName'
1431
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
    26
	classVariableNames:'CachedRemoteMountPoints CachedRemoteMountPointsTimeStamp'
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    27
	poolDictionaries:''
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    28
	privateIn:DirectoryContents
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    29
!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    30
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    31
!DirectoryContents class methodsFor:'documentation'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    32
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    33
copyright
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    34
"
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    35
 COPYRIGHT (c) 1997 by eXept Software AG
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    36
              All Rights Reserved
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    37
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    38
 This software is furnished under a license and may be used
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    39
 only in accordance with the terms of that license and with the
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    40
 inclusion of the above copyright notice.   This software may not
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    41
 be provided or otherwise made available to, or used by, any
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    42
 other person.  No title to or ownership of the software is
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    43
 hereby transferred.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    44
"
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    45
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    46
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    47
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    48
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    49
documentation
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    50
"
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    51
    DirectoryContents provides a cached view onto a fileDirectory.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    52
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    53
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    54
    Notice:
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    55
        This class is not available in other ST-systems;
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    56
        Applications using it may not be portable.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    57
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    58
    [author:]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    59
        Claus Atzkern
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    60
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    61
    [see also:]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    62
        Filename
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    63
        FileStream DirectoryStream OperatingSystem
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    64
"
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    65
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    66
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    67
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    68
!DirectoryContents class methodsFor:'initialization'!
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    69
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    70
initialize
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    71
    "setup lock-mechanism
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    72
    "
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    73
    LockSema    := RecursionLock new.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    74
    ReadersList := Dictionary new.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    75
! !
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    76
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    77
!DirectoryContents class methodsFor:'instance creation'!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    78
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    79
new
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    80
    ^ self basicNew initialize
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    81
! !
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
    82
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    83
!DirectoryContents class methodsFor:'accessing'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    84
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    85
directoryNamed:aDirectory
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    86
    "returns the DirectoryContents for a directory named 
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    87
     aDirectoryName, aString, nil or Filename
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    88
    "
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    89
    |directory contents max lockRead pathName addToList|
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
    90
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    91
    (aDirectory notNil and:[(directory := aDirectory asFilename) exists]) ifFalse:[
620
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
    92
        ^ nil
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
    93
    ].
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
    94
    directory := directory asAbsoluteFilename.
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    95
    contents := nil.
620
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
    96
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    97
    LockSema critical:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    98
        CachedDirectories notNil ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
    99
            contents := self directoryAt:directory.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   100
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   101
            contents isNil ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   102
                max := self maxCachedDirectories.
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   103
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   104
                CachedDirectories size > max ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   105
                    CachedDirectories := CachedDirectories select:[:aDir|
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   106
                        (aDir size > 32 and:[aDir isObsolete not])
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   107
                    ]
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   108
                ].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   109
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   110
                CachedDirectories size > max ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   111
                    CachedDirectories removeFirst
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   112
                ]
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   113
            ].
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   114
        ].
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   115
        contents isNil ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   116
            ReadersList isNil ifTrue:[ReadersList := Dictionary new].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   117
            pathName := directory pathName.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   118
            lockRead := ReadersList at:pathName ifAbsentPut:[Semaphore forMutualExclusion].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   119
        ]
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   120
    ].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   121
    contents notNil ifTrue:[^ contents].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   122
    addToList := false.
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   123
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   124
    lockRead critical:[
1431
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   125
        [  "/ test whether another task got the semaphore and
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   126
           "/ has read the directory contents
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   127
           (contents := self directoryAt:directory) isNil ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   128
                "/ read the directory contents
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   129
                contents  := self new directory:directory.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   130
                "/ only cache if the mod'Time is valid.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   131
                addToList := contents timeStamp notNil.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   132
            ]
1022
6a288db5312a #valueNowOrOnUnwindDo: -> #ensure:
Claus Gittinger <cg@exept.de>
parents: 974
diff changeset
   133
        ] ensure:[
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   134
            LockSema critical:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   135
                addToList ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   136
                    CachedDirectories isNil ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   137
                        CachedDirectories := OrderedCollection new
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   138
                    ].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   139
                    CachedDirectories add:contents
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   140
                ].
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   141
                (lockRead isEmpty and:[ReadersList notNil]) ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   142
                    ReadersList removeKey:pathName ifAbsent:nil
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   143
                ]
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   144
            ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   145
        ]
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   146
    ].    
620
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
   147
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   148
    ^ contents
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   149
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   150
616
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   151
!DirectoryContents class methodsFor:'cache flushing'!
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   152
880
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   153
flushCache
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   154
    "flush list of rememebred directory contents"
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   155
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   156
    LockSema critical:[ CachedDirectories := nil ].
880
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   157
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   158
    "
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   159
     self flushCache
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   160
    "
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   161
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   162
    "Created: / 11.2.2000 / 00:13:59 / cg"
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   163
!
8067101a5d8b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 727
diff changeset
   164
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   165
flushCachedDirectoryFor:aDirectoryOrString
958
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   166
    "remove directory from cache
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   167
    "
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   168
    |index directory|
958
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   169
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   170
    (CachedDirectories notNil and:[aDirectoryOrString notNil]) ifTrue:[
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   171
        directory := aDirectoryOrString asFilename.
958
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   172
1352
609630f5fc5d care for symbolic links
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
   173
        (directory isSymbolicLink not
609630f5fc5d care for symbolic links
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
   174
        and:[ directory isDirectory]) ifTrue:[
958
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   175
            LockSema critical:[
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   176
                CachedDirectories notNil ifTrue:[
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   177
                    directory := directory asAbsoluteFilename.
1349
42d24a10a4be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1347
diff changeset
   178
                    index := CachedDirectories findFirst:[:d | d directory = directory ].
958
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   179
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   180
                    index ~~ 0 ifTrue:[
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   181
                        CachedDirectories removeAtIndex:index.
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   182
                    ]
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   183
                ]
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   184
            ]
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   185
        ]
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   186
    ].
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   187
!
989ff0f0d173 add new method: remove a specified directory from cash
ca
parents: 957
diff changeset
   188
695
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   189
lowSpaceCleanup
1575
Stefan Vogel <sv@exept.de>
parents: 1468
diff changeset
   190
    "flush list of remembered directory contents when low on memory"
695
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   191
1134
66f96c472a47 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   192
    self flushCache
695
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   193
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   194
    "
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   195
     self lowSpaceCleanup
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   196
    "
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   197
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   198
    "Created: / 18.2.1998 / 18:17:05 / cg"
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   199
    "Modified: / 24.9.1998 / 17:51:15 / cg"
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   200
!
368ddb719976 only cache dir if its mod'time is known (for win32)
Claus Gittinger <cg@exept.de>
parents: 679
diff changeset
   201
616
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   202
preSnapshot
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   203
    "flush list of rememebred directory contents' before saving an image"
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   204
1349
42d24a10a4be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1347
diff changeset
   205
    self flushCache.
616
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   206
! !
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   207
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   208
!DirectoryContents class methodsFor:'constants'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   209
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   210
maxCachedDirectories
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   211
    "returns number of maximum cached directories
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   212
    "
616
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   213
    ^ 20
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   214
cb0377b446bd flush cachedDirectory list when saving a snapshot
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
   215
    "Modified: / 25.2.1998 / 19:56:24 / cg"
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   216
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   217
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   218
!DirectoryContents class methodsFor:'private'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   219
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   220
directoryAt:aFilename
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   221
    "checks whether directory already exists and is valid.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   222
     If true the directory is returned otherwise nil
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   223
    "
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   224
    |index directory absoluteFilename|
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   225
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   226
    directory := nil.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   227
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   228
    LockSema critical:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   229
        CachedDirectories notNil ifTrue:[
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   230
            absoluteFilename := aFilename asFilename asAbsoluteFilename.
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   231
            index := CachedDirectories findFirst:[:d| d directory = absoluteFilename ].
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   232
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   233
            index ~~ 0 ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   234
                directory := CachedDirectories at:index.
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   235
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   236
                directory isObsolete ifTrue:[
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   237
                    CachedDirectories removeAtIndex:index.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   238
                    directory := nil.
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   239
                ]
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   240
            ]
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   241
        ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   242
    ].
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   243
    ^ directory
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   244
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   245
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   246
!DirectoryContents class methodsFor:'queries'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   247
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   248
directoryNamed:aDirectoryName detect:aTwoArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   249
    "evaluate the block, [:filename :isDirectory] on the directory
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   250
     contents of a directory named aDirectoryName, until the block
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   251
     returns true. If nothing detected false is returned
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   252
    "
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   253
    |directory dir|
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   254
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   255
    directory := aDirectoryName asFilename.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   256
620
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
   257
    directory exists ifFalse:[
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
   258
        ^ false
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
   259
    ].
2a40beccf337 - useing Filename to read contents of a directory
ca
parents: 616
diff changeset
   260
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   261
    (dir := self directoryAt:directory) notNil ifTrue:[
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   262
        dir contentsDo:[:aFile :isDir|
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   263
            (aTwoArgBlock value:aFile value:isDir) ifTrue:[^ true]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   264
        ].
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   265
        ^ false
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   266
    ].
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   267
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   268
    [
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   269
        directory directoryContentsDo:[:fn |
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   270
            |file|
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   271
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   272
            file := directory construct:fn.
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   273
            (aTwoArgBlock value:file value:(file isDirectory)) ifTrue:[
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   274
                ^ true
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   275
            ]
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   276
        ].
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   277
    ] on:FileStream openErrorSignal do:[:ex|
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   278
          "cannot open directory"
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   279
          ^ false
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   280
    ].
696
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   281
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   282
696
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   283
"/    dir := DirectoryStream directoryNamed:(directory pathName).
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   284
"/
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   285
"/    dir isNil ifFalse:[
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   286
"/        [
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   287
"/            [dir atEnd] whileFalse:[
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   288
"/                (name := dir nextLine) notNil ifTrue:[
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   289
"/                    name := directory construct:name.
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   290
"/
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   291
"/                    (aTwoArgBlock value:name value:(name isDirectory)) ifTrue:[
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   292
"/                        ^ true
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   293
"/                    ]
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   294
"/                ]
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   295
"/            ].
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   296
"/        ] valueNowOrOnUnwindDo:[
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   297
"/            dir close.
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   298
"/        ]
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   299
"/    ].
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   300
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   301
    ^ false
696
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   302
9d1571f69f8e use fileName>>directoryContents instead of a DirectoryStream.
Claus Gittinger <cg@exept.de>
parents: 695
diff changeset
   303
    "Modified: / 24.9.1998 / 21:14:58 / cg"
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   304
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   305
1102
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   306
!DirectoryContents class methodsFor:'utilities'!
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   307
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   308
contentsItemForFileName:aFilenameOrString 
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   309
    | aFilename directory directoryContents|
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   310
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   311
    aFilename := aFilenameOrString asFilename.
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   312
    directory := aFilename directory.
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   313
    directoryContents := self directoryNamed:directory.
1393
bb7048aaf86a care for directory without parent (network-dirs on WIN32)
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   314
    directoryContents isNil ifTrue:[
bb7048aaf86a care for directory without parent (network-dirs on WIN32)
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   315
        aFilename exists ifTrue:[
bb7048aaf86a care for directory without parent (network-dirs on WIN32)
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   316
            ^ (DirectoryContentsItem new fileName:aFilename) info:aFilename info.
bb7048aaf86a care for directory without parent (network-dirs on WIN32)
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   317
        ].
bb7048aaf86a care for directory without parent (network-dirs on WIN32)
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   318
        ^ nil
bb7048aaf86a care for directory without parent (network-dirs on WIN32)
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   319
    ].
1252
933afe6d5bd6 care for directory being removed
Claus Gittinger <cg@exept.de>
parents: 1198
diff changeset
   320
1253
Claus Gittinger <cg@exept.de>
parents: 1252
diff changeset
   321
    directoryContents itemsDo:[:fileItemThere |
1102
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   322
        fileItemThere fileName = aFilename ifTrue:[
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   323
            fileItemThere updateInfo.
1102
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   324
            ^ fileItemThere.
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   325
        ]
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   326
    ].
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   327
    ^ (DirectoryContentsItem new fileName:aFilename) info:aFilename info.
1102
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   328
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   329
    "
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   330
     DirectoryContents contentsItemForFileName:'/etc/passwd'
1105
556e633a86c7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1102
diff changeset
   331
     DirectoryContents contentsItemForFileName:'/'
1102
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   332
    "
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   333
! !
2ec96742a420 utility to get an item
Claus Gittinger <cg@exept.de>
parents: 1101
diff changeset
   334
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   335
!DirectoryContents methodsFor:'accessing'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   336
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   337
directory
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   338
    "returns the directoy name as Filename
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   339
    "
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   340
    ^ directory
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   341
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   342
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   343
modificationTime
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   344
    "get the last modification time of the directory
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   345
    "
951
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   346
    ^ directory modificationTime
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   347
!
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   348
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   349
timeStamp
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   350
    "get the last timeStamp (when the directory info was read) of the directory
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   351
    "
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   352
    ^ timeStamp
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   353
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   354
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   355
!DirectoryContents methodsFor:'enumerating'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   356
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   357
contentsAndBaseNamesDo:aThreeArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   358
    "evaluate the block on each file; the argument to the block is the
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   359
     filename, the baseName and true in case of a directory
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   360
     block arguments: [:fileName :aBaseName :isDirectory|
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   361
    "
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   362
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   363
    self itemsDo:[:eachItem |
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   364
        aThreeArgBlock 
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   365
            value:(eachItem fileName) 
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   366
            value:(eachItem baseName ) 
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   367
            value:(eachItem isDirectory)
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   368
    ].
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   369
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   370
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   371
contentsDo:aTwoArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   372
    "evaluate the block on each file; the argument to the block is the
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   373
     filename and true in case of a directory
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   374
     block arguments: [:fileName :isDirectory|
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   375
    "
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   376
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   377
    self itemsDo:[:eachItem |
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   378
        aTwoArgBlock
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   379
            value:(eachItem fileName) 
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   380
            value:(eachItem isDirectory)
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   381
    ].
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   382
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   383
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   384
directoriesAndBasenamesDo:aTwoArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   385
    "evaluate block on each directory; a Filename and Basename.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   386
     The directories are sorted
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   387
    "
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   388
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   389
    self itemsDo:[:eachItem |
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   390
        eachItem isDirectory ifTrue:[
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   391
            aTwoArgBlock value:(eachItem fileName) value:(eachItem baseName)
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   392
        ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   393
    ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   394
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   395
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   396
directoriesDo:aOneArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   397
    "evaluate block on each directory; a Filename. The directories are sorted
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   398
    "
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   399
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   400
    self itemsDo:[:eachItem |
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   401
        eachItem isDirectory ifTrue:[
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   402
            aOneArgBlock value:(eachItem fileName) 
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   403
        ]
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   404
    ].
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   405
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   406
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   407
filesAndBasenamesDo:aTwoArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   408
    "evaluate block on each file; a Filename and a Basename.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   409
     The files are sorted.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   410
    "
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   411
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   412
    self itemsDo:[:eachItem |
1324
e51285e95b3f not ifTrue -> ifFalse
Claus Gittinger <cg@exept.de>
parents: 1296
diff changeset
   413
        eachItem isDirectory ifFalse:[
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   414
            aTwoArgBlock value:(eachItem fileName) value:(eachItem baseName)
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   415
        ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   416
    ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   417
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   418
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   419
filesDo:aOneArgBlock
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   420
    "evaluate block on each file; a Filename. The files are sorted.
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   421
    "
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   422
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   423
    self itemsDo:[:eachItem |
1324
e51285e95b3f not ifTrue -> ifFalse
Claus Gittinger <cg@exept.de>
parents: 1296
diff changeset
   424
        eachItem isDirectory ifFalse:[
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   425
            aOneArgBlock value:(eachItem fileName)
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   426
        ]
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   427
    ]
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   428
!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   429
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   430
itemsDo:aBlock
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   431
    "evaluate the block on each contentsItem, which contains the fileName and type info"
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   432
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   433
    contents do:[:eachItem |
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   434
        aBlock value:eachItem.
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   435
    ].
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   436
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   437
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   438
!DirectoryContents methodsFor:'instance creation'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   439
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   440
directory:aFilename
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   441
    "instance creation; setup attributes"
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   442
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   443
    |t dircontents|
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   444
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   445
    directory := aFilename asFilename.
1435
5895158e7491 Use Timestamp/#asTimestamp instead of AbsoluteTime/#asAbsoluteTime
Stefan Vogel <sv@exept.de>
parents: 1431
diff changeset
   446
    t := Timestamp now. "/ directory modificationTime.
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   447
    [
1431
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   448
        dircontents := directory directoryContents.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   449
        dircontents sort.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   450
        contents  := dircontents collect:[:eachBasename | DirectoryContentsItem new fileName:(directory construct:eachBasename)].
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   451
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   452
"/        dircontents := directory directoryContentsAsFilenames.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   453
"/        dircontents sort:[:a :b | a baseName < b baseName].
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   454
"/        contents  := dircontents 
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   455
"/                    collect:[:eachFilename | DirectoryContentsItem new fileName:eachFilename].
1155
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   456
    ] on:FileStream openErrorSignal do:[:ex|
edcf3cfe1e93 Handle openErrorSignal in preparition for change openErrorSignal
Stefan Vogel <sv@exept.de>
parents: 1147
diff changeset
   457
        contents := #().
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   458
    ].
1101
8c191935356d *** empty log message ***
penk
parents: 1100
diff changeset
   459
    timeStamp := t.
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   460
! !
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   461
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   462
!DirectoryContents methodsFor:'printing'!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   463
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   464
printOn:aStream
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   465
    aStream nextPutAll:'DirectoryContents of: '.
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   466
    directory printOn:aStream.
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   467
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   468
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   469
!DirectoryContents methodsFor:'private'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   470
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   471
updateContents
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   472
    "ensure that the file-info os present for every item"
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   473
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   474
    contents do:[:eachItem |
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   475
        eachItem updateInfo.
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   476
    ].
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   477
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   478
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   479
!DirectoryContents methodsFor:'queries'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   480
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   481
isObsolete
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   482
    "returns true if the directory contents represented by the receiver is obsolete
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   483
     (i.e. if the fileSystems directory has been changed in the meanwhile)
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   484
    "
951
37870a37b930 consider contents as obsolete, if modification
martin
parents: 906
diff changeset
   485
974
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   486
    |mt|
679
ce7aed726aff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 620
diff changeset
   487
974
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   488
    directory exists ifFalse:[^ true].
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   489
    timeStamp isNil ifTrue:[^ true].
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   490
    (mt := directory modificationTime) isNil ifTrue:[^ true].
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   491
    "/ ignores milliseconds in the comparison
974
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   492
    timeStamp < mt ifTrue:[^ true].
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   493
    timeStamp getSeconds = mt getSeconds ifTrue:[^ true].
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   494
    ^ false
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   495
c4be514ddd96 fix for windows bug (directory has no modification time)
Claus Gittinger <cg@exept.de>
parents: 958
diff changeset
   496
    "Modified: / 23.8.2001 / 16:50:51 / cg"
906
30c1ab2aee8d category change
Claus Gittinger <cg@exept.de>
parents: 904
diff changeset
   497
!
30c1ab2aee8d category change
Claus Gittinger <cg@exept.de>
parents: 904
diff changeset
   498
30c1ab2aee8d category change
Claus Gittinger <cg@exept.de>
parents: 904
diff changeset
   499
size
30c1ab2aee8d category change
Claus Gittinger <cg@exept.de>
parents: 904
diff changeset
   500
    "get number of files including directories in the directory
30c1ab2aee8d category change
Claus Gittinger <cg@exept.de>
parents: 904
diff changeset
   501
    "
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   502
    ^ contents size
904
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   503
! !
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   504
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   505
!DirectoryContents methodsFor:'testing'!
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   506
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   507
isEmpty
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   508
    "retuirns true if directory is empty
f4791de2295b category change
Claus Gittinger <cg@exept.de>
parents: 880
diff changeset
   509
    "
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   510
    ^ contents size == 0
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   511
!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   512
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   513
notEmpty
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   514
    "returns true if directory is not empty
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   515
    "
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   516
    ^ contents size ~~ 0
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   517
! !
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   518
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   519
!DirectoryContents::DirectoryContentsItem methodsFor:'accessing'!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   520
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   521
baseName
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   522
    ^ fileName baseName
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   523
!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   524
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   525
fileName
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   526
    ^ fileName
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   527
!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   528
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   529
fileName:something
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   530
    "set the value of the instance variable 'fileName' (automatically generated)"
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   531
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   532
    fileName := something.
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   533
!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   534
1100
a8c44ef83781 checkin from browser
ca
parents: 1099
diff changeset
   535
info
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   536
    info isNil ifTrue:[
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   537
        self updateInfo.
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   538
    ].
1100
a8c44ef83781 checkin from browser
ca
parents: 1099
diff changeset
   539
    info isSymbol ifTrue:[^ nil]. "/ a remote directory
a8c44ef83781 checkin from browser
ca
parents: 1099
diff changeset
   540
    ^ info
a8c44ef83781 checkin from browser
ca
parents: 1099
diff changeset
   541
!
a8c44ef83781 checkin from browser
ca
parents: 1099
diff changeset
   542
1099
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   543
info:something
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   544
    "set the value of the instance variable 'type' (automatically generated)"
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   545
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   546
    info := something.
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   547
!
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   548
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   549
type
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   550
    info isNil ifTrue:[
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   551
        self updateInfo.
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   552
    ].
1099
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   553
    info isSymbol ifTrue:[^ info].
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   554
    ^ info type
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   555
! !
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   556
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   557
!DirectoryContents::DirectoryContentsItem methodsFor:'misc'!
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   558
1431
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   559
cachedRemoteMountPoints
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   560
    |mountPoints now|
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   561
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   562
    mountPoints := CachedRemoteMountPoints.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   563
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   564
    (mountPoints isNil
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   565
    or:[ CachedRemoteMountPointsTimeStamp isNil
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   566
    or:[ now := Timestamp now.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   567
         (now - CachedRemoteMountPointsTimeStamp) > 30 
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   568
    ]]) ifTrue:[
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   569
        CachedRemoteMountPointsTimeStamp := now.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   570
        mountPoints := OperatingSystem mountPoints.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   571
        mountPoints := mountPoints select:[:mp | mp isRemote].
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   572
        CachedRemoteMountPoints := mountPoints.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   573
    ].
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   574
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   575
    ^ mountPoints.
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   576
!
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   577
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   578
updateInfo
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   579
    "ensure that the file-info is present"
1468
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   580
    
1351
9741c3cbc395 avoid blocking on mounted directories;
Claus Gittinger <cg@exept.de>
parents: 1350
diff changeset
   581
    |mountPoints mountPoint nameString linkName|
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   582
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   583
    info isNil ifTrue:[
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   584
        nameString := fileName name.
1468
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   585
        self assert:[fileName isAbsolute].
1431
049b89c5bf60 cache mountPoints; faster directoryRead & sort
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
   586
        mountPoints := self cachedRemoteMountPoints.
1468
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   587
        info := fileName linkInfo.
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   588
        (info notNil and:[info isSymbolicLink]) ifTrue:[
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   589
            "have to check for both link and link target"
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   590
            linkName := info path.
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   591
            mountPoint := mountPoints 
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   592
                        detect:[:mInfo | |p|
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   593
                            p := mInfo mountPointPath.
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   594
                            ((linkName startsWith:p) and:[ linkName startsWith:(p , '/') ])
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   595
                        ]
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   596
                        ifNone:nil.
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   597
            info := fileName info.  "get the info of the link target"
1351
9741c3cbc395 avoid blocking on mounted directories;
Claus Gittinger <cg@exept.de>
parents: 1350
diff changeset
   598
        ] ifFalse:[
1468
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   599
            "have to check for mountPoint only"
1351
9741c3cbc395 avoid blocking on mounted directories;
Claus Gittinger <cg@exept.de>
parents: 1350
diff changeset
   600
            mountPoint := mountPoints 
1468
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   601
                        detect:[:mInfo | mInfo mountPointPath = nameString ]
476e360d4aeb #linkInfo now returns the info also for files that are not a symlink
Stefan Vogel <sv@exept.de>
parents: 1435
diff changeset
   602
                        ifNone:nil.
1351
9741c3cbc395 avoid blocking on mounted directories;
Claus Gittinger <cg@exept.de>
parents: 1350
diff changeset
   603
        ].
9741c3cbc395 avoid blocking on mounted directories;
Claus Gittinger <cg@exept.de>
parents: 1350
diff changeset
   604
        (mountPoint notNil) ifTrue:[
1350
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   605
            info := #remoteDirectory.
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   606
        ] ifFalse:[
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   607
            info isNil ifTrue:[
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   608
                "/ broken symbolic link
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   609
                info := #symbolicLink.
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   610
            ]
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   611
        ].
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   612
    ].
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   613
! !
61e51decadea lazy generation of info
Claus Gittinger <cg@exept.de>
parents: 1349
diff changeset
   614
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   615
!DirectoryContents::DirectoryContentsItem methodsFor:'printing'!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   616
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   617
printOn:aStream
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   618
    aStream nextPutAll:'DirectoryContentsItem for: '.
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   619
    fileName printOn:aStream.
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   620
! !
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   621
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   622
!DirectoryContents::DirectoryContentsItem methodsFor:'queries'!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   623
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   624
isDirectory
1099
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   625
    |t|
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   626
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   627
    t := self type.
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   628
    ^ (t == #directory or:[t == #remoteDirectory])
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   629
!
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   630
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   631
isRemoteDirectory
1099
81e2d4217524 keep info instead of type alone
ca
parents: 1097
diff changeset
   632
    ^ info == #remoteDirectory
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   633
! !
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   634
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   635
!DirectoryContents class methodsFor:'documentation'!
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   636
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   637
version
1575
Stefan Vogel <sv@exept.de>
parents: 1468
diff changeset
   638
    ^ '$Header: /cvs/stx/stx/libbasic2/DirectoryContents.st,v 1.41 2005-10-19 08:11:58 stefan Exp $'
583
3298b0ca7927 intitial checkin
ca
parents:
diff changeset
   639
! !
1093
052299fc7594 mark remoteDirectories specially
penk
parents: 1022
diff changeset
   640
957
88d941cdbe8f suspend processes reading same directory
ca
parents: 951
diff changeset
   641
DirectoryContents initialize!