Filename.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 02:21:27 +0100
changeset 607 a9a526c51233
parent 545 32adce698074
child 615 e9d0e782206d
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object subclass:#Filename
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    14
	 instanceVariableNames:'nameString'
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    15
	 classVariableNames:'NextTempFilenameIndex'
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    16
	 poolDictionaries:''
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    17
	 category:'System-Support'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    19
!Filename class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    20
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    21
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    22
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    23
 COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    24
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    26
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    27
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    28
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    29
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    30
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    31
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    32
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    33
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    34
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    35
version
545
32adce698074 dont try remove it it does not exist
Claus Gittinger <cg@exept.de>
parents: 542
diff changeset
    36
    ^ '$Header: /cvs/stx/stx/libbasic/Filename.st,v 1.41 1995-11-14 21:42:42 cg Exp $'
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    37
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    38
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    39
documentation
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    40
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    41
    Filenames; originally added for ST-80 compatibility, is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    42
    taking over functionality from other classes (FileDirectory).
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    43
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    44
    Instances of Filename do not nescessarily represent valid or existing
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    45
    files - i.e. it is possible (and useful) to have instances for non-existing
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    46
    files around. In other words: the name-string is not checked automatically
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    47
    for being correct or existing.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    48
    Thus, it is possible to do queries such as:
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    49
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    50
	'/fee/foo/foe' asFilename exists     
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    51
	'/not_existing' asFilename isDirectory 
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    52
	'/foo/bar' asFilename isReadable 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    53
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
    54
    (all of the above examples will probably return false on your machine ;-).
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    55
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    56
    examples:
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    57
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    58
	'Makefile' asFilename readStream
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    59
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    60
	'newFile' asFilename writeStream
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    61
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    62
	Filename newTemporary writeStream
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    63
"
360
claus
parents: 359
diff changeset
    64
!
claus
parents: 359
diff changeset
    65
claus
parents: 359
diff changeset
    66
examples
claus
parents: 359
diff changeset
    67
"
claus
parents: 359
diff changeset
    68
    does a file/directory exist ?:
claus
parents: 359
diff changeset
    69
claus
parents: 359
diff changeset
    70
	|f|
claus
parents: 359
diff changeset
    71
claus
parents: 359
diff changeset
    72
	f := 'foobar' asFilename.
claus
parents: 359
diff changeset
    73
	^ f exists  
claus
parents: 359
diff changeset
    74
claus
parents: 359
diff changeset
    75
claus
parents: 359
diff changeset
    76
    is it a directory ?:
claus
parents: 359
diff changeset
    77
claus
parents: 359
diff changeset
    78
	|f|
claus
parents: 359
diff changeset
    79
claus
parents: 359
diff changeset
    80
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
    81
	^ f isDirectory.   
claus
parents: 359
diff changeset
    82
claus
parents: 359
diff changeset
    83
        
claus
parents: 359
diff changeset
    84
    get the working directory:
claus
parents: 359
diff changeset
    85
claus
parents: 359
diff changeset
    86
	^ Filename defaultDirectory
claus
parents: 359
diff changeset
    87
claus
parents: 359
diff changeset
    88
claus
parents: 359
diff changeset
    89
    get a files full pathname 
claus
parents: 359
diff changeset
    90
    (caring for relative names or symbolic links):
claus
parents: 359
diff changeset
    91
claus
parents: 359
diff changeset
    92
	|f|
claus
parents: 359
diff changeset
    93
claus
parents: 359
diff changeset
    94
	f := '..' asFilename.
claus
parents: 359
diff changeset
    95
	^ f pathName  
claus
parents: 359
diff changeset
    96
claus
parents: 359
diff changeset
    97
claus
parents: 359
diff changeset
    98
    get a directories directory:
claus
parents: 359
diff changeset
    99
claus
parents: 359
diff changeset
   100
	|f|
claus
parents: 359
diff changeset
   101
claus
parents: 359
diff changeset
   102
	f := Filename defaultDirectory.
claus
parents: 359
diff changeset
   103
	^ f directory 
claus
parents: 359
diff changeset
   104
claus
parents: 359
diff changeset
   105
claus
parents: 359
diff changeset
   106
    get a files directory:
claus
parents: 359
diff changeset
   107
claus
parents: 359
diff changeset
   108
	|f|
claus
parents: 359
diff changeset
   109
claus
parents: 359
diff changeset
   110
	f := './smalltalk' asFilename.
claus
parents: 359
diff changeset
   111
	^ f directory 
claus
parents: 359
diff changeset
   112
claus
parents: 359
diff changeset
   113
claus
parents: 359
diff changeset
   114
    getting access & modification times:
claus
parents: 359
diff changeset
   115
claus
parents: 359
diff changeset
   116
claus
parents: 359
diff changeset
   117
	|f|
claus
parents: 359
diff changeset
   118
claus
parents: 359
diff changeset
   119
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
   120
	^ f dates
claus
parents: 359
diff changeset
   121
claus
parents: 359
diff changeset
   122
    access time only:
claus
parents: 359
diff changeset
   123
claus
parents: 359
diff changeset
   124
	|f|
claus
parents: 359
diff changeset
   125
claus
parents: 359
diff changeset
   126
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
   127
	^ f dates at:#accessed  
claus
parents: 359
diff changeset
   128
        
claus
parents: 359
diff changeset
   129
claus
parents: 359
diff changeset
   130
    getting all information on a file/directory:
claus
parents: 359
diff changeset
   131
claus
parents: 359
diff changeset
   132
claus
parents: 359
diff changeset
   133
	|f|
claus
parents: 359
diff changeset
   134
claus
parents: 359
diff changeset
   135
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
   136
	^ f info
claus
parents: 359
diff changeset
   137
claus
parents: 359
diff changeset
   138
claus
parents: 359
diff changeset
   139
    getting a temporary file (unique name):
claus
parents: 359
diff changeset
   140
claus
parents: 359
diff changeset
   141
	|f|
claus
parents: 359
diff changeset
   142
claus
parents: 359
diff changeset
   143
	f := Filename newTemporary.
claus
parents: 359
diff changeset
   144
	^ f    
claus
parents: 359
diff changeset
   145
claus
parents: 359
diff changeset
   146
claus
parents: 359
diff changeset
   147
    creating, writing, reading and removing a temporary file:
claus
parents: 359
diff changeset
   148
claus
parents: 359
diff changeset
   149
claus
parents: 359
diff changeset
   150
	|f writeStream readStream|
claus
parents: 359
diff changeset
   151
claus
parents: 359
diff changeset
   152
	f := Filename newTemporary.
claus
parents: 359
diff changeset
   153
	writeStream := f writeStream.
claus
parents: 359
diff changeset
   154
	writeStream nextPutAll:'hello world'.
claus
parents: 359
diff changeset
   155
	writeStream cr.
claus
parents: 359
diff changeset
   156
	writeStream close.
claus
parents: 359
diff changeset
   157
claus
parents: 359
diff changeset
   158
	'contents (as seen by unix''s cat command:' printNL.
claus
parents: 359
diff changeset
   159
	OperatingSystem executeCommand:('cat ' , f pathName).
claus
parents: 359
diff changeset
   160
claus
parents: 359
diff changeset
   161
	readStream := f readStream.
claus
parents: 359
diff changeset
   162
	Transcript showCr:'contents as seen by smalltalk:'.
claus
parents: 359
diff changeset
   163
	Transcript showCr:(readStream upToEnd).
claus
parents: 359
diff changeset
   164
	readStream close.
claus
parents: 359
diff changeset
   165
claus
parents: 359
diff changeset
   166
	f delete.
claus
parents: 359
diff changeset
   167
        
claus
parents: 359
diff changeset
   168
claus
parents: 359
diff changeset
   169
    getting a directories contents:
claus
parents: 359
diff changeset
   170
claus
parents: 359
diff changeset
   171
	|f files|
claus
parents: 359
diff changeset
   172
claus
parents: 359
diff changeset
   173
	f := '.' asFilename.
claus
parents: 359
diff changeset
   174
	files := f directoryContents.
claus
parents: 359
diff changeset
   175
	Transcript showCr:'the files are:'.
claus
parents: 359
diff changeset
   176
	Transcript showCr:(files printString).
claus
parents: 359
diff changeset
   177
claus
parents: 359
diff changeset
   178
claus
parents: 359
diff changeset
   179
    editing a file:
claus
parents: 359
diff changeset
   180
claus
parents: 359
diff changeset
   181
	|f|
claus
parents: 359
diff changeset
   182
claus
parents: 359
diff changeset
   183
	f := '/tmp/fooBar' asFilename.
claus
parents: 359
diff changeset
   184
	(f writeStream) nextPutAll:'hello world'; close.
claus
parents: 359
diff changeset
   185
claus
parents: 359
diff changeset
   186
	f edit
claus
parents: 359
diff changeset
   187
"
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   188
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
!Filename class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
named:aString
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   193
    "return a filename for a directory named aString.
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   194
     This is the same as 'aString asFilename'."
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   195
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   196
    ^ (self basicNew) setName:aString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   197
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   198
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   199
     Filename named:'/tmp/fooBar'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   200
    "
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   201
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   202
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   203
currentDirectory
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   204
    "return a filename for the current directory"
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   205
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   206
    ^ self named:(FileDirectory currentDirectory pathName)
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   207
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   208
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   209
     Filename currentDirectory 
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   210
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   211
!
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   212
328
claus
parents: 326
diff changeset
   213
defaultDirectory
claus
parents: 326
diff changeset
   214
    "ST80 compatibility: same as currentDirectory"
claus
parents: 326
diff changeset
   215
claus
parents: 326
diff changeset
   216
    ^ self currentDirectory
claus
parents: 326
diff changeset
   217
claus
parents: 326
diff changeset
   218
    "
claus
parents: 326
diff changeset
   219
     Filename defaultDirectory 
claus
parents: 326
diff changeset
   220
    "
claus
parents: 326
diff changeset
   221
!
claus
parents: 326
diff changeset
   222
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   223
defaultDirectoryName
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   224
    "ST80 compatibility: return the defaultDirectories name (as a string)"
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   225
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   226
    ^ self defaultDirectory name
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   227
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   228
    "
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   229
     Filename defaultDirectoryName 
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   230
    "
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   231
!
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   232
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   233
newTemporary
325
claus
parents: 308
diff changeset
   234
    "return a new unique filename - use this for temporary files.
claus
parents: 308
diff changeset
   235
     The filenames returned are '/tmp/stxtmp_xx_nn' where xx is our
claus
parents: 308
diff changeset
   236
     unix process id, and nn is a unique number, incremented with every
483
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   237
     call to this method.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   238
     If any of the environment variables ST_TMPDIR or TMPDIR is set, 
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   239
     its value defines the temp directory."
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   240
483
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   241
    |tempDir|
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   242
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   243
    tempDir := OperatingSystem getEnvironment:'ST_TMPDIR'.
422
claus
parents: 384
diff changeset
   244
    tempDir isNil ifTrue:[
483
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   245
	tempDir := OperatingSystem getEnvironment:'TMPDIR'.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   246
	tempDir isNil ifTrue:[
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   247
	    tempDir := '/tmp'
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   248
	].
422
claus
parents: 384
diff changeset
   249
    ].
483
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   250
    ^ self newTemporaryIn:tempDir
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   251
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   252
    "
422
claus
parents: 384
diff changeset
   253
     Filename newTemporary    
claus
parents: 384
diff changeset
   254
     Filename newTemporary  
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   255
    "
422
claus
parents: 384
diff changeset
   256
claus
parents: 384
diff changeset
   257
    "Modified: 7.9.1995 / 10:48:31 / claus"
483
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   258
    "Modified: 4.11.1995 / 20:08:51 / cg"
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   259
!
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   260
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   261
newTemporaryIn:aDirectoryPrefix
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   262
    "return a new unique filename - use this for temporary files.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   263
     The filenames returned are in aDirectoryPrefix and named 'stxtmp_xx_nn',
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   264
     where xx is our unix process id, and nn is a unique number, incremented 
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   265
     with every call to this method.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   266
     Notice: only a filename object is created and returned - no physical
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   267
     file is created by this method (i.e. you have to send #writeStream or
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   268
     whatever to it in order to really create something).
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   269
     See also: #newTemporary which looks for a good temp directory."
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   270
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   271
    |pid nm|
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   272
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   273
    NextTempFilenameIndex isNil ifTrue:[
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   274
	NextTempFilenameIndex := 1.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   275
    ].
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   276
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   277
    "
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   278
     the following has to be made OS independent ...
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   279
    "
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   280
    pid := OperatingSystem getProcessId printString.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   281
    nm := 'stxtmp_' , pid , '_' , NextTempFilenameIndex printString.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   282
    NextTempFilenameIndex := NextTempFilenameIndex + 1.
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   283
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   284
    (aDirectoryPrefix isNil or:[aDirectoryPrefix asString isEmpty]) ifFalse:[
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   285
	nm := aDirectoryPrefix asFilename construct:nm
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   286
    ] ifTrue:[
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   287
	nm := nm asFilename
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   288
    ].
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   289
    ^ nm
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   290
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   291
    "temp files in '/tmp':
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   292
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   293
     Filename newTemporary   
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   294
     Filename newTemporaryIn:'/tmp'    
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   295
     Filename newTemporaryIn:'/tmp'  
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   296
    "
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   297
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   298
    "temp files somewhere (not recommended):
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   299
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   300
     Filename newTemporaryIn:'/usr/tmp'    
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   301
     Filename newTemporaryIn:'/'  
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   302
    "
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   303
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   304
    "a local temp file:
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   305
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   306
     Filename newTemporaryIn:''         
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   307
     Filename newTemporaryIn:nil         
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   308
     Filename newTemporaryIn:'.'         
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   309
     Filename newTemporaryIn:('source' asFilename) 
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   310
    "
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   311
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   312
    "Modified: 7.9.1995 / 10:48:31 / claus"
f36d0167b819 newTemporyary and newTemporaryIn:
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   313
    "Modified: 4.11.1995 / 20:26:23 / cg"
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   314
!
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   315
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   316
fromUser
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   317
    "show a box to enter a filename. Return a filename instance or
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   318
     nil (if cancel was pressed)."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   319
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   320
    |name|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   321
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   322
    name := FileSelectionBox requestFilename.
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   323
    name notNil ifTrue:[^ self named:name].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   324
    ^ nil
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   325
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   326
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   327
     Filename fromUser
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   328
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
2
claus
parents: 1
diff changeset
   331
!Filename class methodsFor:'queries'!
claus
parents: 1
diff changeset
   332
claus
parents: 1
diff changeset
   333
separator
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   334
    "return the file/directory separator.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   335
     Usually, this is $/ for unix-like systems 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   336
     and $\ for dos-like ones (there may be more in the future)."
2
claus
parents: 1
diff changeset
   337
claus
parents: 1
diff changeset
   338
     ^ OperatingSystem fileSeparator
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   339
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   340
     "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   341
      Filename separator  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   342
     "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   343
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   344
422
claus
parents: 384
diff changeset
   345
suffixSeparator
claus
parents: 384
diff changeset
   346
    "return the filename suffix separator.
claus
parents: 384
diff changeset
   347
     Usually, this is $. for unix-like and msdos systems 
claus
parents: 384
diff changeset
   348
     (there is currently no knowns system, where this differs)"
claus
parents: 384
diff changeset
   349
claus
parents: 384
diff changeset
   350
     ^ $.
claus
parents: 384
diff changeset
   351
claus
parents: 384
diff changeset
   352
     "
claus
parents: 384
diff changeset
   353
      Filename suffixSeparator  
claus
parents: 384
diff changeset
   354
     "
claus
parents: 384
diff changeset
   355
claus
parents: 384
diff changeset
   356
    "Modified: 7.9.1995 / 11:10:43 / claus"
claus
parents: 384
diff changeset
   357
!
claus
parents: 384
diff changeset
   358
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   359
parentDirectoryName 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   360
    "return the name used for the parent directory.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   361
     This is '..' for unix and dos-like systems. 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   362
     (there may be more in the future."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   363
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   364
     ^ OperatingSystem parentDirectoryName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   365
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   366
     "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   367
      Filename parentDirectoryName  
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   368
     "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   369
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   370
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   371
isCaseSensitive
9e273c60e785 more functions
claus
parents: 159
diff changeset
   372
    "return true, if filenames are case sensitive.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   373
     We ask the OS about this, to be independent here."
9e273c60e785 more functions
claus
parents: 159
diff changeset
   374
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   375
    ^ OperatingSystem caseSensitiveFilenames
326
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   376
!
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   377
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   378
defaultClass
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   379
    "ST-80 compatibility:
422
claus
parents: 384
diff changeset
   380
     in ST-80, different subclasses of Filename are used for different
claus
parents: 384
diff changeset
   381
     OperatingSystems; defaultClass is supposed to return an appropriate class.
326
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   382
     Since in ST/X, there is (currently) only one Filename class, return it here."
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   383
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   384
    ^ self
328
claus
parents: 326
diff changeset
   385
!
claus
parents: 326
diff changeset
   386
claus
parents: 326
diff changeset
   387
localNameStringFrom:aString
claus
parents: 326
diff changeset
   388
    "ST-80 compatibility.
422
claus
parents: 384
diff changeset
   389
     what does this do ? (used in FileNavigator-goody).
claus
parents: 384
diff changeset
   390
     GUESS: does it strip off the voulume-character on MSDOS systems ?"
328
claus
parents: 326
diff changeset
   391
claus
parents: 326
diff changeset
   392
    (aString startsWith:'/') ifTrue:[
claus
parents: 326
diff changeset
   393
	^ aString copyFrom:2
claus
parents: 326
diff changeset
   394
    ].
claus
parents: 326
diff changeset
   395
    ^ aString
422
claus
parents: 384
diff changeset
   396
claus
parents: 384
diff changeset
   397
    "Modified: 7.9.1995 / 10:44:56 / claus"
328
claus
parents: 326
diff changeset
   398
!
claus
parents: 326
diff changeset
   399
claus
parents: 326
diff changeset
   400
volumes
claus
parents: 326
diff changeset
   401
    "ST-80 compatibility.
422
claus
parents: 384
diff changeset
   402
     what does this do ? (used in FileNavigator-goody).
claus
parents: 384
diff changeset
   403
     GUESS: does it return the available drives on MSDOS systems ?"
328
claus
parents: 326
diff changeset
   404
356
claus
parents: 328
diff changeset
   405
    ^ #('/')
422
claus
parents: 384
diff changeset
   406
claus
parents: 384
diff changeset
   407
    "Modified: 7.9.1995 / 10:45:25 / claus"
440
claus
parents: 422
diff changeset
   408
!
claus
parents: 422
diff changeset
   409
claus
parents: 422
diff changeset
   410
filenameCompletionFor:aString directory:inDirectory directoriesOnly:directoriesOnly filesOnly:filesOnly ifMultiple:aBlock
claus
parents: 422
diff changeset
   411
    "perform filename completion on aString in some directory;
claus
parents: 422
diff changeset
   412
     return the longest matching filename prefix as a string.
claus
parents: 422
diff changeset
   413
     If directoriesOnly and filesOnly are true, only directories and files
claus
parents: 422
diff changeset
   414
     are considered respectively. If multiple files match, the exception
claus
parents: 422
diff changeset
   415
     block aBlock is evaluated with a filename representing the directory
claus
parents: 422
diff changeset
   416
     (where the match was done) as argument.
claus
parents: 422
diff changeset
   417
     (this may be different from the inDirectory argument, if aString is absolute
claus
parents: 422
diff changeset
   418
      or starts with ../)"
claus
parents: 422
diff changeset
   419
claus
parents: 422
diff changeset
   420
    |s f matchSet nMatch name words dir|
claus
parents: 422
diff changeset
   421
claus
parents: 422
diff changeset
   422
    s := aString.
claus
parents: 422
diff changeset
   423
    "
claus
parents: 422
diff changeset
   424
     find the last word ...
claus
parents: 422
diff changeset
   425
    "
claus
parents: 422
diff changeset
   426
    words := s asCollectionOfWords.
claus
parents: 422
diff changeset
   427
    words size == 0 ifTrue:[
473
f92507d781d2 filenameCompletion: bad return value when called with empty string
Claus Gittinger <cg@exept.de>
parents: 441
diff changeset
   428
	aBlock value:'.' asFilename.
f92507d781d2 filenameCompletion: bad return value when called with empty string
Claus Gittinger <cg@exept.de>
parents: 441
diff changeset
   429
	^ ''
440
claus
parents: 422
diff changeset
   430
    ].
claus
parents: 422
diff changeset
   431
claus
parents: 422
diff changeset
   432
    f := words last asFilename.
claus
parents: 422
diff changeset
   433
claus
parents: 422
diff changeset
   434
    matchSet := f filenameCompletionIn:inDirectory.
claus
parents: 422
diff changeset
   435
claus
parents: 422
diff changeset
   436
    dir := f directory.
claus
parents: 422
diff changeset
   437
claus
parents: 422
diff changeset
   438
    directoriesOnly ifTrue:[
claus
parents: 422
diff changeset
   439
	matchSet := matchSet select:[:aFilename |
claus
parents: 422
diff changeset
   440
	    (dir construct:aFilename) isDirectory
claus
parents: 422
diff changeset
   441
	].
claus
parents: 422
diff changeset
   442
    ] ifFalse:[
claus
parents: 422
diff changeset
   443
	filesOnly ifTrue:[
claus
parents: 422
diff changeset
   444
	    matchSet := matchSet select:[:aFilename |
claus
parents: 422
diff changeset
   445
		(dir construct:aFilename) isDirectory not
claus
parents: 422
diff changeset
   446
	    ].
claus
parents: 422
diff changeset
   447
	]
claus
parents: 422
diff changeset
   448
    ].
claus
parents: 422
diff changeset
   449
claus
parents: 422
diff changeset
   450
    (nMatch := matchSet size) ~~ 1 ifTrue:[
claus
parents: 422
diff changeset
   451
	"
claus
parents: 422
diff changeset
   452
	 more than one possible completion -
claus
parents: 422
diff changeset
   453
	"
claus
parents: 422
diff changeset
   454
	aBlock value:f
claus
parents: 422
diff changeset
   455
    ].
claus
parents: 422
diff changeset
   456
    "
claus
parents: 422
diff changeset
   457
     even with more than one possible completion,
claus
parents: 422
diff changeset
   458
     f's name is now the common prefix
claus
parents: 422
diff changeset
   459
    "
claus
parents: 422
diff changeset
   460
    name := f asString.
claus
parents: 422
diff changeset
   461
    nMatch == 1 ifTrue:[
claus
parents: 422
diff changeset
   462
	"
claus
parents: 422
diff changeset
   463
	 exactly one possible completion -
claus
parents: 422
diff changeset
   464
	"
claus
parents: 422
diff changeset
   465
	f := dir construct:matchSet first.
claus
parents: 422
diff changeset
   466
claus
parents: 422
diff changeset
   467
	directoriesOnly ifFalse:[
claus
parents: 422
diff changeset
   468
	    f isDirectory ifTrue:[
claus
parents: 422
diff changeset
   469
		(name endsWith:(Filename separator)) ifFalse:[
claus
parents: 422
diff changeset
   470
		    name := name , '/'
claus
parents: 422
diff changeset
   471
		].
claus
parents: 422
diff changeset
   472
	    ].
claus
parents: 422
diff changeset
   473
	]
claus
parents: 422
diff changeset
   474
    ].
claus
parents: 422
diff changeset
   475
claus
parents: 422
diff changeset
   476
    "
claus
parents: 422
diff changeset
   477
     construct new contents, by taking
claus
parents: 422
diff changeset
   478
     last words completion
claus
parents: 422
diff changeset
   479
    "
claus
parents: 422
diff changeset
   480
    s := ''.
claus
parents: 422
diff changeset
   481
    1 to:(words size - 1) do:[:idx |
claus
parents: 422
diff changeset
   482
	s := s , (words at:idx) , ' '
claus
parents: 422
diff changeset
   483
    ].
claus
parents: 422
diff changeset
   484
    s := s , name.
claus
parents: 422
diff changeset
   485
claus
parents: 422
diff changeset
   486
    "/ special: if there was no change, and the string represented
claus
parents: 422
diff changeset
   487
    "/ is a directories name, add a directory separator
claus
parents: 422
diff changeset
   488
    s = aString ifTrue:[
claus
parents: 422
diff changeset
   489
	(s endsWith:Filename separator) ifFalse:[
claus
parents: 422
diff changeset
   490
	    s asFilename isDirectory ifTrue:[
claus
parents: 422
diff changeset
   491
		^ s , Filename separator asString
claus
parents: 422
diff changeset
   492
	    ]
claus
parents: 422
diff changeset
   493
	]
claus
parents: 422
diff changeset
   494
    ].
claus
parents: 422
diff changeset
   495
claus
parents: 422
diff changeset
   496
    ^ s
2
claus
parents: 1
diff changeset
   497
! !
claus
parents: 1
diff changeset
   498
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   499
!Filename methodsFor:'error handling'!
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   500
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   501
reportError:string with:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   502
    ^ OperatingSystem errorSignal
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   503
	raiseRequestWith:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   504
	errorString:string
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   505
!
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   506
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   507
fileNotFoundError:filename 
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   508
    ^ OperatingSystem fileNotFoundErrorSignal
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   509
	raiseRequestWith:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   510
	errorString:('file not found: ' , filename asString)
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   511
!
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   512
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   513
fileCreationError:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   514
    ^ OperatingSystem accessDeniedErrorSignal
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   515
	raiseRequestWith:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   516
	errorString:('cannot create/write file: ' , filename asString)
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   517
!
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   518
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   519
accessDeniedError:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   520
    ^ OperatingSystem accessDeniedErrorSignal
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   521
	raiseRequestWith:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   522
	errorString:('access denied: ' , filename asString)
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   523
!
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   524
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   525
removeError:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   526
    ^ OperatingSystem accessDeniedErrorSignal
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   527
	raiseRequestWith:filename
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   528
	errorString:('cannot remove: ' , filename asString)
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   529
! !
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   530
2
claus
parents: 1
diff changeset
   531
!Filename methodsFor:'instance creation'!
claus
parents: 1
diff changeset
   532
249
claus
parents: 216
diff changeset
   533
constructString:subname
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   534
    "taking the receiver as a directory name, construct a new
249
claus
parents: 216
diff changeset
   535
     filenames string for an entry within this directory (i.e. for a file
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   536
     or a subdirectory in that directory)."
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   537
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   538
    |sepString|
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   539
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   540
    sepString := self class separator asString.
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   541
    nameString = sepString ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   542
	"I am the root"
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   543
	^ sepString  , subname
85
claus
parents: 77
diff changeset
   544
    ].
422
claus
parents: 384
diff changeset
   545
    ^ nameString , sepString , subname asString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   546
85
claus
parents: 77
diff changeset
   547
    "
249
claus
parents: 216
diff changeset
   548
     '/tmp' asFilename constructString:'foo'   
claus
parents: 216
diff changeset
   549
     '/' asFilename constructString:'foo'         
claus
parents: 216
diff changeset
   550
     '/usr/tmp' asFilename constructString:'foo'
328
claus
parents: 326
diff changeset
   551
     '/foo/bar' asFilename constructString:'baz' 
249
claus
parents: 216
diff changeset
   552
    "
422
claus
parents: 384
diff changeset
   553
claus
parents: 384
diff changeset
   554
    "Modified: 7.9.1995 / 10:15:22 / claus"
249
claus
parents: 216
diff changeset
   555
!
claus
parents: 216
diff changeset
   556
claus
parents: 216
diff changeset
   557
construct:subname
claus
parents: 216
diff changeset
   558
    "taking the receiver as a directory name, construct a new
claus
parents: 216
diff changeset
   559
     filename for an entry within this directory (i.e. for a file
claus
parents: 216
diff changeset
   560
     or a subdirectory in that directory)."
claus
parents: 216
diff changeset
   561
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   562
    ^ (self constructString:subname) asFilename
249
claus
parents: 216
diff changeset
   563
claus
parents: 216
diff changeset
   564
    "
claus
parents: 216
diff changeset
   565
     '/tmp' asFilename construct:'foo'    
claus
parents: 216
diff changeset
   566
     '/' asFilename construct:'foo'         
claus
parents: 216
diff changeset
   567
     '/usr/tmp' asFilename construct:'foo'
328
claus
parents: 326
diff changeset
   568
     '/foo/bar' asFilename construct:'baz' 
85
claus
parents: 77
diff changeset
   569
    "
2
claus
parents: 1
diff changeset
   570
! !
claus
parents: 1
diff changeset
   571
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   572
!Filename methodsFor:'misc'!
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   573
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   574
, aString
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   575
    "this allows filenames to understand how names are concatenated.
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   576
     Returns a string consisting of the receivers name, concatenated
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   577
     by aString. Notice this is NOT the same as construct:, which inserts
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   578
     a directory delimiter and returns a new fileName instance."
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   579
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   580
    ^ (nameString , aString asString)
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   581
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   582
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   583
     'Makefile' asFilename , '.bak' 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   584
     'Makefile' asFilename construct:'.bak' 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   585
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   586
! !
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   587
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   588
!Filename methodsFor:'comparing'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   589
9e273c60e785 more functions
claus
parents: 159
diff changeset
   590
hash
9e273c60e785 more functions
claus
parents: 159
diff changeset
   591
    "return an integer useful as a hash-key"
9e273c60e785 more functions
claus
parents: 159
diff changeset
   592
9e273c60e785 more functions
claus
parents: 159
diff changeset
   593
    ^ nameString hash
9e273c60e785 more functions
claus
parents: 159
diff changeset
   594
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   595
9e273c60e785 more functions
claus
parents: 159
diff changeset
   596
= aFilename
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   597
    "return true, if the argument represents the same filename"
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   598
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   599
    |str|
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   600
9e273c60e785 more functions
claus
parents: 159
diff changeset
   601
    self species == aFilename species ifTrue:[
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   602
	str := aFilename asString.
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   603
	self class isCaseSensitive ifTrue:[
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   604
	    ^ nameString = str
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   605
	].
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   606
	^ nameString sameAs:str
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   607
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
   608
    ^ false
9e273c60e785 more functions
claus
parents: 159
diff changeset
   609
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
   610
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
!Filename methodsFor:'converting'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
asString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   614
    "return the receiver converted to a string"
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   615
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   616
    ^ nameString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   617
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
asFilename
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   620
    "return the receiver converted to a filename."
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   621
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   622
    "Thats pretty easy here :-)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   623
    ^ self
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   624
!
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   625
328
claus
parents: 326
diff changeset
   626
asAbsoluteFilename
claus
parents: 326
diff changeset
   627
    "return the receiver converted to a filename with
claus
parents: 326
diff changeset
   628
     an absolute pathname."
claus
parents: 326
diff changeset
   629
claus
parents: 326
diff changeset
   630
    ^ self pathName asFilename
claus
parents: 326
diff changeset
   631
!
claus
parents: 326
diff changeset
   632
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   633
makeLegalFilename 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   634
    "convert the receveivers name to be a legal filename.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   635
     The implementation may change in the future to be more
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   636
     OS specific."
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   637
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   638
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   639
     actually, in Unix spaces are allowed - but it makes life
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   640
     so hard; therefore, replace them by underscores ...
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   641
    "
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   642
    nameString replaceAll:(Character space) by:$_.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   643
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   644
     need more - especially on SYS5.3 type systems, 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   645
     we may want to contract the fileName to 14 characters.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   646
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   647
    ^ self
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   648
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   649
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   650
     'hello world' asFilename makeLegalFilename 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   651
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   654
!Filename methodsFor:'private accessing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   656
setName:aString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   657
    "set the filename"
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   658
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   659
    nameString := aString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
2
claus
parents: 1
diff changeset
   662
!Filename methodsFor:'queries'!
claus
parents: 1
diff changeset
   663
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   664
separator
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   665
    "return the directory-separator character (or string)"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   666
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   667
    ^ self class separator
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   668
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   669
422
claus
parents: 384
diff changeset
   670
directoryPathName
claus
parents: 384
diff changeset
   671
    "return the full directory pathname part of the file/directory as a string.
claus
parents: 384
diff changeset
   672
     - thats the full pathname of the directory where the file/dir represented by
claus
parents: 384
diff changeset
   673
       the receiver is contained in.
claus
parents: 384
diff changeset
   674
     See also: directoryName"
claus
parents: 384
diff changeset
   675
claus
parents: 384
diff changeset
   676
    ^ OperatingSystem directoryNameOf:(self pathName)
claus
parents: 384
diff changeset
   677
claus
parents: 384
diff changeset
   678
    "
claus
parents: 384
diff changeset
   679
     '/foo/bar/' asFilename directoryPathName    
claus
parents: 384
diff changeset
   680
     '/foo/bar' asFilename directoryPathName    
claus
parents: 384
diff changeset
   681
     '.' asFilename directoryPathName        
claus
parents: 384
diff changeset
   682
     '..' asFilename directoryPathName       
claus
parents: 384
diff changeset
   683
     '../..' asFilename directoryPathName     
claus
parents: 384
diff changeset
   684
    "
claus
parents: 384
diff changeset
   685
claus
parents: 384
diff changeset
   686
    "Modified: 7.9.1995 / 10:42:13 / claus"
claus
parents: 384
diff changeset
   687
!
claus
parents: 384
diff changeset
   688
328
claus
parents: 326
diff changeset
   689
directoryName
422
claus
parents: 384
diff changeset
   690
    "return the directory name part of the file/directory as a string.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   691
     - thats the name of the directory where the file/dir represented by
422
claus
parents: 384
diff changeset
   692
       the receiver is contained in.
claus
parents: 384
diff changeset
   693
     See also: #directoryPathName"
328
claus
parents: 326
diff changeset
   694
claus
parents: 326
diff changeset
   695
    ^ OperatingSystem directoryNameOf:nameString "/ (self pathName)
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   696
328
claus
parents: 326
diff changeset
   697
    "
claus
parents: 326
diff changeset
   698
     '/foo/bar/' asFilename directoryName    
claus
parents: 326
diff changeset
   699
     '/foo/bar' asFilename directoryName    
422
claus
parents: 384
diff changeset
   700
     'bitmaps' asFilename directoryName        
claus
parents: 384
diff changeset
   701
     'bitmaps' asFilename directoryPathName        
328
claus
parents: 326
diff changeset
   702
     '.' asFilename directoryName        
claus
parents: 326
diff changeset
   703
     '..' asFilename directoryName       
claus
parents: 326
diff changeset
   704
     '../..' asFilename directoryName     
422
claus
parents: 384
diff changeset
   705
     '../..' asFilename directoryPathName     
328
claus
parents: 326
diff changeset
   706
    "
422
claus
parents: 384
diff changeset
   707
claus
parents: 384
diff changeset
   708
    "Modified: 7.9.1995 / 10:42:03 / claus"
328
claus
parents: 326
diff changeset
   709
!
claus
parents: 326
diff changeset
   710
claus
parents: 326
diff changeset
   711
directory
422
claus
parents: 384
diff changeset
   712
    "return the directory name part of the file/directory as a filename.
328
claus
parents: 326
diff changeset
   713
     - thats a filename for the directory where the file/dir represented by
claus
parents: 326
diff changeset
   714
       the receiver is contained in."
claus
parents: 326
diff changeset
   715
claus
parents: 326
diff changeset
   716
    ^ self directoryName asFilename
2
claus
parents: 1
diff changeset
   717
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   718
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   719
     '/foo/bar' asFilename directory
9e273c60e785 more functions
claus
parents: 159
diff changeset
   720
     '.' asFilename directory        
9e273c60e785 more functions
claus
parents: 159
diff changeset
   721
     '..' asFilename directory       
9e273c60e785 more functions
claus
parents: 159
diff changeset
   722
     '../..' asFilename directory     
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   723
    "
2
claus
parents: 1
diff changeset
   724
!
claus
parents: 1
diff changeset
   725
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   726
directoryContents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   727
    "return the contents of the directory as a collection of strings"
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   728
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   729
    ^ (FileDirectory directoryNamed:self asString) contents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   730
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   731
    "
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   732
     '.' asFilename directoryContents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   733
    "
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   734
!
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   735
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   736
tail
422
claus
parents: 384
diff changeset
   737
    "the files name without directory prefix as a string. 
claus
parents: 384
diff changeset
   738
     An alias for baseName, for ST-80 compatiblity."
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   739
9e273c60e785 more functions
claus
parents: 159
diff changeset
   740
    ^ self baseName
9e273c60e785 more functions
claus
parents: 159
diff changeset
   741
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   742
2
claus
parents: 1
diff changeset
   743
baseName
422
claus
parents: 384
diff changeset
   744
    "return my baseName as a string.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   745
     - thats the file/directory name without leading parent-dirs."
2
claus
parents: 1
diff changeset
   746
328
claus
parents: 326
diff changeset
   747
    ^ OperatingSystem baseNameOf:nameString "/ (self pathName) 
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   748
85
claus
parents: 77
diff changeset
   749
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   750
     '/foo/bar' asFilename baseName  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   751
     '.' asFilename baseName          
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   752
     '..' asFilename baseName         
328
claus
parents: 326
diff changeset
   753
     '../..' asFilename baseName        
claus
parents: 326
diff changeset
   754
     '../../libbasic' asFilename baseName        
claus
parents: 326
diff changeset
   755
     '../../libpr' asFilename baseName        
422
claus
parents: 384
diff changeset
   756
     '../../libbasic/Object.st' asFilename baseName        
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   757
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   758
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   759
422
claus
parents: 384
diff changeset
   760
name
claus
parents: 384
diff changeset
   761
    "return the name of the file represented by the receiver as a string.
claus
parents: 384
diff changeset
   762
     This may or may not be a relative name.
claus
parents: 384
diff changeset
   763
     See also: pathName"
claus
parents: 384
diff changeset
   764
claus
parents: 384
diff changeset
   765
    self isAbsolute ifTrue:[^ self pathName].
claus
parents: 384
diff changeset
   766
    ^ nameString
claus
parents: 384
diff changeset
   767
claus
parents: 384
diff changeset
   768
    "
claus
parents: 384
diff changeset
   769
     '/foo/bar' asFilename name        
claus
parents: 384
diff changeset
   770
     '/foo/bar' asFilename pathName    
claus
parents: 384
diff changeset
   771
     '.' asFilename name                
claus
parents: 384
diff changeset
   772
     '.' asFilename pathName             
claus
parents: 384
diff changeset
   773
     '../..' asFilename name             
claus
parents: 384
diff changeset
   774
     '../..' asFilename pathName         
claus
parents: 384
diff changeset
   775
     'bitmaps' asFilename name                
claus
parents: 384
diff changeset
   776
     'bitmaps' asFilename pathName             
claus
parents: 384
diff changeset
   777
     '/tmp/../usr' asFilename name       
claus
parents: 384
diff changeset
   778
     '/tmp/../usr' asFilename pathName   
claus
parents: 384
diff changeset
   779
    "
claus
parents: 384
diff changeset
   780
claus
parents: 384
diff changeset
   781
    "Modified: 7.9.1995 / 10:41:14 / claus"
claus
parents: 384
diff changeset
   782
!
claus
parents: 384
diff changeset
   783
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   784
pathName
422
claus
parents: 384
diff changeset
   785
    "return the full pathname of the file represented by the receiver,
claus
parents: 384
diff changeset
   786
     as a string. See also: name"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   787
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   788
    |parentName sep|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   789
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   790
    sep := self class separator.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   791
    (nameString startsWith:sep) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   792
	parentName := self class parentDirectoryName.
357
claus
parents: 356
diff changeset
   793
	(nameString findString:parentName) == 0 ifTrue:[
claus
parents: 356
diff changeset
   794
	    ^ nameString
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   795
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   796
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   797
    ^ (FileDirectory directoryNamed:nameString) pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   798
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   799
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   800
     '/foo/bar' asFilename pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   801
     '.' asFilename pathName 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   802
     '../..' asFilename pathName 
422
claus
parents: 384
diff changeset
   803
     '../..' asFilename name 
357
claus
parents: 356
diff changeset
   804
     '/tmp/../usr' asFilename pathName  
85
claus
parents: 77
diff changeset
   805
    "
422
claus
parents: 384
diff changeset
   806
claus
parents: 384
diff changeset
   807
    "Modified: 7.9.1995 / 10:42:39 / claus"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   808
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   809
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   810
isAbsolute
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   811
    "return true, if the receiver represents an absolute pathname
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   812
     (in contrast to one relative to the current directory)."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   813
85
claus
parents: 77
diff changeset
   814
    ^ (nameString startsWith:self class separator)
claus
parents: 77
diff changeset
   815
claus
parents: 77
diff changeset
   816
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   817
     '/foo/bar' asFilename isAbsolute   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   818
     '..' asFilename isAbsolute         
328
claus
parents: 326
diff changeset
   819
     '..' asAbsoluteFilename isAbsolute         
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   820
     'source/SBrowser.st' asFilename isAbsolute  
85
claus
parents: 77
diff changeset
   821
    "
claus
parents: 77
diff changeset
   822
!
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   823
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   824
isRelative
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   825
    "return true, if this name is interpreted relative to some
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   826
     directory (opposite of absolute)"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   827
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   828
    ^ self isAbsolute not
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   829
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   830
85
claus
parents: 77
diff changeset
   831
isDirectory
claus
parents: 77
diff changeset
   832
    "return true, if the receiver represents an existing,
claus
parents: 77
diff changeset
   833
     readable directories pathname."
claus
parents: 77
diff changeset
   834
claus
parents: 77
diff changeset
   835
    ^ OperatingSystem isDirectory:nameString
claus
parents: 77
diff changeset
   836
claus
parents: 77
diff changeset
   837
    "
claus
parents: 77
diff changeset
   838
     '/foo/bar' asFilename isDirectory
claus
parents: 77
diff changeset
   839
     '/tmp' asFilename isDirectory
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   840
     'Makefile' asFilename isDirectory   
85
claus
parents: 77
diff changeset
   841
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   842
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   843
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   844
exists
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   845
    "return true, if such a file exists."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   846
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   847
    ^ OperatingSystem isValidPath:nameString
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   848
85
claus
parents: 77
diff changeset
   849
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   850
     '/foo/bar' asFilename exists 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   851
     '/tmp' asFilename exists  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   852
     'Makefile' asFilename exists   
85
claus
parents: 77
diff changeset
   853
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   854
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   855
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   856
isReadable
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   857
    "return true, if such a file exists and is readable."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   858
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   859
    ^ OperatingSystem isReadable:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   860
85
claus
parents: 77
diff changeset
   861
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   862
     '/foo/bar' asFilename isReadable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   863
     '/tmp' asFilename isReadable      
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   864
     'Makefile' asFilename isReadable   
85
claus
parents: 77
diff changeset
   865
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   866
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   867
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   868
canBeWritten
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   869
    "same as isWritable - for ST-80 compatibility"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   870
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   871
    ^ self isWritable
328
claus
parents: 326
diff changeset
   872
claus
parents: 326
diff changeset
   873
    "
claus
parents: 326
diff changeset
   874
     '/foo/bar' asFilename canBeWritten 
claus
parents: 326
diff changeset
   875
     '/tmp' asFilename canBeWritten   
claus
parents: 326
diff changeset
   876
     'Makefile' asFilename canBeWritten   
claus
parents: 326
diff changeset
   877
    "
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   878
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   879
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   880
isWritable
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   881
    "return true, if such a file exists and is writable."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   882
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   883
    ^ OperatingSystem isWritable:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   884
85
claus
parents: 77
diff changeset
   885
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   886
     '/foo/bar' asFilename isWritable 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   887
     '/tmp' asFilename isWritable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   888
     'Makefile' asFilename isWritable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   889
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   890
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   891
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   892
isExecutable
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   893
    "return true, if such a file exists and is executable (by Unix's definition).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   894
     For directories, true is returned if the directory can be entered.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   895
     See isExecutableProgram for a related check."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   896
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   897
    ^ OperatingSystem isExecutable:nameString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   898
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   899
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   900
     '/foo/bar' asFilename isExecutable 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   901
     '/tmp' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   902
     'Makefile' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   903
     '/bin/ls' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   904
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   905
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   906
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   907
isExecutableProgram
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   908
    "return true, if such a file exists and is an executable program.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   909
     (i.e. for directories, false is returned.)"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   910
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   911
    ^ (OperatingSystem isExecutable:nameString)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   912
      and:[(OperatingSystem isDirectory:nameString) not]
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   913
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   914
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   915
     '/tmp' asFilename isExecutable         
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   916
     '/bin/ls' asFilename isExecutable       
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   917
     '/tmp' asFilename isExecutableProgram   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   918
     '/bin/ls' asFilename isExecutableProgram    
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   919
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   920
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   921
356
claus
parents: 328
diff changeset
   922
isSymbolicLink
claus
parents: 328
diff changeset
   923
    "return true, if the file represented by the receiver is a symbolic
claus
parents: 328
diff changeset
   924
     link. Notice that not all OS's support symbolic links; those that do
claus
parents: 328
diff changeset
   925
     not will always return false."
claus
parents: 328
diff changeset
   926
claus
parents: 328
diff changeset
   927
    ^ OperatingSystem isSymbolicLink:nameString
claus
parents: 328
diff changeset
   928
claus
parents: 328
diff changeset
   929
    "
claus
parents: 328
diff changeset
   930
     'Make.proto' asFilename isSymbolicLink  
claus
parents: 328
diff changeset
   931
     'Makefile' asFilename isSymbolicLink   
claus
parents: 328
diff changeset
   932
    "
claus
parents: 328
diff changeset
   933
!
claus
parents: 328
diff changeset
   934
422
claus
parents: 384
diff changeset
   935
prefixAndSuffix
claus
parents: 384
diff changeset
   936
    "return an array consisting of my prefix and suffix.
claus
parents: 384
diff changeset
   937
     The suffix is the namepart after the final period character,
claus
parents: 384
diff changeset
   938
     the prefix everything before, except for the period.
claus
parents: 384
diff changeset
   939
     (on some systems, the suffix-character may be different from a period).
claus
parents: 384
diff changeset
   940
     For example, foo.bar.baz has a prefix of 'foo.bar' and a suffix of '.baz'.
claus
parents: 384
diff changeset
   941
claus
parents: 384
diff changeset
   942
     Notice: there is currently no known system which uses other than
claus
parents: 384
diff changeset
   943
     the period character as suffixCharacter."
claus
parents: 384
diff changeset
   944
claus
parents: 384
diff changeset
   945
    |nm idx|
claus
parents: 384
diff changeset
   946
claus
parents: 384
diff changeset
   947
    nm := self baseName.
claus
parents: 384
diff changeset
   948
    idx := nm lastIndexOf:(self class suffixSeparator).
claus
parents: 384
diff changeset
   949
    idx == 0 ifTrue:[
claus
parents: 384
diff changeset
   950
	^ Array with:nm with:''
claus
parents: 384
diff changeset
   951
    ].
claus
parents: 384
diff changeset
   952
    ^ Array 
claus
parents: 384
diff changeset
   953
	with:(nm copyTo:idx-1)
claus
parents: 384
diff changeset
   954
	with:(nm copyFrom:idx+1)
claus
parents: 384
diff changeset
   955
claus
parents: 384
diff changeset
   956
    "
claus
parents: 384
diff changeset
   957
     'abc.st' asFilename prefixAndSuffix  
claus
parents: 384
diff changeset
   958
     'abc' asFilename prefixAndSuffix  
claus
parents: 384
diff changeset
   959
     'a.b.c' asFilename prefixAndSuffix 
claus
parents: 384
diff changeset
   960
claus
parents: 384
diff changeset
   961
     |parts| 
claus
parents: 384
diff changeset
   962
     parts := 'Object.st' asFilename prefixAndSuffix.
claus
parents: 384
diff changeset
   963
     ((parts at:1) , '.o') asFilename
claus
parents: 384
diff changeset
   964
    "
claus
parents: 384
diff changeset
   965
claus
parents: 384
diff changeset
   966
    "Modified: 7.9.1995 / 11:15:42 / claus"
claus
parents: 384
diff changeset
   967
!
claus
parents: 384
diff changeset
   968
claus
parents: 384
diff changeset
   969
suffix
claus
parents: 384
diff changeset
   970
    "return my suffix.
claus
parents: 384
diff changeset
   971
     The suffix is the namepart after the final period character,
claus
parents: 384
diff changeset
   972
     or the empty string, if the name does not contain a period."
claus
parents: 384
diff changeset
   973
claus
parents: 384
diff changeset
   974
    ^ self prefixAndSuffix at:2
claus
parents: 384
diff changeset
   975
claus
parents: 384
diff changeset
   976
    "
claus
parents: 384
diff changeset
   977
     'abc.st' asFilename suffix   
claus
parents: 384
diff changeset
   978
     'abc' asFilename suffix      
claus
parents: 384
diff changeset
   979
     'a.b.c' asFilename suffix    
claus
parents: 384
diff changeset
   980
    "
claus
parents: 384
diff changeset
   981
claus
parents: 384
diff changeset
   982
    "Modified: 7.9.1995 / 11:09:03 / claus"
claus
parents: 384
diff changeset
   983
!
claus
parents: 384
diff changeset
   984
328
claus
parents: 326
diff changeset
   985
filesMatching:aPattern
claus
parents: 326
diff changeset
   986
    ^ self directoryContents select:[:name | aPattern match:name]
claus
parents: 326
diff changeset
   987
claus
parents: 326
diff changeset
   988
    "
claus
parents: 326
diff changeset
   989
     Filename currentDirectory filesMatching:'M*' 
claus
parents: 326
diff changeset
   990
    "
claus
parents: 326
diff changeset
   991
!
claus
parents: 326
diff changeset
   992
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   993
filenameCompletion
440
claus
parents: 422
diff changeset
   994
    "try to complete the recevier filename.
claus
parents: 422
diff changeset
   995
     This method has both a return value and a side effect on the receiver:
claus
parents: 422
diff changeset
   996
       it returns a collection of matching filename objects,
claus
parents: 422
diff changeset
   997
       and leaves changes the receivers filename-string to the longest common
claus
parents: 422
diff changeset
   998
       match.
claus
parents: 422
diff changeset
   999
     If none matches, the returned collection is empty and the recevier is unchanged.
claus
parents: 422
diff changeset
  1000
     If there is only one match, the size of the returned collection is exactly 1,
claus
parents: 422
diff changeset
  1001
     containing the fully expanded filename and the receivers name is changed to it."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1002
440
claus
parents: 422
diff changeset
  1003
    ^ self filenameCompletionIn:nil
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1004
440
claus
parents: 422
diff changeset
  1005
    " 
claus
parents: 422
diff changeset
  1006
     'mak' asFilename filenameCompletion  
claus
parents: 422
diff changeset
  1007
     'Make' asFilename filenameCompletion 
claus
parents: 422
diff changeset
  1008
     'Makef' asFilename filenameCompletion;yourself  
claus
parents: 422
diff changeset
  1009
     '/u' asFilename filenameCompletion             
claus
parents: 422
diff changeset
  1010
     '../../libpr' asFilename inspect filenameCompletion    
claus
parents: 422
diff changeset
  1011
    "
claus
parents: 422
diff changeset
  1012
!
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1013
440
claus
parents: 422
diff changeset
  1014
filenameCompletionIn:aDirectory
claus
parents: 422
diff changeset
  1015
    "try to complete the recevier filename.
claus
parents: 422
diff changeset
  1016
     This method has both a return value and a side effect on the receiver:
claus
parents: 422
diff changeset
  1017
       it returns a collection of matching filename objects,
claus
parents: 422
diff changeset
  1018
       and leaves changes the receivers filename-string to the longest common
claus
parents: 422
diff changeset
  1019
       match.
claus
parents: 422
diff changeset
  1020
     If none matches, the returned collection is empty and the recevier is unchanged.
claus
parents: 422
diff changeset
  1021
     If there is only one match, the size of the returned collection is exactly 1,
claus
parents: 422
diff changeset
  1022
     containing the fully expanded filename and the receivers name is changed to it."
claus
parents: 422
diff changeset
  1023
claus
parents: 422
diff changeset
  1024
    |dir baseName matching matchLen try allMatching 
claus
parents: 422
diff changeset
  1025
     sepString parentString prefix nMatch|
claus
parents: 422
diff changeset
  1026
claus
parents: 422
diff changeset
  1027
    sepString := self class separator asString.
claus
parents: 422
diff changeset
  1028
    (nameString endsWith:sepString) ifTrue:[
claus
parents: 422
diff changeset
  1029
	^ #()
328
claus
parents: 326
diff changeset
  1030
    ].
claus
parents: 326
diff changeset
  1031
440
claus
parents: 422
diff changeset
  1032
    parentString := self class parentDirectoryName.
claus
parents: 422
diff changeset
  1033
    baseName := self baseName.
claus
parents: 422
diff changeset
  1034
    baseName ~= nameString ifTrue:[
claus
parents: 422
diff changeset
  1035
	prefix := self directoryName.
claus
parents: 422
diff changeset
  1036
    ].
claus
parents: 422
diff changeset
  1037
441
claus
parents: 440
diff changeset
  1038
    self isAbsolute ifTrue:[
440
claus
parents: 422
diff changeset
  1039
	dir := self directory
claus
parents: 422
diff changeset
  1040
    ] ifFalse:[
441
claus
parents: 440
diff changeset
  1041
	aDirectory isNil ifTrue:[
claus
parents: 440
diff changeset
  1042
	    dir := self directory
claus
parents: 440
diff changeset
  1043
	] ifFalse:[
claus
parents: 440
diff changeset
  1044
	    dir := (aDirectory construct:nameString) directory
claus
parents: 440
diff changeset
  1045
	]
328
claus
parents: 326
diff changeset
  1046
    ].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1047
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1048
    matching := OrderedCollection new.
440
claus
parents: 422
diff changeset
  1049
    dir directoryContents do:[:fileName |
claus
parents: 422
diff changeset
  1050
	((fileName ~= '.') and:[fileName ~= parentString]) ifTrue:[
claus
parents: 422
diff changeset
  1051
	    (fileName startsWith:baseName) ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1052
		matching add:fileName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1053
	    ]
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1054
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1055
    ].
440
claus
parents: 422
diff changeset
  1056
    (nMatch := matching size) > 1 ifTrue:[
claus
parents: 422
diff changeset
  1057
	"
claus
parents: 422
diff changeset
  1058
	 find the longest common prefix
claus
parents: 422
diff changeset
  1059
	"
claus
parents: 422
diff changeset
  1060
	matchLen := baseName size.
claus
parents: 422
diff changeset
  1061
	matchLen > matching first size ifTrue:[
claus
parents: 422
diff changeset
  1062
	    try := baseName.
claus
parents: 422
diff changeset
  1063
	    allMatching := false
claus
parents: 422
diff changeset
  1064
	] ifFalse:[
claus
parents: 422
diff changeset
  1065
	    try := matching first copyTo:matchLen.
claus
parents: 422
diff changeset
  1066
	    allMatching := true.
claus
parents: 422
diff changeset
  1067
	].
claus
parents: 422
diff changeset
  1068
claus
parents: 422
diff changeset
  1069
	[allMatching] whileTrue:[
claus
parents: 422
diff changeset
  1070
	    matching do:[:aName |
claus
parents: 422
diff changeset
  1071
		(aName startsWith:try) ifFalse:[
claus
parents: 422
diff changeset
  1072
		    allMatching := false
claus
parents: 422
diff changeset
  1073
		]
claus
parents: 422
diff changeset
  1074
	    ].
claus
parents: 422
diff changeset
  1075
	    allMatching ifTrue:[
claus
parents: 422
diff changeset
  1076
		matchLen <  matching first size ifTrue:[
claus
parents: 422
diff changeset
  1077
		    matchLen := matchLen + 1.
claus
parents: 422
diff changeset
  1078
		    try := matching first copyTo:matchLen.
claus
parents: 422
diff changeset
  1079
		] ifFalse:[
claus
parents: 422
diff changeset
  1080
		    allMatching := false
claus
parents: 422
diff changeset
  1081
		]
claus
parents: 422
diff changeset
  1082
	    ] ifFalse:[
claus
parents: 422
diff changeset
  1083
		try := matching first copyTo:matchLen - 1.
claus
parents: 422
diff changeset
  1084
	    ]
claus
parents: 422
diff changeset
  1085
	].
claus
parents: 422
diff changeset
  1086
	"
claus
parents: 422
diff changeset
  1087
	 and set my name to the last full match
claus
parents: 422
diff changeset
  1088
	"
claus
parents: 422
diff changeset
  1089
	nameString := try
claus
parents: 422
diff changeset
  1090
    ].
claus
parents: 422
diff changeset
  1091
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1092
    "
440
claus
parents: 422
diff changeset
  1093
     if I had a directory-prefix, change names in collection ...
claus
parents: 422
diff changeset
  1094
    "
claus
parents: 422
diff changeset
  1095
    prefix notNil ifTrue:[
claus
parents: 422
diff changeset
  1096
	prefix = '/' ifTrue:[
claus
parents: 422
diff changeset
  1097
	    "/ avoid introducing double slashes
claus
parents: 422
diff changeset
  1098
	    prefix := ''
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1099
	].
440
claus
parents: 422
diff changeset
  1100
	matching := matching collect:[:n | prefix , '/' , n].
claus
parents: 422
diff changeset
  1101
	nMatch == 1 ifTrue:[
claus
parents: 422
diff changeset
  1102
	    nameString := matching first
claus
parents: 422
diff changeset
  1103
	] ifFalse:[
claus
parents: 422
diff changeset
  1104
	    nMatch > 1 ifTrue:[
claus
parents: 422
diff changeset
  1105
		nameString := prefix , '/' , nameString
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1106
	    ]
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1107
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1108
    ] ifFalse:[
440
claus
parents: 422
diff changeset
  1109
	nMatch == 1 ifTrue:[
claus
parents: 422
diff changeset
  1110
	    nameString := matching first
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1111
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1112
    ].
440
claus
parents: 422
diff changeset
  1113
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1114
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1115
     return the match-set, so caller can decide what to do
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1116
     (i.e. show the matches, output a warning etc ...)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1117
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1118
    ^ matching
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1119
440
claus
parents: 422
diff changeset
  1120
    " trivial cases:
claus
parents: 422
diff changeset
  1121
claus
parents: 422
diff changeset
  1122
     '../' asFilename filenameCompletion    
claus
parents: 422
diff changeset
  1123
     '/' asFilename filenameCompletion      
claus
parents: 422
diff changeset
  1124
     '/usr/' asFilename filenameCompletion   
claus
parents: 422
diff changeset
  1125
claus
parents: 422
diff changeset
  1126
     'mak' asFilename filenameCompletion   
claus
parents: 422
diff changeset
  1127
     'Make' asFilename filenameCompletion    
claus
parents: 422
diff changeset
  1128
     'Makef' asFilename filenameCompletion
claus
parents: 422
diff changeset
  1129
     '/u' asFilename filenameCompletion             
claus
parents: 422
diff changeset
  1130
     '../../libpr' asFilename filenameCompletion    
85
claus
parents: 77
diff changeset
  1131
    "
2
claus
parents: 1
diff changeset
  1132
! !
claus
parents: 1
diff changeset
  1133
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1134
!Filename methodsFor:'file queries'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1135
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1136
info
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1137
    "return the files info; that is a collection of file attributes,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1138
     (actually a dictionary) where the keys are #type, #uid, #gid, #size etc.
356
claus
parents: 328
diff changeset
  1139
     The actual amount and detail returned may depend on the OS used.
claus
parents: 328
diff changeset
  1140
     On unix, if you ask for the info of a symbolic link, the target
359
claus
parents: 357
diff changeset
  1141
     files info is returned. (see also: #linkInfo)
356
claus
parents: 328
diff changeset
  1142
claus
parents: 328
diff changeset
  1143
     On unix, the contents is:
claus
parents: 328
diff changeset
  1144
	id            -> the inode number (integer)
claus
parents: 328
diff changeset
  1145
	uid           -> the numeric user id of the files owner
claus
parents: 328
diff changeset
  1146
	gid           -> the numeric group id of the files owner
claus
parents: 328
diff changeset
  1147
	statusChanged -> the absoluteTime when the files status changed last
claus
parents: 328
diff changeset
  1148
			 (i.e. protection change, owner change etc.)
claus
parents: 328
diff changeset
  1149
	accessed      -> the absoluteTime when the file was last accessed
claus
parents: 328
diff changeset
  1150
	modified      -> the absoluteTime when the file was last modified
claus
parents: 328
diff changeset
  1151
	size          -> the size (in bytes) of the file
claus
parents: 328
diff changeset
  1152
	type          -> the files type (#regular, #directory, #characterSpecial)
claus
parents: 328
diff changeset
  1153
	mode          -> the files access protection bits (rwxrwxrwx mask).
claus
parents: 328
diff changeset
  1154
claus
parents: 328
diff changeset
  1155
     The minimum returned info (i.e. on all OS's) will consist of at least:
claus
parents: 328
diff changeset
  1156
	modified
claus
parents: 328
diff changeset
  1157
	size
claus
parents: 328
diff changeset
  1158
	type
claus
parents: 328
diff changeset
  1159
claus
parents: 328
diff changeset
  1160
     Some OS's (VMS) may return more info.
claus
parents: 328
diff changeset
  1161
claus
parents: 328
diff changeset
  1162
     Dont expect things like uid/gid/mode to be there; write your application
claus
parents: 328
diff changeset
  1163
     to either handle the cases where info-entries are not present,
359
claus
parents: 357
diff changeset
  1164
     or (better) use one of isXXXX query methods. (Be prepared for DOS ...)
356
claus
parents: 328
diff changeset
  1165
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1166
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1167
    ^ OperatingSystem infoOf:nameString
328
claus
parents: 326
diff changeset
  1168
claus
parents: 326
diff changeset
  1169
    "
claus
parents: 326
diff changeset
  1170
     Filename currentDirectory info
356
claus
parents: 328
diff changeset
  1171
     '/dev/null' asFilename info 
328
claus
parents: 326
diff changeset
  1172
     'Make.proto' asFilename info
356
claus
parents: 328
diff changeset
  1173
     'source/Point.st' asFilename info 
359
claus
parents: 357
diff changeset
  1174
     'source/Point.st' asFilename linkInfo 
356
claus
parents: 328
diff changeset
  1175
     '../../libbasic/Point.st' asFilename info 
claus
parents: 328
diff changeset
  1176
    "
claus
parents: 328
diff changeset
  1177
!
claus
parents: 328
diff changeset
  1178
claus
parents: 328
diff changeset
  1179
linkInfo
claus
parents: 328
diff changeset
  1180
    "return the files info if its a symbolic link; nil otherwise.
claus
parents: 328
diff changeset
  1181
     On OS's which do not support symbolic links, nil is always returned.
359
claus
parents: 357
diff changeset
  1182
     The information is the same as returned by #info, except that if the
claus
parents: 357
diff changeset
  1183
     receiver represents a symbolic link, the links information 
claus
parents: 357
diff changeset
  1184
     is returned 
claus
parents: 357
diff changeset
  1185
     (while in this case, #info returns the info of the target file, 
claus
parents: 357
diff changeset
  1186
      which is accessed via the symbolic link).
356
claus
parents: 328
diff changeset
  1187
claus
parents: 328
diff changeset
  1188
     In addition to the normal entries, Unix returns an additional entry:
claus
parents: 328
diff changeset
  1189
	 path -> the target files pathname
claus
parents: 328
diff changeset
  1190
claus
parents: 328
diff changeset
  1191
     See the comment in #info for more details."
claus
parents: 328
diff changeset
  1192
claus
parents: 328
diff changeset
  1193
    ^ OperatingSystem linkInfoOf:nameString
claus
parents: 328
diff changeset
  1194
claus
parents: 328
diff changeset
  1195
    "
claus
parents: 328
diff changeset
  1196
     Filename currentDirectory linkInfo 
claus
parents: 328
diff changeset
  1197
     '/dev/null' asFilename linkInfo    
claus
parents: 328
diff changeset
  1198
     'Make.proto' asFilename linkInfo   
claus
parents: 328
diff changeset
  1199
     'Make.proto' asFilename linkInfo at:#path  
claus
parents: 328
diff changeset
  1200
     'source/Point.st' asFilename linkInfo 
claus
parents: 328
diff changeset
  1201
     '../../libbasic/Point.st' asFilename linkInfo 
328
claus
parents: 326
diff changeset
  1202
    "
claus
parents: 326
diff changeset
  1203
!
claus
parents: 326
diff changeset
  1204
claus
parents: 326
diff changeset
  1205
dates
claus
parents: 326
diff changeset
  1206
    "return the files modification and access times as an object (currently a dictionary)
356
claus
parents: 328
diff changeset
  1207
     that responds to the at: message with arguments 
claus
parents: 328
diff changeset
  1208
     #modified, #accessed or #statusChanged."
328
claus
parents: 326
diff changeset
  1209
claus
parents: 326
diff changeset
  1210
    |info dates|
claus
parents: 326
diff changeset
  1211
claus
parents: 326
diff changeset
  1212
    info := OperatingSystem infoOf:nameString.
claus
parents: 326
diff changeset
  1213
    info isNil ifTrue:[
claus
parents: 326
diff changeset
  1214
	info := OperatingSystem linkInfoOf:nameString.
claus
parents: 326
diff changeset
  1215
	info isNil ifTrue:[
claus
parents: 326
diff changeset
  1216
	    ^ nil
claus
parents: 326
diff changeset
  1217
	]
claus
parents: 326
diff changeset
  1218
    ].
claus
parents: 326
diff changeset
  1219
    dates := IdentityDictionary new.
claus
parents: 326
diff changeset
  1220
    dates at:#modified put:(info at:#modified).
claus
parents: 326
diff changeset
  1221
    dates at:#accessed put:(info at:#accessed).
claus
parents: 326
diff changeset
  1222
    dates at:#statusChanged put:(info at:#statusChanged).
claus
parents: 326
diff changeset
  1223
    ^ dates
claus
parents: 326
diff changeset
  1224
claus
parents: 326
diff changeset
  1225
    "
claus
parents: 326
diff changeset
  1226
     Filename currentDirectory dates
claus
parents: 326
diff changeset
  1227
     '../regression' asFilename dates
claus
parents: 326
diff changeset
  1228
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1229
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1230
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1231
fileSize
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1232
    "return the size of the file in bytes"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1233
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1234
    |info|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1235
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1236
    info := self info.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1237
    info isNil ifTrue:[^ nil].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1238
    ^ info at:#size
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1239
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1240
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1241
fileType
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1242
    "this returns a string describing the type of contents of
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1243
     the file. This is done using the unix 'file' command,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1244
     (which usually is configurable by /etc/magic).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1245
     On non-unix systems, this may return an empty string, not knowning
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1246
     about the contents."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1247
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1248
    |stream typeString|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1249
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1250
    typeString := ''.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1251
    stream := PipeStream readingFrom:('file ' , self pathName).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1252
    stream notNil ifTrue:[
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1253
	typeString := stream contents asString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1254
	stream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1255
	typeString := typeString copyFrom:(typeString indexOf:$:) + 1.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1256
	typeString := typeString withoutSeparators
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1257
    ] ifFalse:[
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1258
	"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1259
	 could add some fallback code here, for systems, where no
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1260
	 file command is avaliable ...
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1261
	 ... or at least analyze directory info.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1262
	"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1263
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1264
    ^ typeString
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1265
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1266
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1267
     'Makefile' asFilename fileType 
325
claus
parents: 308
diff changeset
  1268
     '.' asFilename fileType     
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1269
     '/dev/null' asFilename fileType        
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1270
     'smalltalk.rc' asFilename fileType    
325
claus
parents: 308
diff changeset
  1271
     'bitmaps/SBrowser.xbm' asFilename fileType    
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1272
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1273
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1274
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1275
!Filename methodsFor:'file operations'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1276
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1277
delete
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1278
    "remove the file - same as remove, for ST-80 compatibility"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1279
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1280
    self remove
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1281
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1282
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1283
remove
538
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1284
    "remove the file/directory - the argument must be convertable to a String.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1285
     Return true if sucessfull, false if not.
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1286
     Use recursiveRemove in order to (recursively) remove non empty directories."
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1287
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1288
    |ok|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1289
545
32adce698074 dont try remove it it does not exist
Claus Gittinger <cg@exept.de>
parents: 542
diff changeset
  1290
    self exists ifFalse:[ ^ self].
538
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1291
    self isDirectory ifTrue:[
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1292
	ok := OperatingSystem removeDirectory:nameString
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1293
    ] ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1294
	ok := OperatingSystem removeFile:nameString
538
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1295
    ].
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1296
    ok ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1297
	self removeError:self
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1298
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1299
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1300
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1301
     (FileStream newFileNamed:'foo') close.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1302
     'foo' asFilename remove
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1303
    "
538
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1304
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1305
    "
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1306
     'foo' asFilename makeDirectory.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1307
     'foo/bar' asFilename writeStream close.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1308
     ('foo' asFilename remove) ifFalse:[
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1309
	Transcript showCr:'could not remove foo'
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1310
     ]
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1311
    "
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1312
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1313
    "Modified: 14.11.1995 / 11:18:26 / cg"
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1314
!
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1315
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1316
recursiveRemove
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1317
    "remove the directory and all of its subfiles/subdirectories."
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1318
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1319
    |ok|
538
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1320
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1321
    ok := OperatingSystem recursiveRemoveDirectory:nameString.
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1322
    ok ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1323
	self removeError:self
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1324
    ].
538
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1325
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1326
    "
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1327
     'foo' asFilename makeDirectory.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1328
     'foo/bar' asFilename writeStream close.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1329
     ('foo' asFilename remove) ifFalse:[
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1330
	Transcript showCr:'could not remove foo'
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1331
     ]
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1332
    "
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1333
    "
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1334
     'foo' asFilename makeDirectory.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1335
     'foo/bar' asFilename writeStream close.
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1336
     ('foo' asFilename recursiveRemove) ifFalse:[
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1337
	Transcript showCr:'could not remove foo'
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1338
     ]
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1339
    "
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1340
b9337c6c55bb added recursiveRemove; remove now also removes directories
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
  1341
    "Created: 14.11.1995 / 11:19:29 / cg"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1342
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1343
2
claus
parents: 1
diff changeset
  1344
renameTo:newName
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1345
    "rename the file - the argument must be convertable to a String."
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1346
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1347
    |ok|
2
claus
parents: 1
diff changeset
  1348
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1349
    ok := OperatingSystem renameFile:nameString to:(newName asString).
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1350
    ok ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1351
	self exists ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1352
	    ^ self fileNotFoundError:self
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1353
	].
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1354
	^ self accessDeniedError:newName asFilename.
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1355
    ].
2
claus
parents: 1
diff changeset
  1356
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1357
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1358
     '/tmp/foo' asFilename renameTo:'/tmp/bar'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1359
    "
2
claus
parents: 1
diff changeset
  1360
!
claus
parents: 1
diff changeset
  1361
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1362
copyTo:newName
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1363
    "copy the file - the argument must be convertable to a filename.
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1364
     Return true if successfull, false if not."
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1365
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1366
    |inStream outStream buffer bufferSize count newFile|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1367
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1368
    bufferSize := 8 * 1024.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1369
    buffer := ByteArray new:bufferSize.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1370
    inStream := self readStream.
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1371
    inStream isNil ifTrue:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1372
	^ self fileNotFoundError:self 
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1373
    ].
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1374
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1375
    outStream := (newFile := newName asFilename) writeStream.
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1376
    outStream isNil ifTrue:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1377
	^ self fileCreationError:newFile
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1378
    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1379
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1380
    [inStream atEnd] whileFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1381
	count := inStream nextBytes:bufferSize into:buffer.
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1382
	(outStream nextPutBytes:count from:buffer) ~= count ifTrue:[
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1383
	    ^ self fileCreationError:newFile
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1384
	]
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1385
    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1386
    outStream close.
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
  1387
    inStream close.
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1388
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1389
    "
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1390
     'Makefile' asFilename copyTo:'Makefile.foo'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1391
     'smalltalk' asFilename copyTo:'/dev/null'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1392
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1393
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1394
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1395
moveTo:newName
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1396
    "copy the file represented by the receiver, then delete it.
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1397
     This is different to renaming in case of cross device moves.
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1398
     Return true if successfull, false if not."
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1399
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1400
    self copyTo:newName.
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1401
    self remove
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1402
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1403
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1404
makeDirectory
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1405
    "create a directory with the receivers name.
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1406
     Return true if successfull, false if not."
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1407
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1408
    (OperatingSystem createDirectory:nameString) ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1409
	^ self fileCreationError:self
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1410
    ]
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1411
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1412
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1413
addAccessRights:aCollection
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1414
    "add the access rights as specified in aCollection for the file represented
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1415
     by the receiver. The argument must be a collection of symbols,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1416
     such as #readUser, #writeGroup etc."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1417
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1418
    |access|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1419
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1420
    access := OperatingSystem accessModeOf:nameString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1421
    aCollection do:[:accessSymbol |
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1422
	access := access bitOr:(OperatingSystem accessMaskFor:accessSymbol).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1423
    ].
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1424
    (OperatingSystem changeAccessModeOf:nameString to:access) ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1425
	^ self accessDeniedError:self
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1426
    ]
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1427
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1428
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1429
     'foo' asFilename writeStream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1430
     'foo' asFilename addAccessRights:#(readUser readGroup readOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1431
     'foo' asFilename addAccessRights:#(writeUser writeGroup writeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1432
     'foo' asFilename addAccessRights:#(executeUser executeGroup executeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1433
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1434
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1435
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1436
removeAccessRights:aCollection
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1437
    "remove the access rights as specified in aCollection for the file represented
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1438
     by the receiver. The argument must be a collection of symbols,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1439
     such as #readUser, #writeGroup etc."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1440
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1441
    |access|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1442
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1443
    access := OperatingSystem accessModeOf:nameString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1444
    aCollection do:[:accessSymbol |
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1445
	access := access bitAnd:(OperatingSystem accessMaskFor:accessSymbol) bitInvert.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1446
    ].
542
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1447
    (OperatingSystem changeAccessModeOf:nameString to:access) ifFalse:[
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1448
	^ self accessDeniedError:self
fec8c38962ba error reporting
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
  1449
    ].
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1450
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1451
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1452
     'foo' asFilename writeStream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1453
     'foo' asFilename removeAccessRights:#(readUser readGroup readOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1454
     'foo' asFilename removeAccessRights:#(writeUser writeGroup writeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1455
     'foo' asFilename removeAccessRights:#(executeUser executeGroup executeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1456
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1457
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1458
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1459
makeReadableForAll
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1460
    "make the file readable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1461
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1462
    ^ self addAccessRights:#(readUser readGroup readOthers)
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1463
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1464
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1465
makeReadable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1466
    "make the file readable for  the owner - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1467
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1468
    ^ self addAccessRights:#(readUser)
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1469
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1470
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1471
makeWritable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1472
    "make the file writableable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1473
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1474
    ^ self addAccessRights:#(writeUser)
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1475
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1476
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1477
makeWritableForAll
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1478
    "make the file writable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1479
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1480
    ^ self addAccessRights:#(writeUser writeGroup writeOthers)
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1481
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1482
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1483
makeUnwritable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1484
    "make the file unwritable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1485
539
11aca4b770ac more fileOPs return true/false
Claus Gittinger <cg@exept.de>
parents: 538
diff changeset
  1486
    ^ self removeAccessRights:#(writeUser writeGroup writeOthers)
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1487
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1488
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1489
!Filename methodsFor:'file utilities'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1490
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1491
fileIn
2
claus
parents: 1
diff changeset
  1492
    "load smalltalk code from the file"
claus
parents: 1
diff changeset
  1493
claus
parents: 1
diff changeset
  1494
    ^ self readStream fileIn
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1495
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1496
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1497
edit
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1498
    "start an editView on the file represented by the receiver"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1499
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1500
    EditTextView openOn:self asString
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1501
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1502
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1503
     'smalltalk.rc' asFilename edit
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1504
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1505
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1506
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1507
contentsOfEntireFile
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1508
    "return the contents of the file as a string"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1509
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1510
    |s contents|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1511
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1512
    s := self readStream.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1513
    [
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1514
	contents := s contents
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1515
    ] valueNowOrOnUnwindDo:[s close].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1516
    ^ contents
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1517
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1518
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1519
!Filename methodsFor:'file access'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1520
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1521
newReadWriteStream
325
claus
parents: 308
diff changeset
  1522
    "return a stream for read/write the file represented by the receiver.
claus
parents: 308
diff changeset
  1523
     If the file does not already exist, it is created."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1524
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1525
    ^ FileStream newFileNamed:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1526
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1527
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1528
readWriteStream
325
claus
parents: 308
diff changeset
  1529
    "return a stream for read/write the file represented by the receiver.
claus
parents: 308
diff changeset
  1530
     If the file does not already exist, nil is returned."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1531
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1532
    ^ FileStream oldFileNamed:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1533
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1534
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1535
readStream
325
claus
parents: 308
diff changeset
  1536
    "return a stream for reading from the file represented by the receiver.
claus
parents: 308
diff changeset
  1537
     If the file does not already exist, nil is returned."
2
claus
parents: 1
diff changeset
  1538
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1539
    ^ FileStream readonlyFileNamed:nameString
325
claus
parents: 308
diff changeset
  1540
claus
parents: 308
diff changeset
  1541
    "
claus
parents: 308
diff changeset
  1542
     '/tmp/foo' asFilename readStream 
claus
parents: 308
diff changeset
  1543
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1544
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1545
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1546
writeStream
325
claus
parents: 308
diff changeset
  1547
    "return a stream for writing to the file represented by the receiver.
claus
parents: 308
diff changeset
  1548
     If the file does not already exist, it is created."
2
claus
parents: 1
diff changeset
  1549
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1550
    ^ FileStream newFileForWritingNamed:nameString
325
claus
parents: 308
diff changeset
  1551
claus
parents: 308
diff changeset
  1552
    "
claus
parents: 308
diff changeset
  1553
     '/tmp/foo' asFilename writeStream 
claus
parents: 308
diff changeset
  1554
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1555
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1556
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1557
appendingWriteStream
325
claus
parents: 308
diff changeset
  1558
    "return a stream for appending to the file represented by the receiver.
claus
parents: 308
diff changeset
  1559
     If the file does not already exist, it is created."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1560
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1561
    ^ FileStream appendingOldFileNamed:nameString 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1562
! !
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1563
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1564
!Filename methodsFor:'printing & storing'!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1565
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1566
storeOn:aStream
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1567
    "append a printed representation of the receiver to aStream,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1568
     which allows reconstructing it via readFrom:"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1569
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1570
    aStream nextPut:$(.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1571
    nameString storeOn:aStream.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1572
    aStream nextPutAll:' asFilename)'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1573
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1574
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1575
printOn:aStream
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1576
    "append a printed representation of the receiver to aStream."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1577
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1578
    aStream nextPutAll:'FileName('''.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1579
    nameString printOn:aStream.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1580
    aStream nextPutAll:''')'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1581
! !