OpenVMSFilename.st
author Claus Gittinger <cg@exept.de>
Tue, 16 Sep 1997 06:06:10 +0200
changeset 2934 eef5b537406e
parent 2932 427725621da0
child 2937 3f64925c9df3
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
     1
'From Smalltalk/X, Version:3.1.9 on 9-sep-1997 at 11:55:40 pm'                  !
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
Filename subclass:#OpenVMSFilename
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
     4
	instanceVariableNames:'osName'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
     5
	classVariableNames:'StandardSuffixTable'
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	poolDictionaries:''
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
	category:'OS-OpenVMS'
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
!
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    10
Object subclass:#NameComponents
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    11
	instanceVariableNames:'volume directory filename'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    12
	classVariableNames:''
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    13
	poolDictionaries:''
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    14
	privateIn:OpenVMSFilename
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    15
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    16
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    17
!OpenVMSFilename class methodsFor:'documentation'!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    18
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    19
copyright
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    20
"
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    21
 COPYRIGHT (c) 1997 by eXept Software AG
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    22
              All Rights Reserved
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    23
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    24
 This software is furnished under a license and may be used
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    25
 only in accordance with the terms of that license and with the
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    26
 inclusion of the above copyright notice.   This software may not
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    27
 be provided or otherwise made available to, or used by, any
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    28
 other person.  No title to or ownership of the software is
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    29
 hereby transferred.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    30
"
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    31
!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    32
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    33
documentation
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    34
"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    35
    Filenames in OpenVMS.
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    36
    
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    37
    For your convenience, UNIX style filenames are converted
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    38
    to VMS format.
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    39
"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    40
! !
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
    41
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    42
!OpenVMSFilename class methodsFor:'initialization'!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    43
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    44
initStandardSuffixTable
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    45
    "since there is no 'file' command to extract the type,
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    46
     return a guess based upon the files suffix. The following
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    47
     table defines what is returned."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    48
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    49
    StandardSuffixTable := Dictionary new.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    50
    #(  
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    51
	'COM'	'command procedure'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    52
	'DIR'	'directory'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    53
	'EXE'	'executable'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    54
    	'LIS'	'listing'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    55
    	'OBJ'	'object file'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    56
    	'TMP'	'temporary'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    57
    	'ADA'	'ADA source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    58
    	'BAS'	'basic source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    59
    	'C'	'c source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    60
    	'COB'	'cobol source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    61
    	'FOR'	'fortran source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    62
    	'PAS'	'pascal source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    63
    	'PL1'	'PL/1 source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    64
    	'ST'	'smalltalk source'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    65
    	'STH'	'stc generated header'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    66
    ) pairWiseDo:[:k :v |
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    67
	StandardSuffixTable at:k put:v
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    68
    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    69
! !
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    70
2913
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    71
!OpenVMSFilename class methodsFor:'instance creation'!
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    72
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    73
currentDirectory
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    74
    "return a filename for the current directory"
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    75
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    76
    ^ self named:'[]'
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    77
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    78
    "
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    79
     Filename currentDirectory
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    80
    "
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    81
!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    82
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    83
rootDirectory
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    84
    "return a filename for the root directory"
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    85
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    86
    ^ self named:'[000000]'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    87
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    88
    "
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    89
     Filename rootDirectory
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    90
    "
2913
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    91
! !
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
    92
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    93
!OpenVMSFilename class methodsFor:'parsing'!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    94
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    95
components:aString
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    96
    "break a filenameString into path components.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    97
     Cannot really do it, since applications assume, they can
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    98
     create a valid path by concatenating a dirName, the separator
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
    99
     and a baseName."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   100
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   101
    |idx|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   102
2934
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   103
    idx := (aString lastIndexOf:$]) max:(aString lastIndexOf:self separator).
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   104
    idx ~~ 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   105
	^ OrderedCollection 
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   106
	        with:(aString copyTo:idx)
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   107
		with:(aString copyFrom:idx+1)
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   108
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   109
    ^ OrderedCollection with:aString
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   110
! !
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   111
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   112
!OpenVMSFilename methodsFor:'helpers'!
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   113
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   114
nameFromComponents:aComponentObject
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   115
    "concatenate the components, return a fileNameString"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   116
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   117
    |sv sd sf s sep volume directory filename dcomps idx|
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   118
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   119
    volume := aComponentObject volume.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   120
    directory := aComponentObject directory.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   121
    filename := aComponentObject filename.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   122
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   123
    volume notNil ifTrue:[
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   124
        sv := volume , ':'
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   125
    ] ifFalse:[
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   126
        sv := ''
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   127
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   128
    directory size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   129
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   130
	"/ strip of '-''s - if possible
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   131
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   132
	(directory includes:$-) ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   133
	    dcomps := directory asCollectionOfSubstringsSeparatedBy:$..
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   134
	    [(idx := dcomps indexOf:'-') > 1] whileTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   135
		((dcomps at:(idx-1)) ~= '-') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   136
		    dcomps := (dcomps copyTo:(idx-2)) , (dcomps copyFrom:idx+1)
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   137
		]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   138
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   139
	    directory := dcomps asStringWith:$.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   140
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   141
        sd := '[' , directory , ']'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   142
    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   143
	sd := ''
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   144
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   145
    filename size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   146
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   147
	"/ soon no longer needed - I never create UNIX names
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   148
	"/ internally ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   149
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   150
	(filename includesAny:'/\') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   151
	    (filename includes:$/) ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   152
		"/ a UNIX component given ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   153
		sep := $/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   154
	    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   155
		"/ an MSDOS component given ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   156
		sep := $\
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   157
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   158
	    "/ special hack - convert UNIX/MSDOS path to VMS conventions
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   159
	    (filename startsWith:sep) ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   160
		"/ mhm that should not happen ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   161
		filename := filename copyFrom:2
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   162
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   163
	    (filename endsWith:sep) ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   164
		"/ mhm that should not happen ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   165
		filename := filename copyWithoutLast:1
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   166
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   167
	    dcomps := filename asCollectionOfSubstringsSeparatedBy:sep.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   168
	    sf := dcomps last.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   169
	    dcomps := dcomps copyWithoutLast:1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   170
	    dcomps := dcomps 
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   171
			collect:[:aDirComponent |
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   172
				    aDirComponent = '..' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   173
				        '-'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   174
				    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   175
				        aDirComponent
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   176
				    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   177
	    		        ].		    
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   178
    	    directory size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   179
	        sd := '[' , directory , '.' , (dcomps asStringWith:$.) , ']'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   180
	    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   181
	        sd := '[' , (dcomps asStringWith:$.) , ']'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   182
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   183
	] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   184
            sf := filename
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   185
	]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   186
    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   187
	sf := ''
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   188
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   189
    s := sv, sd, sf.
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   190
    s isEmpty ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   191
        ^ '[]'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   192
    ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   193
    ^ s
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   194
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   195
    "Modified: 9.9.1997 / 09:38:41 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   196
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   197
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   198
parseComponentsFrom:aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   199
    "given a pathName, decompose into volume, directory & filename.
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   200
     Return the components as a componentObject (which is a dump
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   201
     container for those components).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   202
     Beside parsing VMS filenames, this also detects UNIX and MSDOS
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   203
     names and tries to convert them into VMS format - however,
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   204
     in your applications you probably should not depend on this
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   205
     to work out correctly every time. To make certain, only
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   206
     provide relative UNIX/MSDOS pathnames (if at all)."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   207
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   208
    |nameString v d f idx0 idx idx1 idx2 dcomps sep abs len|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   209
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   210
    nameString := aString.
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   211
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   212
    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   213
    "/ hack - allow Unix names ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   214
    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   215
    nameString = '.' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   216
        'OpenVMSFilename [warning]: use of Unix name: ''.''' infoPrintCR.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   217
        nameString := '[]'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   218
    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   219
        nameString = '..' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   220
            'OpenVMSFilename [warning]: use of Unix name: ''..''' infoPrintCR.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   221
            nameString := '[-]'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   222
        ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   223
	     nameString = '/' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   224
                'OpenVMSFilename [warning]: use of Unix name: ''/''' infoPrintCR.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   225
	        nameString := '[000000]'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   226
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   227
	]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   228
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   229
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   230
    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   231
    "/ a unix or msdos filename - convert.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   232
    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   233
    (nameString includesAny:'/\') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   234
	(nameString includes:$/) ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   235
	    "/ a UNIX component given ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   236
	    sep := $/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   237
	] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   238
	    "/ an MSDOS component given ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   239
	    sep := $\
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   240
	].
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   241
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   242
	"/ although not legal,
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   243
	"/ we support the form volume:<unixPath>
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   244
	"/ this makes your life easier in the FileBrowser
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   245
	"/ or FileEntry dialogs. However, you should not
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   246
	"/ place such filenames into your program, since
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   247
	"/ those are not compatible with UNIX/MSDOS conventions
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   248
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   249
	idx1 := nameString indexOf:sep.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   250
	idx2 := nameString indexOf:$:.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   251
	idx2 ~~ 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   252
	    idx2 < idx1 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   253
	        "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   254
	        "/ something like:
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   255
	        "/   volume:<unixPath>
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   256
	        "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   257
		v := nameString copyTo:idx2-1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   258
		nameString := nameString copyFrom:idx2+1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   259
		idx1 := nameString indexOf:$/.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   260
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   261
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   262
	abs := false.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   263
	(nameString startsWith:sep) ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   264
	    abs := true.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   265
	    nameString := nameString copyFrom:2.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   266
	    [nameString startsWith:sep] whileTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   267
	        nameString := nameString copyFrom:2.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   268
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   269
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   270
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   271
	dcomps := nameString asCollectionOfSubstringsSeparatedBy:$/.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   272
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   273
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   274
	"/ replace '..' by '-'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   275
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   276
	dcomps replaceAll:'..' with:'-'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   277
	f := dcomps last.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   278
	d := (dcomps copyWithoutLast:1) asStringWith:$..
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   279
	abs ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   280
	    d := '.' , d
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   281
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   282
	nameString := '[' , d , ']' , f
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   283
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   284
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   285
    nameString = '[]' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   286
	"/ replace by currentDirectory
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   287
	nameString := OperatingSystem pathNameOf:'[]'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   288
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   289
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   290
    len := nameString size.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   291
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   292
    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   293
    "/ is there a volume ?
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   294
    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   295
    idx := nameString indexOf:$:.
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   296
    idx ~~ 0 ifTrue:[
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   297
        v := nameString copyTo:idx - 1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   298
	"/ eat up any additional colons
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   299
	[(idx < len) and:[(nameString at:idx+1)==$:]] whileTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   300
	    idx := idx + 1
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   301
	]
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   302
    ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   303
    idx := idx + 1.
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   304
    idx > len ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   305
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   306
	"/ a volume alone; i.e.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   307
	"/ something like: 'volume:'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   308
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   309
    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   310
	d := ''.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   311
        [(idx < len)
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   312
	 and:[(nameString at:idx) == $[ ]] whileTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   313
            idx0 := idx + 1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   314
            idx := nameString indexOf:$] startingAt:idx0.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   315
            idx == 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   316
                "/ mhmh - malformed. what should we do here ?
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   317
                self error:'malformed filename'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   318
            ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   319
	    d isEmpty ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   320
                d := nameString copyFrom:idx0 to:(idx-1).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   321
	    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   322
		d := d , '.' , (nameString copyFrom:idx0 to:(idx-1)).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   323
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   324
            idx := idx + 1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   325
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   326
	    "/ eat up any additional colons
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   327
	    [(idx <= len) and:[(nameString at:idx)==$:]] whileTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   328
	        idx := idx + 1
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   329
	    ]
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   330
        ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   331
        f := nameString copyFrom:idx.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   332
	"/ if the directory starts with '000000.', cut it off
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   333
	(d startsWith:'000000.') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   334
	    d := d copyFrom:8
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   335
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   336
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   337
	"/ check if the filename component has multiple '.'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   338
	"/ characters in it; if so, translate them into
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   339
	"/ underscore characters (except for the last one).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   340
	f size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   341
	    (f occurrencesOf:$.) > 1 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   342
		f replaceAll:$. with:$_ from:1 to:(f lastIndexOf:$.)-1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   343
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   344
	].
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   345
    ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   346
    ^ NameComponents basicNew volume:v directory:d filename:f
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   347
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   348
    "Modified: 9.9.1997 / 08:50:04 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   349
! !
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   350
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
!OpenVMSFilename class methodsFor:'queries'!
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   353
directorySuffix
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   354
    ^ '.DIR'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   355
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   356
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
isBadCharacter:aCharacter
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
    "return true, if aCharacter is unallowed in a filename."
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   360
    ('/\' includes:aCharacter) ifTrue:[^ true].
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
    ^ super isBadCharacter:aCharacter
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
    "Created: 8.9.1997 / 00:14:47 / cg"
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
!
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   366
isCaseSensitive
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   367
    "return true, if filenames are case sensitive.return true, if filenames are case sensitive."
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   368
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   369
    ^ false
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   370
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   371
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   372
maxComponentLength
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   373
    "return the maximum number of characters a filename component
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   374
     may have in VMS"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   375
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   376
    ^ 39
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   377
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   378
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   379
maxLength
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   380
    "return the maximum number of characters a filename may have in VMS"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   381
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   382
    ^ 1024
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   383
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   384
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
separator
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
    "return the file/directory separator.
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
     For openVMS, the separator concept does not really fit,
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   388
     since names are composed as 'volume:[dir.dir.dir]file.ext'."
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
     ^ $.
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   392
     "
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   393
      Filename concreteClass separator  
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
     "
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   396
    "Created: 8.9.1997 / 00:17:28 / cg"
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   397
    "Modified: 9.9.1997 / 08:51:01 / cg"
2907
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   398
!
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
tempFileNameTemplate
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
    "return a template for temporary files.
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
     This is expanded with the current processID and a sequenceNumber
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
     to generate a unique filename."
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
    ^ 'AAA_%1_%2.TMP'
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
    "Created: 8.9.1997 / 00:01:46 / cg"
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
    "Modified: 8.9.1997 / 00:29:23 / cg"
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   409
! !
1666bf27f351 VMS changes
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   411
!OpenVMSFilename methodsFor:'file queries'!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   412
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   413
fileType
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   414
    "this returns a string describing the type of contents of
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   415
     the file. Here, the suffix is examined for a standard
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   416
     suffix and an appropriate string is returned.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   417
     Poor VMS - no file command."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   418
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   419
    |suff type info fmt|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   420
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   421
    StandardSuffixTable isNil ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   422
	self class initStandardSuffixTable
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   423
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   424
    
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   425
    suff := self suffix asUppercase.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   426
    type := StandardSuffixTable at:suff ifAbsent:nil.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   427
    type isNil ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   428
	type := super filyType.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   429
	type = 'file' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   430
	    "/ look at its record format
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   431
	    info := self info.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   432
	    fmt := info recordFormat ? ''.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   433
	    fmt size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   434
	        type := type , '(' , fmt ,')'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   435
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   436
	]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   437
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   438
    ^ type
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   439
! !
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   440
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   441
!OpenVMSFilename methodsFor:'private accessing'!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   442
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   443
osNameForDirectory
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   444
    "internal - return the OS's name for the receiver when
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   445
     used as a directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   446
     On VMS, a path like '[dir1]dir2' must be converted to
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   447
     '[dir1.dir2]' in order for the OS calls to retrieve
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   448
     correct information."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   449
  
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   450
    |comps f d|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   451
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   452
    comps := self parseComponentsFrom:nameString.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   453
    d := comps directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   454
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   455
    (f := comps filename) size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   456
	(f asUppercase endsWith:'.DIR') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   457
	    f := f copyWithoutLast:4
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   458
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   459
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   460
	"/ something like v:file or v:[dir]file
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   461
	"/ make it: v:[.file] or v:[dir.file]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   462
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   463
	d isNil ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   464
	    d := ''
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   465
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   466
	comps directory:(d , '.' , f).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   467
	comps filename:''.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   468
	^ self nameFromComponents:comps
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   469
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   470
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   471
    "/ ok, an empty fileName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   472
    d size == 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   473
	"/ v: -> v:[000000]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   474
	
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   475
	comps directory:'000000'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   476
	^ self nameFromComponents:comps
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   477
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   478
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   479
    "/ v:[d1.d2] -> remains
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   480
    ^ nameString
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   481
!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   482
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   483
osNameForFile
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   484
    "internal - return the OS's name for the receiver.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   485
     On VMS, a path like '[dir1.dir2]' must be converted to
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   486
     '[dir1]dir2.dir' in order for the OS calls to retrieve
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   487
     correct information."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   488
  
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   489
    |comps f d v idx|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   490
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   491
    osName notNil ifTrue:[^ osName].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   492
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   493
    comps := self parseComponentsFrom:nameString.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   494
    d := comps directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   495
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   496
    (f := comps filename) size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   497
	d size == 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   498
	    v := comps volume.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   499
	    v size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   500
	        "/ something like v:file
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   501
	        "/ make it: v:[000000]file
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   502
	        comps directory:'000000'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   503
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   504
	].
2932
427725621da0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2925
diff changeset
   505
	"/
427725621da0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2925
diff changeset
   506
	"/ if it has no suffix, at least append a suffix character
427725621da0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2925
diff changeset
   507
	"/
427725621da0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2925
diff changeset
   508
	(f includes:$.) ifFalse:[
427725621da0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2925
diff changeset
   509
	    comps filename:(f , '.')
427725621da0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2925
diff changeset
   510
	].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   511
	osName := self nameFromComponents:comps.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   512
	^ osName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   513
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   514
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   515
    "/ ok, an empty fileName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   516
    d size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   517
        idx := d lastIndexOf:$..
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   518
        idx ~~ 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   519
	    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   520
	    "/ something like: '[d1.d2]' -> '[d1]d2.DIR'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   521
	    "/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   522
	    comps directory:(d copyTo:(idx-1)).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   523
	    comps filename:((d copyFrom:idx+1) , '.DIR').
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   524
            osName := self nameFromComponents:comps.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   525
	    ^ osName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   526
        ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   527
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   528
	"/ something like: '[d]' -> '[000000]d.DIR'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   529
	"/
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   530
	comps directory:'000000'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   531
	comps filename:(d , '.DIR').
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   532
	osName := self nameFromComponents:comps.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   533
	^ osName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   534
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   535
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   536
    "/ mhmh - an empty directory and empty file
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   537
    "/ i.e. something like v:
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   538
    "/ make it: v:000000.dir
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   539
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   540
    osName := nameString , '[000000]'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   541
    ^ osName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   542
! !
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   543
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   544
!OpenVMSFilename methodsFor:'instance creation'!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   545
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   546
constructString:subname
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   547
    "taking the receiver as a directory name, construct a new
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   548
     filename-string for an entry within this directory
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   549
     (i.e. for a file or a subdirectory in that directory)."
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   550
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   551
    |d f comps dcomps sub subcomps subD|
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   552
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   553
    comps := self parseComponentsFrom:nameString.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   554
    d := comps directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   555
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   556
    (f := comps filename) size > 0 ifTrue:[
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   557
        "/ path was of the form vol:[d1...dN]foo
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   558
        "/ assume foo is a directory and append it to directory path.
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   559
	"/ effectively clearing the filename part.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   560
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   561
	"/ cut off .DIR ending
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   562
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   563
        (f asUppercase endsWith:'.DIR') ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   564
            f := f copyWithoutLast:4
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   565
        ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   566
	(d size == 0 or:[d = '000000']) ifTrue:[
2913
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
   567
	    d := f.
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
   568
	] ifFalse:[
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   569
	    d := d , '.' , f
2913
31d7aab40357 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2911
diff changeset
   570
	].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   571
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   572
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   573
    "/ UNIX compatibility
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   574
    sub := subname.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   575
    (sub = '..') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   576
        sub := '-'
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   577
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   578
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   579
    sub = '-' ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   580
        "/ try to cut it off here ...
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   581
        dcomps := d asCollectionOfSubstringsSeparatedBy:$..
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   582
        dcomps size > 1 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   583
	    "/ 'foo.bar.baz.-' -> 'foo.bar'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   584
            dcomps := dcomps copyWithoutLast:1.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   585
            d := (dcomps asStringWith:$.).
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   586
        ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   587
	    dcomps size == 1 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   588
	        "/ 'foo.-' -> '000000'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   589
                d := '000000'.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   590
	    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   591
	        "/ 'any.-'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   592
                d := d , '.' , sub.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   593
	    ]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   594
        ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   595
	sub := ''
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   596
    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   597
        "/ get subnames components
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   598
        subcomps := self parseComponentsFrom:subname.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   599
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   600
	"/ concatenate
2934
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   601
	d size == 0 ifTrue:[
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   602
	    d := ''.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   603
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   604
	subD := subcomps directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   605
	subD size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   606
	    (subD startsWith:$.) ifTrue:[
2934
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   607
		(d = '' and:[comps volume size > 0]) ifTrue:[
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   608
		    "/ I am a volume only; no initial '.' in dir.
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   609
		    d := subD copyFrom:2
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   610
		] ifFalse:[
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   611
		    d := d , subD
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   612
		]
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   613
	    ] ifFalse:[
2934
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   614
		(d = '' and:[comps volume size > 0]) ifTrue:[
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   615
		    "/ I am a volume only; no initial '.' in dir.
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   616
		    d := subD
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   617
		] ifFalse:[
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   618
		    d := d , '.' , subD
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   619
		]
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   620
	    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   621
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   622
	sub := subcomps filename.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   623
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   624
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   625
    comps directory:d.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   626
    comps filename:sub.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   627
    ^ self nameFromComponents:comps
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   628
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   629
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   630
     (OpenVMSFilename named:'sys$root:[foo.bar]') construct:'baz'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   631
     (OpenVMSFilename named:'sys$root:[foo.bar]baz') construct:'foo'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   632
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   633
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   634
    "Modified: 9.9.1997 / 05:26:04 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   635
! !
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   636
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   637
!OpenVMSFilename methodsFor:'queries'!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   638
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   639
isAbsolute
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   640
    "return true, if the receiver represents an absolute pathname
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   641
     (in contrast to one relative to the current directory)."
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   642
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   643
    |comps d|
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   644
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   645
    comps := self parseComponentsFrom:nameString.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   646
    (d := comps directory) isNil ifTrue:[
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   647
        "/ mhmh ...
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   648
	comps volume size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   649
	    "/ something like v:file
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   650
	    "/ (assumed in v's root dir)
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   651
	    ^ true
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   652
	].
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   653
        ^ false
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   654
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   655
    d size == 0 ifTrue:[
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   656
        "/ [] - the current directory is relative
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   657
        ^ false
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   658
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   659
    d = '-' ifTrue:[
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   660
        "/ [-] - the parent directory is relative
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   661
        ^ false
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   662
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   663
    (d startsWith:'-.') ifTrue:[
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   664
        "/ [-.] - some parent directory is relative
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   665
        ^ false
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   666
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   667
    ^ (d startsWith:'.') not
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   668
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   669
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   670
     (OpenVMSFilename named:'dka:[foo.bar]baz.st') isAbsolute   
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   671
     (OpenVMSFilename named:'[foo.bar]baz.st') isAbsolute    
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   672
     (OpenVMSFilename named:'[.foo.bar]baz.st') isAbsolute   
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   673
     (OpenVMSFilename named:'[]baz.st') isAbsolute           
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   674
     (OpenVMSFilename named:'[-]baz.st') isAbsolute    
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   675
     (OpenVMSFilename named:'[-.-]baz.st') isAbsolute   
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   676
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   677
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   678
    "Modified: 9.9.1997 / 09:03:42 / cg"
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   679
!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   680
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   681
isExplicitRelative
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   682
    "return true, if this name is an explicit relative name
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   683
    (i.e. dir starts with '[.name]' or '[-.]', to avoid path-prepending)"
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   684
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   685
    |comps d|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   686
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   687
    comps := self parseComponentsFrom:nameString.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   688
    d := comps directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   689
    d size > 0 ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   690
	(d startsWith:'.') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   691
	    ^ true
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   692
	].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   693
	(d startsWith:'-.') ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   694
	    ^ true
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   695
	]
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   696
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   697
    ^ false
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   698
! !
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   699
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   700
!OpenVMSFilename methodsFor:'queries-path & name'!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   701
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   702
baseName
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   703
    "return my baseName as a string.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   704
     - thats the file/directory name without leading parent-dirs.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   705
     See also: #pathName, #directoryName and #directoryPathName.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   706
     Compatibility note: use #tail for ST-80 compatibility."
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   707
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   708
    |idx d f comps|
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   709
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   710
    comps := self parseComponentsFrom:nameString.
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   711
    (f := comps filename) size > 0  ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   712
        ^ f
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   713
    ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   714
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   715
    "/ path was of the form vol:[d1...dN]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   716
    "/ cut off the last directory.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   717
    d := comps directory.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   718
    d notNil ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   719
        d = '' ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   720
            "/ [] 
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   721
            "/ ought to get the current directory ...
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   722
            ^ ''
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   723
        ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   724
        d = '-' ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   725
            "/ [-]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   726
            "/ ought to get the current directory ...
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   727
            ^ ''
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   728
        ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   729
        (d endsWith:'.-') ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   730
            "/ [rest.-]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   731
            "/ ought to expand and get final directory ...
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   732
            ^ ''
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   733
        ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   734
        idx := d lastIndexOf:$..
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   735
        idx ~~ 0 ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   736
            ^ (d copyFrom:idx+1) , '.DIR'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   737
        ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   738
        ^ d , '.DIR'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   739
    ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   740
    ^ ''
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   741
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   742
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   743
     (OpenVMSFilename named:'dka100:[stx.libbasic]Object.st') baseName
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   744
     (OpenVMSFilename named:'stx$root:[stx.libbasic.-]Object.st') baseName 
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   745
     (OpenVMSFilename named:'[-]Object.st') baseName                       
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   746
     (OpenVMSFilename named:'[]Object.st') baseName                        
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   747
     (OpenVMSFilename named:'Object.st') baseName                          
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   748
     (OpenVMSFilename named:'[stx.libbasic]') baseName                     
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   749
     (OpenVMSFilename named:'[stx]') baseName                     
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   750
     (OpenVMSFilename named:'[]') baseName                     
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   751
     (OpenVMSFilename named:'[-]') baseName                     
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   752
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   753
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   754
    "Created: 9.9.1997 / 09:23:15 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   755
    "Modified: 9.9.1997 / 10:52:04 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   756
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   757
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   758
directoryName
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   759
    "return the directory name part of the file/directory as a string.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   760
     - thats the name of the directory where the file/dir represented by
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   761
       the receiver is contained in.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   762
     (this is almost equivalent to #directory, but returns
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   763
      a string instead of a Filename instance).
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   764
     See also: #pathName, #directoryPathName and #baseName.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   765
     Compatibility note: use #head for ST-80 compatibility."
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   766
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   767
    |idx d f comps|
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   768
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   769
    comps := self parseComponentsFrom:nameString.
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   770
    d := comps directory.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   771
    (f := comps filename) size > 0  ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   772
        comps filename:nil.
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   773
        ^ self nameFromComponents:comps
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   774
    ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   775
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   776
    "/ path was of the form vol:[d1...dN]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   777
    "/ cut off the last directory.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   778
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   779
    d isNil ifFalse:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   780
        d = '' ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   781
            "/ [] -> [-]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   782
        ] ifFalse:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   783
            d = '-' ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   784
                "/ [-] -> [-.-]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   785
                d := '-.-'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   786
            ] ifFalse:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   787
                (d endsWith:'.-') ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   788
                    "/ [rest.-] -> [rest.-.-]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   789
                    d := d , '.-'
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   790
                ] ifFalse:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   791
                    idx := d lastIndexOf:$..
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   792
                    idx ~~ 0 ifTrue:[
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   793
                        d := d copyTo:idx-1
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   794
                    ]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   795
                ]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   796
            ]
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   797
        ].
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   798
        comps directory:d.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   799
    ].
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   800
    ^ self nameFromComponents:comps
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   801
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   802
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   803
     (OpenVMSFilename named:'dka100:[stx.libbasic]Object.st') directoryName
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   804
     (OpenVMSFilename named:'stx$root:[stx.libbasic.-]Object.st') directoryName 
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   805
     (OpenVMSFilename named:'[-]Object.st') directoryName                       
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   806
     (OpenVMSFilename named:'[]Object.st') directoryName                        
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   807
     (OpenVMSFilename named:'Object.st') directoryName                          
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   808
     (OpenVMSFilename named:'[stx.libbasic]') directoryName                     
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   809
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   810
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   811
    "Created: 9.9.1997 / 09:23:15 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   812
    "Modified: 9.9.1997 / 10:36:42 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   813
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   814
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   815
isVolumeOnly
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   816
    "temporary kludge - return true, if the receiver consists of
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   817
     a volume name only"
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   818
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   819
    |comps|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   820
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   821
    comps := self parseComponentsFrom:nameString.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   822
    comps directory size > 0 ifTrue:[^ false].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   823
    comps filename size >0 ifTrue:[^ false].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   824
    ^ true
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   825
!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   826
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   827
volume
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   828
    "return the disc volume part of the name or an empty string."
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   829
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   830
    ^ (self parseComponentsFrom:nameString) volume ? ''
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   831
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   832
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   833
     (OpenVMSFilename named:'dka100:[stx.libbasic]Object.st') volume  
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   834
     (OpenVMSFilename named:'stx$root:[stx.libbasic.-]Object.st') volume 
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   835
     (OpenVMSFilename named:'[-]Object.st') volume                       
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   836
     (OpenVMSFilename named:'[]Object.st') volume                        
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   837
     (OpenVMSFilename named:'Object.st') volume                          
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   838
     (OpenVMSFilename named:'[stx.libbasic]') volume                     
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   839
    "
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   840
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   841
    "Modified: 9.9.1997 / 08:56:05 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   842
! !
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   843
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   844
!OpenVMSFilename::NameComponents methodsFor:'accessing'!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   845
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   846
directory
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   847
    ^ directory
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   848
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   849
    "Created: 9.9.1997 / 05:21:04 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   850
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   851
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   852
directory:aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   853
    directory := aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   854
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   855
    "Created: 9.9.1997 / 05:21:11 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   856
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   857
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   858
filename
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   859
    ^ filename
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   860
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   861
    "Created: 9.9.1997 / 05:21:23 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   862
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   863
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   864
filename:aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   865
    filename := aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   866
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   867
    "Created: 9.9.1997 / 05:21:28 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   868
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   869
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   870
volume
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   871
    ^ volume
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   872
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   873
    "Created: 9.9.1997 / 05:20:58 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   874
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   875
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   876
volume:aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   877
    volume := aString
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   878
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   879
    "Created: 9.9.1997 / 05:21:17 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   880
!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   881
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   882
volume:v directory:d filename:n
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   883
    volume := v.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   884
    directory := d.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   885
    filename := n.
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   886
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   887
    "Created: 9.9.1997 / 05:20:53 / cg"
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   888
! !
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   889
2925
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   890
!OpenVMSFilename methodsFor:'file operations'!
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   891
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   892
remove
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   893
    "remove the file/directory.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   894
     Raise an error if not successful.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   895
     Use #recursiveRemove in order to (recursively) remove non empty directories.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   896
     This has been redefined, to add ';*' to the filename, unless an explicit
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   897
     version number has been provided."
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   898
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   899
    |ok baseName osName|
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   900
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   901
    self exists ifFalse:[^ self].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   902
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   903
    osName := self osNameForFile.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   904
    self isDirectory ifTrue:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   905
	ok := OperatingSystem removeDirectory:osName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   906
    ] ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   907
        baseName := self baseName.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   908
        (baseName includes:$;) ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   909
	    osName := osName , ';*'
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   910
        ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   911
	ok := OperatingSystem removeFile:osName
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   912
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   913
    ok ifFalse:[
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   914
        self removeError:self
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   915
    ].
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   916
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   917
    "
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   918
     (FileStream newFileNamed:'foo') close.
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   919
     'foo' asFilename remove
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   920
    "
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   921
! !
1a64228425ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2913
diff changeset
   922
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   923
!OpenVMSFilename class methodsFor:'documentation'!
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   924
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   925
version
2934
eef5b537406e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2932
diff changeset
   926
    ^ '$Header: /cvs/stx/stx/libbasic/OpenVMSFilename.st,v 1.6 1997-09-16 04:06:10 cg Exp $'
2911
9964e6839a8e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2907
diff changeset
   927
! !