Filename.st
author claus
Sun, 02 Jul 1995 03:08:30 +0200
changeset 360 90c3608b92a3
parent 359 b8df66983eff
child 379 5b5a130ccd09
permissions -rw-r--r--
.
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
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
Filename comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    20
COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    21
	     All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    22
360
claus
parents: 359
diff changeset
    23
$Header: /cvs/stx/stx/libbasic/Filename.st,v 1.29 1995-07-02 01:06:48 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    24
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    26
!Filename class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    27
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    28
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    29
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    30
 COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    31
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    32
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    33
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    34
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    35
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    36
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    37
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    38
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    39
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    40
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    41
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    42
version
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    43
"
360
claus
parents: 359
diff changeset
    44
$Header: /cvs/stx/stx/libbasic/Filename.st,v 1.29 1995-07-02 01:06:48 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    45
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    46
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    47
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    48
documentation
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    49
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    50
    Filenames; originally added for ST-80 compatibility, is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    51
    taking over functionality from other classes (FileDirectory).
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    52
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    53
    Instances of Filename do not nescessarily represent valid or existing
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    54
    files - i.e. it is possible (and useful) to have instances for non-existing
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    55
    files around. In other words: the name-string is not checked automatically
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    56
    for being correct or existing.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    57
    Thus, it is possible to do queries such as:
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    58
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    59
	'/fee/foo/foe' asFilename exists     
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    60
	'/not_existing' asFilename isDirectory 
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
    61
	'/foo/bar' asFilename isReadable 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    62
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
    63
    (all of the above examples will probably return false on your machine ;-).
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    64
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    65
    examples:
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    66
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    67
	'Makefile' asFilename readStream
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    68
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    69
	'newFile' asFilename writeStream
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    70
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
    71
	Filename newTemporary writeStream
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    72
"
360
claus
parents: 359
diff changeset
    73
!
claus
parents: 359
diff changeset
    74
claus
parents: 359
diff changeset
    75
examples
claus
parents: 359
diff changeset
    76
"
claus
parents: 359
diff changeset
    77
    does a file/directory exist ?:
claus
parents: 359
diff changeset
    78
claus
parents: 359
diff changeset
    79
	|f|
claus
parents: 359
diff changeset
    80
claus
parents: 359
diff changeset
    81
	f := 'foobar' asFilename.
claus
parents: 359
diff changeset
    82
	^ f exists  
claus
parents: 359
diff changeset
    83
claus
parents: 359
diff changeset
    84
claus
parents: 359
diff changeset
    85
    is it a directory ?:
claus
parents: 359
diff changeset
    86
claus
parents: 359
diff changeset
    87
	|f|
claus
parents: 359
diff changeset
    88
claus
parents: 359
diff changeset
    89
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
    90
	^ f isDirectory.   
claus
parents: 359
diff changeset
    91
claus
parents: 359
diff changeset
    92
        
claus
parents: 359
diff changeset
    93
    get the working directory:
claus
parents: 359
diff changeset
    94
claus
parents: 359
diff changeset
    95
	^ Filename defaultDirectory
claus
parents: 359
diff changeset
    96
claus
parents: 359
diff changeset
    97
claus
parents: 359
diff changeset
    98
    get a files full pathname 
claus
parents: 359
diff changeset
    99
    (caring for relative names or symbolic links):
claus
parents: 359
diff changeset
   100
claus
parents: 359
diff changeset
   101
	|f|
claus
parents: 359
diff changeset
   102
claus
parents: 359
diff changeset
   103
	f := '..' asFilename.
claus
parents: 359
diff changeset
   104
	^ f pathName  
claus
parents: 359
diff changeset
   105
claus
parents: 359
diff changeset
   106
claus
parents: 359
diff changeset
   107
    get a directories directory:
claus
parents: 359
diff changeset
   108
claus
parents: 359
diff changeset
   109
	|f|
claus
parents: 359
diff changeset
   110
claus
parents: 359
diff changeset
   111
	f := Filename defaultDirectory.
claus
parents: 359
diff changeset
   112
	^ f directory 
claus
parents: 359
diff changeset
   113
claus
parents: 359
diff changeset
   114
claus
parents: 359
diff changeset
   115
    get a files directory:
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 := './smalltalk' asFilename.
claus
parents: 359
diff changeset
   120
	^ f directory 
claus
parents: 359
diff changeset
   121
claus
parents: 359
diff changeset
   122
claus
parents: 359
diff changeset
   123
    getting access & modification times:
claus
parents: 359
diff changeset
   124
claus
parents: 359
diff changeset
   125
claus
parents: 359
diff changeset
   126
	|f|
claus
parents: 359
diff changeset
   127
claus
parents: 359
diff changeset
   128
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
   129
	^ f dates
claus
parents: 359
diff changeset
   130
claus
parents: 359
diff changeset
   131
    access time only:
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 dates at:#accessed  
claus
parents: 359
diff changeset
   137
        
claus
parents: 359
diff changeset
   138
claus
parents: 359
diff changeset
   139
    getting all information on a file/directory:
claus
parents: 359
diff changeset
   140
claus
parents: 359
diff changeset
   141
claus
parents: 359
diff changeset
   142
	|f|
claus
parents: 359
diff changeset
   143
claus
parents: 359
diff changeset
   144
	f := '/tmp' asFilename.
claus
parents: 359
diff changeset
   145
	^ f info
claus
parents: 359
diff changeset
   146
claus
parents: 359
diff changeset
   147
claus
parents: 359
diff changeset
   148
    getting a temporary file (unique name):
claus
parents: 359
diff changeset
   149
claus
parents: 359
diff changeset
   150
	|f|
claus
parents: 359
diff changeset
   151
claus
parents: 359
diff changeset
   152
	f := Filename newTemporary.
claus
parents: 359
diff changeset
   153
	^ f    
claus
parents: 359
diff changeset
   154
claus
parents: 359
diff changeset
   155
claus
parents: 359
diff changeset
   156
    creating, writing, reading and removing a temporary file:
claus
parents: 359
diff changeset
   157
claus
parents: 359
diff changeset
   158
claus
parents: 359
diff changeset
   159
	|f writeStream readStream|
claus
parents: 359
diff changeset
   160
claus
parents: 359
diff changeset
   161
	f := Filename newTemporary.
claus
parents: 359
diff changeset
   162
	writeStream := f writeStream.
claus
parents: 359
diff changeset
   163
	writeStream nextPutAll:'hello world'.
claus
parents: 359
diff changeset
   164
	writeStream cr.
claus
parents: 359
diff changeset
   165
	writeStream close.
claus
parents: 359
diff changeset
   166
claus
parents: 359
diff changeset
   167
	'contents (as seen by unix''s cat command:' printNL.
claus
parents: 359
diff changeset
   168
	OperatingSystem executeCommand:('cat ' , f pathName).
claus
parents: 359
diff changeset
   169
claus
parents: 359
diff changeset
   170
	readStream := f readStream.
claus
parents: 359
diff changeset
   171
	Transcript showCr:'contents as seen by smalltalk:'.
claus
parents: 359
diff changeset
   172
	Transcript showCr:(readStream upToEnd).
claus
parents: 359
diff changeset
   173
	readStream close.
claus
parents: 359
diff changeset
   174
claus
parents: 359
diff changeset
   175
	f delete.
claus
parents: 359
diff changeset
   176
        
claus
parents: 359
diff changeset
   177
claus
parents: 359
diff changeset
   178
    getting a directories contents:
claus
parents: 359
diff changeset
   179
claus
parents: 359
diff changeset
   180
	|f files|
claus
parents: 359
diff changeset
   181
claus
parents: 359
diff changeset
   182
	f := '.' asFilename.
claus
parents: 359
diff changeset
   183
	files := f directoryContents.
claus
parents: 359
diff changeset
   184
	Transcript showCr:'the files are:'.
claus
parents: 359
diff changeset
   185
	Transcript showCr:(files printString).
claus
parents: 359
diff changeset
   186
claus
parents: 359
diff changeset
   187
claus
parents: 359
diff changeset
   188
    editing a file:
claus
parents: 359
diff changeset
   189
claus
parents: 359
diff changeset
   190
	|f|
claus
parents: 359
diff changeset
   191
claus
parents: 359
diff changeset
   192
	f := '/tmp/fooBar' asFilename.
claus
parents: 359
diff changeset
   193
	(f writeStream) nextPutAll:'hello world'; close.
claus
parents: 359
diff changeset
   194
claus
parents: 359
diff changeset
   195
	f edit
claus
parents: 359
diff changeset
   196
"
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   197
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
!Filename class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
named:aString
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   202
    "return a filename for a directory named aString."
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   203
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   204
    ^ (self basicNew) setName:aString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   205
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   206
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   207
     Filename named:'/tmp/fooBar'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   208
    "
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   209
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   210
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   211
currentDirectory
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   212
    "return a filename for the current directory"
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   213
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   214
    ^ self named:(FileDirectory currentDirectory pathName)
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   215
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   216
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   217
     Filename currentDirectory 
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   218
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   219
!
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   220
328
claus
parents: 326
diff changeset
   221
defaultDirectory
claus
parents: 326
diff changeset
   222
    "ST80 compatibility: same as currentDirectory"
claus
parents: 326
diff changeset
   223
claus
parents: 326
diff changeset
   224
    ^ self currentDirectory
claus
parents: 326
diff changeset
   225
claus
parents: 326
diff changeset
   226
    "
claus
parents: 326
diff changeset
   227
     Filename defaultDirectory 
claus
parents: 326
diff changeset
   228
    "
claus
parents: 326
diff changeset
   229
!
claus
parents: 326
diff changeset
   230
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   231
newTemporary
325
claus
parents: 308
diff changeset
   232
    "return a new unique filename - use this for temporary files.
claus
parents: 308
diff changeset
   233
     The filenames returned are '/tmp/stxtmp_xx_nn' where xx is our
claus
parents: 308
diff changeset
   234
     unix process id, and nn is a unique number, incremented with every
claus
parents: 308
diff changeset
   235
     call to this method."
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   236
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   237
    |pid nm|
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   238
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   239
    NextTempFilenameIndex isNil ifTrue:[
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   240
	NextTempFilenameIndex := 1.
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   241
    ].
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   242
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   243
     the following has to be made OS independent ...
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   244
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   245
    pid := OperatingSystem getProcessId printString.
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   246
    nm := '/tmp/stxtmp_' , pid , '_' , NextTempFilenameIndex printString.
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   247
    NextTempFilenameIndex := NextTempFilenameIndex + 1.
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   248
    ^ self named:nm
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   249
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   250
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   251
     Filename newTemporary
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   252
     Filename newTemporary
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   253
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   254
!
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   255
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   256
fromUser
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   257
    "show a box to enter a filename. Return a filename instance or
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   258
     nil (if cancel was pressed)."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   259
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   260
    |name|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   261
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   262
    name := FileSelectionBox requestFilename.
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   263
    name notNil ifTrue:[^ self named:name].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   264
    ^ nil
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   265
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   266
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   267
     Filename fromUser
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   268
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
2
claus
parents: 1
diff changeset
   271
!Filename class methodsFor:'queries'!
claus
parents: 1
diff changeset
   272
claus
parents: 1
diff changeset
   273
separator
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   274
    "return the file/directory separator.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   275
     Usually, this is $/ for unix-like systems 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   276
     and $\ for dos-like ones (there may be more in the future)."
2
claus
parents: 1
diff changeset
   277
claus
parents: 1
diff changeset
   278
     ^ OperatingSystem fileSeparator
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   279
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   280
     "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   281
      Filename separator  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   282
     "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   283
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   284
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   285
parentDirectoryName 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   286
    "return the name used for the parent directory.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   287
     This is '..' for unix and dos-like systems. 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   288
     (there may be more in the future."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   289
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   290
     ^ OperatingSystem parentDirectoryName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   291
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   292
     "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   293
      Filename parentDirectoryName  
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   294
     "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   295
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   296
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   297
isCaseSensitive
9e273c60e785 more functions
claus
parents: 159
diff changeset
   298
    "return true, if filenames are case sensitive.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   299
     We ask the OS about this, to be independent here."
9e273c60e785 more functions
claus
parents: 159
diff changeset
   300
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   301
    ^ OperatingSystem caseSensitiveFilenames
326
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   302
!
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   303
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   304
defaultClass
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   305
    "ST-80 compatibility:
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   306
     in ST-80, different subclasses of FIlename are used for different
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   307
     OperatingSYstems; defaultClass is supposed to return an appropriate class.
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   308
     Since in ST/X, there is (currently) only one Filename class, return it here."
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   309
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   310
    ^ self
328
claus
parents: 326
diff changeset
   311
!
claus
parents: 326
diff changeset
   312
claus
parents: 326
diff changeset
   313
localNameStringFrom:aString
claus
parents: 326
diff changeset
   314
    "ST-80 compatibility.
claus
parents: 326
diff changeset
   315
     what does this do ? (used in FileNavigator-goody)"
claus
parents: 326
diff changeset
   316
claus
parents: 326
diff changeset
   317
    (aString startsWith:'/') ifTrue:[
claus
parents: 326
diff changeset
   318
	^ aString copyFrom:2
claus
parents: 326
diff changeset
   319
    ].
claus
parents: 326
diff changeset
   320
    ^ aString
claus
parents: 326
diff changeset
   321
!
claus
parents: 326
diff changeset
   322
claus
parents: 326
diff changeset
   323
volumes
claus
parents: 326
diff changeset
   324
    "ST-80 compatibility.
claus
parents: 326
diff changeset
   325
     what does this do ? (used in FileNavigator-goody)"
claus
parents: 326
diff changeset
   326
356
claus
parents: 328
diff changeset
   327
    ^ #('/')
2
claus
parents: 1
diff changeset
   328
! !
claus
parents: 1
diff changeset
   329
claus
parents: 1
diff changeset
   330
!Filename methodsFor:'instance creation'!
claus
parents: 1
diff changeset
   331
249
claus
parents: 216
diff changeset
   332
constructString:subname
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   333
    "taking the receiver as a directory name, construct a new
249
claus
parents: 216
diff changeset
   334
     filenames string for an entry within this directory (i.e. for a file
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   335
     or a subdirectory in that directory)."
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   336
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   337
    |sepString|
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   338
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   339
    sepString := self class separator asString.
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   340
    nameString = sepString ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   341
	"I am the root"
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   342
	^ sepString  , subname
85
claus
parents: 77
diff changeset
   343
    ].
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   344
    ^ nameString , sepString , subname
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   345
85
claus
parents: 77
diff changeset
   346
    "
249
claus
parents: 216
diff changeset
   347
     '/tmp' asFilename constructString:'foo'   
claus
parents: 216
diff changeset
   348
     '/' asFilename constructString:'foo'         
claus
parents: 216
diff changeset
   349
     '/usr/tmp' asFilename constructString:'foo'
328
claus
parents: 326
diff changeset
   350
     '/foo/bar' asFilename constructString:'baz' 
249
claus
parents: 216
diff changeset
   351
    "
claus
parents: 216
diff changeset
   352
!
claus
parents: 216
diff changeset
   353
claus
parents: 216
diff changeset
   354
construct:subname
claus
parents: 216
diff changeset
   355
    "taking the receiver as a directory name, construct a new
claus
parents: 216
diff changeset
   356
     filename for an entry within this directory (i.e. for a file
claus
parents: 216
diff changeset
   357
     or a subdirectory in that directory)."
claus
parents: 216
diff changeset
   358
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   359
    ^ (self constructString:subname) asFilename
249
claus
parents: 216
diff changeset
   360
claus
parents: 216
diff changeset
   361
    "
claus
parents: 216
diff changeset
   362
     '/tmp' asFilename construct:'foo'    
claus
parents: 216
diff changeset
   363
     '/' asFilename construct:'foo'         
claus
parents: 216
diff changeset
   364
     '/usr/tmp' asFilename construct:'foo'
328
claus
parents: 326
diff changeset
   365
     '/foo/bar' asFilename construct:'baz' 
85
claus
parents: 77
diff changeset
   366
    "
2
claus
parents: 1
diff changeset
   367
! !
claus
parents: 1
diff changeset
   368
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   369
!Filename methodsFor:'misc'!
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   370
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   371
, aString
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   372
    "this allows filenames to understand how names are concatenated.
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   373
     Returns a string consisting of the receivers name, concatenated
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   374
     by aString. Notice this is NOT the same as construct:, which inserts
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   375
     a directory delimiter and returns a new fileName instance."
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   376
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   377
    ^ (nameString , aString asString)
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   378
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   379
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   380
     'Makefile' asFilename , '.bak' 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   381
     'Makefile' asFilename construct:'.bak' 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   382
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   383
! !
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   384
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   385
!Filename methodsFor:'comparing'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   386
9e273c60e785 more functions
claus
parents: 159
diff changeset
   387
hash
9e273c60e785 more functions
claus
parents: 159
diff changeset
   388
    "return an integer useful as a hash-key"
9e273c60e785 more functions
claus
parents: 159
diff changeset
   389
9e273c60e785 more functions
claus
parents: 159
diff changeset
   390
    ^ nameString hash
9e273c60e785 more functions
claus
parents: 159
diff changeset
   391
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   392
9e273c60e785 more functions
claus
parents: 159
diff changeset
   393
= aFilename
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   394
    "return true, if the argument represents the same filename"
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   395
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   396
    |str|
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   397
9e273c60e785 more functions
claus
parents: 159
diff changeset
   398
    self species == aFilename species ifTrue:[
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   399
	str := aFilename asString.
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   400
	self class isCaseSensitive ifTrue:[
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   401
	    ^ nameString = str
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   402
	].
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   403
	^ nameString sameAs:str
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   404
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
   405
    ^ false
9e273c60e785 more functions
claus
parents: 159
diff changeset
   406
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
   407
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
!Filename methodsFor:'converting'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
asString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   411
    "return the receiver converted to a string"
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   412
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   413
    ^ nameString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
asFilename
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   417
    "return the receiver converted to a filename."
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   418
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   419
    "Thats pretty easy here :-)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
    ^ self
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   421
!
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   422
328
claus
parents: 326
diff changeset
   423
asAbsoluteFilename
claus
parents: 326
diff changeset
   424
    "return the receiver converted to a filename with
claus
parents: 326
diff changeset
   425
     an absolute pathname."
claus
parents: 326
diff changeset
   426
claus
parents: 326
diff changeset
   427
    ^ self pathName asFilename
claus
parents: 326
diff changeset
   428
!
claus
parents: 326
diff changeset
   429
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   430
makeLegalFilename 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   431
    "convert the receveivers name to be a legal filename.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   432
     The implementation may change in the future to be more
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   433
     OS specific."
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   434
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   435
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   436
     actually, in Unix spaces are allowed - but it makes life
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   437
     so hard; therefore, replace them by underscores ...
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   438
    "
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   439
    nameString replaceAll:(Character space) by:$_.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   440
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   441
     need more - especially on SYS5.3 type systems, 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   442
     we may want to contract the fileName to 14 characters.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   443
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   444
    ^ self
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   445
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   446
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   447
     'hello world' asFilename makeLegalFilename 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   448
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   451
!Filename methodsFor:'private accessing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   453
setName:aString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   454
    "set the filename"
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   455
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   456
    nameString := aString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
2
claus
parents: 1
diff changeset
   459
!Filename methodsFor:'queries'!
claus
parents: 1
diff changeset
   460
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   461
separator
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   462
    "return the directory-separator character (or string)"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   463
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   464
    ^ self class separator
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   465
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   466
328
claus
parents: 326
diff changeset
   467
directoryName
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   468
    "return the directory name part of the file/directory.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   469
     - thats the name of the directory where the file/dir represented by
328
claus
parents: 326
diff changeset
   470
       the receiver is contained in."
claus
parents: 326
diff changeset
   471
claus
parents: 326
diff changeset
   472
    ^ OperatingSystem directoryNameOf:nameString "/ (self pathName)
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   473
328
claus
parents: 326
diff changeset
   474
    "
claus
parents: 326
diff changeset
   475
     '/foo/bar/' asFilename directoryName    
claus
parents: 326
diff changeset
   476
     '/foo/bar' asFilename directoryName    
claus
parents: 326
diff changeset
   477
     '.' asFilename directoryName        
claus
parents: 326
diff changeset
   478
     '..' asFilename directoryName       
claus
parents: 326
diff changeset
   479
     '../..' asFilename directoryName     
claus
parents: 326
diff changeset
   480
    "
claus
parents: 326
diff changeset
   481
!
claus
parents: 326
diff changeset
   482
claus
parents: 326
diff changeset
   483
directory
claus
parents: 326
diff changeset
   484
    "return the directory name part of the file/directory.
claus
parents: 326
diff changeset
   485
     - thats a filename for the directory where the file/dir represented by
claus
parents: 326
diff changeset
   486
       the receiver is contained in."
claus
parents: 326
diff changeset
   487
claus
parents: 326
diff changeset
   488
    ^ self directoryName asFilename
2
claus
parents: 1
diff changeset
   489
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   490
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   491
     '/foo/bar' asFilename directory
9e273c60e785 more functions
claus
parents: 159
diff changeset
   492
     '.' asFilename directory        
9e273c60e785 more functions
claus
parents: 159
diff changeset
   493
     '..' asFilename directory       
9e273c60e785 more functions
claus
parents: 159
diff changeset
   494
     '../..' asFilename directory     
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   495
    "
2
claus
parents: 1
diff changeset
   496
!
claus
parents: 1
diff changeset
   497
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   498
directoryContents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   499
    "return the contents of the directory as a collection of strings"
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   500
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   501
    ^ (FileDirectory directoryNamed:self asString) contents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   502
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   503
    "
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   504
     '.' asFilename directoryContents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   505
    "
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   506
!
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   507
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   508
tail
9e273c60e785 more functions
claus
parents: 159
diff changeset
   509
    "the files name without directory prefix. For ST-80 compatiblity."
9e273c60e785 more functions
claus
parents: 159
diff changeset
   510
9e273c60e785 more functions
claus
parents: 159
diff changeset
   511
    ^ self baseName
9e273c60e785 more functions
claus
parents: 159
diff changeset
   512
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   513
2
claus
parents: 1
diff changeset
   514
baseName
claus
parents: 1
diff changeset
   515
    "return my baseName
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   516
     - thats the file/directory name without leading parent-dirs."
2
claus
parents: 1
diff changeset
   517
328
claus
parents: 326
diff changeset
   518
    ^ OperatingSystem baseNameOf:nameString "/ (self pathName) 
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   519
85
claus
parents: 77
diff changeset
   520
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   521
     '/foo/bar' asFilename baseName  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   522
     '.' asFilename baseName          
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   523
     '..' asFilename baseName         
328
claus
parents: 326
diff changeset
   524
     '../..' asFilename baseName        
claus
parents: 326
diff changeset
   525
     '../../libbasic' asFilename baseName        
claus
parents: 326
diff changeset
   526
     '../../libpr' asFilename baseName        
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   527
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   528
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   529
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   530
pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   531
    "return the full pathname of the file represented by the receiver."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   532
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   533
    |parentName sep|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   534
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   535
    sep := self class separator.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   536
    (nameString startsWith:sep) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   537
	parentName := self class parentDirectoryName.
357
claus
parents: 356
diff changeset
   538
	(nameString findString:parentName) == 0 ifTrue:[
claus
parents: 356
diff changeset
   539
	    ^ nameString
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   540
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   541
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   542
    ^ (FileDirectory directoryNamed:nameString) pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   543
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   544
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   545
     '/foo/bar' asFilename pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   546
     '.' asFilename pathName 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   547
     '../..' asFilename pathName 
357
claus
parents: 356
diff changeset
   548
     '/tmp/../usr' asFilename pathName  
85
claus
parents: 77
diff changeset
   549
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   550
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   551
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   552
isAbsolute
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   553
    "return true, if the receiver represents an absolute pathname
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   554
     (in contrast to one relative to the current directory)."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   555
85
claus
parents: 77
diff changeset
   556
    ^ (nameString startsWith:self class separator)
claus
parents: 77
diff changeset
   557
claus
parents: 77
diff changeset
   558
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   559
     '/foo/bar' asFilename isAbsolute   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   560
     '..' asFilename isAbsolute         
328
claus
parents: 326
diff changeset
   561
     '..' asAbsoluteFilename isAbsolute         
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   562
     'source/SBrowser.st' asFilename isAbsolute  
85
claus
parents: 77
diff changeset
   563
    "
claus
parents: 77
diff changeset
   564
!
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   565
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   566
isRelative
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   567
    "return true, if this name is interpreted relative to some
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   568
     directory (opposite of absolute)"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   569
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   570
    ^ self isAbsolute not
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   571
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   572
85
claus
parents: 77
diff changeset
   573
isDirectory
claus
parents: 77
diff changeset
   574
    "return true, if the receiver represents an existing,
claus
parents: 77
diff changeset
   575
     readable directories pathname."
claus
parents: 77
diff changeset
   576
claus
parents: 77
diff changeset
   577
    ^ OperatingSystem isDirectory:nameString
claus
parents: 77
diff changeset
   578
claus
parents: 77
diff changeset
   579
    "
claus
parents: 77
diff changeset
   580
     '/foo/bar' asFilename isDirectory
claus
parents: 77
diff changeset
   581
     '/tmp' asFilename isDirectory
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   582
     'Makefile' asFilename isDirectory   
85
claus
parents: 77
diff changeset
   583
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   584
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   585
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   586
exists
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   587
    "return true, if such a file exists."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   588
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   589
    ^ OperatingSystem isValidPath:nameString
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   590
85
claus
parents: 77
diff changeset
   591
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   592
     '/foo/bar' asFilename exists 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   593
     '/tmp' asFilename exists  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   594
     'Makefile' asFilename exists   
85
claus
parents: 77
diff changeset
   595
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   596
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   597
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   598
isReadable
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   599
    "return true, if such a file exists and is readable."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   600
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   601
    ^ OperatingSystem isReadable:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   602
85
claus
parents: 77
diff changeset
   603
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   604
     '/foo/bar' asFilename isReadable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   605
     '/tmp' asFilename isReadable      
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   606
     'Makefile' asFilename isReadable   
85
claus
parents: 77
diff changeset
   607
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   608
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   609
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   610
canBeWritten
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   611
    "same as isWritable - for ST-80 compatibility"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   612
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   613
    ^ self isWritable
328
claus
parents: 326
diff changeset
   614
claus
parents: 326
diff changeset
   615
    "
claus
parents: 326
diff changeset
   616
     '/foo/bar' asFilename canBeWritten 
claus
parents: 326
diff changeset
   617
     '/tmp' asFilename canBeWritten   
claus
parents: 326
diff changeset
   618
     'Makefile' asFilename canBeWritten   
claus
parents: 326
diff changeset
   619
    "
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   620
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   621
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   622
isWritable
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   623
    "return true, if such a file exists and is writable."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   624
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   625
    ^ OperatingSystem isWritable:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   626
85
claus
parents: 77
diff changeset
   627
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   628
     '/foo/bar' asFilename isWritable 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   629
     '/tmp' asFilename isWritable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   630
     'Makefile' asFilename isWritable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   631
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   632
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   633
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   634
isExecutable
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   635
    "return true, if such a file exists and is executable (by Unix's definition).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   636
     For directories, true is returned if the directory can be entered.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   637
     See isExecutableProgram for a related check."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   638
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   639
    ^ OperatingSystem isExecutable:nameString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   640
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   641
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   642
     '/foo/bar' asFilename isExecutable 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   643
     '/tmp' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   644
     'Makefile' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   645
     '/bin/ls' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   646
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   647
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   648
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   649
isExecutableProgram
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   650
    "return true, if such a file exists and is an executable program.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   651
     (i.e. for directories, false is returned.)"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   652
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   653
    ^ (OperatingSystem isExecutable:nameString)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   654
      and:[(OperatingSystem isDirectory:nameString) not]
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   655
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   656
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   657
     '/tmp' asFilename isExecutable         
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   658
     '/bin/ls' asFilename isExecutable       
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   659
     '/tmp' asFilename isExecutableProgram   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   660
     '/bin/ls' asFilename isExecutableProgram    
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   661
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   662
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   663
356
claus
parents: 328
diff changeset
   664
isSymbolicLink
claus
parents: 328
diff changeset
   665
    "return true, if the file represented by the receiver is a symbolic
claus
parents: 328
diff changeset
   666
     link. Notice that not all OS's support symbolic links; those that do
claus
parents: 328
diff changeset
   667
     not will always return false."
claus
parents: 328
diff changeset
   668
claus
parents: 328
diff changeset
   669
    ^ OperatingSystem isSymbolicLink:nameString
claus
parents: 328
diff changeset
   670
claus
parents: 328
diff changeset
   671
    "
claus
parents: 328
diff changeset
   672
     'Make.proto' asFilename isSymbolicLink  
claus
parents: 328
diff changeset
   673
     'Makefile' asFilename isSymbolicLink   
claus
parents: 328
diff changeset
   674
    "
claus
parents: 328
diff changeset
   675
!
claus
parents: 328
diff changeset
   676
328
claus
parents: 326
diff changeset
   677
filesMatching:aPattern
claus
parents: 326
diff changeset
   678
    ^ self directoryContents select:[:name | aPattern match:name]
claus
parents: 326
diff changeset
   679
claus
parents: 326
diff changeset
   680
    "
claus
parents: 326
diff changeset
   681
     Filename currentDirectory filesMatching:'M*' 
claus
parents: 326
diff changeset
   682
    "
claus
parents: 326
diff changeset
   683
!
claus
parents: 326
diff changeset
   684
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   685
filenameCompletion
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   686
    "try to complete the filename. This method has both a side effect,
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   687
     and a return value:
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   688
	 it returns a collection of matching filename strings,
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   689
	 and sets (as side effect) the receivers filename to the longest common
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   690
	 match. 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   691
     (i.e. if the size of the returned collection is exactly 1,
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   692
      the completion has succeeded and the receivers name has been changed to
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   693
      that. 
328
claus
parents: 326
diff changeset
   694
      If the returned collection is empty, nothing matched and the receivers
claus
parents: 326
diff changeset
   695
      names is unchanged.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   696
      If the size of the returned collection is greater than one, the receivers
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   697
      filename-string has been set to the longest common filename-prefix)"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   698
328
claus
parents: 326
diff changeset
   699
    |dir name matching matchLen try allMatching sep parent prefix|
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   700
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   701
    sep := self class separator asString.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   702
    parent := self class parentDirectoryName.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   703
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   704
    dir := self directory.
328
claus
parents: 326
diff changeset
   705
    prefix := parent , sep.
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   706
    (nameString endsWith:sep) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   707
	name := ''
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   708
    ] ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   709
	name := self baseName.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   710
    ].
328
claus
parents: 326
diff changeset
   711
    [name startsWith:prefix] whileTrue:[
claus
parents: 326
diff changeset
   712
	self halt.
claus
parents: 326
diff changeset
   713
	dir := dir directory.
claus
parents: 326
diff changeset
   714
	name := name copyFrom:(prefix size + 1)
claus
parents: 326
diff changeset
   715
    ].
claus
parents: 326
diff changeset
   716
claus
parents: 326
diff changeset
   717
    dir := dir asString.
claus
parents: 326
diff changeset
   718
    name = parent ifTrue:[
claus
parents: 326
diff changeset
   719
	^ dir asFilename filenameCompletion
claus
parents: 326
diff changeset
   720
    ].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   721
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   722
    matching := OrderedCollection new.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   723
    (FileDirectory directoryNamed:dir) do:[:fileName |
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   724
	((fileName ~= '.') and:[fileName ~= parent]) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   725
	    (fileName startsWith:name) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   726
		matching add:fileName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   727
	    ]
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   728
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   729
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   730
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   731
     if there is only one, change my name ...
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   732
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   733
    matching size == 1 ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   734
	dir = sep ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   735
	   dir := ''
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   736
	].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   737
	nameString := dir , sep , matching first.
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   738
	matching first = name ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   739
	    self isDirectory ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   740
		nameString := nameString , self class separator asString
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   741
	    ]
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   742
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   743
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   744
	matching size > 1 ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   745
	    "
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   746
	     find the longest common prefix
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   747
	    "
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   748
	    matchLen := name size.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   749
	    matchLen > matching first size ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   750
		try := name.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   751
		allMatching := false
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   752
	    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   753
		try := matching first copyTo:matchLen.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   754
		allMatching := true.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   755
	    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   756
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   757
	    [allMatching] whileTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   758
		matching do:[:aName |
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   759
		    (aName startsWith:try) ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   760
			allMatching := false
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   761
		    ]
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   762
		].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   763
		allMatching ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   764
		    matchLen <  matching first size ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   765
			matchLen := matchLen + 1.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   766
			try := matching first copyTo:matchLen.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   767
		    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   768
			allMatching := false
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   769
		    ]
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   770
		] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   771
		    try := matching first copyTo:matchLen - 1.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   772
		]
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   773
	    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   774
	    "
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   775
	     and set my name to the last full match
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   776
	    "
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   777
	    dir = sep ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   778
	       dir := ''
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   779
	    ].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   780
	    nameString := dir , sep , try
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   781
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   782
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   783
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   784
     return the match-set, so caller can decide what to do
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   785
     (i.e. show the matches, output a warning etc ...)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   786
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   787
    ^ matching
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   788
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   789
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   790
     'Make' asFilename filenameCompletion;yourself 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   791
     'Makef' asFilename filenameCompletion;yourself 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   792
     '/u' asFilename filenameCompletion 
328
claus
parents: 326
diff changeset
   793
     '../../libpr' asFilename filenameCompletion 
85
claus
parents: 77
diff changeset
   794
    "
2
claus
parents: 1
diff changeset
   795
! !
claus
parents: 1
diff changeset
   796
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   797
!Filename methodsFor:'file queries'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   798
9e273c60e785 more functions
claus
parents: 159
diff changeset
   799
info
9e273c60e785 more functions
claus
parents: 159
diff changeset
   800
    "return the files info; that is a collection of file attributes,
9e273c60e785 more functions
claus
parents: 159
diff changeset
   801
     (actually a dictionary) where the keys are #type, #uid, #gid, #size etc.
356
claus
parents: 328
diff changeset
   802
     The actual amount and detail returned may depend on the OS used.
claus
parents: 328
diff changeset
   803
     On unix, if you ask for the info of a symbolic link, the target
359
claus
parents: 357
diff changeset
   804
     files info is returned. (see also: #linkInfo)
356
claus
parents: 328
diff changeset
   805
claus
parents: 328
diff changeset
   806
     On unix, the contents is:
claus
parents: 328
diff changeset
   807
	id            -> the inode number (integer)
claus
parents: 328
diff changeset
   808
	uid           -> the numeric user id of the files owner
claus
parents: 328
diff changeset
   809
	gid           -> the numeric group id of the files owner
claus
parents: 328
diff changeset
   810
	statusChanged -> the absoluteTime when the files status changed last
claus
parents: 328
diff changeset
   811
			 (i.e. protection change, owner change etc.)
claus
parents: 328
diff changeset
   812
	accessed      -> the absoluteTime when the file was last accessed
claus
parents: 328
diff changeset
   813
	modified      -> the absoluteTime when the file was last modified
claus
parents: 328
diff changeset
   814
	size          -> the size (in bytes) of the file
claus
parents: 328
diff changeset
   815
	type          -> the files type (#regular, #directory, #characterSpecial)
claus
parents: 328
diff changeset
   816
	mode          -> the files access protection bits (rwxrwxrwx mask).
claus
parents: 328
diff changeset
   817
claus
parents: 328
diff changeset
   818
     The minimum returned info (i.e. on all OS's) will consist of at least:
claus
parents: 328
diff changeset
   819
	modified
claus
parents: 328
diff changeset
   820
	size
claus
parents: 328
diff changeset
   821
	type
claus
parents: 328
diff changeset
   822
claus
parents: 328
diff changeset
   823
     Some OS's (VMS) may return more info.
claus
parents: 328
diff changeset
   824
claus
parents: 328
diff changeset
   825
     Dont expect things like uid/gid/mode to be there; write your application
claus
parents: 328
diff changeset
   826
     to either handle the cases where info-entries are not present,
359
claus
parents: 357
diff changeset
   827
     or (better) use one of isXXXX query methods. (Be prepared for DOS ...)
356
claus
parents: 328
diff changeset
   828
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   829
9e273c60e785 more functions
claus
parents: 159
diff changeset
   830
    ^ OperatingSystem infoOf:nameString
328
claus
parents: 326
diff changeset
   831
claus
parents: 326
diff changeset
   832
    "
claus
parents: 326
diff changeset
   833
     Filename currentDirectory info
356
claus
parents: 328
diff changeset
   834
     '/dev/null' asFilename info 
328
claus
parents: 326
diff changeset
   835
     'Make.proto' asFilename info
356
claus
parents: 328
diff changeset
   836
     'source/Point.st' asFilename info 
359
claus
parents: 357
diff changeset
   837
     'source/Point.st' asFilename linkInfo 
356
claus
parents: 328
diff changeset
   838
     '../../libbasic/Point.st' asFilename info 
claus
parents: 328
diff changeset
   839
    "
claus
parents: 328
diff changeset
   840
!
claus
parents: 328
diff changeset
   841
claus
parents: 328
diff changeset
   842
linkInfo
claus
parents: 328
diff changeset
   843
    "return the files info if its a symbolic link; nil otherwise.
claus
parents: 328
diff changeset
   844
     On OS's which do not support symbolic links, nil is always returned.
359
claus
parents: 357
diff changeset
   845
     The information is the same as returned by #info, except that if the
claus
parents: 357
diff changeset
   846
     receiver represents a symbolic link, the links information 
claus
parents: 357
diff changeset
   847
     is returned 
claus
parents: 357
diff changeset
   848
     (while in this case, #info returns the info of the target file, 
claus
parents: 357
diff changeset
   849
      which is accessed via the symbolic link).
356
claus
parents: 328
diff changeset
   850
claus
parents: 328
diff changeset
   851
     In addition to the normal entries, Unix returns an additional entry:
claus
parents: 328
diff changeset
   852
	 path -> the target files pathname
claus
parents: 328
diff changeset
   853
claus
parents: 328
diff changeset
   854
     See the comment in #info for more details."
claus
parents: 328
diff changeset
   855
claus
parents: 328
diff changeset
   856
    ^ OperatingSystem linkInfoOf:nameString
claus
parents: 328
diff changeset
   857
claus
parents: 328
diff changeset
   858
    "
claus
parents: 328
diff changeset
   859
     Filename currentDirectory linkInfo 
claus
parents: 328
diff changeset
   860
     '/dev/null' asFilename linkInfo    
claus
parents: 328
diff changeset
   861
     'Make.proto' asFilename linkInfo   
claus
parents: 328
diff changeset
   862
     'Make.proto' asFilename linkInfo at:#path  
claus
parents: 328
diff changeset
   863
     'source/Point.st' asFilename linkInfo 
claus
parents: 328
diff changeset
   864
     '../../libbasic/Point.st' asFilename linkInfo 
328
claus
parents: 326
diff changeset
   865
    "
claus
parents: 326
diff changeset
   866
!
claus
parents: 326
diff changeset
   867
claus
parents: 326
diff changeset
   868
dates
claus
parents: 326
diff changeset
   869
    "return the files modification and access times as an object (currently a dictionary)
356
claus
parents: 328
diff changeset
   870
     that responds to the at: message with arguments 
claus
parents: 328
diff changeset
   871
     #modified, #accessed or #statusChanged."
328
claus
parents: 326
diff changeset
   872
claus
parents: 326
diff changeset
   873
    |info dates|
claus
parents: 326
diff changeset
   874
claus
parents: 326
diff changeset
   875
    info := OperatingSystem infoOf:nameString.
claus
parents: 326
diff changeset
   876
    info isNil ifTrue:[
claus
parents: 326
diff changeset
   877
	info := OperatingSystem linkInfoOf:nameString.
claus
parents: 326
diff changeset
   878
	info isNil ifTrue:[
claus
parents: 326
diff changeset
   879
	    ^ nil
claus
parents: 326
diff changeset
   880
	]
claus
parents: 326
diff changeset
   881
    ].
claus
parents: 326
diff changeset
   882
    dates := IdentityDictionary new.
claus
parents: 326
diff changeset
   883
    dates at:#modified put:(info at:#modified).
claus
parents: 326
diff changeset
   884
    dates at:#accessed put:(info at:#accessed).
claus
parents: 326
diff changeset
   885
    dates at:#statusChanged put:(info at:#statusChanged).
claus
parents: 326
diff changeset
   886
    ^ dates
claus
parents: 326
diff changeset
   887
claus
parents: 326
diff changeset
   888
    "
claus
parents: 326
diff changeset
   889
     Filename currentDirectory dates
claus
parents: 326
diff changeset
   890
     '../regression' asFilename dates
claus
parents: 326
diff changeset
   891
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   892
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   893
9e273c60e785 more functions
claus
parents: 159
diff changeset
   894
fileSize
9e273c60e785 more functions
claus
parents: 159
diff changeset
   895
    "return the size of the file in bytes"
9e273c60e785 more functions
claus
parents: 159
diff changeset
   896
9e273c60e785 more functions
claus
parents: 159
diff changeset
   897
    |info|
9e273c60e785 more functions
claus
parents: 159
diff changeset
   898
9e273c60e785 more functions
claus
parents: 159
diff changeset
   899
    info := self info.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   900
    info isNil ifTrue:[^ nil].
9e273c60e785 more functions
claus
parents: 159
diff changeset
   901
    ^ info at:#size
9e273c60e785 more functions
claus
parents: 159
diff changeset
   902
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   903
9e273c60e785 more functions
claus
parents: 159
diff changeset
   904
fileType
9e273c60e785 more functions
claus
parents: 159
diff changeset
   905
    "this returns a string describing the type of contents of
9e273c60e785 more functions
claus
parents: 159
diff changeset
   906
     the file. This is done using the unix 'file' command,
9e273c60e785 more functions
claus
parents: 159
diff changeset
   907
     (which usually is configurable by /etc/magic).
9e273c60e785 more functions
claus
parents: 159
diff changeset
   908
     On non-unix systems, this may return an empty string, not knowning
9e273c60e785 more functions
claus
parents: 159
diff changeset
   909
     about the contents."
9e273c60e785 more functions
claus
parents: 159
diff changeset
   910
9e273c60e785 more functions
claus
parents: 159
diff changeset
   911
    |stream typeString|
9e273c60e785 more functions
claus
parents: 159
diff changeset
   912
9e273c60e785 more functions
claus
parents: 159
diff changeset
   913
    typeString := ''.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   914
    stream := PipeStream readingFrom:('file ' , self pathName).
9e273c60e785 more functions
claus
parents: 159
diff changeset
   915
    stream notNil ifTrue:[
9e273c60e785 more functions
claus
parents: 159
diff changeset
   916
	typeString := stream contents asString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   917
	stream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   918
	typeString := typeString copyFrom:(typeString indexOf:$:) + 1.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   919
	typeString := typeString withoutSeparators
9e273c60e785 more functions
claus
parents: 159
diff changeset
   920
    ] ifFalse:[
9e273c60e785 more functions
claus
parents: 159
diff changeset
   921
	"
9e273c60e785 more functions
claus
parents: 159
diff changeset
   922
	 could add some fallback code here, for systems, where no
9e273c60e785 more functions
claus
parents: 159
diff changeset
   923
	 file command is avaliable ...
9e273c60e785 more functions
claus
parents: 159
diff changeset
   924
	 ... or at least analyze directory info.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   925
	"
9e273c60e785 more functions
claus
parents: 159
diff changeset
   926
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
   927
    ^ typeString
9e273c60e785 more functions
claus
parents: 159
diff changeset
   928
9e273c60e785 more functions
claus
parents: 159
diff changeset
   929
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
   930
     'Makefile' asFilename fileType 
325
claus
parents: 308
diff changeset
   931
     '.' asFilename fileType     
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   932
     '/dev/null' asFilename fileType        
9e273c60e785 more functions
claus
parents: 159
diff changeset
   933
     'smalltalk.rc' asFilename fileType    
325
claus
parents: 308
diff changeset
   934
     'bitmaps/SBrowser.xbm' asFilename fileType    
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   935
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
   936
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
   937
9e273c60e785 more functions
claus
parents: 159
diff changeset
   938
!Filename methodsFor:'file operations'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   939
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   940
delete
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   941
    "remove the file - same as remove, for ST-80 compatibility"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   942
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   943
    ^ self remove
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   944
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   945
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   946
remove
192
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
   947
    "remove the file - the argument must be convertable to a String.
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
   948
     Return true if sucessfull, false if not."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   949
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   950
    ^ OperatingSystem removeFile:nameString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   951
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   952
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   953
     (FileStream newFileNamed:'foo') close.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   954
     'foo' asFilename remove
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   955
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   956
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   957
2
claus
parents: 1
diff changeset
   958
renameTo:newName
192
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
   959
    "rename the file - the argument must be convertable to a String.
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
   960
     Return true if sucessfull, false if not."
2
claus
parents: 1
diff changeset
   961
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   962
    ^ OperatingSystem renameFile:nameString to:(newName asString)
2
claus
parents: 1
diff changeset
   963
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   964
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   965
     '/tmp/foo' asFilename renameTo:'/tmp/bar'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   966
    "
2
claus
parents: 1
diff changeset
   967
!
claus
parents: 1
diff changeset
   968
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   969
copyTo:newName
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   970
    "copy the file - the argument must be convertable to a filename"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   971
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   972
    |inStream outStream buffer bufferSize count|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   973
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   974
    bufferSize := 8 * 1024.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   975
    buffer := ByteArray new:bufferSize.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   976
    inStream := self readStream.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   977
    outStream := newName asFilename writeStream.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   978
    (inStream isNil or:[outStream isNil]) ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   979
	^ self error:'file copy failed'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   980
    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   981
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   982
    [inStream atEnd] whileFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   983
	count := inStream nextBytes:bufferSize into:buffer.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   984
	outStream nextPutBytes:count from:buffer.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   985
    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   986
    outStream close.
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   987
    inStream close.
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   988
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   989
    "
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   990
     'Makefile' asFilename copyTo:'Makefile.foo'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   991
     'smalltalk' asFilename copyTo:'/dev/null'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   992
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   993
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   994
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   995
moveTo:newName
9e273c60e785 more functions
claus
parents: 159
diff changeset
   996
    "copy the file represented by the receiver, then delete it.
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   997
     This is different to renaming in case of cross device moves."
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   998
9e273c60e785 more functions
claus
parents: 159
diff changeset
   999
    self copyTo:newName.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1000
    self remove
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1001
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1002
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1003
makeDirectory
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1004
    "create a directory with the receivers name"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1005
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1006
    OperatingSystem createDirectory:nameString
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1007
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1008
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1009
addAccessRights:aCollection
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1010
    "add the access rights as specified in aCollection for the file represented
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1011
     by the receiver. The argument must be a collection of symbols,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1012
     such as #readUser, #writeGroup etc."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1013
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1014
    |access|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1015
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1016
    access := OperatingSystem accessModeOf:nameString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1017
    aCollection do:[:accessSymbol |
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1018
	access := access bitOr:(OperatingSystem accessMaskFor:accessSymbol).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1019
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1020
    OperatingSystem changeAccessModeOf:nameString to:access
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1021
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1022
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1023
     'foo' asFilename writeStream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1024
     'foo' asFilename addAccessRights:#(readUser readGroup readOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1025
     'foo' asFilename addAccessRights:#(writeUser writeGroup writeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1026
     'foo' asFilename addAccessRights:#(executeUser executeGroup executeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1027
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1028
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1029
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1030
removeAccessRights:aCollection
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1031
    "remove the access rights as specified in aCollection for the file represented
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1032
     by the receiver. The argument must be a collection of symbols,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1033
     such as #readUser, #writeGroup etc."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1034
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1035
    |access|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1036
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1037
    access := OperatingSystem accessModeOf:nameString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1038
    aCollection do:[:accessSymbol |
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1039
	access := access bitAnd:(OperatingSystem accessMaskFor:accessSymbol) bitInvert.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1040
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1041
    OperatingSystem changeAccessModeOf:nameString to:access
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1042
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1043
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1044
     'foo' asFilename writeStream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1045
     'foo' asFilename removeAccessRights:#(readUser readGroup readOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1046
     'foo' asFilename removeAccessRights:#(writeUser writeGroup writeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1047
     'foo' asFilename removeAccessRights:#(executeUser executeGroup executeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1048
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1049
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1050
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1051
makeReadableForAll
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1052
    "make the file readable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1053
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1054
    self addAccessRights:#(readUser readGroup readOthers)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1055
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1056
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1057
makeReadable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1058
    "make the file readable for  the owner - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1059
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1060
    self addAccessRights:#(readUser)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1061
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1062
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1063
makeWritable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1064
    "make the file writableable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1065
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1066
    self addAccessRights:#(writeUser)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1067
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1068
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1069
makeWritableForAll
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1070
    "make the file writable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1071
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1072
    self addAccessRights:#(writeUser writeGroup writeOthers)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1073
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1074
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1075
makeUnwritable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1076
    "make the file unwritable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1077
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1078
    self removeAccessRights:#(writeUser writeGroup writeOthers)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1079
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1080
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1081
!Filename methodsFor:'file utilities'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1082
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1083
fileIn
2
claus
parents: 1
diff changeset
  1084
    "load smalltalk code from the file"
claus
parents: 1
diff changeset
  1085
claus
parents: 1
diff changeset
  1086
    ^ self readStream fileIn
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1087
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1088
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1089
edit
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1090
    "start an editView on the file represented by the receiver"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1091
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1092
    EditTextView openOn:self asString
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1093
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1094
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1095
     'smalltalk.rc' asFilename edit
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1096
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1097
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1098
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1099
contentsOfEntireFile
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1100
    "return the contents of the file as a string"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1101
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1102
    |s contents|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1103
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1104
    s := self readStream.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1105
    [
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1106
	contents := s contents
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1107
    ] valueNowOrOnUnwindDo:[s close].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1108
    ^ contents
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1109
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1110
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1111
!Filename methodsFor:'file access'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1112
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1113
newReadWriteStream
325
claus
parents: 308
diff changeset
  1114
    "return a stream for read/write the file represented by the receiver.
claus
parents: 308
diff changeset
  1115
     If the file does not already exist, it is created."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1116
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1117
    ^ FileStream newFileNamed:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1118
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1119
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1120
readWriteStream
325
claus
parents: 308
diff changeset
  1121
    "return a stream for read/write the file represented by the receiver.
claus
parents: 308
diff changeset
  1122
     If the file does not already exist, nil is returned."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1123
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1124
    ^ FileStream oldFileNamed:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1125
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1126
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1127
readStream
325
claus
parents: 308
diff changeset
  1128
    "return a stream for reading from the file represented by the receiver.
claus
parents: 308
diff changeset
  1129
     If the file does not already exist, nil is returned."
2
claus
parents: 1
diff changeset
  1130
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1131
    ^ FileStream readonlyFileNamed:nameString
325
claus
parents: 308
diff changeset
  1132
claus
parents: 308
diff changeset
  1133
    "
claus
parents: 308
diff changeset
  1134
     '/tmp/foo' asFilename readStream 
claus
parents: 308
diff changeset
  1135
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1136
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1137
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1138
writeStream
325
claus
parents: 308
diff changeset
  1139
    "return a stream for writing to the file represented by the receiver.
claus
parents: 308
diff changeset
  1140
     If the file does not already exist, it is created."
2
claus
parents: 1
diff changeset
  1141
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1142
    ^ FileStream newFileForWritingNamed:nameString
325
claus
parents: 308
diff changeset
  1143
claus
parents: 308
diff changeset
  1144
    "
claus
parents: 308
diff changeset
  1145
     '/tmp/foo' asFilename writeStream 
claus
parents: 308
diff changeset
  1146
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1147
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1148
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1149
appendingWriteStream
325
claus
parents: 308
diff changeset
  1150
    "return a stream for appending to the file represented by the receiver.
claus
parents: 308
diff changeset
  1151
     If the file does not already exist, it is created."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1152
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1153
    ^ FileStream appendingOldFileNamed:nameString 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1154
! !
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1155
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1156
!Filename methodsFor:'printing & storing'!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1157
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1158
storeOn:aStream
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1159
    "append a printed representation of the receiver to aStream,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1160
     which allows reconstructing it via readFrom:"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1161
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1162
    aStream nextPut:$(.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1163
    nameString storeOn:aStream.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1164
    aStream nextPutAll:' asFilename)'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1165
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1166
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1167
printOn:aStream
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1168
    "append a printed representation of the receiver to aStream."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1169
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1170
    aStream nextPutAll:'FileName('''.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1171
    nameString printOn:aStream.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1172
    aStream nextPutAll:''')'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1173
! !