Filename.st
author Claus Gittinger <cg@exept.de>
Thu, 02 Nov 1995 17:45:39 +0100
changeset 473 f92507d781d2
parent 441 41684f79f318
child 483 f36d0167b819
permissions -rw-r--r--
filenameCompletion: bad return value when called with empty string
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
473
f92507d781d2 filenameCompletion: bad return value when called with empty string
Claus Gittinger <cg@exept.de>
parents: 441
diff changeset
    23
$Header: /cvs/stx/stx/libbasic/Filename.st,v 1.35 1995-11-02 16:45:39 cg 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
"
473
f92507d781d2 filenameCompletion: bad return value when called with empty string
Claus Gittinger <cg@exept.de>
parents: 441
diff changeset
    44
$Header: /cvs/stx/stx/libbasic/Filename.st,v 1.35 1995-11-02 16:45:39 cg 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
422
claus
parents: 384
diff changeset
   237
    |pid tempDir nm|
276
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
    ].
422
claus
parents: 384
diff changeset
   242
    tempDir := OperatingSystem getEnvironment:'TMPDIR'.
claus
parents: 384
diff changeset
   243
    tempDir isNil ifTrue:[
claus
parents: 384
diff changeset
   244
	tempDir := '/tmp'
claus
parents: 384
diff changeset
   245
    ].
claus
parents: 384
diff changeset
   246
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   247
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   248
     the following has to be made OS independent ...
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   249
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   250
    pid := OperatingSystem getProcessId printString.
422
claus
parents: 384
diff changeset
   251
    nm := tempDir , '/stxtmp_' , pid , '_' , NextTempFilenameIndex printString.
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   252
    NextTempFilenameIndex := NextTempFilenameIndex + 1.
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   253
    ^ self named:nm
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   254
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   255
    "
422
claus
parents: 384
diff changeset
   256
     Filename newTemporary    
claus
parents: 384
diff changeset
   257
     Filename newTemporary  
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   258
    "
422
claus
parents: 384
diff changeset
   259
claus
parents: 384
diff changeset
   260
    "Modified: 7.9.1995 / 10:48:31 / claus"
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   261
!
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   262
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   263
fromUser
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   264
    "show a box to enter a filename. Return a filename instance or
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   265
     nil (if cancel was pressed)."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   266
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   267
    |name|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   268
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   269
    name := FileSelectionBox requestFilename.
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   270
    name notNil ifTrue:[^ self named:name].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   271
    ^ nil
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   272
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   273
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   274
     Filename fromUser
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   275
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
2
claus
parents: 1
diff changeset
   278
!Filename class methodsFor:'queries'!
claus
parents: 1
diff changeset
   279
claus
parents: 1
diff changeset
   280
separator
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   281
    "return the file/directory separator.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   282
     Usually, this is $/ for unix-like systems 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   283
     and $\ for dos-like ones (there may be more in the future)."
2
claus
parents: 1
diff changeset
   284
claus
parents: 1
diff changeset
   285
     ^ OperatingSystem fileSeparator
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   286
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   287
     "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   288
      Filename separator  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   289
     "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   290
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   291
422
claus
parents: 384
diff changeset
   292
suffixSeparator
claus
parents: 384
diff changeset
   293
    "return the filename suffix separator.
claus
parents: 384
diff changeset
   294
     Usually, this is $. for unix-like and msdos systems 
claus
parents: 384
diff changeset
   295
     (there is currently no knowns system, where this differs)"
claus
parents: 384
diff changeset
   296
claus
parents: 384
diff changeset
   297
     ^ $.
claus
parents: 384
diff changeset
   298
claus
parents: 384
diff changeset
   299
     "
claus
parents: 384
diff changeset
   300
      Filename suffixSeparator  
claus
parents: 384
diff changeset
   301
     "
claus
parents: 384
diff changeset
   302
claus
parents: 384
diff changeset
   303
    "Modified: 7.9.1995 / 11:10:43 / claus"
claus
parents: 384
diff changeset
   304
!
claus
parents: 384
diff changeset
   305
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   306
parentDirectoryName 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   307
    "return the name used for the parent directory.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   308
     This is '..' for unix and dos-like systems. 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   309
     (there may be more in the future."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   310
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   311
     ^ OperatingSystem parentDirectoryName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   312
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   313
     "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   314
      Filename parentDirectoryName  
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   315
     "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   316
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   317
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   318
isCaseSensitive
9e273c60e785 more functions
claus
parents: 159
diff changeset
   319
    "return true, if filenames are case sensitive.
9e273c60e785 more functions
claus
parents: 159
diff changeset
   320
     We ask the OS about this, to be independent here."
9e273c60e785 more functions
claus
parents: 159
diff changeset
   321
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   322
    ^ OperatingSystem caseSensitiveFilenames
326
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   323
!
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   324
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   325
defaultClass
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   326
    "ST-80 compatibility:
422
claus
parents: 384
diff changeset
   327
     in ST-80, different subclasses of Filename are used for different
claus
parents: 384
diff changeset
   328
     OperatingSystems; defaultClass is supposed to return an appropriate class.
326
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   329
     Since in ST/X, there is (currently) only one Filename class, return it here."
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   330
d2902942491d *** empty log message ***
claus
parents: 325
diff changeset
   331
    ^ self
328
claus
parents: 326
diff changeset
   332
!
claus
parents: 326
diff changeset
   333
claus
parents: 326
diff changeset
   334
localNameStringFrom:aString
claus
parents: 326
diff changeset
   335
    "ST-80 compatibility.
422
claus
parents: 384
diff changeset
   336
     what does this do ? (used in FileNavigator-goody).
claus
parents: 384
diff changeset
   337
     GUESS: does it strip off the voulume-character on MSDOS systems ?"
328
claus
parents: 326
diff changeset
   338
claus
parents: 326
diff changeset
   339
    (aString startsWith:'/') ifTrue:[
claus
parents: 326
diff changeset
   340
	^ aString copyFrom:2
claus
parents: 326
diff changeset
   341
    ].
claus
parents: 326
diff changeset
   342
    ^ aString
422
claus
parents: 384
diff changeset
   343
claus
parents: 384
diff changeset
   344
    "Modified: 7.9.1995 / 10:44:56 / claus"
328
claus
parents: 326
diff changeset
   345
!
claus
parents: 326
diff changeset
   346
claus
parents: 326
diff changeset
   347
volumes
claus
parents: 326
diff changeset
   348
    "ST-80 compatibility.
422
claus
parents: 384
diff changeset
   349
     what does this do ? (used in FileNavigator-goody).
claus
parents: 384
diff changeset
   350
     GUESS: does it return the available drives on MSDOS systems ?"
328
claus
parents: 326
diff changeset
   351
356
claus
parents: 328
diff changeset
   352
    ^ #('/')
422
claus
parents: 384
diff changeset
   353
claus
parents: 384
diff changeset
   354
    "Modified: 7.9.1995 / 10:45:25 / claus"
440
claus
parents: 422
diff changeset
   355
!
claus
parents: 422
diff changeset
   356
claus
parents: 422
diff changeset
   357
filenameCompletionFor:aString directory:inDirectory directoriesOnly:directoriesOnly filesOnly:filesOnly ifMultiple:aBlock
claus
parents: 422
diff changeset
   358
    "perform filename completion on aString in some directory;
claus
parents: 422
diff changeset
   359
     return the longest matching filename prefix as a string.
claus
parents: 422
diff changeset
   360
     If directoriesOnly and filesOnly are true, only directories and files
claus
parents: 422
diff changeset
   361
     are considered respectively. If multiple files match, the exception
claus
parents: 422
diff changeset
   362
     block aBlock is evaluated with a filename representing the directory
claus
parents: 422
diff changeset
   363
     (where the match was done) as argument.
claus
parents: 422
diff changeset
   364
     (this may be different from the inDirectory argument, if aString is absolute
claus
parents: 422
diff changeset
   365
      or starts with ../)"
claus
parents: 422
diff changeset
   366
claus
parents: 422
diff changeset
   367
    |s f matchSet nMatch name words dir|
claus
parents: 422
diff changeset
   368
claus
parents: 422
diff changeset
   369
    s := aString.
claus
parents: 422
diff changeset
   370
    "
claus
parents: 422
diff changeset
   371
     find the last word ...
claus
parents: 422
diff changeset
   372
    "
claus
parents: 422
diff changeset
   373
    words := s asCollectionOfWords.
claus
parents: 422
diff changeset
   374
    words size == 0 ifTrue:[
473
f92507d781d2 filenameCompletion: bad return value when called with empty string
Claus Gittinger <cg@exept.de>
parents: 441
diff changeset
   375
	aBlock value:'.' asFilename.
f92507d781d2 filenameCompletion: bad return value when called with empty string
Claus Gittinger <cg@exept.de>
parents: 441
diff changeset
   376
	^ ''
440
claus
parents: 422
diff changeset
   377
    ].
claus
parents: 422
diff changeset
   378
claus
parents: 422
diff changeset
   379
    f := words last asFilename.
claus
parents: 422
diff changeset
   380
claus
parents: 422
diff changeset
   381
    matchSet := f filenameCompletionIn:inDirectory.
claus
parents: 422
diff changeset
   382
claus
parents: 422
diff changeset
   383
    dir := f directory.
claus
parents: 422
diff changeset
   384
claus
parents: 422
diff changeset
   385
    directoriesOnly ifTrue:[
claus
parents: 422
diff changeset
   386
	matchSet := matchSet select:[:aFilename |
claus
parents: 422
diff changeset
   387
	    (dir construct:aFilename) isDirectory
claus
parents: 422
diff changeset
   388
	].
claus
parents: 422
diff changeset
   389
    ] ifFalse:[
claus
parents: 422
diff changeset
   390
	filesOnly ifTrue:[
claus
parents: 422
diff changeset
   391
	    matchSet := matchSet select:[:aFilename |
claus
parents: 422
diff changeset
   392
		(dir construct:aFilename) isDirectory not
claus
parents: 422
diff changeset
   393
	    ].
claus
parents: 422
diff changeset
   394
	]
claus
parents: 422
diff changeset
   395
    ].
claus
parents: 422
diff changeset
   396
claus
parents: 422
diff changeset
   397
    (nMatch := matchSet size) ~~ 1 ifTrue:[
claus
parents: 422
diff changeset
   398
	"
claus
parents: 422
diff changeset
   399
	 more than one possible completion -
claus
parents: 422
diff changeset
   400
	"
claus
parents: 422
diff changeset
   401
	aBlock value:f
claus
parents: 422
diff changeset
   402
    ].
claus
parents: 422
diff changeset
   403
    "
claus
parents: 422
diff changeset
   404
     even with more than one possible completion,
claus
parents: 422
diff changeset
   405
     f's name is now the common prefix
claus
parents: 422
diff changeset
   406
    "
claus
parents: 422
diff changeset
   407
    name := f asString.
claus
parents: 422
diff changeset
   408
    nMatch == 1 ifTrue:[
claus
parents: 422
diff changeset
   409
	"
claus
parents: 422
diff changeset
   410
	 exactly one possible completion -
claus
parents: 422
diff changeset
   411
	"
claus
parents: 422
diff changeset
   412
	f := dir construct:matchSet first.
claus
parents: 422
diff changeset
   413
claus
parents: 422
diff changeset
   414
	directoriesOnly ifFalse:[
claus
parents: 422
diff changeset
   415
	    f isDirectory ifTrue:[
claus
parents: 422
diff changeset
   416
		(name endsWith:(Filename separator)) ifFalse:[
claus
parents: 422
diff changeset
   417
		    name := name , '/'
claus
parents: 422
diff changeset
   418
		].
claus
parents: 422
diff changeset
   419
	    ].
claus
parents: 422
diff changeset
   420
	]
claus
parents: 422
diff changeset
   421
    ].
claus
parents: 422
diff changeset
   422
claus
parents: 422
diff changeset
   423
    "
claus
parents: 422
diff changeset
   424
     construct new contents, by taking
claus
parents: 422
diff changeset
   425
     last words completion
claus
parents: 422
diff changeset
   426
    "
claus
parents: 422
diff changeset
   427
    s := ''.
claus
parents: 422
diff changeset
   428
    1 to:(words size - 1) do:[:idx |
claus
parents: 422
diff changeset
   429
	s := s , (words at:idx) , ' '
claus
parents: 422
diff changeset
   430
    ].
claus
parents: 422
diff changeset
   431
    s := s , name.
claus
parents: 422
diff changeset
   432
claus
parents: 422
diff changeset
   433
    "/ special: if there was no change, and the string represented
claus
parents: 422
diff changeset
   434
    "/ is a directories name, add a directory separator
claus
parents: 422
diff changeset
   435
    s = aString ifTrue:[
claus
parents: 422
diff changeset
   436
	(s endsWith:Filename separator) ifFalse:[
claus
parents: 422
diff changeset
   437
	    s asFilename isDirectory ifTrue:[
claus
parents: 422
diff changeset
   438
		^ s , Filename separator asString
claus
parents: 422
diff changeset
   439
	    ]
claus
parents: 422
diff changeset
   440
	]
claus
parents: 422
diff changeset
   441
    ].
claus
parents: 422
diff changeset
   442
claus
parents: 422
diff changeset
   443
    ^ s
2
claus
parents: 1
diff changeset
   444
! !
claus
parents: 1
diff changeset
   445
claus
parents: 1
diff changeset
   446
!Filename methodsFor:'instance creation'!
claus
parents: 1
diff changeset
   447
249
claus
parents: 216
diff changeset
   448
constructString:subname
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   449
    "taking the receiver as a directory name, construct a new
249
claus
parents: 216
diff changeset
   450
     filenames string for an entry within this directory (i.e. for a file
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   451
     or a subdirectory in that directory)."
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   452
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   453
    |sepString|
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   454
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   455
    sepString := self class separator asString.
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   456
    nameString = sepString ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   457
	"I am the root"
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   458
	^ sepString  , subname
85
claus
parents: 77
diff changeset
   459
    ].
422
claus
parents: 384
diff changeset
   460
    ^ nameString , sepString , subname asString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   461
85
claus
parents: 77
diff changeset
   462
    "
249
claus
parents: 216
diff changeset
   463
     '/tmp' asFilename constructString:'foo'   
claus
parents: 216
diff changeset
   464
     '/' asFilename constructString:'foo'         
claus
parents: 216
diff changeset
   465
     '/usr/tmp' asFilename constructString:'foo'
328
claus
parents: 326
diff changeset
   466
     '/foo/bar' asFilename constructString:'baz' 
249
claus
parents: 216
diff changeset
   467
    "
422
claus
parents: 384
diff changeset
   468
claus
parents: 384
diff changeset
   469
    "Modified: 7.9.1995 / 10:15:22 / claus"
249
claus
parents: 216
diff changeset
   470
!
claus
parents: 216
diff changeset
   471
claus
parents: 216
diff changeset
   472
construct:subname
claus
parents: 216
diff changeset
   473
    "taking the receiver as a directory name, construct a new
claus
parents: 216
diff changeset
   474
     filename for an entry within this directory (i.e. for a file
claus
parents: 216
diff changeset
   475
     or a subdirectory in that directory)."
claus
parents: 216
diff changeset
   476
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   477
    ^ (self constructString:subname) asFilename
249
claus
parents: 216
diff changeset
   478
claus
parents: 216
diff changeset
   479
    "
claus
parents: 216
diff changeset
   480
     '/tmp' asFilename construct:'foo'    
claus
parents: 216
diff changeset
   481
     '/' asFilename construct:'foo'         
claus
parents: 216
diff changeset
   482
     '/usr/tmp' asFilename construct:'foo'
328
claus
parents: 326
diff changeset
   483
     '/foo/bar' asFilename construct:'baz' 
85
claus
parents: 77
diff changeset
   484
    "
2
claus
parents: 1
diff changeset
   485
! !
claus
parents: 1
diff changeset
   486
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   487
!Filename methodsFor:'misc'!
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   488
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   489
, aString
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   490
    "this allows filenames to understand how names are concatenated.
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   491
     Returns a string consisting of the receivers name, concatenated
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   492
     by aString. Notice this is NOT the same as construct:, which inserts
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   493
     a directory delimiter and returns a new fileName instance."
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   494
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   495
    ^ (nameString , aString asString)
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   496
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   497
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   498
     'Makefile' asFilename , '.bak' 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   499
     'Makefile' asFilename construct:'.bak' 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   500
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   501
! !
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   502
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   503
!Filename methodsFor:'comparing'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   504
9e273c60e785 more functions
claus
parents: 159
diff changeset
   505
hash
9e273c60e785 more functions
claus
parents: 159
diff changeset
   506
    "return an integer useful as a hash-key"
9e273c60e785 more functions
claus
parents: 159
diff changeset
   507
9e273c60e785 more functions
claus
parents: 159
diff changeset
   508
    ^ nameString hash
9e273c60e785 more functions
claus
parents: 159
diff changeset
   509
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   510
9e273c60e785 more functions
claus
parents: 159
diff changeset
   511
= aFilename
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   512
    "return true, if the argument represents the same filename"
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   513
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   514
    |str|
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   515
9e273c60e785 more functions
claus
parents: 159
diff changeset
   516
    self species == aFilename species ifTrue:[
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   517
	str := aFilename asString.
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   518
	self class isCaseSensitive ifTrue:[
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   519
	    ^ nameString = str
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   520
	].
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   521
	^ nameString sameAs:str
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   522
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
   523
    ^ false
9e273c60e785 more functions
claus
parents: 159
diff changeset
   524
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
   525
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
!Filename methodsFor:'converting'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
asString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   529
    "return the receiver converted to a string"
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   530
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   531
    ^ nameString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
asFilename
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   535
    "return the receiver converted to a filename."
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   536
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   537
    "Thats pretty easy here :-)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
    ^ self
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   539
!
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   540
328
claus
parents: 326
diff changeset
   541
asAbsoluteFilename
claus
parents: 326
diff changeset
   542
    "return the receiver converted to a filename with
claus
parents: 326
diff changeset
   543
     an absolute pathname."
claus
parents: 326
diff changeset
   544
claus
parents: 326
diff changeset
   545
    ^ self pathName asFilename
claus
parents: 326
diff changeset
   546
!
claus
parents: 326
diff changeset
   547
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   548
makeLegalFilename 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   549
    "convert the receveivers name to be a legal filename.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   550
     The implementation may change in the future to be more
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   551
     OS specific."
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   552
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   553
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   554
     actually, in Unix spaces are allowed - but it makes life
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   555
     so hard; therefore, replace them by underscores ...
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
   556
    "
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   557
    nameString replaceAll:(Character space) by:$_.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   558
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   559
     need more - especially on SYS5.3 type systems, 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   560
     we may want to contract the fileName to 14 characters.
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   561
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   562
    ^ self
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   563
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   564
    "
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   565
     'hello world' asFilename makeLegalFilename 
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
   566
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   567
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   568
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 195
diff changeset
   569
!Filename methodsFor:'private accessing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   571
setName:aString
38
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   572
    "set the filename"
454b1b94a48e *** empty log message ***
claus
parents: 5
diff changeset
   573
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   574
    nameString := aString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   576
2
claus
parents: 1
diff changeset
   577
!Filename methodsFor:'queries'!
claus
parents: 1
diff changeset
   578
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   579
separator
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   580
    "return the directory-separator character (or string)"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   581
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   582
    ^ self class separator
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   583
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   584
422
claus
parents: 384
diff changeset
   585
directoryPathName
claus
parents: 384
diff changeset
   586
    "return the full directory pathname part of the file/directory as a string.
claus
parents: 384
diff changeset
   587
     - thats the full pathname of the directory where the file/dir represented by
claus
parents: 384
diff changeset
   588
       the receiver is contained in.
claus
parents: 384
diff changeset
   589
     See also: directoryName"
claus
parents: 384
diff changeset
   590
claus
parents: 384
diff changeset
   591
    ^ OperatingSystem directoryNameOf:(self pathName)
claus
parents: 384
diff changeset
   592
claus
parents: 384
diff changeset
   593
    "
claus
parents: 384
diff changeset
   594
     '/foo/bar/' asFilename directoryPathName    
claus
parents: 384
diff changeset
   595
     '/foo/bar' asFilename directoryPathName    
claus
parents: 384
diff changeset
   596
     '.' asFilename directoryPathName        
claus
parents: 384
diff changeset
   597
     '..' asFilename directoryPathName       
claus
parents: 384
diff changeset
   598
     '../..' asFilename directoryPathName     
claus
parents: 384
diff changeset
   599
    "
claus
parents: 384
diff changeset
   600
claus
parents: 384
diff changeset
   601
    "Modified: 7.9.1995 / 10:42:13 / claus"
claus
parents: 384
diff changeset
   602
!
claus
parents: 384
diff changeset
   603
328
claus
parents: 326
diff changeset
   604
directoryName
422
claus
parents: 384
diff changeset
   605
    "return the directory name part of the file/directory as a string.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   606
     - thats the name of the directory where the file/dir represented by
422
claus
parents: 384
diff changeset
   607
       the receiver is contained in.
claus
parents: 384
diff changeset
   608
     See also: #directoryPathName"
328
claus
parents: 326
diff changeset
   609
claus
parents: 326
diff changeset
   610
    ^ OperatingSystem directoryNameOf:nameString "/ (self pathName)
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   611
328
claus
parents: 326
diff changeset
   612
    "
claus
parents: 326
diff changeset
   613
     '/foo/bar/' asFilename directoryName    
claus
parents: 326
diff changeset
   614
     '/foo/bar' asFilename directoryName    
422
claus
parents: 384
diff changeset
   615
     'bitmaps' asFilename directoryName        
claus
parents: 384
diff changeset
   616
     'bitmaps' asFilename directoryPathName        
328
claus
parents: 326
diff changeset
   617
     '.' asFilename directoryName        
claus
parents: 326
diff changeset
   618
     '..' asFilename directoryName       
claus
parents: 326
diff changeset
   619
     '../..' asFilename directoryName     
422
claus
parents: 384
diff changeset
   620
     '../..' asFilename directoryPathName     
328
claus
parents: 326
diff changeset
   621
    "
422
claus
parents: 384
diff changeset
   622
claus
parents: 384
diff changeset
   623
    "Modified: 7.9.1995 / 10:42:03 / claus"
328
claus
parents: 326
diff changeset
   624
!
claus
parents: 326
diff changeset
   625
claus
parents: 326
diff changeset
   626
directory
422
claus
parents: 384
diff changeset
   627
    "return the directory name part of the file/directory as a filename.
328
claus
parents: 326
diff changeset
   628
     - thats a filename for the directory where the file/dir represented by
claus
parents: 326
diff changeset
   629
       the receiver is contained in."
claus
parents: 326
diff changeset
   630
claus
parents: 326
diff changeset
   631
    ^ self directoryName asFilename
2
claus
parents: 1
diff changeset
   632
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   633
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   634
     '/foo/bar' asFilename directory
9e273c60e785 more functions
claus
parents: 159
diff changeset
   635
     '.' asFilename directory        
9e273c60e785 more functions
claus
parents: 159
diff changeset
   636
     '..' asFilename directory       
9e273c60e785 more functions
claus
parents: 159
diff changeset
   637
     '../..' asFilename directory     
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   638
    "
2
claus
parents: 1
diff changeset
   639
!
claus
parents: 1
diff changeset
   640
308
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   641
directoryContents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   642
    "return the contents of the directory as a collection of strings"
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   643
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   644
    ^ (FileDirectory directoryNamed:self asString) contents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   645
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   646
    "
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   647
     '.' asFilename directoryContents
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   648
    "
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   649
!
f04744ef7b5d *** empty log message ***
claus
parents: 276
diff changeset
   650
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   651
tail
422
claus
parents: 384
diff changeset
   652
    "the files name without directory prefix as a string. 
claus
parents: 384
diff changeset
   653
     An alias for baseName, for ST-80 compatiblity."
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
   654
9e273c60e785 more functions
claus
parents: 159
diff changeset
   655
    ^ self baseName
9e273c60e785 more functions
claus
parents: 159
diff changeset
   656
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
   657
2
claus
parents: 1
diff changeset
   658
baseName
422
claus
parents: 384
diff changeset
   659
    "return my baseName as a string.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   660
     - thats the file/directory name without leading parent-dirs."
2
claus
parents: 1
diff changeset
   661
328
claus
parents: 326
diff changeset
   662
    ^ OperatingSystem baseNameOf:nameString "/ (self pathName) 
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   663
85
claus
parents: 77
diff changeset
   664
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   665
     '/foo/bar' asFilename baseName  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   666
     '.' asFilename baseName          
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   667
     '..' asFilename baseName         
328
claus
parents: 326
diff changeset
   668
     '../..' asFilename baseName        
claus
parents: 326
diff changeset
   669
     '../../libbasic' asFilename baseName        
claus
parents: 326
diff changeset
   670
     '../../libpr' asFilename baseName        
422
claus
parents: 384
diff changeset
   671
     '../../libbasic/Object.st' asFilename baseName        
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   672
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   673
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   674
422
claus
parents: 384
diff changeset
   675
name
claus
parents: 384
diff changeset
   676
    "return the name of the file represented by the receiver as a string.
claus
parents: 384
diff changeset
   677
     This may or may not be a relative name.
claus
parents: 384
diff changeset
   678
     See also: pathName"
claus
parents: 384
diff changeset
   679
claus
parents: 384
diff changeset
   680
    self isAbsolute ifTrue:[^ self pathName].
claus
parents: 384
diff changeset
   681
    ^ nameString
claus
parents: 384
diff changeset
   682
claus
parents: 384
diff changeset
   683
    "
claus
parents: 384
diff changeset
   684
     '/foo/bar' asFilename name        
claus
parents: 384
diff changeset
   685
     '/foo/bar' asFilename pathName    
claus
parents: 384
diff changeset
   686
     '.' asFilename name                
claus
parents: 384
diff changeset
   687
     '.' asFilename pathName             
claus
parents: 384
diff changeset
   688
     '../..' asFilename name             
claus
parents: 384
diff changeset
   689
     '../..' asFilename pathName         
claus
parents: 384
diff changeset
   690
     'bitmaps' asFilename name                
claus
parents: 384
diff changeset
   691
     'bitmaps' asFilename pathName             
claus
parents: 384
diff changeset
   692
     '/tmp/../usr' asFilename name       
claus
parents: 384
diff changeset
   693
     '/tmp/../usr' asFilename pathName   
claus
parents: 384
diff changeset
   694
    "
claus
parents: 384
diff changeset
   695
claus
parents: 384
diff changeset
   696
    "Modified: 7.9.1995 / 10:41:14 / claus"
claus
parents: 384
diff changeset
   697
!
claus
parents: 384
diff changeset
   698
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   699
pathName
422
claus
parents: 384
diff changeset
   700
    "return the full pathname of the file represented by the receiver,
claus
parents: 384
diff changeset
   701
     as a string. See also: name"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   702
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   703
    |parentName sep|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   704
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   705
    sep := self class separator.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   706
    (nameString startsWith:sep) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   707
	parentName := self class parentDirectoryName.
357
claus
parents: 356
diff changeset
   708
	(nameString findString:parentName) == 0 ifTrue:[
claus
parents: 356
diff changeset
   709
	    ^ nameString
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   710
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   711
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   712
    ^ (FileDirectory directoryNamed:nameString) pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   713
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   714
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   715
     '/foo/bar' asFilename pathName
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   716
     '.' asFilename pathName 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   717
     '../..' asFilename pathName 
422
claus
parents: 384
diff changeset
   718
     '../..' asFilename name 
357
claus
parents: 356
diff changeset
   719
     '/tmp/../usr' asFilename pathName  
85
claus
parents: 77
diff changeset
   720
    "
422
claus
parents: 384
diff changeset
   721
claus
parents: 384
diff changeset
   722
    "Modified: 7.9.1995 / 10:42:39 / claus"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   723
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   724
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   725
isAbsolute
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   726
    "return true, if the receiver represents an absolute pathname
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   727
     (in contrast to one relative to the current directory)."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   728
85
claus
parents: 77
diff changeset
   729
    ^ (nameString startsWith:self class separator)
claus
parents: 77
diff changeset
   730
claus
parents: 77
diff changeset
   731
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   732
     '/foo/bar' asFilename isAbsolute   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   733
     '..' asFilename isAbsolute         
328
claus
parents: 326
diff changeset
   734
     '..' asAbsoluteFilename isAbsolute         
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   735
     'source/SBrowser.st' asFilename isAbsolute  
85
claus
parents: 77
diff changeset
   736
    "
claus
parents: 77
diff changeset
   737
!
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   738
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   739
isRelative
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   740
    "return true, if this name is interpreted relative to some
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   741
     directory (opposite of absolute)"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   742
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   743
    ^ self isAbsolute not
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   744
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   745
85
claus
parents: 77
diff changeset
   746
isDirectory
claus
parents: 77
diff changeset
   747
    "return true, if the receiver represents an existing,
claus
parents: 77
diff changeset
   748
     readable directories pathname."
claus
parents: 77
diff changeset
   749
claus
parents: 77
diff changeset
   750
    ^ OperatingSystem isDirectory:nameString
claus
parents: 77
diff changeset
   751
claus
parents: 77
diff changeset
   752
    "
claus
parents: 77
diff changeset
   753
     '/foo/bar' asFilename isDirectory
claus
parents: 77
diff changeset
   754
     '/tmp' asFilename isDirectory
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   755
     'Makefile' asFilename isDirectory   
85
claus
parents: 77
diff changeset
   756
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   757
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   758
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   759
exists
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   760
    "return true, if such a file exists."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   761
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   762
    ^ OperatingSystem isValidPath:nameString
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   763
85
claus
parents: 77
diff changeset
   764
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   765
     '/foo/bar' asFilename exists 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   766
     '/tmp' asFilename exists  
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   767
     'Makefile' asFilename exists   
85
claus
parents: 77
diff changeset
   768
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   769
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   770
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   771
isReadable
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   772
    "return true, if such a file exists and is readable."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   773
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   774
    ^ OperatingSystem isReadable:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   775
85
claus
parents: 77
diff changeset
   776
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   777
     '/foo/bar' asFilename isReadable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   778
     '/tmp' asFilename isReadable      
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   779
     'Makefile' asFilename isReadable   
85
claus
parents: 77
diff changeset
   780
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   781
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   782
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   783
canBeWritten
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   784
    "same as isWritable - for ST-80 compatibility"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   785
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   786
    ^ self isWritable
328
claus
parents: 326
diff changeset
   787
claus
parents: 326
diff changeset
   788
    "
claus
parents: 326
diff changeset
   789
     '/foo/bar' asFilename canBeWritten 
claus
parents: 326
diff changeset
   790
     '/tmp' asFilename canBeWritten   
claus
parents: 326
diff changeset
   791
     'Makefile' asFilename canBeWritten   
claus
parents: 326
diff changeset
   792
    "
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   793
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   794
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   795
isWritable
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   796
    "return true, if such a file exists and is writable."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   797
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   798
    ^ OperatingSystem isWritable:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   799
85
claus
parents: 77
diff changeset
   800
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   801
     '/foo/bar' asFilename isWritable 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   802
     '/tmp' asFilename isWritable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   803
     'Makefile' asFilename isWritable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   804
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   805
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   806
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   807
isExecutable
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   808
    "return true, if such a file exists and is executable (by Unix's definition).
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   809
     For directories, true is returned if the directory can be entered.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   810
     See isExecutableProgram for a related check."
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   811
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   812
    ^ OperatingSystem isExecutable:nameString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   813
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   814
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   815
     '/foo/bar' asFilename isExecutable 
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   816
     '/tmp' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   817
     'Makefile' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   818
     '/bin/ls' asFilename isExecutable   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   819
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   820
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   821
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   822
isExecutableProgram
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   823
    "return true, if such a file exists and is an executable program.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   824
     (i.e. for directories, false is returned.)"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   825
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   826
    ^ (OperatingSystem isExecutable:nameString)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   827
      and:[(OperatingSystem isDirectory:nameString) not]
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   828
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   829
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   830
     '/tmp' asFilename isExecutable         
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   831
     '/bin/ls' asFilename isExecutable       
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   832
     '/tmp' asFilename isExecutableProgram   
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   833
     '/bin/ls' asFilename isExecutableProgram    
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   834
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   835
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   836
356
claus
parents: 328
diff changeset
   837
isSymbolicLink
claus
parents: 328
diff changeset
   838
    "return true, if the file represented by the receiver is a symbolic
claus
parents: 328
diff changeset
   839
     link. Notice that not all OS's support symbolic links; those that do
claus
parents: 328
diff changeset
   840
     not will always return false."
claus
parents: 328
diff changeset
   841
claus
parents: 328
diff changeset
   842
    ^ OperatingSystem isSymbolicLink:nameString
claus
parents: 328
diff changeset
   843
claus
parents: 328
diff changeset
   844
    "
claus
parents: 328
diff changeset
   845
     'Make.proto' asFilename isSymbolicLink  
claus
parents: 328
diff changeset
   846
     'Makefile' asFilename isSymbolicLink   
claus
parents: 328
diff changeset
   847
    "
claus
parents: 328
diff changeset
   848
!
claus
parents: 328
diff changeset
   849
422
claus
parents: 384
diff changeset
   850
prefixAndSuffix
claus
parents: 384
diff changeset
   851
    "return an array consisting of my prefix and suffix.
claus
parents: 384
diff changeset
   852
     The suffix is the namepart after the final period character,
claus
parents: 384
diff changeset
   853
     the prefix everything before, except for the period.
claus
parents: 384
diff changeset
   854
     (on some systems, the suffix-character may be different from a period).
claus
parents: 384
diff changeset
   855
     For example, foo.bar.baz has a prefix of 'foo.bar' and a suffix of '.baz'.
claus
parents: 384
diff changeset
   856
claus
parents: 384
diff changeset
   857
     Notice: there is currently no known system which uses other than
claus
parents: 384
diff changeset
   858
     the period character as suffixCharacter."
claus
parents: 384
diff changeset
   859
claus
parents: 384
diff changeset
   860
    |nm idx|
claus
parents: 384
diff changeset
   861
claus
parents: 384
diff changeset
   862
    nm := self baseName.
claus
parents: 384
diff changeset
   863
    idx := nm lastIndexOf:(self class suffixSeparator).
claus
parents: 384
diff changeset
   864
    idx == 0 ifTrue:[
claus
parents: 384
diff changeset
   865
	^ Array with:nm with:''
claus
parents: 384
diff changeset
   866
    ].
claus
parents: 384
diff changeset
   867
    ^ Array 
claus
parents: 384
diff changeset
   868
	with:(nm copyTo:idx-1)
claus
parents: 384
diff changeset
   869
	with:(nm copyFrom:idx+1)
claus
parents: 384
diff changeset
   870
claus
parents: 384
diff changeset
   871
    "
claus
parents: 384
diff changeset
   872
     'abc.st' asFilename prefixAndSuffix  
claus
parents: 384
diff changeset
   873
     'abc' asFilename prefixAndSuffix  
claus
parents: 384
diff changeset
   874
     'a.b.c' asFilename prefixAndSuffix 
claus
parents: 384
diff changeset
   875
claus
parents: 384
diff changeset
   876
     |parts| 
claus
parents: 384
diff changeset
   877
     parts := 'Object.st' asFilename prefixAndSuffix.
claus
parents: 384
diff changeset
   878
     ((parts at:1) , '.o') asFilename
claus
parents: 384
diff changeset
   879
    "
claus
parents: 384
diff changeset
   880
claus
parents: 384
diff changeset
   881
    "Modified: 7.9.1995 / 11:15:42 / claus"
claus
parents: 384
diff changeset
   882
!
claus
parents: 384
diff changeset
   883
claus
parents: 384
diff changeset
   884
suffix
claus
parents: 384
diff changeset
   885
    "return my suffix.
claus
parents: 384
diff changeset
   886
     The suffix is the namepart after the final period character,
claus
parents: 384
diff changeset
   887
     or the empty string, if the name does not contain a period."
claus
parents: 384
diff changeset
   888
claus
parents: 384
diff changeset
   889
    ^ self prefixAndSuffix at:2
claus
parents: 384
diff changeset
   890
claus
parents: 384
diff changeset
   891
    "
claus
parents: 384
diff changeset
   892
     'abc.st' asFilename suffix   
claus
parents: 384
diff changeset
   893
     'abc' asFilename suffix      
claus
parents: 384
diff changeset
   894
     'a.b.c' asFilename suffix    
claus
parents: 384
diff changeset
   895
    "
claus
parents: 384
diff changeset
   896
claus
parents: 384
diff changeset
   897
    "Modified: 7.9.1995 / 11:09:03 / claus"
claus
parents: 384
diff changeset
   898
!
claus
parents: 384
diff changeset
   899
328
claus
parents: 326
diff changeset
   900
filesMatching:aPattern
claus
parents: 326
diff changeset
   901
    ^ self directoryContents select:[:name | aPattern match:name]
claus
parents: 326
diff changeset
   902
claus
parents: 326
diff changeset
   903
    "
claus
parents: 326
diff changeset
   904
     Filename currentDirectory filesMatching:'M*' 
claus
parents: 326
diff changeset
   905
    "
claus
parents: 326
diff changeset
   906
!
claus
parents: 326
diff changeset
   907
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   908
filenameCompletion
440
claus
parents: 422
diff changeset
   909
    "try to complete the recevier filename.
claus
parents: 422
diff changeset
   910
     This method has both a return value and a side effect on the receiver:
claus
parents: 422
diff changeset
   911
       it returns a collection of matching filename objects,
claus
parents: 422
diff changeset
   912
       and leaves changes the receivers filename-string to the longest common
claus
parents: 422
diff changeset
   913
       match.
claus
parents: 422
diff changeset
   914
     If none matches, the returned collection is empty and the recevier is unchanged.
claus
parents: 422
diff changeset
   915
     If there is only one match, the size of the returned collection is exactly 1,
claus
parents: 422
diff changeset
   916
     containing the fully expanded filename and the receivers name is changed to it."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   917
440
claus
parents: 422
diff changeset
   918
    ^ self filenameCompletionIn:nil
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   919
440
claus
parents: 422
diff changeset
   920
    " 
claus
parents: 422
diff changeset
   921
     'mak' asFilename filenameCompletion  
claus
parents: 422
diff changeset
   922
     'Make' asFilename filenameCompletion 
claus
parents: 422
diff changeset
   923
     'Makef' asFilename filenameCompletion;yourself  
claus
parents: 422
diff changeset
   924
     '/u' asFilename filenameCompletion             
claus
parents: 422
diff changeset
   925
     '../../libpr' asFilename inspect filenameCompletion    
claus
parents: 422
diff changeset
   926
    "
claus
parents: 422
diff changeset
   927
!
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   928
440
claus
parents: 422
diff changeset
   929
filenameCompletionIn:aDirectory
claus
parents: 422
diff changeset
   930
    "try to complete the recevier filename.
claus
parents: 422
diff changeset
   931
     This method has both a return value and a side effect on the receiver:
claus
parents: 422
diff changeset
   932
       it returns a collection of matching filename objects,
claus
parents: 422
diff changeset
   933
       and leaves changes the receivers filename-string to the longest common
claus
parents: 422
diff changeset
   934
       match.
claus
parents: 422
diff changeset
   935
     If none matches, the returned collection is empty and the recevier is unchanged.
claus
parents: 422
diff changeset
   936
     If there is only one match, the size of the returned collection is exactly 1,
claus
parents: 422
diff changeset
   937
     containing the fully expanded filename and the receivers name is changed to it."
claus
parents: 422
diff changeset
   938
claus
parents: 422
diff changeset
   939
    |dir baseName matching matchLen try allMatching 
claus
parents: 422
diff changeset
   940
     sepString parentString prefix nMatch|
claus
parents: 422
diff changeset
   941
claus
parents: 422
diff changeset
   942
    sepString := self class separator asString.
claus
parents: 422
diff changeset
   943
    (nameString endsWith:sepString) ifTrue:[
claus
parents: 422
diff changeset
   944
	^ #()
328
claus
parents: 326
diff changeset
   945
    ].
claus
parents: 326
diff changeset
   946
440
claus
parents: 422
diff changeset
   947
    parentString := self class parentDirectoryName.
claus
parents: 422
diff changeset
   948
    baseName := self baseName.
claus
parents: 422
diff changeset
   949
    baseName ~= nameString ifTrue:[
claus
parents: 422
diff changeset
   950
	prefix := self directoryName.
claus
parents: 422
diff changeset
   951
    ].
claus
parents: 422
diff changeset
   952
441
claus
parents: 440
diff changeset
   953
    self isAbsolute ifTrue:[
440
claus
parents: 422
diff changeset
   954
	dir := self directory
claus
parents: 422
diff changeset
   955
    ] ifFalse:[
441
claus
parents: 440
diff changeset
   956
	aDirectory isNil ifTrue:[
claus
parents: 440
diff changeset
   957
	    dir := self directory
claus
parents: 440
diff changeset
   958
	] ifFalse:[
claus
parents: 440
diff changeset
   959
	    dir := (aDirectory construct:nameString) directory
claus
parents: 440
diff changeset
   960
	]
328
claus
parents: 326
diff changeset
   961
    ].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   962
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   963
    matching := OrderedCollection new.
440
claus
parents: 422
diff changeset
   964
    dir directoryContents do:[:fileName |
claus
parents: 422
diff changeset
   965
	((fileName ~= '.') and:[fileName ~= parentString]) ifTrue:[
claus
parents: 422
diff changeset
   966
	    (fileName startsWith:baseName) ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   967
		matching add:fileName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   968
	    ]
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
   969
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   970
    ].
440
claus
parents: 422
diff changeset
   971
    (nMatch := matching size) > 1 ifTrue:[
claus
parents: 422
diff changeset
   972
	"
claus
parents: 422
diff changeset
   973
	 find the longest common prefix
claus
parents: 422
diff changeset
   974
	"
claus
parents: 422
diff changeset
   975
	matchLen := baseName size.
claus
parents: 422
diff changeset
   976
	matchLen > matching first size ifTrue:[
claus
parents: 422
diff changeset
   977
	    try := baseName.
claus
parents: 422
diff changeset
   978
	    allMatching := false
claus
parents: 422
diff changeset
   979
	] ifFalse:[
claus
parents: 422
diff changeset
   980
	    try := matching first copyTo:matchLen.
claus
parents: 422
diff changeset
   981
	    allMatching := true.
claus
parents: 422
diff changeset
   982
	].
claus
parents: 422
diff changeset
   983
claus
parents: 422
diff changeset
   984
	[allMatching] whileTrue:[
claus
parents: 422
diff changeset
   985
	    matching do:[:aName |
claus
parents: 422
diff changeset
   986
		(aName startsWith:try) ifFalse:[
claus
parents: 422
diff changeset
   987
		    allMatching := false
claus
parents: 422
diff changeset
   988
		]
claus
parents: 422
diff changeset
   989
	    ].
claus
parents: 422
diff changeset
   990
	    allMatching ifTrue:[
claus
parents: 422
diff changeset
   991
		matchLen <  matching first size ifTrue:[
claus
parents: 422
diff changeset
   992
		    matchLen := matchLen + 1.
claus
parents: 422
diff changeset
   993
		    try := matching first copyTo:matchLen.
claus
parents: 422
diff changeset
   994
		] ifFalse:[
claus
parents: 422
diff changeset
   995
		    allMatching := false
claus
parents: 422
diff changeset
   996
		]
claus
parents: 422
diff changeset
   997
	    ] ifFalse:[
claus
parents: 422
diff changeset
   998
		try := matching first copyTo:matchLen - 1.
claus
parents: 422
diff changeset
   999
	    ]
claus
parents: 422
diff changeset
  1000
	].
claus
parents: 422
diff changeset
  1001
	"
claus
parents: 422
diff changeset
  1002
	 and set my name to the last full match
claus
parents: 422
diff changeset
  1003
	"
claus
parents: 422
diff changeset
  1004
	nameString := try
claus
parents: 422
diff changeset
  1005
    ].
claus
parents: 422
diff changeset
  1006
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1007
    "
440
claus
parents: 422
diff changeset
  1008
     if I had a directory-prefix, change names in collection ...
claus
parents: 422
diff changeset
  1009
    "
claus
parents: 422
diff changeset
  1010
    prefix notNil ifTrue:[
claus
parents: 422
diff changeset
  1011
	prefix = '/' ifTrue:[
claus
parents: 422
diff changeset
  1012
	    "/ avoid introducing double slashes
claus
parents: 422
diff changeset
  1013
	    prefix := ''
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1014
	].
440
claus
parents: 422
diff changeset
  1015
	matching := matching collect:[:n | prefix , '/' , n].
claus
parents: 422
diff changeset
  1016
	nMatch == 1 ifTrue:[
claus
parents: 422
diff changeset
  1017
	    nameString := matching first
claus
parents: 422
diff changeset
  1018
	] ifFalse:[
claus
parents: 422
diff changeset
  1019
	    nMatch > 1 ifTrue:[
claus
parents: 422
diff changeset
  1020
		nameString := prefix , '/' , nameString
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1021
	    ]
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1022
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1023
    ] ifFalse:[
440
claus
parents: 422
diff changeset
  1024
	nMatch == 1 ifTrue:[
claus
parents: 422
diff changeset
  1025
	    nameString := matching first
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1026
	]
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1027
    ].
440
claus
parents: 422
diff changeset
  1028
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1029
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1030
     return the match-set, so caller can decide what to do
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1031
     (i.e. show the matches, output a warning etc ...)
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1032
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1033
    ^ matching
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1034
440
claus
parents: 422
diff changeset
  1035
    " trivial cases:
claus
parents: 422
diff changeset
  1036
claus
parents: 422
diff changeset
  1037
     '../' asFilename filenameCompletion    
claus
parents: 422
diff changeset
  1038
     '/' asFilename filenameCompletion      
claus
parents: 422
diff changeset
  1039
     '/usr/' asFilename filenameCompletion   
claus
parents: 422
diff changeset
  1040
claus
parents: 422
diff changeset
  1041
     'mak' asFilename filenameCompletion   
claus
parents: 422
diff changeset
  1042
     'Make' asFilename filenameCompletion    
claus
parents: 422
diff changeset
  1043
     'Makef' asFilename filenameCompletion
claus
parents: 422
diff changeset
  1044
     '/u' asFilename filenameCompletion             
claus
parents: 422
diff changeset
  1045
     '../../libpr' asFilename filenameCompletion    
85
claus
parents: 77
diff changeset
  1046
    "
2
claus
parents: 1
diff changeset
  1047
! !
claus
parents: 1
diff changeset
  1048
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1049
!Filename methodsFor:'file queries'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1050
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1051
info
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1052
    "return the files info; that is a collection of file attributes,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1053
     (actually a dictionary) where the keys are #type, #uid, #gid, #size etc.
356
claus
parents: 328
diff changeset
  1054
     The actual amount and detail returned may depend on the OS used.
claus
parents: 328
diff changeset
  1055
     On unix, if you ask for the info of a symbolic link, the target
359
claus
parents: 357
diff changeset
  1056
     files info is returned. (see also: #linkInfo)
356
claus
parents: 328
diff changeset
  1057
claus
parents: 328
diff changeset
  1058
     On unix, the contents is:
claus
parents: 328
diff changeset
  1059
	id            -> the inode number (integer)
claus
parents: 328
diff changeset
  1060
	uid           -> the numeric user id of the files owner
claus
parents: 328
diff changeset
  1061
	gid           -> the numeric group id of the files owner
claus
parents: 328
diff changeset
  1062
	statusChanged -> the absoluteTime when the files status changed last
claus
parents: 328
diff changeset
  1063
			 (i.e. protection change, owner change etc.)
claus
parents: 328
diff changeset
  1064
	accessed      -> the absoluteTime when the file was last accessed
claus
parents: 328
diff changeset
  1065
	modified      -> the absoluteTime when the file was last modified
claus
parents: 328
diff changeset
  1066
	size          -> the size (in bytes) of the file
claus
parents: 328
diff changeset
  1067
	type          -> the files type (#regular, #directory, #characterSpecial)
claus
parents: 328
diff changeset
  1068
	mode          -> the files access protection bits (rwxrwxrwx mask).
claus
parents: 328
diff changeset
  1069
claus
parents: 328
diff changeset
  1070
     The minimum returned info (i.e. on all OS's) will consist of at least:
claus
parents: 328
diff changeset
  1071
	modified
claus
parents: 328
diff changeset
  1072
	size
claus
parents: 328
diff changeset
  1073
	type
claus
parents: 328
diff changeset
  1074
claus
parents: 328
diff changeset
  1075
     Some OS's (VMS) may return more info.
claus
parents: 328
diff changeset
  1076
claus
parents: 328
diff changeset
  1077
     Dont expect things like uid/gid/mode to be there; write your application
claus
parents: 328
diff changeset
  1078
     to either handle the cases where info-entries are not present,
359
claus
parents: 357
diff changeset
  1079
     or (better) use one of isXXXX query methods. (Be prepared for DOS ...)
356
claus
parents: 328
diff changeset
  1080
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1081
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1082
    ^ OperatingSystem infoOf:nameString
328
claus
parents: 326
diff changeset
  1083
claus
parents: 326
diff changeset
  1084
    "
claus
parents: 326
diff changeset
  1085
     Filename currentDirectory info
356
claus
parents: 328
diff changeset
  1086
     '/dev/null' asFilename info 
328
claus
parents: 326
diff changeset
  1087
     'Make.proto' asFilename info
356
claus
parents: 328
diff changeset
  1088
     'source/Point.st' asFilename info 
359
claus
parents: 357
diff changeset
  1089
     'source/Point.st' asFilename linkInfo 
356
claus
parents: 328
diff changeset
  1090
     '../../libbasic/Point.st' asFilename info 
claus
parents: 328
diff changeset
  1091
    "
claus
parents: 328
diff changeset
  1092
!
claus
parents: 328
diff changeset
  1093
claus
parents: 328
diff changeset
  1094
linkInfo
claus
parents: 328
diff changeset
  1095
    "return the files info if its a symbolic link; nil otherwise.
claus
parents: 328
diff changeset
  1096
     On OS's which do not support symbolic links, nil is always returned.
359
claus
parents: 357
diff changeset
  1097
     The information is the same as returned by #info, except that if the
claus
parents: 357
diff changeset
  1098
     receiver represents a symbolic link, the links information 
claus
parents: 357
diff changeset
  1099
     is returned 
claus
parents: 357
diff changeset
  1100
     (while in this case, #info returns the info of the target file, 
claus
parents: 357
diff changeset
  1101
      which is accessed via the symbolic link).
356
claus
parents: 328
diff changeset
  1102
claus
parents: 328
diff changeset
  1103
     In addition to the normal entries, Unix returns an additional entry:
claus
parents: 328
diff changeset
  1104
	 path -> the target files pathname
claus
parents: 328
diff changeset
  1105
claus
parents: 328
diff changeset
  1106
     See the comment in #info for more details."
claus
parents: 328
diff changeset
  1107
claus
parents: 328
diff changeset
  1108
    ^ OperatingSystem linkInfoOf:nameString
claus
parents: 328
diff changeset
  1109
claus
parents: 328
diff changeset
  1110
    "
claus
parents: 328
diff changeset
  1111
     Filename currentDirectory linkInfo 
claus
parents: 328
diff changeset
  1112
     '/dev/null' asFilename linkInfo    
claus
parents: 328
diff changeset
  1113
     'Make.proto' asFilename linkInfo   
claus
parents: 328
diff changeset
  1114
     'Make.proto' asFilename linkInfo at:#path  
claus
parents: 328
diff changeset
  1115
     'source/Point.st' asFilename linkInfo 
claus
parents: 328
diff changeset
  1116
     '../../libbasic/Point.st' asFilename linkInfo 
328
claus
parents: 326
diff changeset
  1117
    "
claus
parents: 326
diff changeset
  1118
!
claus
parents: 326
diff changeset
  1119
claus
parents: 326
diff changeset
  1120
dates
claus
parents: 326
diff changeset
  1121
    "return the files modification and access times as an object (currently a dictionary)
356
claus
parents: 328
diff changeset
  1122
     that responds to the at: message with arguments 
claus
parents: 328
diff changeset
  1123
     #modified, #accessed or #statusChanged."
328
claus
parents: 326
diff changeset
  1124
claus
parents: 326
diff changeset
  1125
    |info dates|
claus
parents: 326
diff changeset
  1126
claus
parents: 326
diff changeset
  1127
    info := OperatingSystem infoOf:nameString.
claus
parents: 326
diff changeset
  1128
    info isNil ifTrue:[
claus
parents: 326
diff changeset
  1129
	info := OperatingSystem linkInfoOf:nameString.
claus
parents: 326
diff changeset
  1130
	info isNil ifTrue:[
claus
parents: 326
diff changeset
  1131
	    ^ nil
claus
parents: 326
diff changeset
  1132
	]
claus
parents: 326
diff changeset
  1133
    ].
claus
parents: 326
diff changeset
  1134
    dates := IdentityDictionary new.
claus
parents: 326
diff changeset
  1135
    dates at:#modified put:(info at:#modified).
claus
parents: 326
diff changeset
  1136
    dates at:#accessed put:(info at:#accessed).
claus
parents: 326
diff changeset
  1137
    dates at:#statusChanged put:(info at:#statusChanged).
claus
parents: 326
diff changeset
  1138
    ^ dates
claus
parents: 326
diff changeset
  1139
claus
parents: 326
diff changeset
  1140
    "
claus
parents: 326
diff changeset
  1141
     Filename currentDirectory dates
claus
parents: 326
diff changeset
  1142
     '../regression' asFilename dates
claus
parents: 326
diff changeset
  1143
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1144
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1145
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1146
fileSize
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1147
    "return the size of the file in bytes"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1148
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1149
    |info|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1150
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1151
    info := self info.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1152
    info isNil ifTrue:[^ nil].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1153
    ^ info at:#size
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1154
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1155
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1156
fileType
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1157
    "this returns a string describing the type of contents of
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1158
     the file. This is done using the unix 'file' command,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1159
     (which usually is configurable by /etc/magic).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1160
     On non-unix systems, this may return an empty string, not knowning
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1161
     about the contents."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1162
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1163
    |stream typeString|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1164
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1165
    typeString := ''.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1166
    stream := PipeStream readingFrom:('file ' , self pathName).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1167
    stream notNil ifTrue:[
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1168
	typeString := stream contents asString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1169
	stream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1170
	typeString := typeString copyFrom:(typeString indexOf:$:) + 1.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1171
	typeString := typeString withoutSeparators
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1172
    ] ifFalse:[
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1173
	"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1174
	 could add some fallback code here, for systems, where no
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1175
	 file command is avaliable ...
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1176
	 ... or at least analyze directory info.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1177
	"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1178
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1179
    ^ typeString
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1180
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1181
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1182
     'Makefile' asFilename fileType 
325
claus
parents: 308
diff changeset
  1183
     '.' asFilename fileType     
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1184
     '/dev/null' asFilename fileType        
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1185
     'smalltalk.rc' asFilename fileType    
325
claus
parents: 308
diff changeset
  1186
     'bitmaps/SBrowser.xbm' asFilename fileType    
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1187
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1188
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1189
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1190
!Filename methodsFor:'file operations'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1191
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1192
delete
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1193
    "remove the file - same as remove, for ST-80 compatibility"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1194
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1195
    ^ self remove
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1196
!
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1197
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1198
remove
192
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
  1199
    "remove the file - the argument must be convertable to a String.
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
  1200
     Return true if sucessfull, false if not."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1201
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1202
    ^ OperatingSystem removeFile:nameString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1203
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1204
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1205
     (FileStream newFileNamed:'foo') close.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1206
     'foo' asFilename remove
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1207
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1208
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1209
2
claus
parents: 1
diff changeset
  1210
renameTo:newName
192
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
  1211
    "rename the file - the argument must be convertable to a String.
3b0eb8864842 *** empty log message ***
claus
parents: 174
diff changeset
  1212
     Return true if sucessfull, false if not."
2
claus
parents: 1
diff changeset
  1213
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1214
    ^ OperatingSystem renameFile:nameString to:(newName asString)
2
claus
parents: 1
diff changeset
  1215
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1216
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1217
     '/tmp/foo' asFilename renameTo:'/tmp/bar'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1218
    "
2
claus
parents: 1
diff changeset
  1219
!
claus
parents: 1
diff changeset
  1220
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1221
copyTo:newName
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1222
    "copy the file - the argument must be convertable to a filename"
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1223
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1224
    |inStream outStream buffer bufferSize count|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1225
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1226
    bufferSize := 8 * 1024.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1227
    buffer := ByteArray new:bufferSize.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1228
    inStream := self readStream.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1229
    outStream := newName asFilename writeStream.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1230
    (inStream isNil or:[outStream isNil]) ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1231
	^ self error:'file copy failed'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1232
    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1233
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1234
    [inStream atEnd] whileFalse:[
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1235
	count := inStream nextBytes:bufferSize into:buffer.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1236
	outStream nextPutBytes:count from:buffer.
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1237
    ].
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1238
    outStream close.
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
  1239
    inStream close.
159
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1240
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1241
    "
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1242
     'Makefile' asFilename copyTo:'Makefile.foo'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1243
     'smalltalk' asFilename copyTo:'/dev/null'
514c749165c3 *** empty log message ***
claus
parents: 132
diff changeset
  1244
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1245
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1246
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1247
moveTo:newName
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1248
    "copy the file represented by the receiver, then delete it.
195
515af3696a5c *** empty log message ***
claus
parents: 192
diff changeset
  1249
     This is different to renaming in case of cross device moves."
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1250
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1251
    self copyTo:newName.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1252
    self remove
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1253
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1254
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1255
makeDirectory
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1256
    "create a directory with the receivers name"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1257
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1258
    OperatingSystem createDirectory:nameString
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1259
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1260
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1261
addAccessRights:aCollection
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1262
    "add the access rights as specified in aCollection for the file represented
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1263
     by the receiver. The argument must be a collection of symbols,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1264
     such as #readUser, #writeGroup etc."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1265
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1266
    |access|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1267
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1268
    access := OperatingSystem accessModeOf:nameString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1269
    aCollection do:[:accessSymbol |
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1270
	access := access bitOr:(OperatingSystem accessMaskFor:accessSymbol).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1271
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1272
    OperatingSystem changeAccessModeOf:nameString to:access
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1273
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1274
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1275
     'foo' asFilename writeStream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1276
     'foo' asFilename addAccessRights:#(readUser readGroup readOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1277
     'foo' asFilename addAccessRights:#(writeUser writeGroup writeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1278
     'foo' asFilename addAccessRights:#(executeUser executeGroup executeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1279
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1280
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1281
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1282
removeAccessRights:aCollection
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1283
    "remove the access rights as specified in aCollection for the file represented
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1284
     by the receiver. The argument must be a collection of symbols,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1285
     such as #readUser, #writeGroup etc."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1286
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1287
    |access|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1288
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1289
    access := OperatingSystem accessModeOf:nameString.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1290
    aCollection do:[:accessSymbol |
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1291
	access := access bitAnd:(OperatingSystem accessMaskFor:accessSymbol) bitInvert.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1292
    ].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1293
    OperatingSystem changeAccessModeOf:nameString to:access
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1294
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1295
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1296
     'foo' asFilename writeStream close.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1297
     'foo' asFilename removeAccessRights:#(readUser readGroup readOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1298
     'foo' asFilename removeAccessRights:#(writeUser writeGroup writeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1299
     'foo' asFilename removeAccessRights:#(executeUser executeGroup executeOthers).
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1300
    "
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1301
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1302
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1303
makeReadableForAll
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1304
    "make the file readable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1305
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1306
    self addAccessRights:#(readUser readGroup readOthers)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1307
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1308
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1309
makeReadable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1310
    "make the file readable for  the owner - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1311
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1312
    self addAccessRights:#(readUser)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1313
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1314
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1315
makeWritable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1316
    "make the file writableable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1317
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1318
    self addAccessRights:#(writeUser)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1319
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1320
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1321
makeWritableForAll
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1322
    "make the file writable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1323
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1324
    self addAccessRights:#(writeUser writeGroup writeOthers)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1325
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1326
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1327
makeUnwritable
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1328
    "make the file unwritable for all - you must have permission to do so."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1329
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1330
    self removeAccessRights:#(writeUser writeGroup writeOthers)
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1331
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1332
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1333
!Filename methodsFor:'file utilities'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1334
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1335
fileIn
2
claus
parents: 1
diff changeset
  1336
    "load smalltalk code from the file"
claus
parents: 1
diff changeset
  1337
claus
parents: 1
diff changeset
  1338
    ^ self readStream fileIn
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1339
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1340
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1341
edit
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1342
    "start an editView on the file represented by the receiver"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1343
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1344
    EditTextView openOn:self asString
276
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1345
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1346
    "
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1347
     'smalltalk.rc' asFilename edit
3b6d97620494 *** empty log message ***
claus
parents: 249
diff changeset
  1348
    "
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1349
!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1350
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1351
contentsOfEntireFile
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1352
    "return the contents of the file as a string"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1353
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1354
    |s contents|
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1355
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1356
    s := self readStream.
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1357
    [
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1358
	contents := s contents
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1359
    ] valueNowOrOnUnwindDo:[s close].
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1360
    ^ contents
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1361
! !
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1362
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1363
!Filename methodsFor:'file access'!
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1364
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1365
newReadWriteStream
325
claus
parents: 308
diff changeset
  1366
    "return a stream for read/write the file represented by the receiver.
claus
parents: 308
diff changeset
  1367
     If the file does not already exist, it is created."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1368
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1369
    ^ FileStream newFileNamed:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1370
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1371
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1372
readWriteStream
325
claus
parents: 308
diff changeset
  1373
    "return a stream for read/write the file represented by the receiver.
claus
parents: 308
diff changeset
  1374
     If the file does not already exist, nil is returned."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1375
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1376
    ^ FileStream oldFileNamed:nameString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1377
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1378
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1379
readStream
325
claus
parents: 308
diff changeset
  1380
    "return a stream for reading from the file represented by the receiver.
claus
parents: 308
diff changeset
  1381
     If the file does not already exist, nil is returned."
2
claus
parents: 1
diff changeset
  1382
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1383
    ^ FileStream readonlyFileNamed:nameString
325
claus
parents: 308
diff changeset
  1384
claus
parents: 308
diff changeset
  1385
    "
claus
parents: 308
diff changeset
  1386
     '/tmp/foo' asFilename readStream 
claus
parents: 308
diff changeset
  1387
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1388
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1389
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1390
writeStream
325
claus
parents: 308
diff changeset
  1391
    "return a stream for writing to the file represented by the receiver.
claus
parents: 308
diff changeset
  1392
     If the file does not already exist, it is created."
2
claus
parents: 1
diff changeset
  1393
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1394
    ^ FileStream newFileForWritingNamed:nameString
325
claus
parents: 308
diff changeset
  1395
claus
parents: 308
diff changeset
  1396
    "
claus
parents: 308
diff changeset
  1397
     '/tmp/foo' asFilename writeStream 
claus
parents: 308
diff changeset
  1398
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1399
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1400
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1401
appendingWriteStream
325
claus
parents: 308
diff changeset
  1402
    "return a stream for appending to the file represented by the receiver.
claus
parents: 308
diff changeset
  1403
     If the file does not already exist, it is created."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1404
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1405
    ^ FileStream appendingOldFileNamed:nameString 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1406
! !
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1407
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1408
!Filename methodsFor:'printing & storing'!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1409
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1410
storeOn:aStream
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1411
    "append a printed representation of the receiver to aStream,
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1412
     which allows reconstructing it via readFrom:"
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1413
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1414
    aStream nextPut:$(.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1415
    nameString storeOn:aStream.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1416
    aStream nextPutAll:' asFilename)'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1417
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1418
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1419
printOn:aStream
174
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1420
    "append a printed representation of the receiver to aStream."
9e273c60e785 more functions
claus
parents: 159
diff changeset
  1421
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1422
    aStream nextPutAll:'FileName('''.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1423
    nameString printOn:aStream.
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1424
    aStream nextPutAll:''')'
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1425
! !