CharacterArray.st
author claus
Thu, 20 Apr 1995 20:04:43 +0200
changeset 327 183f094cfd72
parent 326 d2902942491d
child 328 7b542c0bf1dd
permissions -rw-r--r--
last with old match code
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     1
"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1994 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
     3
	      All Rights Reserved
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     4
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
af7aeb79b25e Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    11
"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    12
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    13
ByteArray subclass:#CharacterArray
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
    15
       classVariableNames:'PreviousMatch'
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    17
       category:'Collections-Text'
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    18
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    19
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    20
CharacterArray comment:'
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    21
COPYRIGHT (c) 1994 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    22
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
    23
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/CharacterArray.st,v 1.18 1995-04-20 18:04:43 claus Exp $
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    25
'!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    26
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    27
!CharacterArray class methodsFor:'documentation'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    28
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    29
copyright
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    30
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    31
 COPYRIGHT (c) 1994 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    32
	      All Rights Reserved
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    33
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    34
 This software is furnished under a license and may be used
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    35
 only in accordance with the terms of that license and with the
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    37
 be provided or otherwise made available to, or used by, any
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    38
 other person.  No title to or ownership of the software is
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    39
 hereby transferred.
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    40
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    41
!
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    42
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    43
version
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    44
"
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/CharacterArray.st,v 1.18 1995-04-20 18:04:43 claus Exp $
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    46
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    47
!
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    48
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    49
documentation
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    50
"
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    51
    CharacterArray is a superclass for all kinds of Strings (i.e.
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    52
    (singleByte-)Strings, TwoByteStrings and whatever comes in the future.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    53
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    54
    As the name already implies, this class is abstract, meaning that there are
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    55
    no instances of it. All this class does is provide common protocol for 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    56
    concrete subclasses.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    57
"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    58
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    59
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    60
!CharacterArray class methodsFor:'instance creation'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    61
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    62
basicNew
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    63
    "return a new empty string"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    65
    ^ self basicNew:0
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    66
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    67
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    68
new
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    69
    "return a new empty string"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    70
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    71
    ^ self basicNew:0
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    72
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    73
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    74
fromString:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    75
    "return a copy of the argument, aString"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    76
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    77
    ^ (self basicNew:(aString size)) replaceFrom:1 with:aString
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    78
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    79
    "TwoByteString fromString:'hello'"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    80
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    81
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    82
!CharacterArray methodsFor:'converting'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    83
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    84
asUppercase
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    85
    "return a copy of myself in uppercase letters"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    86
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    87
    |newStr
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    88
     mySize "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    89
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    90
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    91
    newStr := self species new:mySize.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    92
    1 to:mySize do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    93
	newStr at:i put:(self at:i) asUppercase
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    94
    ].
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
    95
    ^ newStr
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
    96
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
    97
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
    98
     'helloWorld' asUppercase      
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
    99
     'helloWorld' asUppercaseFirst 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   100
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   101
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   102
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   103
asLowercase
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   104
    "return a copy of myself in lowercase letters"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   105
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   106
    |newStr
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   107
     mySize "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   108
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   109
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   110
    newStr := self species new:mySize.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   111
    1 to:mySize do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   112
	newStr at:i put:(self at:i) asLowercase
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   113
    ].
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   114
    ^ newStr
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   115
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   116
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   117
     'HelloWorld' asLowercase   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   118
     'HelloWorld' asLowercaseFirst   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   119
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   120
!
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   121
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   122
asUppercaseFirst
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   123
    "return a copy of myself where the first character is
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   124
     converted to uppercase."
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   125
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   126
    |newString|
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   127
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   128
    newString := self copy.
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   129
    newString size > 0 ifTrue:[
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   130
	newString at:1 put:(newString at:1) asUppercase
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   131
    ].
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   132
    ^ newString
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   133
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   134
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   135
     'helloWorld' asUppercase      
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   136
     'helloWorld' asUppercaseFirst 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   137
     'HelloWorld' asUppercaseFirst   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   138
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   139
!
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   140
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   141
asLowercaseFirst
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   142
    "return a copy of myself where the first character is
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   143
     converted to lowercase."
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   144
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   145
    |newString|
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   146
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   147
    newString := self copy.
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   148
    newString size > 0 ifTrue:[
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   149
	newString at:1 put:(newString at:1) asLowercase
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   150
    ].
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   151
    ^ newString
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   152
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   153
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   154
     'HelloWorld' asLowercase   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   155
     'HelloWorld' asLowercaseFirst   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   156
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   157
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   158
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   159
asString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   160
    "return myself - I am a string"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   161
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   162
    ^ self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   163
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   164
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   165
asTwoByteString
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   166
    "return the receiver converted to a two-byte string"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   167
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   168
    ^ TwoByteString fromString:self
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   169
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   170
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   171
asSingleByteString
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   172
    "return the receiver converted to a 'normal' string"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   173
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   174
    ^ String fromString:self
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   175
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   176
244
9faa2da0650a Text <-> StringCollection
claus
parents: 215
diff changeset
   177
asStringCollection
9faa2da0650a Text <-> StringCollection
claus
parents: 215
diff changeset
   178
    "return a collection of lines from myself."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   179
247
9e3057039d60 asText eliminated
claus
parents: 244
diff changeset
   180
    ^ StringCollection from:self
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   181
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   182
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   183
asComposedText
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   184
    ^ ComposedText fromString:self
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   185
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   186
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   187
asNumber
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   188
    "read a number from the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   189
     Notice, that errors may occur during the read, so you better
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   190
     setup some signal handler when using this method."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   191
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   192
    ^ Number readFromString:self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   193
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   194
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   195
     '123'     asNumber
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   196
     '123.567' asNumber
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   197
     '(5/6)'   asNumber
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   198
     'foo'     asNumber
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   199
     Object errorSignal handle:[:ex | ex returnWith:0] do:['foo' asNumber] 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   200
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   201
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   202
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   203
asInteger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   204
    "read an integer from the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   205
     Notice, that errors may occur during the read, so you better
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   206
     setup some signal handler when using this method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   207
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   208
    ^ Integer readFromString:self
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   209
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   210
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   211
     '12345678901234567890' asInteger
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   212
     '-1234' asInteger
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   213
     '0.123' asInteger   <- reader stops at ., returning 0 here
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   214
     '0.123' asNumber    <- returns what you expect
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   215
     Object errorSignal handle:[:ex | ex returnWith:0] do:['foo' asInteger] 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   216
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   217
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   218
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   219
asFloat
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   220
    "read a float number from the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   221
     Notice, that errors may occur during the read, so you better
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   222
     setup some signal handler when using this method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   223
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   224
    ^ (Number readFromString:self) asFloat
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   225
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   226
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   227
     '0.123' asFloat 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   228
     '12345' asFloat
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   229
     '(1/5)' asFloat
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   230
     Object errorSignal handle:[:ex | ex returnWith:0] do:['foo' asFloat] 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   231
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   232
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   233
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   234
asFilename
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   235
    "return a Filename with pathname taken from the receiver"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   236
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   237
    ^ Filename named:self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   238
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   239
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   240
asCollectionOfWords
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   241
    "return a collection containing the words (separated by whitespace) 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   242
     of the receiver. Multiple occurences of whitespace characters will
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   243
     be treated like one - i.e. whitespace is skipped."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   244
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   245
    |words
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   246
     start  "{ Class:SmallInteger }" 
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   247
     stop   "{ Class:SmallInteger }" 
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   248
     mySize "{ Class:SmallInteger }"|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   249
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   250
    words := OrderedCollection new.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   251
    start := 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   252
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   253
    [start <= mySize] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   254
	start := self indexOfNonSeparatorStartingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   255
	start == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   256
	    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   257
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   258
	stop := self indexOfSeparatorStartingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   259
	stop == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   260
	    words add:(self copyFrom:start to:mySize).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   261
	    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   262
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   263
	words add:(self copyFrom:start to:(stop - 1)).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   264
	start := stop
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   265
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   266
    ^ words
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   267
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   268
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   269
     'hello world isnt this nice' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   270
     '    hello    world   isnt   this   nice  ' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   271
     'hello' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   272
     '' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   273
     '      ' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   274
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   275
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   276
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   277
asCollectionOfSubstringsSeparatedBy:aCharacter
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   278
    "return a collection containing the lines (separated by aCharacter) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   279
     of the receiver. If aCharacter occurs multiple times in a row, 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   280
     the result will contain empty strings."
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   281
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   282
    |lines myClass
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   283
     numberOfLines "{ Class:SmallInteger }"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   284
     startIndex    "{ Class:SmallInteger }"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   285
     stopIndex     "{ Class:SmallInteger }" |
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   286
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   287
    "count first, to avoid regrowing"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   288
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   289
    numberOfLines := (self occurrencesOf:aCharacter) + 1.
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   290
    lines := OrderedCollection new:numberOfLines.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   291
    myClass := self species.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   292
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   293
    startIndex := 1.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   294
    1 to:numberOfLines do:[:lineNr |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   295
	stopIndex := self indexOf:aCharacter startingAt:startIndex.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   296
	stopIndex == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   297
	    stopIndex := self size
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   298
	] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   299
	    stopIndex := stopIndex - 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   300
	].
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   301
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   302
	(stopIndex < startIndex) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   303
	    lines add:(myClass new:0)
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   304
	] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   305
	    lines add:(self copyFrom:startIndex to:stopIndex)
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   306
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   307
	startIndex := stopIndex + 2
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   308
    ].
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   309
    ^ lines
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   310
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   311
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   312
     '1 one:2 two:3 three:4 four:5 five' withCRs asCollectionOfSubstringsSeparatedBy:$: 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   313
     '1 one 2 two 3 three 4 four 5 five' withCRs asCollectionOfSubstringsSeparatedBy:Character space
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   314
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   315
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   316
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   317
asCollectionOfLines
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   318
    "return a collection containing the lines (separated by cr) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   319
     of the receiver. If multiple cr's occur in a row, the result will
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   320
     contain empty strings."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   321
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   322
    ^ self asCollectionOfSubstringsSeparatedBy:Character cr
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   323
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   324
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   325
     '1 one\2 two\3 three\4 four\5 five' withCRs asCollectionOfLines
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   326
     '1 one\\\\2 two\3 three' withCRs asCollectionOfLines  
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   327
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   328
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   329
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   330
asArrayOfSubstrings
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   331
    "return an array of substrings from the receiver, interpreting
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   332
     separators (i.e. spaces & newlines) as word-delimiters.
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   333
     This is a compatibility method - the actual work is done in
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   334
     asCollectionOfWords."
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   335
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   336
    ^ self asCollectionOfWords asArray
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   337
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   338
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   339
     '1 one two three four 5 five' asArrayOfSubstrings  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   340
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   341
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   342
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   343
asCollectionOfSubstringsSeparatedByAny:aCollectionOfSeparators
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   344
    "return a collection containing the words (separated by any character
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   345
     from aCollectionOfSeparators) of the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   346
     This allows breaking up strings using any character as separator."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   347
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   348
    |words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   349
     start  "{ Class:SmallInteger }" 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   350
     stop   "{ Class:SmallInteger }" 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   351
     mySize "{ Class:SmallInteger }"|
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   352
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   353
    words := OrderedCollection new.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   354
    start := 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   355
    mySize := self size.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   356
    [start <= mySize] whileTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   357
	"skip multiple separators"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   358
	[aCollectionOfSeparators includes:(self at:start)] whileTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   359
	    start := start + 1 .
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   360
	    start > mySize ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   361
		^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   362
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   363
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   364
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   365
	stop := self indexOfAny:aCollectionOfSeparators startingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   366
	stop == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   367
	    words add:(self copyFrom:start to:mySize).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   368
	    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   369
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   370
	words add:(self copyFrom:start to:(stop - 1)).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   371
	start := stop
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   372
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   373
    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   374
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   375
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   376
     'hello:world:isnt:this nice' asCollectionOfSubstringsSeparatedByAny:#($:)
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   377
     'hello:world:isnt:this nice' asCollectionOfSubstringsSeparatedByAny:(Array with:$: with:Character space) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   378
     'h1e2l3l4o' asCollectionOfSubstringsSeparatedByAny:($1 to: $9) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   379
    "
163
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   380
!
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   381
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   382
contractTo:maxLen
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   383
    "if the receivers size is less or equal to maxLen, return it.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   384
     Otherwise, return a copy of the receiver, where some characters 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   385
     in the middle have been replaced by '...' for a total string length
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   386
     of maxLen. Can be used to abbreviate long entries in tables."
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   387
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   388
    |sz halfSize|
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   389
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   390
    (sz := self size) > maxLen ifTrue:[
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   391
	halfSize := maxLen // 2.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   392
	^ self copyReplaceFrom:halfSize - 1
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   393
			    to:sz - maxLen + halfSize + 1
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   394
			    with:'...'
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   395
    ]
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   396
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   397
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   398
     '12345678901234' contractTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   399
     '123456789012345' contractTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   400
     '1234567890123456' contractTo:15         
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   401
     'aShortString' contractTo:15 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   402
     'aVeryLongNameForAStringThatShouldBeShortened' contractTo:15 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   403
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   404
!
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   405
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   406
contractAtEndTo:maxLen
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   407
    "if the receivers size is less or equal to maxLen, return it.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   408
     Otherwise, return a copy of the receiver, where some characters 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   409
     at the end have been replaced by '...' for a total string length
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   410
     of maxLen. Can be used to abbreviate long entries in tables."
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   411
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   412
    |sz|
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   413
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   414
    (sz := self size) > maxLen ifTrue:[
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   415
	^ self copyReplaceFrom:maxLen - 3
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   416
			    with:'...'
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   417
    ]
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   418
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   419
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   420
     '12345678901234' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   421
     '123456789012345' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   422
     '1234567890123456' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   423
     'aShortString' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   424
     'aVeryLongNameForAStringThatShouldBeShortened' contractAtEndTo:15 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   425
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   426
!
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   427
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   428
contractAtBeginningTo:maxLen
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   429
    "if the receivers size is less or equal to maxLen, return it.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   430
     Otherwise, return a copy of the receiver, where some characters 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   431
     at the beginning have been replaced by '...' for a total string length
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   432
     of maxLen. Can be used to abbreviate long entries in tables."
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   433
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   434
    |sz|
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   435
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   436
    (sz := self size) > maxLen ifTrue:[
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   437
	^ '...' , (self copyFrom:(sz - (maxLen - 4))) 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   438
    ]
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   439
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   440
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   441
     '12345678901234' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   442
     '123456789012345' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   443
     '1234567890123456' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   444
     'aShortString' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   445
     'aVeryLongNameForAStringThatShouldBeShortened' contractAtBeginningTo:15
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   446
    "
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   447
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   448
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   449
withCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   450
    "return a new string consisting of receivers characters
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   451
     with all \-characters replaced by cr-characters."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   452
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   453
    ^ self copy replaceAll:$\ by:(Character cr)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   454
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   455
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   456
     'hello\world' withCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   457
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   458
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   459
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   460
withoutCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   461
    "return a new collection consisting of receivers elements
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   462
     with all cr-characters replaced by \-characters.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   463
     This is the reverse operation of withCRs."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   464
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   465
    ^ self copy replaceAll:(Character cr) by:$\
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   466
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   467
     'hello
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   468
world' withoutCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   469
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   470
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   471
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   472
withoutSpaces
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   473
    "return a copy of myself without leading and trailing spaces.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   474
     Notice: this does NOT remove tabs, newline or any other whitespace.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   475
     Use withoutSeparators for this."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   476
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   477
    |startIndex "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   478
     endIndex   "{ Class: SmallInteger }" 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   479
     sz|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   480
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   481
    sz := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   482
    startIndex := 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   483
    endIndex := sz.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   484
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   485
    [(startIndex < endIndex) and:[(self at:startIndex) == Character space]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   486
	startIndex := startIndex + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   487
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   488
    [(endIndex > 1) and:[(self at:endIndex) == Character space]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   489
	endIndex := endIndex - 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   490
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   491
    startIndex > endIndex ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   492
	^ ''
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   493
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   494
    ((startIndex == 1) and:[endIndex == sz]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   495
	^ self
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   496
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   497
    ^ self copyFrom:startIndex to:endIndex
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   498
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   499
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   500
     '    foo    ' withoutSpaces  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   501
     'foo    '     withoutSpaces   
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   502
     '    foo'     withoutSpaces  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   503
     '       '     withoutSpaces   
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   504
     ('  foo' , Character tab asString , '    ') withoutSpaces inspect 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   505
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   506
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   507
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   508
withoutSeparators
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   509
    "return a copy of myself without leading and trailing whitespace.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   510
     Whitespace is space, tab, newline, formfeed.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   511
     Use withoutSpaces, if you want to remove spaces only."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   512
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   513
    |startIndex "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   514
     endIndex   "{ Class: SmallInteger }" 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   515
     sz|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   516
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   517
    sz := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   518
    startIndex := 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   519
    endIndex := sz.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   520
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   521
    [(startIndex < endIndex) and:[(self at:startIndex) isSeparator]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   522
	startIndex := startIndex + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   523
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   524
    [(endIndex > 1) and:[(self at:endIndex) isSeparator]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   525
	endIndex := endIndex - 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   526
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   527
    startIndex > endIndex ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   528
	^ ''
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   529
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   530
    ((startIndex == 1) and:[endIndex == sz]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   531
	^ self
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   532
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   533
    ^ self copyFrom:startIndex to:endIndex
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   534
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   535
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   536
     '    foo    ' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   537
     '    foo' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   538
     'foo    ' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   539
     '       ' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   540
     ('  foo' , Character tab asString , '    ') withoutSeparators inspect 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   541
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   542
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   543
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   544
withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   545
    "return a copy of the receiver where leading spaces are
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   546
     replaced by tabulator characters (assuming 8-col tabs)"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   547
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   548
    |idx nTabs newString|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   549
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   550
    idx := self findFirst:[:c | (c ~~ Character space)].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   551
    nTabs := (idx-1) // 8.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   552
    nTabs == 0 ifTrue:[^ self].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   553
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   554
    "any tabs"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   555
    newString := self class new:(self size - (nTabs * 7)).
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   556
    newString atAll:(1 to:nTabs) put:(Character tab).
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   557
    newString replaceFrom:(nTabs + 1) with:self startingAt:(nTabs * 8 + 1).
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   558
    ^ newString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   559
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   560
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   561
     '12345678901234567890' withTabs 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   562
     '       8901234567890' withTabs 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   563
     '        901234567890' withTabs  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   564
     '               67890' withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   565
     '                7890' withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   566
     '                 890' withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   567
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   568
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   569
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   570
withTabsExpanded
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   571
    "return a copy of the receiver where all tabulator characters
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   572
     are expanded into spaces (assuming 8-col tabs)"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   573
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   574
    |idx str|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   575
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   576
    (self includes:(Character tab)) ifFalse:[^ self].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   577
    str := WriteStream on:String new.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   578
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   579
    idx := 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   580
    self do:[:ch |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   581
	ch == Character tab ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   582
	    str nextPut:ch.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   583
	    idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   584
	] ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   585
	    (idx \\ 8) to:8 do:[:ii |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   586
		str space.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   587
		idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   588
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   589
	]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   590
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   591
    ^ str contents
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   592
! !
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   593
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   594
!CharacterArray methodsFor:'ST/V compatibility'!
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   595
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   596
replChar:oldChar with:newChar
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   597
    "return a copy of the receiver, with all oldChars replaced
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   598
     by newChar.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   599
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   600
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   601
    ^ self copy replaceAll:oldChar by:newChar
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   602
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   603
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   604
     '12345678901234567890' replChar:$0 with:$* 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   605
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   606
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   607
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   608
replChar:oldChar withString:newString
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   609
    "return a copy of the receiver, with all oldChars replaced
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   610
     by newString (i.e. slice in the newString in place of the oldChar).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   611
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   612
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   613
    |tmpStream|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   614
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   615
    tmpStream := WriteStream on:(self class new).
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   616
    self do:[:element |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   617
	element = oldChar ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   618
	    tmpStream nextPutAll:newString
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   619
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   620
	    tmpStream nextPut:element 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   621
	].
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   622
    ].
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   623
    ^ tmpStream contents
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   624
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   625
   "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   626
     '12345678901234567890' replChar:$0 withString:'foo' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   627
     'a string with spaces' replChar:$  withString:' foo '  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   628
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   629
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   630
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   631
trimBlanks
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   632
    "return a copy of the receiver without leading
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   633
     and trailing spaces.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   634
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   635
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   636
    ^ self withoutSpaces
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   637
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   638
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   639
     '    spaces at beginning' trimBlanks     
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   640
     'spaces at end    ' trimBlanks           
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   641
     '    spaces at beginning and end     ' trimBlanks    
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   642
     'no spaces' trimBlanks              
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   643
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   644
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   645
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   646
byteAt:index put:aByte
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   647
    "store a byte at given index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   648
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   649
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   650
    (aByte == 0) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   651
	"store a space instead"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   652
	^ super basicAt:index put:(Character space)
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   653
    ].
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   654
    ^ super at:index put:(Character value:aByte)
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   655
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   656
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   657
!CharacterArray methodsFor:'printing & storing'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   658
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   659
article
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   660
    "return an article string for the receiver."
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   661
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   662
    |firstChar|
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   663
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   664
    firstChar := (self at:1) asLowercase. 
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   665
    (firstChar isVowel or:[firstChar == $x]) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   666
	firstChar ~~ $u ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   667
	     ^ 'an'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   668
	]
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   669
    ].
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   670
    ^ 'a'
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   671
!
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
   672
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   673
printOn:aStream
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   674
    "print the receiver on aStream"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   675
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   676
    aStream nextPutAll:self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   677
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   678
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   679
printString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   680
    "return a string for printing - thats myself"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   681
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   682
    ^ self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   683
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   684
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   685
displayString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   686
    "return a string to display the receiver - use storeString to have
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   687
     quotes around."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   688
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   689
    ^ self storeString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   690
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   691
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   692
!CharacterArray methodsFor:'comparing'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   693
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   694
hash
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   695
    "return an integer useful as a hash-key"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   696
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   697
%{  /* NOCONTEXT */
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   698
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   699
    REGISTER int g, val;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   700
    REGISTER unsigned char *cp, *cp0;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   701
    int l;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   702
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   703
    cp = _stringVal(self);
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   704
    l = _stringSize(self);
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   705
    if (__qClass(self) != String) {
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   706
	int n = __OBJS2BYTES__(_intVal(_ClassInstPtr(__qClass(self))->c_ninstvars));
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   707
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   708
	cp += n;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   709
	l -= n;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   710
    }
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   711
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   712
    /*
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   713
     * this is the dragon-book algorithm with a funny start
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   714
     * value (to give short strings a number above 8192)
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   715
     */
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   716
    val = 12345;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   717
    for (cp0 = cp, cp += l - 1; cp >= cp0; cp--) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   718
	val = (val << 5) + (*cp & 0x1F);
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   719
	if (g = (val & 0x3E000000))
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   720
	    val ^= g >> 25 /* 23 */ /* 25 */;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   721
	val &= 0x3FFFFFFF;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   722
    }
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   723
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   724
    if (l) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   725
	l |= 1; 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   726
	val = (val * l) & 0x3FFFFFFF;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   727
    }
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   728
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   729
    RETURN ( _MKSMALLINT(val) );
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   730
%}
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   731
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   732
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   733
<= something
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   734
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   735
     receiver is less than or equal to the argument. Otherwise return false."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   736
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   737
    ^ (self > something) not
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   738
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   739
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   740
< something
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   741
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   742
     receiver is less than the argument. Otherwise return false."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   743
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   744
    ^ (something > self)
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   745
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   746
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   747
>= something
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   748
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   749
     receiver is greater than or equal to the argument.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   750
     Otherwise return false."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   751
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   752
    ^ (something > self) not
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   753
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   754
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   755
> aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   756
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   757
     receiver is greater than the argument. Otherwise return false.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   758
     In contrast to ST-80, case differences are NOT ignored, thus
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   759
     'foo' > 'Foo' will return true. 
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   760
     Since this is incompatible to ST-80, this may change."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   761
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   762
    |mySize    "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   763
     otherSize "{ Class: SmallInteger }" 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   764
     c1 c2|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   765
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   766
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   767
    otherSize := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   768
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   769
    1 to:(mySize min:otherSize) do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   770
	c1 := self at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   771
	c2 := aString at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   772
	c1 > c2 ifTrue:[^ true].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   773
	c1 < c2 ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   774
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   775
    ^ mySize > otherSize
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   776
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   777
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   778
= aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   779
    "Compare the receiver with the argument and return true if the
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   780
     receiver is equal to the argument. Otherwise return false.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   781
     This compare does NOT ignore case differences, 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   782
     therefore 'foo' = 'Foo' will return false.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   783
     Since this is incompatible to ST-80, this may change."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   784
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   785
    |mySize    "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   786
     otherSize |
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   787
215
a1768b48c8af *** empty log message ***
claus
parents: 196
diff changeset
   788
    aString species == self species ifFalse:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   789
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   790
    otherSize := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   791
    mySize == otherSize ifFalse:[^ false].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   792
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   793
    1 to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   794
	(self at:index) = (aString at:index) ifFalse:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   795
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   796
    ^ true
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   797
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   798
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   799
     'foo' = 'Foo'  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   800
     'foo' = 'bar'  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   801
     'foo' = 'foo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   802
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   803
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   804
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   805
trueCompare:aString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   806
    "Compare the receiver with the argument and return 1 if the receiver is
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   807
     greater, 0 if equal and -1 if less than the argument. 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   808
     Case differences are NOT ignored, thus
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   809
     'foo' trueCompare: 'Foo' will return 1."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   810
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   811
    |mySize    "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   812
     otherSize "{ Class: SmallInteger }" 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   813
     c1 c2|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   814
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   815
    mySize := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   816
    otherSize := aString size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   817
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   818
    1 to:(mySize min:otherSize) do:[:index |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   819
	c1 := self at:index.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   820
	c2 := aString at:index.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   821
	c1 > c2 ifTrue:[^ 1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   822
	c1 < c2 ifTrue:[^ -1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   823
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   824
    mySize > otherSize ifTrue:[^ 1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   825
    mySize < otherSize ifTrue:[^ -1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   826
    ^ 0
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   827
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   828
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   829
sameAs:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   830
    "Compare the receiver with the argument like =, but ignore
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   831
     case differences. Return true or false."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   832
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   833
    |mySize "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   834
     otherSize c1 c2|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   835
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   836
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   837
    otherSize := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   838
    mySize == otherSize ifFalse:[^ false].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   839
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   840
    1 to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   841
	c1 := self at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   842
	c2 := aString at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   843
	c1 == c2 ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   844
	    c1 asLowercase = c2 asLowercase ifFalse:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   845
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   846
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   847
    ^ true
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   848
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   849
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   850
     'foo' sameAs: 'Foo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   851
     'foo' sameAs: 'bar' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   852
     'foo' sameAs: 'foo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   853
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   854
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   855
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   856
!CharacterArray methodsFor:'character searching'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   857
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   858
includesMatchCharacters
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   859
    "return true if the receiver includes any meta characters (i.e. $* or $#) 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   860
     for match operations; false if not"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   861
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   862
    ^ self includesAny:'*#['
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   863
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   864
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   865
indexOfSeparator
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   866
    "return the index of the first whitespace character"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   867
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   868
    ^ self indexOfSeparatorStartingAt:1
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   869
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   870
    "'hello world' indexOfSeparator"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   871
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   872
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   873
indexOfSeparatorStartingAt:startIndex
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   874
    "return the index of the next whitespace character"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   875
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   876
    |start  "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   877
     mySize "{ Class: SmallInteger }"|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   878
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   879
    start := startIndex.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   880
    mySize := self size.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   881
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   882
    start to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   883
	(self at:index) isSeparator ifTrue:[^ index]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   884
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   885
    ^ 0
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   886
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   887
    "'hello world' indexOfSeparatorStartingAt:3"
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   888
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   889
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   890
indexOfNonSeparatorStartingAt:startIndex
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   891
    "return the index of the next non-whitespace character"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   892
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   893
    |start  "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   894
     mySize "{ Class: SmallInteger }"|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   895
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   896
    start := startIndex.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   897
    mySize := self size.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   898
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   899
    start to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   900
	(self at:index) isSeparator ifFalse:[^ index]
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   901
    ].
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   902
    ^ 0
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   903
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   904
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   905
     '    hello world' indexOfNonSeparatorStartingAt:1 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   906
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   907
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   908
     |s index1 index2|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   909
     s := '   foo    bar      baz'.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   910
     index1 := s indexOfNonSeparatorStartingAt:1.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   911
     index2 := s indexOfSeparatorStartingAt:index1.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   912
     s copyFrom:index1 to:index2 - 1
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   913
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   914
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   915
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   916
!CharacterArray methodsFor:'substring searching'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   917
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   918
findString:subString 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   919
    "find a substring. if found, return the index;
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   920
     if not found, return 0."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   921
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   922
    ^ self findString:subString startingAt:1 ifAbsent:[0]
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   923
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   924
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   925
     'hello world' findString:'llo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   926
     'hello world' findString:'ole'  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   927
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   928
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   929
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   930
findString:subString startingAt:index
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   931
    "find a substring, starting at index. if found, return the index;
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   932
     if not found, return 0."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   933
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   934
    ^ self findString:subString startingAt:index ifAbsent:[0]
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   935
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   936
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   937
     'hello yello' findString:'llo' startingAt:1   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   938
     'hello yello' findString:'llo' startingAt:5   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   939
     'hello yello' findString:'llo' startingAt:15   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   940
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   941
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   942
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   943
findString:subString startingAt:index ifAbsent:exceptionBlock
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   944
    "find a substring, starting at index. if found, return the index;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   945
     if not found, return the result of evaluating exceptionBlock.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   946
     This is a q&d hack - not very efficient"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   947
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   948
    |firstChar found
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   949
     startIndex "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   950
     subSize    "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   951
     mySize     "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   952
     runIdx     "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   953
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   954
    subSize := subString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   955
    subSize == 0 ifTrue:[^ index]. "empty string matches"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   956
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   957
    firstChar := subString at:1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   958
    startIndex := self indexOf:firstChar startingAt:index.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   959
    [startIndex == 0] whileFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   960
	runIdx := startIndex.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   961
	found := true.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   962
	1 to:subSize do:[:i |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   963
	    runIdx > mySize ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   964
		found := false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   965
	    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   966
		(subString at:i) ~~ (self at:runIdx) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   967
		    found := false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   968
		]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   969
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   970
	    runIdx := runIdx + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   971
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   972
	found ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   973
	    ^ startIndex
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   974
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   975
	startIndex := self indexOf:firstChar startingAt:(startIndex + 1)
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   976
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   977
    ^ exceptionBlock value
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   978
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   979
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   980
!CharacterArray methodsFor:'pattern matching'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   981
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
   982
from:matchStart to:matchStop match:aString from:start to:stop ignoreCase:ignoreCase
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   983
    "helper for match; return true if the characters from start to stop in
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   984
     aString are matching the receivers characters from matchStart to matchStop.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   985
     The receiver may contain meta-match characters $* (to match any string) 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   986
     or $# (to match any character) or [...] (to match from a set of characters).
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
   987
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
   988
     This algorithm is not at all efficient; for heavy duty pattern matching,
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   989
     an interface (primitive) to the regex pattern matching package should be
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   990
     added."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   991
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   992
    |matchChar 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   993
     mStart "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   994
     mStop  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   995
     sStart "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   996
     sStop  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   997
     mSize  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   998
     sSize  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   999
     index cont matchLast
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1000
     matchSet c1 c2 checkChar included|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1001
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1002
    mStart := matchStart.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1003
    mStop := matchStop.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1004
    sStart := start.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1005
    sStop := stop.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1006
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1007
    [true] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1008
	mSize := mStop - mStart + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1009
	sSize := sStop - sStart + 1.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1010
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1011
	"empty strings match"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1012
	(mSize == 0) ifTrue:[^ (sSize == 0)].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1013
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1014
	matchChar := self at:mStart.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1015
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1016
	(matchChar == $#) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1017
	    "testString empty -> no match"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1018
	    (sSize == 0) ifTrue:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1019
	    "# matches single character"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1020
	    ((sSize == 1) and:[mSize == 1]) ifTrue:[^ true].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1021
	    "cut off 1st chars and continue"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1022
	    mStart := mStart + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1023
	    sStart := sStart + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1024
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1025
	    (matchChar == $[) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1026
		"testString empty -> no match"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1027
		(sSize == 0) ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1028
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1029
		included := false.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1030
		checkChar := aString at:sStart.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1031
		c1 := nil.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1032
		[matchChar == $]] whileFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1033
		    mStart := mStart + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1034
		    mSize := mSize - 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1035
		    matchChar := self at:mStart.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1036
		    ((matchChar == $-) and:[c1 notNil]) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1037
			mStart := mStart + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1038
			mSize := mSize - 1.
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1039
			included ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1040
			    c2 := self at:mStart.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1041
			    ignoreCase ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1042
				included := checkChar asUppercase asciiValue
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1043
						between:c1 asUppercase asciiValue
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1044
						and:c2 asUppercase asciiValue.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1045
			    ] ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1046
				included := checkChar asciiValue
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1047
						between:c1 asciiValue
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1048
						and:c2 asciiValue.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1049
			    ]
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1050
			].
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1051
			c1 := nil
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1052
		    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1053
			(matchChar == $]) ifFalse:[
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1054
			    included := (checkChar == matchChar).
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1055
			    c1 := matchChar
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1056
			]
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1057
		    ]
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1058
		].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1059
		mStart := mStart + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1060
		mSize := mSize - 1.
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1061
		included ifFalse:[^ false].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1062
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1063
"/                matchSet := Set new.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1064
"/                c1 := nil.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1065
"/                [matchChar == $]] whileFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1066
"/                    mStart := mStart + 1.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1067
"/                    mSize := mSize - 1.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1068
"/                    matchChar := self at:mStart.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1069
"/                    ((matchChar == $-) and:[c1 notNil]) ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1070
"/                        mStart := mStart + 1.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1071
"/                        mSize := mSize - 1.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1072
"/                        c2 := self at:mStart.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1073
"/                        (c1 to:c2) do:[:c | matchSet add:c].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1074
"/                        c1 := nil
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1075
"/                    ] ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1076
"/                        (matchChar == $]) ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1077
"/                            matchSet add:matchChar.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1078
"/                            c1 := matchChar.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1079
"/                        ].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1080
"/                    ].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1081
"/                ].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1082
"/                mStart := mStart + 1.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1083
"/                mSize := mSize - 1.
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1084
"/                (matchSet includes:(aString at:sStart)) ifFalse:[^ false].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1085
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1086
		((sSize == 1) and:[mSize == 0]) ifTrue:[^ true].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1087
		"cut off 1st char and continue"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1088
		sStart := sStart + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1089
	    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1090
		(matchChar == $*) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1091
		    "* matches anything"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1092
		    (mSize == 1) ifTrue:[^ true].
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1093
		    "testString empty & matchString not empty -> we have no match"
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1094
		    (sSize == 0) ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1095
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1096
		    "try to avoid some of the recursion by checking last
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1097
		     character and continue with shortened strings if possible"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1098
		    cont := false.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1099
		    (mStop >= mStart) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1100
			matchLast := self at:mStop.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1101
			(matchLast ~~ $*) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1102
			    (matchLast == $#) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1103
				cont := true
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1104
			    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1105
				(matchLast == (aString at:sStop)) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1106
				    cont := true
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1107
				]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1108
			    ]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1109
			]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1110
		    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1111
		    cont ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1112
			index := sStart.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1113
			[index <= sStop] whileTrue:[
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1114
			    (self from:(mStart + 1) to:mStop 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1115
				  match:aString 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1116
				  from:index to:sStop
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1117
				  ignoreCase:ignoreCase) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1118
				^ true
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1119
			    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1120
			    index := index + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1121
			].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1122
			^ false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1123
		    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1124
		    mStop := mStop - 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1125
		    sStop := sStop - 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1126
		] ifFalse:[
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1127
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1128
		    "testString empty ?"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1129
		    (sSize == 0) ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1130
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1131
		    "first characters equal ?"
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1132
		    ignoreCase ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1133
			((aString at:sStart) asUppercase ~~ matchChar asUppercase) ifTrue:[^ false].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1134
		    ] ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1135
			((aString at:sStart) ~~ matchChar) ifTrue:[^ false].
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1136
		    ].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1137
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1138
		    "avoid recursion if possible"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1139
		    ((sSize == mSize) and:[self = aString]) ifTrue:[^ true].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1140
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1141
		    "cut off 1st chars and continue"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1142
		    mStart := mStart + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1143
		    sStart := sStart + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1144
		]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1145
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1146
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1147
    ]
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1148
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1149
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1150
from:matchStart to:matchStop match:aString from:start to:stop
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1151
    ^ self from:matchStart to:matchStop match:aString from:start to:stop ignoreCase:false
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1152
!
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1153
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1154
match:aString ignoreCase:ignoreCase
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1155
    "return true if aString matches self, where self may contain meta-match 
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1156
     characters $* (to match any string) or $# (to match any character)."
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1157
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1158
    ^ self from:1 to:(self size) match:aString from:1 to:(aString size) ignoreCase:ignoreCase
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1159
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1160
    "
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1161
     '*ute*' match:'COMPUTER' ignoreCase:true
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1162
     '*uter' match:'COMPUTER' ignoreCase:false 
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1163
     '[abcd]*' match:'computer' 
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1164
     '[a-k]*' match:'komputer' 
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1165
     '*some*compl*ern*' match:'this is some more complicated pattern match' 
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1166
     '*some*compl*ern*' match:'this is another complicated pattern match' 
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1167
    "
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1168
!
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1169
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1170
match:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1171
    "return true if aString matches self, where self may contain meta-match 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1172
     characters $* (to match any string) or $# (to match any character)."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1173
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1174
    ^ self match:aString ignoreCase:false
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1175
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1176
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1177
     '*ute*' match:'computer' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1178
     '*uter' match:'computer' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1179
     'uter*' match:'computer' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1180
     '*ute*' match:'' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1181
     '[abcd]*' match:'computer' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1182
     '[abcd]*' match:'komputer' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1183
     '*some*compl*ern*' match:'this is some more complicated pattern match' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1184
     '*some*compl*ern*' match:'this is another complicated pattern match' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1185
    "
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1186
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1187
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1188
matchString:matchString startingAt:index ifAbsent:exceptionBlock
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1189
    "find a matchstring, starting at index. if found, return the index;
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1190
     if not found, return the result of evaluating exceptionBlock.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1191
     This is a q&d hack - not very efficient"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1192
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1193
    |firstChar found
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1194
     startIndex "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1195
     matchSize    "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1196
     mySize     "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1197
     runIdx     "{ Class: SmallInteger }" 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1198
     realMatchString|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1199
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1200
    matchSize := matchString size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1201
    matchSize == 0 ifTrue:[^ index]. "empty string matches"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1202
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1203
    realMatchString := matchString.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1204
    (realMatchString endsWith:$*) ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1205
	realMatchString := realMatchString , '*'.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1206
	matchSize := matchSize + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1207
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1208
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1209
    mySize := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1210
    firstChar := realMatchString at:1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1211
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1212
    firstChar asString includesMatchCharacters ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1213
	index to:mySize do:[:col |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1214
	    (realMatchString from:1 to:matchSize match:self from:col to:mySize ignoreCase:false)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1215
	    ifTrue:[^ col]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1216
	].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1217
	^ exceptionBlock value.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1218
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1219
    startIndex := self indexOf:firstChar startingAt:index.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1220
    [startIndex == 0] whileFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1221
	(realMatchString from:1 to:matchSize match:self from:startIndex to:mySize ignoreCase:false)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1222
	ifTrue:[^ startIndex].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1223
	startIndex := self indexOf:firstChar startingAt:(startIndex + 1)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1224
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1225
    ^ exceptionBlock value
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1226
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1227
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1228
asMatchScanCollection
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1229
    |coll idx end c1 c2 matchSet previous|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1230
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1231
    coll := OrderedCollection new.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1232
    idx := 1. end := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1233
    [idx <= end] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1234
	|char this|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1235
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1236
	char := self at:idx.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1237
	char == $* ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1238
	    previous ~~ #anyString ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1239
		this := #anyString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1240
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1241
	] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1242
	    char == $# ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1243
		previous ~~ #anyString ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1244
		    this := #any
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1245
		]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1246
	    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1247
		char == $[ ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1248
		    matchSet := IdentitySet new.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1249
		    idx := idx + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1250
		    idx > end ifTrue:[^ nil].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1251
		    char := self at:idx.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1252
		    c1 := nil.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1253
		    [char ~~ $]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1254
			((char == $-) and:[c1 notNil]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1255
			    idx := idx + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1256
			    idx > end ifTrue:[^ nil].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1257
			    c2 := self at:idx.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1258
			    (c1 to:c2) do:[:c | matchSet add:c].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1259
			    c1 := nil.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1260
			    idx := idx + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1261
			] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1262
			    (char ~~ $]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1263
				matchSet add:char.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1264
				c1 := char.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1265
				idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1266
			    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1267
			].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1268
			idx > end ifTrue:[^ nil].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1269
			char := self at:idx
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1270
		    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1271
		    this := matchSet asString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1272
		] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1273
		    this := char
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1274
		]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1275
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1276
	].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1277
	this notNil ifTrue:[coll add:this. previous := this].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1278
	idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1279
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1280
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1281
    ^ coll asArray
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1282
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1283
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1284
     '*ute*' asMatchScanCollection  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1285
     '**ute**' asMatchScanCollection  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1286
     '*uter' asMatchScanCollection   
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1287
     '[cC]#mpute[rR]' asMatchScanCollection  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1288
     '[abcd]*' asMatchScanCollection      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1289
     '[a-k]*'asMatchScanCollection       
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1290
     '*some*compl*ern*' asMatchScanCollection 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1291
     '[a-' asMatchScanCollection  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1292
     '[a-zA-Z]' asMatchScanCollection  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1293
     '[a-z01234A-Z]' asMatchScanCollection  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1294
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1295
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1296
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1297
newmatch:aString ignoreCase:ignoreCase
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1298
    "return true if aString matches self, where self may contain meta-match 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1299
     characters $* (to match any string) or $# (to match any character)."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1300
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1301
    |matchScanArray|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1302
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1303
    (PreviousMatch notNil
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1304
    and:[PreviousMatch key = self]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1305
	matchScanArray := PreviousMatch value
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1306
    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1307
	matchScanArray := self asMatchScanCollection.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1308
	matchScanArray isNil ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1309
	    'CHARARRAY: invalid matchpattern:' errorPrint. self errorPrintNL.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1310
	    ^ false
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1311
	].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1312
	PreviousMatch := self -> matchScanArray.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1313
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1314
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1315
    ^ self matchScan:matchScanArray 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1316
	   from:1 to:(matchScanArray size) 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1317
	   with:aString 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1318
	   from:1 to:(aString size) 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1319
	   ignoreCase:ignoreCase
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1320
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1321
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1322
     '*ute*' newmatch:'COMPUTER' ignoreCase:true  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1323
     '*uter' newmatch:'COMPUTER' ignoreCase:false 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1324
     '[abcd]*' newmatch:'computer' ignoreCase:false 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1325
     '[abcd]*' newmatch:'Computer' ignoreCase:false 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1326
     '[a-k]*' newmatch:'komputer' ignoreCase:false   
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1327
     '[a-k]*' newmatch:'zomputer' ignoreCase:false    
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1328
     '[a-k]*' newmatch:'Komputer' ignoreCase:false    
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1329
     '[a-k]*' newmatch:'Komputer' ignoreCase:true     
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1330
     '*some*compl*ern*' newmatch:'this is some more complicated pattern match' ignoreCase:true 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1331
     '*some*compl*ern*' newmatch:'this is another complicated pattern match' ignoreCase:true 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1332
     Time millisecondsToRun:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1333
	Symbol allInstancesDo:[:sym |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1334
	    'A*' match:sym ignoreCase:false
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1335
	]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1336
     ]. 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1337
     Time millisecondsToRun:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1338
	Symbol allInstancesDo:[:sym |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1339
	    'A*' newmatch:sym ignoreCase:false
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1340
	]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1341
     ]. 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1342
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1343
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1344
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1345
matchScan:matchScanArray from:matchStart to:matchStop with:aString from:start to:stop ignoreCase:ignoreCase
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1346
    "helper for match; return true if the characters from start to stop in
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1347
     aString are matching the scan in matchScan from matchStart to matchStop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1348
     The matchScan is as created by asMatchScan.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1349
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1350
     This algorithm is not at all efficient; for heavy duty pattern matching,
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1351
     an interface (primitive) to the regex pattern matching package should be
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1352
     added."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1353
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1354
    |matchEntry 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1355
     mStart "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1356
     mStop  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1357
     sStart "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1358
     sStop  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1359
     mSize  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1360
     sSize  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1361
     index  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1362
     quickCheck matchLast
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1363
     matchSet checkChar included|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1364
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1365
    mStart := matchStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1366
    mStop := matchStop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1367
    sStart := start.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1368
    sStop := stop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1369
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1370
    [true] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1371
	mSize := mStop - mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1372
	sSize := sStop - sStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1373
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1374
	"empty strings match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1375
	(mSize == 0) ifTrue:[^ (sSize == 0)].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1376
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1377
	matchEntry := matchScanArray at:mStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1378
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1379
	"/ the most common case first:
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1380
	(sSize ~~ 0 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1381
	and:[(checkChar := (aString at:sStart)) == matchEntry]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1382
	    "advance by one and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1383
	    mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1384
	    sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1385
	] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1386
	    (matchEntry == #any) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1387
		"restString empty -> no match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1388
		(sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1389
		"# matches single character"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1390
		((sSize == 1) and:[mSize == 1]) ifTrue:[^ true].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1391
		"advance by one and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1392
		mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1393
		sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1394
	    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1395
		(matchEntry == #anyString) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1396
		    "* alone matches anything"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1397
		    (mSize == 1) ifTrue:[^ true].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1398
		    "restString empty & matchString not empty -> no match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1399
		    (sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1400
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1401
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1402
		     try to avoid some of the recursion by checking last
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1403
		     character and continue with shortened strings if possible
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1404
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1405
		    quickCheck := false.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1406
		    (mStop >= mStart) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1407
			matchLast := matchScanArray at:mStop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1408
			(matchLast ~~ #anyString) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1409
			    (matchLast == #any) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1410
				quickCheck := true
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1411
			    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1412
				matchLast == (aString at:sStop) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1413
				    quickCheck := true
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1414
				] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1415
				    matchLast isString ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1416
					quickCheck := matchLast includes:(aString at:sStop)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1417
				    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1418
				]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1419
			    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1420
			]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1421
		    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1422
		    quickCheck ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1423
			"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1424
			 no quick check possible;
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1425
			 loop over all possible substrings
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1426
			"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1427
			index := sStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1428
			[index <= sStop] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1429
			    (self matchScan:matchScanArray 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1430
				  from:(mStart + 1) 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1431
				  to:mStop 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1432
				  with:aString 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1433
				  from:index 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1434
				  to:stop 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1435
				  ignoreCase:ignoreCase) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1436
				^ true
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1437
			    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1438
			    index := index + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1439
			].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1440
			^ false
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1441
		    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1442
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1443
		     quickCheck ok, advance from the right
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1444
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1445
		    mStop := mStop - 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1446
		    sStop := sStop - 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1447
		] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1448
		    (matchEntry isString) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1449
			"testString empty -> no match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1450
			(sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1451
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1452
			included := false.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1453
			"/ checkChar := aString at:sStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1454
			included := matchEntry includes:checkChar.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1455
			included ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1456
			    ignoreCase ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1457
				checkChar isUppercase ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1458
				    included := matchEntry includes:checkChar asLowercase.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1459
				] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1460
				    included := matchEntry includes:checkChar asUppercase.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1461
				]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1462
			    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1463
			].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1464
			mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1465
			mSize := mSize - 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1466
			included ifFalse:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1467
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1468
			((sSize == 1) and:[mSize == 0]) ifTrue:[^ true].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1469
			"cut off 1st char and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1470
			sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1471
		    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1472
			"/ must be single character
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1473
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1474
			"testString empty ?"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1475
			(sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1476
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1477
			"first characters equal ?"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1478
			"/ checkChar := aString at:sStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1479
			ignoreCase ifFalse:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1480
			(checkChar asUppercase ~~ matchEntry asUppercase) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1481
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1482
			"advance and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1483
			mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1484
			sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1485
		    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1486
		]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1487
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1488
	]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1489
    ]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1490
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1491
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1492
!CharacterArray methodsFor:'testing'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1493
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1494
isBlank
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1495
    "return true, if the receiver contains spaces only"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1496
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1497
    self do:[:char |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1498
	char ~~ Character space ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1499
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1500
    ^ true
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1501
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1502
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1503
isAlphaNumeric
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1504
    "return true, if the receiver is some alphanumeric word;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1505
     i.e. consists of a letter followed by letters or digits."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1506
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1507
    self size == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1508
	"mhmh what is this ?"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1509
	^ false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1510
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1511
    (self at:1) isLetter ifFalse:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1512
    self do:[:char |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1513
	char isLetterOrDigit ifFalse:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1514
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1515
    ^ true
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1516
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1517
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1518
     'helloWorld' isAlphaNumeric  
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1519
     'foo1234' isAlphaNumeric    
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1520
     'f1234' isAlphaNumeric      
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1521
     '1234' isAlphaNumeric       
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1522
     '+' isAlphaNumeric         
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1523
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1524
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1525
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1526
countWords
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1527
    "return the number of words, which are separated by separators"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1528
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1529
    |tally "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1530
     start "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1531
     mySize "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1532
     stop ch|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1533
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1534
    tally := 0.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1535
    start := 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1536
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1537
    [start <= mySize] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1538
	ch := self at:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1539
	ch isSeparator ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1540
	    start := start + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1541
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1542
	    stop := self indexOfSeparatorStartingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1543
	    (stop == 0) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1544
		stop := mySize + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1545
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1546
	    tally := tally + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1547
	    start := stop
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1548
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1549
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1550
    ^ tally
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1551
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1552
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1553
     'hello world isnt this nice' countWords'
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1554
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1555
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1556
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1557
numArgs
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1558
    "treating the receiver as a message selector, return how many arguments would it take"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1559
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1560
    |binopChars|
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1561
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1562
    (self size > 2) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1563
	binopChars := '|&-+=*/\<>~@,'.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1564
	(self size == 1) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1565
	    ((binopChars occurrencesOf:(self at:1)) == 0) ifTrue:[^ 0].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1566
	    ^ 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1567
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1568
	((binopChars occurrencesOf:(self at:1)) == 0) ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1569
	    ((binopChars occurrencesOf:(self at:2)) == 0) ifFalse:[^ 1]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1570
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1571
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1572
    ^ self occurrencesOf:$:
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1573
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1574
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1575
     'foo:bar:' numArgs  
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1576
     #foo:bar: numArgs    
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1577
     'hello' numArgs       
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1578
     '+' numArgs   
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1579
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1580
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1581
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1582
partsIfSelector
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1583
    "treat the receiver as a message selector, return a collection of parts."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1584
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1585
    |idx1 "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1586
     coll idx2 sz|
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1587
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1588
    coll := OrderedCollection new.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1589
    idx1 := 1.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1590
    sz := self size.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1591
    [true] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1592
	idx2 := self indexOf:$: startingAt:idx1 + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1593
	(idx2 == 0 or:[idx2 == sz]) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1594
	    coll add:(self copyFrom:idx1).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1595
	    ^ coll
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1596
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1597
	coll add:(self copyFrom:idx1 to:idx2).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1598
	idx1 := idx2 + 1
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1599
    ].
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1600
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1601
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1602
     'foo:bar:' partsIfSelector     
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1603
     #foo:bar: partsIfSelector     
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1604
     'hello' partsIfSelector       
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1605
     '+' partsIfSelector           
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1606
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1607
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1608
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1609
levenshteinTo:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1610
    "return the levenshtein distance to the argument, aString;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1611
     this value corrensponds to the number of replacements that have to be
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1612
     made to get aString from the receiver.
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1613
     See IEEE transactions on Computers 1976 Pg 172 ff."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1614
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1615
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1616
     in the following, we assum that ommiting a character
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1617
     is less of an error than inserting an extra character.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1618
     Therefore the different insertion (i) and deletion (d)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1619
     values.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1620
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1621
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1622
    ^ self levenshteinTo:aString s:4 c:1 i:2 d:6
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1623
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1624
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1625
     'ocmprt' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1626
     'computer' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1627
     'ocmputer' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1628
     'cmputer' levenshteinTo:'computer'
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1629
     'computer' levenshteinTo:'cmputer'
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1630
     'Computer' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1631
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1632
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1633
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1634
levenshteinTo:aString s:substWeight c:caseWeight i:insrtWeight d:deleteWeight
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1635
    "parametrized levenshtein. 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1636
     return the levenshtein distance to the argument, aString;
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1637
     this value corrensponds to the number of replacements that have to be
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1638
     made to get aString from the receiver.
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1639
     The arguments are the costs for substitution, case-change, insertion and 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1640
     deletion of a character.
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1641
     See IEEE transactions on Computers 1976 Pg 172 ff"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1642
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1643
    |d  "delta matrix"
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1644
     len1 "{ Class: SmallInteger }"
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1645
     len2 "{ Class: SmallInteger }"
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1646
     dim  "{ Class: SmallInteger }"
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1647
     prevRow row col 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1648
     dimPlus1 "{ Class: SmallInteger }"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1649
     min pp c1 c2|
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1650
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1651
    len1 := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1652
    len2 := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1653
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1654
    "create the help-matrix"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1655
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1656
    dim := len1 max:len2.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1657
    dimPlus1 := dim + 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1658
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1659
    d := Array new:dimPlus1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1660
    1 to:dimPlus1 do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1661
	d at:i put:(Array new:dimPlus1)
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1662
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1663
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1664
    "init help-matrix"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1665
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1666
    (d at:1) at:1 put:0.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1667
    row := d at:1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1668
    1 to:dim do:[:j |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1669
	row at:(j + 1) put:( (row at:j) + insrtWeight )
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1670
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1671
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1672
    1 to:dim do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1673
	 (d at:(i + 1)) at:1 put:(  ((d at:i) at:1) + deleteWeight )
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1674
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1675
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1676
    1 to:len1 do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1677
	c1 := self at:i.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1678
	1 to:len2 do:[:j |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1679
	    c2 := aString at:j.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1680
	    (c1 == c2) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1681
		pp := 0
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1682
	    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1683
		(c1 asLowercase == c2 asLowercase) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1684
		    pp := caseWeight
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1685
		] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1686
		    pp := substWeight
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1687
		]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1688
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1689
	    prevRow := d at:i.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1690
	    row := d at:(i + 1).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1691
	    col := j + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1692
	    min := (prevRow at:j) + pp.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1693
	    min := min min:( (row at:j) + insrtWeight).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1694
	    min := min min:( (prevRow at:col) + deleteWeight).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1695
	    row at:col put: min
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1696
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1697
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1698
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1699
    ^ (d at:(len1 + 1)) at:(len2 + 1)
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1700
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1701
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1702
spellAgainst: aString 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1703
    "return an integer between 0 and 100 indicating how similar 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1704
     the argument is to the receiver.  No case conversion is done.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1705
     This algorithm is much simpler (but also less exact) than the
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1706
     levenshtein distance. Experiment which is better for your
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1707
     application."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1708
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1709
    | i1     "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1710
      i2     "{ Class: SmallInteger }"
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1711
      next1  "{ Class: SmallInteger }"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1712
      next2  "{ Class: SmallInteger }"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1713
      size1  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1714
      size2  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1715
      score  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1716
      maxLen "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1717
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1718
    size1 := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1719
    size2 := aString size.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1720
    maxLen := size1 max:size2.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1721
    score := 0.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1722
    i1 := i2 := 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1723
    [i1 <= size1 and: [i2 <= size2]] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1724
	next1 := i1 + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1725
	next2 := i2 + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1726
	(self at:i1) == (aString at:i2) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1727
	    score := score+1.             
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1728
	    i1 := next1.                    
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1729
	    i2 := next2
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1730
	] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1731
	    (i2 < size2 and: [(self at:i1) == (aString at:next2)]) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1732
		i2 := next2
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1733
	    ] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1734
		(i1 < size1 and: [(self at:next1) == (aString at:i2)]) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1735
		    i1 := next1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1736
		] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1737
		    i1 := next1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1738
		    i2 := next2
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1739
		] 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1740
	    ] 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1741
	] 
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1742
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1743
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1744
    score = maxLen ifTrue: [^ 100].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1745
    ^ 100 * score // maxLen
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1746
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1747
    " 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1748
     'Smalltalk' spellAgainst: 'Smalltlak' 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1749
     'Smalltalk' spellAgainst: 'smalltlak' 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1750
     'Smalltalk' spellAgainst: 'smalltalk' 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1751
     'Smalltalk' spellAgainst: 'smalltlk'  
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1752
     'Smalltalk' spellAgainst: 'Smalltolk'   
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1753
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1754
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1755
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1756
!CharacterArray methodsFor:'padded copying'!
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1757
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1758
paddedTo:newSize with:padCharacter
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1759
    "return a new string consisting of the receivers characters,
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1760
     plus pad characters up to length.
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1761
     If the receivers size is equal or greater than the length argument, 
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1762
     the receiver is returned unchanged."
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1763
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1764
    |s len|
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1765
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1766
    len := self size.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1767
    len < newSize ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1768
	s := self species new:newSize withAll:padCharacter.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1769
	s replaceFrom:1 to:len with:self.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1770
	^ s
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1771
    ]
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1772
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1773
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1774
     'foo' paddedTo:10 with:$.             
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1775
     123 printString paddedTo:10 with:$*   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1776
     (Float pi printString) paddedTo:15 with:(Character space)  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1777
     (Float pi printString) paddedTo:15 with:$-  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1778
     (Float pi class name , ' ') paddedTo:15 with:$.  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1779
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1780
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1781
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1782
leftPaddedTo:size with:padCharacter
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1783
    "return a new string of length size, which contains the receiver
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1784
     right-adjusted (i.e. padded on the left).
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1785
     Characters on the left are filled with padCharacter.
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1786
     If the receivers size is equal or greater than the length argument, 
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1787
     the receiver is returned unchanged."
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1788
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1789
    |len s|
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1790
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1791
    len := self size.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1792
    (len < size) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1793
	s := self species new:size withAll:padCharacter.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1794
	s replaceFrom:(size - len + 1) with:self.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1795
	^ s
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1796
    ]
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1797
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1798
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1799
     'foo' leftPaddedTo:10 with:$.      
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1800
     'fooBar' leftPaddedTo:5 with:$.      
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1801
     123 printString leftPaddedTo:10 with:$.        
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  1802
     (' ' , 123 printString) leftPaddedTo:10 with:$.        
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1803
     (Float pi printString) leftPaddedTo:15 with:(Character space)  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1804
     (Float pi printString) leftPaddedTo:15 with:$-           
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1805
     (' ' , Float pi class name) leftPaddedTo:15 with:$.     
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1806
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1807
! !
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1808
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1809
!CharacterArray methodsFor:'copying'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1810
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1811
concatenate:string1 and:string2
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1812
    "return the concatenation of myself and the arguments, string1 and string2.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1813
     This is equivalent to self , string1 , string2
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1814
     - generated by compiler when such a construct is detected and the receiver
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1815
     is known to be a string."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1816
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1817
    ^ self , string1 , string2
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1818
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1819
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1820
concatenate:string1 and:string2 and:string3
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1821
    "return the concatenation of myself and the string arguments.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1822
     This is equivalent to self , string1 , string2 , string3
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1823
     - generated by compiler when such a construct is detected and the receiver
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  1824
     is known to be a string."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1825
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1826
    ^ self , string1 , string2 , string3
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1827
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1828
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1829
!CharacterArray methodsFor:'queries'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1830
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1831
isString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1832
    "return true, if the receiver is some kind of string;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1833
     true is returned here - redefinition of Object>>isString."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1834
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1835
    ^ true
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1836
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1837
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1838
encoding
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1839
    ^ #unknown
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1840
! !