CharacterArray.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 02:16:37 +0100
changeset 605 8b17f96bf05a
parent 581 8a991a4cb738
child 608 cd5ac440fa95
permissions -rw-r--r--
checkin from browser
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 class methodsFor:'documentation'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    21
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    22
copyright
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    23
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    24
 COPYRIGHT (c) 1994 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    25
	      All Rights Reserved
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    26
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    27
 This software is furnished under a license and may be used
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    28
 only in accordance with the terms of that license and with the
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    30
 be provided or otherwise made available to, or used by, any
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    31
 other person.  No title to or ownership of the software is
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    32
 hereby transferred.
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    33
"
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    34
!
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    35
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    36
version
581
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    37
    ^ '$Header: /cvs/stx/stx/libbasic/CharacterArray.st,v 1.37 1995-11-20 14:34:42 cg Exp $'
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    38
!
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
    39
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    40
documentation
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    41
"
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    42
    CharacterArray is a superclass for all kinds of Strings (i.e.
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    43
    (singleByte-)Strings, TwoByteStrings and whatever comes in the future.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    44
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    45
    As the name already implies, this class is abstract, meaning that there are
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    46
    no instances of it. All this class does is provide common protocol for 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    47
    concrete subclasses.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    48
"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    49
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    50
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
    51
!CharacterArray class methodsFor:'instance creation'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    52
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    53
basicNew
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    54
    "return a new empty string"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    55
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    56
    ^ self basicNew:0
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    57
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    58
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    59
new
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    60
    "return a new empty string"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    61
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    62
    ^ self basicNew:0
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    63
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    65
fromString:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    66
    "return a copy of the argument, aString"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
    67
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    68
    ^ (self basicNew:(aString size)) replaceFrom:1 with:aString
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    69
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
    70
    "TwoByteString fromString:'hello'"
581
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    71
!
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    72
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    73
fromStringCollection:aCollectionOfStrings
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    74
    "return new string formed by concatenating a copy of the argument, aString"
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    75
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    76
    ^ self fromStringCollection:aCollectionOfStrings separatedBy:''
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    77
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    78
    "
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    79
     String fromStringCollection:#('hello' 'world' 'how' 'about' 'this')
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    80
    "
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    81
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    82
    "Created: 20.11.1995 / 15:26:59 / cg"
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    83
!
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    84
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    85
fromStringCollection:aCollectionOfStrings separatedBy:aSeparatorString
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    86
    "return new string formed by concatenating a copy of the argument, aString"
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    87
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    88
    |newString first|
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    89
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    90
    newString := ''.
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    91
    first := true.
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    92
    aCollectionOfStrings do:[:s | 
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    93
	first ifFalse:[
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    94
	    newString := newString , aSeparatorString
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    95
	] ifTrue:[
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    96
	    first := false
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    97
	].
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    98
	newString := newString , s
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    99
    ].
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   100
    ^ newString
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   101
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   102
    "
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   103
     String fromStringCollection:#('hello' 'world' 'how' 'about' 'this') separatedBy:' '
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   104
    "
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   105
8a991a4cb738 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   106
    "Created: 20.11.1995 / 15:32:17 / cg"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   107
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   108
443
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   109
!CharacterArray class methodsFor:'code tables'!
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   110
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   111
decoderTableFor:encoding
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   112
    "this is an experimental interface - unfinished"
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   113
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   114
    |table|
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   115
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   116
    table := (0 to:255) asByteArray.
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   117
    encoding == #mac ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   118
	table at:8r232+1 put:246. "/ german umlaut o
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   119
	table at:8r212+1 put:228. "/ german umlaut a
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   120
	table at:8r237+1 put:252. "/ german umlaut u
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   121
	table at:8r206+1 put:220. "/ german umlaut U
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   122
	"/ more needed here - need info to do it ....
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   123
    ].
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   124
    "/ more encodings needed here ....
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   125
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   126
    ^ table
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   127
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   128
    "Created: 20.10.1995 / 23:04:43 / cg"
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   129
! !
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   130
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
   131
!CharacterArray methodsFor:'converting'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   132
443
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   133
replaceFrom:aString decode:encoding 
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   134
    "this is an experimental interface - unfinished"
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   135
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   136
    |table|
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   137
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   138
    table := self class decoderTableFor:encoding.
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   139
    table isNil ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   140
	^ self replaceFrom:aString
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   141
    ].
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   142
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   143
    1 to:self size do:[:index |
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   144
	|char oldCode newCode|
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   145
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   146
	char := aString at:index.
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   147
	oldCode := char asciiValue.
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   148
	newCode := table at:(oldCode + 1).
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   149
	newCode ~~ oldCode ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   150
	    self at:index put:(Character value:newCode)
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   151
	]
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   152
    ].
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   153
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   154
    "Created: 20.10.1995 / 23:00:09 / cg"
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   155
    "Modified: 20.10.1995 / 23:08:16 / cg"
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   156
!
Claus Gittinger <cg@exept.de>
parents: 428
diff changeset
   157
343
claus
parents: 328
diff changeset
   158
string
claus
parents: 328
diff changeset
   159
    ^ self
claus
parents: 328
diff changeset
   160
!
claus
parents: 328
diff changeset
   161
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   162
asUppercase
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   163
    "return a copy of myself in uppercase letters"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   164
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   165
    |newStr
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   166
     mySize "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   167
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   168
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   169
    newStr := self species new:mySize.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   170
    1 to:mySize do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   171
	newStr at:i put:(self at:i) asUppercase
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   172
    ].
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   173
    ^ newStr
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   174
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   175
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   176
     'helloWorld' asUppercase      
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   177
     'helloWorld' asUppercaseFirst 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   178
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   179
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   180
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   181
asLowercase
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   182
    "return a copy of myself in lowercase letters"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   183
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   184
    |newStr
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   185
     mySize "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   186
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   187
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   188
    newStr := self species new:mySize.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   189
    1 to:mySize do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   190
	newStr at:i put:(self at:i) asLowercase
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   191
    ].
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   192
    ^ newStr
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   193
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   194
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   195
     'HelloWorld' asLowercase   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   196
     'HelloWorld' asLowercaseFirst   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   197
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   198
!
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   199
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   200
asUppercaseFirst
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   201
    "return a copy of myself where the first character is
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   202
     converted to uppercase."
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   203
345
claus
parents: 343
diff changeset
   204
    |newString sz|
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   205
345
claus
parents: 343
diff changeset
   206
    sz := self size.
claus
parents: 343
diff changeset
   207
    newString := self copyFrom:1 to:sz.
claus
parents: 343
diff changeset
   208
    sz > 0 ifTrue:[
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   209
	newString at:1 put:(newString at:1) asUppercase
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   210
    ].
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   211
    ^ newString
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   212
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   213
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   214
     'helloWorld' asUppercase      
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   215
     'helloWorld' asUppercaseFirst 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   216
     'HelloWorld' asUppercaseFirst   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   217
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   218
!
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   219
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   220
asLowercaseFirst
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   221
    "return a copy of myself where the first character is
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   222
     converted to lowercase."
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   223
345
claus
parents: 343
diff changeset
   224
    |newString sz|
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   225
345
claus
parents: 343
diff changeset
   226
    sz := self size.
claus
parents: 343
diff changeset
   227
    newString := self copyFrom:1 to:sz.
claus
parents: 343
diff changeset
   228
    sz > 0 ifTrue:[
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   229
	newString at:1 put:(newString at:1) asLowercase
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   230
    ].
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   231
    ^ newString
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   232
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   233
    "
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   234
     'HelloWorld' asLowercase   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   235
     'HelloWorld' asLowercaseFirst   
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
   236
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   237
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   238
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   239
asString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   240
    "return myself - I am a string"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   241
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   242
    ^ self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   243
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   244
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   245
asTwoByteString
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   246
    "return the receiver converted to a two-byte string"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   247
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   248
    ^ TwoByteString fromString:self
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   249
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   250
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   251
asSingleByteString
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   252
    "return the receiver converted to a 'normal' string"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   253
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   254
    ^ String fromString:self
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   255
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   256
244
9faa2da0650a Text <-> StringCollection
claus
parents: 215
diff changeset
   257
asStringCollection
9faa2da0650a Text <-> StringCollection
claus
parents: 215
diff changeset
   258
    "return a collection of lines from myself."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   259
247
9e3057039d60 asText eliminated
claus
parents: 244
diff changeset
   260
    ^ StringCollection from:self
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   261
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   262
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   263
asComposedText
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   264
    ^ ComposedText fromString:self
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   265
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   266
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   267
asNumber
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   268
    "read a number from the receiver.
345
claus
parents: 343
diff changeset
   269
     Notice, that (in contrast to ST-80) errors may occur during the read, 
claus
parents: 343
diff changeset
   270
     so you better setup some signal handler when using this method.
claus
parents: 343
diff changeset
   271
     This may change if ANSI specifies it."
claus
parents: 343
diff changeset
   272
claus
parents: 343
diff changeset
   273
"/ ST-80 behavior:
claus
parents: 343
diff changeset
   274
"/  ^ Number readFromString:self onError:0
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   275
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   276
    ^ Number readFromString:self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   277
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   278
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   279
     '123'     asNumber
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   280
     '123.567' asNumber
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   281
     '(5/6)'   asNumber
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   282
     'foo'     asNumber
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   283
     Object errorSignal handle:[:ex | ex returnWith:0] do:['foo' asNumber] 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   284
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   285
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   286
345
claus
parents: 343
diff changeset
   287
asNumberFromFormatString:ignored
claus
parents: 343
diff changeset
   288
    "read a number from the receiver, ignoring any nonDigit characters.
claus
parents: 343
diff changeset
   289
     This is typically used to convert from strings which include
claus
parents: 343
diff changeset
   290
     dollar-signs or millenium digits. However, this method also ignores
claus
parents: 343
diff changeset
   291
     the decimal point (if any) and therefore should be used with care."
claus
parents: 343
diff changeset
   292
claus
parents: 343
diff changeset
   293
    |tempString|
claus
parents: 343
diff changeset
   294
claus
parents: 343
diff changeset
   295
    tempString := self collect:[:char | char isDigit].
claus
parents: 343
diff changeset
   296
    ^ Number readFromString:tempString onError:0
claus
parents: 343
diff changeset
   297
claus
parents: 343
diff changeset
   298
    "
claus
parents: 343
diff changeset
   299
     'USD 123' asNumberFromFormatString:'foo'
claus
parents: 343
diff changeset
   300
     'DM 123'  asNumberFromFormatString:'foo'
claus
parents: 343
diff changeset
   301
     '123'     asNumberFromFormatString:'foo'
claus
parents: 343
diff changeset
   302
     '123.567' asNumberFromFormatString:'foo'
claus
parents: 343
diff changeset
   303
     '(5/6)'   asNumberFromFormatString:'foo'
claus
parents: 343
diff changeset
   304
     'foo'     asNumberFromFormatString:'foo'
claus
parents: 343
diff changeset
   305
    "
claus
parents: 343
diff changeset
   306
!
claus
parents: 343
diff changeset
   307
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   308
asInteger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   309
    "read an integer from the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   310
     Notice, that errors may occur during the read, so you better
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   311
     setup some signal handler when using this method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   312
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   313
    ^ Integer readFromString:self
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   314
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   315
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   316
     '12345678901234567890' asInteger
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   317
     '-1234' asInteger
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   318
     '0.123' asInteger   <- reader stops at ., returning 0 here
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   319
     '0.123' asNumber    <- returns what you expect
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   320
     Object errorSignal handle:[:ex | ex returnWith:0] do:['foo' asInteger] 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   321
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   322
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   323
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   324
asFloat
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   325
    "read a float number from the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   326
     Notice, that errors may occur during the read, so you better
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   327
     setup some signal handler when using this method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   328
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   329
    ^ (Number readFromString:self) asFloat
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   330
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   331
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   332
     '0.123' asFloat 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   333
     '12345' asFloat
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   334
     '(1/5)' asFloat
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   335
     Object errorSignal handle:[:ex | ex returnWith:0] do:['foo' asFloat] 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   336
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   337
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   338
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   339
asFilename
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   340
    "return a Filename with pathname taken from the receiver"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   341
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   342
    ^ Filename named:self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   343
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   344
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   345
asCollectionOfWords
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   346
    "return a collection containing the words (separated by whitespace) 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   347
     of the receiver. Multiple occurences of whitespace characters will
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   348
     be treated like one - i.e. whitespace is skipped."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   349
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   350
    |words
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   351
     start  "{ Class:SmallInteger }" 
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   352
     stop   "{ Class:SmallInteger }" 
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   353
     mySize "{ Class:SmallInteger }"|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   354
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   355
    words := OrderedCollection new.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   356
    start := 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   357
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   358
    [start <= mySize] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   359
	start := self indexOfNonSeparatorStartingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   360
	start == 0 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
	stop := self indexOfSeparatorStartingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   364
	stop == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   365
	    words add:(self copyFrom:start to:mySize).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   366
	    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   367
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   368
	words add:(self copyFrom:start to:(stop - 1)).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   369
	start := stop
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   370
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   371
    ^ words
af7aeb79b25e Initial revision
claus
parents:
diff changeset
   372
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   373
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   374
     'hello world isnt this nice' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   375
     '    hello    world   isnt   this   nice  ' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   376
     'hello' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   377
     '' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   378
     '      ' asCollectionOfWords
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   379
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   380
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   381
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   382
asCollectionOfSubstringsSeparatedBy:aCharacter
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   383
    "return a collection containing the lines (separated by aCharacter) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   384
     of the receiver. If aCharacter occurs multiple times in a row, 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   385
     the result will contain empty strings."
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   386
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   387
    |lines myClass
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   388
     numberOfLines "{ Class:SmallInteger }"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   389
     startIndex    "{ Class:SmallInteger }"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   390
     stopIndex     "{ Class:SmallInteger }" |
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   391
357
claus
parents: 356
diff changeset
   392
    "
claus
parents: 356
diff changeset
   393
     count first, to avoid regrowing of the OC
claus
parents: 356
diff changeset
   394
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   395
    numberOfLines := (self occurrencesOf:aCharacter) + 1.
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   396
    lines := OrderedCollection new:numberOfLines.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   397
    myClass := self species.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   398
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   399
    startIndex := 1.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   400
    1 to:numberOfLines do:[:lineNr |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   401
	stopIndex := self indexOf:aCharacter startingAt:startIndex.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   402
	stopIndex == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   403
	    stopIndex := self size
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   404
	] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   405
	    stopIndex := stopIndex - 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   406
	].
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   407
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   408
	(stopIndex < startIndex) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   409
	    lines add:(myClass new:0)
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   410
	] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   411
	    lines add:(self copyFrom:startIndex to:stopIndex)
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   412
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   413
	startIndex := stopIndex + 2
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   414
    ].
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   415
    ^ lines
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   416
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   417
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   418
     '1 one:2 two:3 three:4 four:5 five' withCRs asCollectionOfSubstringsSeparatedBy:$: 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   419
     '1 one 2 two 3 three 4 four 5 five' withCRs asCollectionOfSubstringsSeparatedBy:Character space
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   420
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   421
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   422
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   423
asCollectionOfLines
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   424
    "return a collection containing the lines (separated by cr) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   425
     of the receiver. If multiple cr's occur in a row, the result will
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   426
     contain empty strings."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   427
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   428
    ^ self asCollectionOfSubstringsSeparatedBy:Character cr
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   429
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   430
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   431
     '1 one\2 two\3 three\4 four\5 five' withCRs asCollectionOfLines
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   432
     '1 one\\\\2 two\3 three' withCRs asCollectionOfLines  
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
   433
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   434
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   435
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   436
asArrayOfSubstrings
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   437
    "return an array of substrings from the receiver, interpreting
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   438
     separators (i.e. spaces & newlines) as word-delimiters.
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   439
     This is a compatibility method - the actual work is done in
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   440
     asCollectionOfWords."
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   441
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   442
    ^ self asCollectionOfWords asArray
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   443
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   444
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   445
     '1 one two three four 5 five' asArrayOfSubstrings  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   446
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   447
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   448
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   449
asCollectionOfSubstringsSeparatedByAny:aCollectionOfSeparators
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   450
    "return a collection containing the words (separated by any character
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   451
     from aCollectionOfSeparators) of the receiver.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   452
     This allows breaking up strings using any character as separator."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   453
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   454
    |words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   455
     start  "{ Class:SmallInteger }" 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   456
     stop   "{ Class:SmallInteger }" 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   457
     mySize "{ Class:SmallInteger }"|
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   458
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   459
    words := OrderedCollection new.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   460
    start := 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   461
    mySize := self size.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   462
    [start <= mySize] whileTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   463
	"skip multiple separators"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   464
	[aCollectionOfSeparators includes:(self at:start)] whileTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   465
	    start := start + 1 .
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   466
	    start > mySize ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   467
		^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   468
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   469
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   470
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   471
	stop := self indexOfAny:aCollectionOfSeparators startingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   472
	stop == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   473
	    words add:(self copyFrom:start to:mySize).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   474
	    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   475
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   476
	words add:(self copyFrom:start to:(stop - 1)).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   477
	start := stop
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   478
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   479
    ^ words
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   480
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   481
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   482
     'hello:world:isnt:this nice' asCollectionOfSubstringsSeparatedByAny:#($:)
516
17a170eb1112 speedup indexOfAny:startingAt: if arg is a string
Claus Gittinger <cg@exept.de>
parents: 505
diff changeset
   483
     'hello:world:isnt:this nice' asCollectionOfSubstringsSeparatedByAny:':' 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   484
     'hello:world:isnt:this nice' asCollectionOfSubstringsSeparatedByAny:(Array with:$: with:Character space) 
516
17a170eb1112 speedup indexOfAny:startingAt: if arg is a string
Claus Gittinger <cg@exept.de>
parents: 505
diff changeset
   485
     'hello:world:isnt:this nice' asCollectionOfSubstringsSeparatedByAny:': ' 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   486
     'h1e2l3l4o' asCollectionOfSubstringsSeparatedByAny:($1 to: $9) 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   487
    "
345
claus
parents: 343
diff changeset
   488
!
claus
parents: 343
diff changeset
   489
claus
parents: 343
diff changeset
   490
tokensBasedOn:aCharacter
claus
parents: 343
diff changeset
   491
    "this is an ST-80 alias for the ST/X method
claus
parents: 343
diff changeset
   492
	asCollectionOfSubstringsSeparatedBy:"
claus
parents: 343
diff changeset
   493
claus
parents: 343
diff changeset
   494
    ^ self asCollectionOfSubstringsSeparatedBy:aCharacter
claus
parents: 343
diff changeset
   495
claus
parents: 343
diff changeset
   496
    "
claus
parents: 343
diff changeset
   497
     'hello:world:isnt:this nice' tokensBasedOn:$:
claus
parents: 343
diff changeset
   498
     'foo,bar,baz' tokensBasedOn:$,
claus
parents: 343
diff changeset
   499
     '/etc/passwd' asFilename readStream nextLine tokensBasedOn:$:
claus
parents: 343
diff changeset
   500
    "
328
claus
parents: 327
diff changeset
   501
! !
claus
parents: 327
diff changeset
   502
claus
parents: 327
diff changeset
   503
!CharacterArray methodsFor:'special string converting'!
163
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   504
345
claus
parents: 343
diff changeset
   505
chopTo:maxLen
claus
parents: 343
diff changeset
   506
    "if the receivers size is less or equal to maxLen, return it.
claus
parents: 343
diff changeset
   507
     Otherwise, return a copy of the receiver, where some characters 
claus
parents: 343
diff changeset
   508
     in the middle have been removed for a total string length
claus
parents: 343
diff changeset
   509
     of maxLen."
claus
parents: 343
diff changeset
   510
claus
parents: 343
diff changeset
   511
    |sz n1 n2|
claus
parents: 343
diff changeset
   512
claus
parents: 343
diff changeset
   513
    (sz := self size) > maxLen ifTrue:[
claus
parents: 343
diff changeset
   514
	n1 := n2 := maxLen // 2.
claus
parents: 343
diff changeset
   515
	maxLen odd ifTrue:[
claus
parents: 343
diff changeset
   516
	    n2 := n1 + 1
claus
parents: 343
diff changeset
   517
	].
claus
parents: 343
diff changeset
   518
	^ (self copyFrom:1 to:n1) , (self copyFrom:sz - n2 + 1)
claus
parents: 343
diff changeset
   519
    ]
claus
parents: 343
diff changeset
   520
claus
parents: 343
diff changeset
   521
    "
claus
parents: 343
diff changeset
   522
     '12345678901234'   chopTo:15            
claus
parents: 343
diff changeset
   523
     '123456789012345'  chopTo:15         
claus
parents: 343
diff changeset
   524
     '1234567890123456' chopTo:15      
claus
parents: 343
diff changeset
   525
     'aShortString' chopTo:15 
claus
parents: 343
diff changeset
   526
     'aVeryLongNameForAStringThatShouldBeShortened' chopTo:15 
claus
parents: 343
diff changeset
   527
    "
claus
parents: 343
diff changeset
   528
!
claus
parents: 343
diff changeset
   529
163
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   530
contractTo:maxLen
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   531
    "if the receivers size is less or equal to maxLen, return it.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   532
     Otherwise, return a copy of the receiver, where some characters 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   533
     in the middle have been replaced by '...' for a total string length
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   534
     of maxLen. Can be used to abbreviate long entries in tables."
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   535
359
claus
parents: 357
diff changeset
   536
    |sz "{ SmallInteger }"
claus
parents: 357
diff changeset
   537
     halfSize "{ SmallInteger }"|
163
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   538
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   539
    (sz := self size) > maxLen ifTrue:[
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   540
	halfSize := maxLen // 2.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   541
	^ self copyReplaceFrom:halfSize - 1
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   542
			    to:sz - maxLen + halfSize + 1
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   543
			    with:'...'
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   544
    ]
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   545
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   546
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   547
     '12345678901234' contractTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   548
     '123456789012345' contractTo:15          
345
claus
parents: 343
diff changeset
   549
     '1234567890123456' contractTo:15        
163
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   550
     'aShortString' contractTo:15 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   551
     'aVeryLongNameForAStringThatShouldBeShortened' contractTo:15 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   552
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   553
!
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   554
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   555
contractAtEndTo:maxLen
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   556
    "if the receivers size is less or equal to maxLen, return it.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   557
     Otherwise, return a copy of the receiver, where some characters 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   558
     at the end have been replaced by '...' for a total string length
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   559
     of maxLen. Can be used to abbreviate long entries in tables."
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   560
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   561
    |sz|
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   562
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   563
    (sz := self size) > maxLen ifTrue:[
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   564
	^ self copyReplaceFrom:maxLen - 3
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   565
			    with:'...'
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   566
    ]
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   567
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   568
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   569
     '12345678901234' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   570
     '123456789012345' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   571
     '1234567890123456' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   572
     'aShortString' contractAtEndTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   573
     'aVeryLongNameForAStringThatShouldBeShortened' contractAtEndTo:15 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   574
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   575
!
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   576
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   577
contractAtBeginningTo:maxLen
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   578
    "if the receivers size is less or equal to maxLen, return it.
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   579
     Otherwise, return a copy of the receiver, where some characters 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   580
     at the beginning have been replaced by '...' for a total string length
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   581
     of maxLen. Can be used to abbreviate long entries in tables."
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   582
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   583
    |sz|
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   584
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   585
    (sz := self size) > maxLen ifTrue:[
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   586
	^ '...' , (self copyFrom:(sz - (maxLen - 4))) 
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   587
    ]
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   588
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   589
    "
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   590
     '12345678901234' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   591
     '123456789012345' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   592
     '1234567890123456' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   593
     'aShortString' contractAtBeginningTo:15          
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   594
     'aVeryLongNameForAStringThatShouldBeShortened' contractAtBeginningTo:15
9868f2750ba5 added contract methods
claus
parents: 154
diff changeset
   595
    "
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   596
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   597
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   598
withCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   599
    "return a new string consisting of receivers characters
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   600
     with all \-characters replaced by cr-characters."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   601
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   602
    ^ self copy replaceAll:$\ by:(Character cr)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   603
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   604
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   605
     'hello\world' withCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   606
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   607
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   608
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   609
withoutCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   610
    "return a new collection consisting of receivers elements
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   611
     with all cr-characters replaced by \-characters.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   612
     This is the reverse operation of withCRs."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   613
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   614
    ^ self copy replaceAll:(Character cr) by:$\
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   615
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   616
     'hello
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   617
world' withoutCRs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   618
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   619
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   620
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   621
withoutSpaces
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   622
    "return a copy of myself without leading and trailing spaces.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   623
     Notice: this does NOT remove tabs, newline or any other whitespace.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   624
     Use withoutSeparators for this."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   625
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   626
    |startIndex "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   627
     endIndex   "{ Class: SmallInteger }" 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   628
     sz|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   629
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   630
    sz := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   631
    startIndex := 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   632
    endIndex := sz.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   633
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   634
    [(startIndex < endIndex) and:[(self at:startIndex) == Character space]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   635
	startIndex := startIndex + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   636
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   637
    [(endIndex > 1) and:[(self at:endIndex) == Character space]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   638
	endIndex := endIndex - 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   639
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   640
    startIndex > endIndex ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   641
	^ ''
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   642
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   643
    ((startIndex == 1) and:[endIndex == sz]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   644
	^ self
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   645
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   646
    ^ self copyFrom:startIndex to:endIndex
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   647
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   648
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   649
     '    foo    ' withoutSpaces  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   650
     'foo    '     withoutSpaces   
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   651
     '    foo'     withoutSpaces  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   652
     '       '     withoutSpaces   
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   653
     ('  foo' , Character tab asString , '    ') withoutSpaces inspect 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   654
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   655
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   656
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   657
withoutSeparators
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   658
    "return a copy of myself without leading and trailing whitespace.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   659
     Whitespace is space, tab, newline, formfeed.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   660
     Use withoutSpaces, if you want to remove spaces only."
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   661
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   662
    |startIndex "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   663
     endIndex   "{ Class: SmallInteger }" 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   664
     sz|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   665
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   666
    sz := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   667
    startIndex := 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   668
    endIndex := sz.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   669
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   670
    [(startIndex < endIndex) and:[(self at:startIndex) isSeparator]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   671
	startIndex := startIndex + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   672
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   673
    [(endIndex > 1) and:[(self at:endIndex) isSeparator]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   674
	endIndex := endIndex - 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   675
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   676
    startIndex > endIndex ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   677
	^ ''
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   678
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   679
    ((startIndex == 1) and:[endIndex == sz]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   680
	^ self
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   681
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   682
    ^ self copyFrom:startIndex to:endIndex
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   683
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   684
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   685
     '    foo    ' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   686
     '    foo' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   687
     'foo    ' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   688
     '       ' withoutSeparators      
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   689
     ('  foo' , Character tab asString , '    ') withoutSeparators inspect 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   690
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   691
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   692
360
claus
parents: 359
diff changeset
   693
withoutLeadingSeparators
claus
parents: 359
diff changeset
   694
    "return a copy of myself without leading separators.
claus
parents: 359
diff changeset
   695
     Notice: this does remove tabs, newline or any other whitespace.
claus
parents: 359
diff changeset
   696
     Returns an empty string, if the receiver consist only of whitespace."
claus
parents: 359
diff changeset
   697
claus
parents: 359
diff changeset
   698
    |index|
claus
parents: 359
diff changeset
   699
claus
parents: 359
diff changeset
   700
    index := self indexOfNonSeparatorStartingAt:1.
claus
parents: 359
diff changeset
   701
    index ~~ 0 ifTrue:[
claus
parents: 359
diff changeset
   702
	index == 1 ifTrue:[
claus
parents: 359
diff changeset
   703
	    ^ self
claus
parents: 359
diff changeset
   704
	].
claus
parents: 359
diff changeset
   705
	^ self copyFrom:index
claus
parents: 359
diff changeset
   706
    ].
claus
parents: 359
diff changeset
   707
    ^ ''
claus
parents: 359
diff changeset
   708
claus
parents: 359
diff changeset
   709
    "
claus
parents: 359
diff changeset
   710
     '    foo    ' withoutLeadingSeparators  
claus
parents: 359
diff changeset
   711
     'foo    '     withoutLeadingSeparators   
claus
parents: 359
diff changeset
   712
     '    foo'     withoutLeadingSeparators  
claus
parents: 359
diff changeset
   713
     '       '     withoutLeadingSeparators   
claus
parents: 359
diff changeset
   714
     'foo'         withoutLeadingSeparators   
claus
parents: 359
diff changeset
   715
     ('  ' , Character tab asString , ' foo   ') withoutLeadingSeparators inspect 
claus
parents: 359
diff changeset
   716
    "
claus
parents: 359
diff changeset
   717
!
claus
parents: 359
diff changeset
   718
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   719
withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   720
    "return a copy of the receiver where leading spaces are
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   721
     replaced by tabulator characters (assuming 8-col tabs)"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   722
359
claus
parents: 357
diff changeset
   723
    |idx   "{ SmallInteger }" 
claus
parents: 357
diff changeset
   724
     nTabs "{ SmallInteger }" 
claus
parents: 357
diff changeset
   725
     newString|
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   726
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   727
    idx := self findFirst:[:c | (c ~~ Character space)].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   728
    nTabs := (idx-1) // 8.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   729
    nTabs == 0 ifTrue:[^ self].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   730
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   731
    "any tabs"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   732
    newString := self class new:(self size - (nTabs * 7)).
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   733
    newString atAll:(1 to:nTabs) put:(Character tab).
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   734
    newString replaceFrom:(nTabs + 1) with:self startingAt:(nTabs * 8 + 1).
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   735
    ^ newString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   736
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   737
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   738
     '12345678901234567890' withTabs 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   739
     '       8901234567890' withTabs 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   740
     '        901234567890' withTabs  
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   741
     '               67890' withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   742
     '                7890' withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   743
     '                 890' withTabs
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   744
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   745
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   746
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   747
withTabsExpanded
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   748
    "return a copy of the receiver where all tabulator characters
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   749
     are expanded into spaces (assuming 8-col tabs)"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   750
359
claus
parents: 357
diff changeset
   751
    |idx "{ SmallInteger }" str|
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   752
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   753
    (self includes:(Character tab)) ifFalse:[^ self].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   754
    str := WriteStream on:String new.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   755
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   756
    idx := 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   757
    self do:[:ch |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   758
	ch == Character tab ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   759
	    str nextPut:ch.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   760
	    idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   761
	] ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   762
	    (idx \\ 8) to:8 do:[:ii |
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   763
		str space.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   764
		idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   765
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   766
	]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   767
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
   768
    ^ str contents
428
claus
parents: 398
diff changeset
   769
claus
parents: 398
diff changeset
   770
    "
claus
parents: 398
diff changeset
   771
     (String with:Character tab
claus
parents: 398
diff changeset
   772
	     with:Character tab
claus
parents: 398
diff changeset
   773
	     with:$1) withTabsExpanded
claus
parents: 398
diff changeset
   774
claus
parents: 398
diff changeset
   775
     (String with:Character tab
claus
parents: 398
diff changeset
   776
	     with:$1
claus
parents: 398
diff changeset
   777
	     with:Character tab
claus
parents: 398
diff changeset
   778
	     with:$2) withTabsExpanded  
claus
parents: 398
diff changeset
   779
    "
328
claus
parents: 327
diff changeset
   780
!
claus
parents: 327
diff changeset
   781
359
claus
parents: 357
diff changeset
   782
withEscapes
claus
parents: 357
diff changeset
   783
    "return a new string consisting of receivers characters
claus
parents: 357
diff changeset
   784
     with all \X-character escapes replaced by corresponding-characters.
claus
parents: 357
diff changeset
   785
     (similar to the way C-language Strings are converted).
claus
parents: 357
diff changeset
   786
     The following escapes are supported:
claus
parents: 357
diff changeset
   787
	\r      return character
claus
parents: 357
diff changeset
   788
	\n      newline character
claus
parents: 357
diff changeset
   789
	\b      backspace character
claus
parents: 357
diff changeset
   790
	\f      formfeed character
claus
parents: 357
diff changeset
   791
	\t      tab character
claus
parents: 357
diff changeset
   792
	\\      the \ character itself
claus
parents: 357
diff changeset
   793
	\nnn    three digit octal number defining the characters ascii value
claus
parents: 357
diff changeset
   794
	\other  other
claus
parents: 357
diff changeset
   795
claus
parents: 357
diff changeset
   796
     Notice, that \' is NOT a valid escape, since the general syntax of
claus
parents: 357
diff changeset
   797
     string constants is not affected by this method.
claus
parents: 357
diff changeset
   798
claus
parents: 357
diff changeset
   799
     Although easily implementable, this is NOT done automatically
claus
parents: 357
diff changeset
   800
     by the compiler (due to a lack of a language standard for this).
claus
parents: 357
diff changeset
   801
     However, the compiler may detect sends ot #withEscapes to string literals
claus
parents: 357
diff changeset
   802
     and place a modified string constant into the binary/byte-code.
claus
parents: 357
diff changeset
   803
     Therefore, no runtime penalty will be payed for using these escapes.
claus
parents: 357
diff changeset
   804
     (not in pre 2.11 versions)
claus
parents: 357
diff changeset
   805
    "
claus
parents: 357
diff changeset
   806
claus
parents: 357
diff changeset
   807
    |sz      "{ SmallInteger }"
claus
parents: 357
diff changeset
   808
     newSize "{ SmallInteger }"
claus
parents: 357
diff changeset
   809
     srcIdx  "{ SmallInteger }"
claus
parents: 357
diff changeset
   810
     dstIdx  "{ SmallInteger }"
claus
parents: 357
diff changeset
   811
     val     "{ SmallInteger }"
claus
parents: 357
diff changeset
   812
     newString next start| 
claus
parents: 357
diff changeset
   813
claus
parents: 357
diff changeset
   814
    "
claus
parents: 357
diff changeset
   815
     first, count the number of escapes, to allow preallocation
claus
parents: 357
diff changeset
   816
     of the new string ...
claus
parents: 357
diff changeset
   817
     (it is faster to scan the string twice than to reallocate it multiple
claus
parents: 357
diff changeset
   818
      times in a WriteStream)
claus
parents: 357
diff changeset
   819
    "
claus
parents: 357
diff changeset
   820
    sz := newSize := self size.
claus
parents: 357
diff changeset
   821
    srcIdx := 1.
claus
parents: 357
diff changeset
   822
    [(srcIdx := self indexOf:$\ startingAt:srcIdx) ~~ 0] whileTrue:[
claus
parents: 357
diff changeset
   823
	srcIdx == sz ifFalse:[
claus
parents: 357
diff changeset
   824
	    newSize := newSize - 1.
claus
parents: 357
diff changeset
   825
	    srcIdx := srcIdx + 1.
claus
parents: 357
diff changeset
   826
	    next := self at:srcIdx.
claus
parents: 357
diff changeset
   827
	    next == $0 ifTrue:[
claus
parents: 357
diff changeset
   828
		[(self at:srcIdx) isDigit] whileTrue:[
claus
parents: 357
diff changeset
   829
		    newSize := newSize - 1. srcIdx := srcIdx + 1.
claus
parents: 357
diff changeset
   830
		]
claus
parents: 357
diff changeset
   831
	    ].
claus
parents: 357
diff changeset
   832
	].
claus
parents: 357
diff changeset
   833
	srcIdx := srcIdx + 1.
claus
parents: 357
diff changeset
   834
    ].
claus
parents: 357
diff changeset
   835
claus
parents: 357
diff changeset
   836
    newSize == sz ifTrue:[
claus
parents: 357
diff changeset
   837
	^ self
claus
parents: 357
diff changeset
   838
    ].
claus
parents: 357
diff changeset
   839
claus
parents: 357
diff changeset
   840
    newString := self species new:newSize.
claus
parents: 357
diff changeset
   841
    "
claus
parents: 357
diff changeset
   842
     copy over, replace escapes
claus
parents: 357
diff changeset
   843
    "
claus
parents: 357
diff changeset
   844
    srcIdx := dstIdx := 1.
claus
parents: 357
diff changeset
   845
    [srcIdx <= sz] whileTrue:[
claus
parents: 357
diff changeset
   846
	next := self at:srcIdx.
claus
parents: 357
diff changeset
   847
	srcIdx := srcIdx + 1.
claus
parents: 357
diff changeset
   848
	next == $\ ifTrue:[
claus
parents: 357
diff changeset
   849
	    srcIdx <= sz ifTrue:[
claus
parents: 357
diff changeset
   850
		next := self at:srcIdx.
claus
parents: 357
diff changeset
   851
		srcIdx := srcIdx + 1.
claus
parents: 357
diff changeset
   852
		next == $r ifTrue:[
claus
parents: 357
diff changeset
   853
		    next := Character return
claus
parents: 357
diff changeset
   854
		] ifFalse:[
claus
parents: 357
diff changeset
   855
		    next == $n ifTrue:[
claus
parents: 357
diff changeset
   856
			next := Character nl
claus
parents: 357
diff changeset
   857
		    ] ifFalse:[
claus
parents: 357
diff changeset
   858
			next == $b ifTrue:[
claus
parents: 357
diff changeset
   859
			    next := Character backspace
claus
parents: 357
diff changeset
   860
			] ifFalse:[
claus
parents: 357
diff changeset
   861
			    next == $f ifTrue:[
claus
parents: 357
diff changeset
   862
				next := Character newPage
claus
parents: 357
diff changeset
   863
			    ] ifFalse:[
claus
parents: 357
diff changeset
   864
				next == $t ifTrue:[
claus
parents: 357
diff changeset
   865
				    next := Character tab
claus
parents: 357
diff changeset
   866
				] ifFalse:[
claus
parents: 357
diff changeset
   867
				    next == $0 ifTrue:[
claus
parents: 357
diff changeset
   868
					val := 0.
claus
parents: 357
diff changeset
   869
					[next isDigit] whileTrue:[
claus
parents: 357
diff changeset
   870
					    val := val * 8 + next digitValue.
claus
parents: 357
diff changeset
   871
					    next := self at:srcIdx.
claus
parents: 357
diff changeset
   872
					    srcIdx := srcIdx + 1.
claus
parents: 357
diff changeset
   873
					].
claus
parents: 357
diff changeset
   874
					next := Character value:val.
claus
parents: 357
diff changeset
   875
				    ]
claus
parents: 357
diff changeset
   876
				]
claus
parents: 357
diff changeset
   877
			    ]
claus
parents: 357
diff changeset
   878
			]
claus
parents: 357
diff changeset
   879
		    ]
claus
parents: 357
diff changeset
   880
		].
claus
parents: 357
diff changeset
   881
	    ].
claus
parents: 357
diff changeset
   882
	].
claus
parents: 357
diff changeset
   883
	newString at:dstIdx put:next.
claus
parents: 357
diff changeset
   884
	dstIdx := dstIdx + 1.
claus
parents: 357
diff changeset
   885
    ].
claus
parents: 357
diff changeset
   886
    ^ newString
claus
parents: 357
diff changeset
   887
claus
parents: 357
diff changeset
   888
    "
claus
parents: 357
diff changeset
   889
     'hello world' withEscapes  
claus
parents: 357
diff changeset
   890
     'hello\world' withEscapes   
claus
parents: 357
diff changeset
   891
     'hello\world\' withEscapes   
claus
parents: 357
diff changeset
   892
     'hello world\' withEscapes   
claus
parents: 357
diff changeset
   893
     'hello\tworld' withEscapes   
claus
parents: 357
diff changeset
   894
     'hello\nworld\na\n\tnice\n\t\tstring' withEscapes   
claus
parents: 357
diff changeset
   895
     'hello\tworld\n' withEscapes   
claus
parents: 357
diff changeset
   896
     'hello\010world' withEscapes   
claus
parents: 357
diff changeset
   897
     'hello\r\nworld' withEscapes   
claus
parents: 357
diff changeset
   898
    "
claus
parents: 357
diff changeset
   899
!
claus
parents: 357
diff changeset
   900
328
claus
parents: 327
diff changeset
   901
expandPlaceholdersWith:argArray
claus
parents: 327
diff changeset
   902
    "return a copy of the receiver, where all %i escapes are
claus
parents: 327
diff changeset
   903
     replaced by corresponding arguments from the argArray.
claus
parents: 327
diff changeset
   904
     I.e. 'hello %1; how is %2' expandPlaceholdersWith:#('world' 'this') results
395
claus
parents: 384
diff changeset
   905
     in the new string 'hello world; how is this'.
claus
parents: 384
diff changeset
   906
     To get a '%' character, use a '%%'-escape.
claus
parents: 384
diff changeset
   907
     See also bindWith:... for VisualAge compatibility."
328
claus
parents: 327
diff changeset
   908
359
claus
parents: 357
diff changeset
   909
    |expandedString next 
claus
parents: 357
diff changeset
   910
     idx   "{ SmallInteger }"
claus
parents: 357
diff changeset
   911
     start "{ SmallInteger }"
claus
parents: 357
diff changeset
   912
     stop  "{ SmallInteger }"|
328
claus
parents: 327
diff changeset
   913
claus
parents: 327
diff changeset
   914
    expandedString := ''.
claus
parents: 327
diff changeset
   915
    stop := self size.
claus
parents: 327
diff changeset
   916
    start := 1.
claus
parents: 327
diff changeset
   917
    [start <= stop] whileTrue:[
claus
parents: 327
diff changeset
   918
	idx := self indexOf:$% startingAt:start.
claus
parents: 327
diff changeset
   919
	idx == 0 ifTrue:[
claus
parents: 327
diff changeset
   920
	    ^ expandedString , (self copyFrom:start to:stop)
claus
parents: 327
diff changeset
   921
	].
claus
parents: 327
diff changeset
   922
	"found a %"
claus
parents: 327
diff changeset
   923
	expandedString := expandedString , (self copyFrom:start to:(idx - 1)).
claus
parents: 327
diff changeset
   924
	next := self at:(idx + 1).
claus
parents: 327
diff changeset
   925
	(next == $%) ifTrue:[
claus
parents: 327
diff changeset
   926
	    expandedString := expandedString , '%'
claus
parents: 327
diff changeset
   927
	] ifFalse:[
claus
parents: 327
diff changeset
   928
	    expandedString := expandedString , (argArray at:(next digitValue)) printString
claus
parents: 327
diff changeset
   929
	].
claus
parents: 327
diff changeset
   930
	start := idx + 2
claus
parents: 327
diff changeset
   931
    ].
claus
parents: 327
diff changeset
   932
    ^  expandedString
claus
parents: 327
diff changeset
   933
claus
parents: 327
diff changeset
   934
    "
claus
parents: 327
diff changeset
   935
     'hello %1' expandPlaceholdersWith:#('world') 
claus
parents: 327
diff changeset
   936
     'hello %1; how is %2' expandPlaceholdersWith:#('world' 'this') 
359
claus
parents: 357
diff changeset
   937
     'hello %2; how is %1' expandPlaceholdersWith:#('world' 'this') 
328
claus
parents: 327
diff changeset
   938
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   939
! !
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
   940
395
claus
parents: 384
diff changeset
   941
!CharacterArray methodsFor:'Compatibility - VisualAge'!
claus
parents: 384
diff changeset
   942
claus
parents: 384
diff changeset
   943
addLineDelimiter
claus
parents: 384
diff changeset
   944
    "replace all '\'-characters by line delimiter (cr) - characters.
claus
parents: 384
diff changeset
   945
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
   946
claus
parents: 384
diff changeset
   947
    ^ self withCRs
claus
parents: 384
diff changeset
   948
!
claus
parents: 384
diff changeset
   949
claus
parents: 384
diff changeset
   950
bindWith:aString
claus
parents: 384
diff changeset
   951
    "return a copy of the receiver, where a '%1' escape is
claus
parents: 384
diff changeset
   952
     replaced by aString.
claus
parents: 384
diff changeset
   953
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
   954
claus
parents: 384
diff changeset
   955
    ^ self expandPlaceholdersWith:(Array with:aString)
claus
parents: 384
diff changeset
   956
claus
parents: 384
diff changeset
   957
    "
claus
parents: 384
diff changeset
   958
     'do you like %1 ?' bindWith:'smalltalk'
claus
parents: 384
diff changeset
   959
    "
claus
parents: 384
diff changeset
   960
!
claus
parents: 384
diff changeset
   961
claus
parents: 384
diff changeset
   962
bindWith:string1 with:string2
claus
parents: 384
diff changeset
   963
    "return a copy of the receiver, where a '%1' escape is
claus
parents: 384
diff changeset
   964
     replaced by string1 and '%2' is replaced by string2.
claus
parents: 384
diff changeset
   965
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
   966
claus
parents: 384
diff changeset
   967
    ^ self expandPlaceholdersWith:(Array with:string1 with:string2)
claus
parents: 384
diff changeset
   968
claus
parents: 384
diff changeset
   969
    "
claus
parents: 384
diff changeset
   970
     'do you prefer %1 or rather %2 ?'
claus
parents: 384
diff changeset
   971
	bindWith:'smalltalk' with:'c++'
claus
parents: 384
diff changeset
   972
    "
claus
parents: 384
diff changeset
   973
!
claus
parents: 384
diff changeset
   974
claus
parents: 384
diff changeset
   975
bindWith:str1 with:str2 with:str3
claus
parents: 384
diff changeset
   976
    "return a copy of the receiver, where a '%1', '%2' and '%3' escapes
claus
parents: 384
diff changeset
   977
     are replaced by str1, str2 and str3 respectively.
claus
parents: 384
diff changeset
   978
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
   979
claus
parents: 384
diff changeset
   980
    ^ self expandPlaceholdersWith:(Array with:str1 with:str2 with:str3)
claus
parents: 384
diff changeset
   981
claus
parents: 384
diff changeset
   982
    "
claus
parents: 384
diff changeset
   983
     'do you prefer %1 or rather %2 (not talking about %3) ?'
claus
parents: 384
diff changeset
   984
	bindWith:'smalltalk' with:'c++' with:'c'
claus
parents: 384
diff changeset
   985
    "
claus
parents: 384
diff changeset
   986
!
claus
parents: 384
diff changeset
   987
claus
parents: 384
diff changeset
   988
bindWith:str1 with:str2 with:str3 with:str4
claus
parents: 384
diff changeset
   989
    "return a copy of the receiver, where a '%1', '%2', '%3' and '%4' escapes
claus
parents: 384
diff changeset
   990
     are replaced by str1, str2, str3 and str4 respectively.
claus
parents: 384
diff changeset
   991
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
   992
claus
parents: 384
diff changeset
   993
    ^ self expandPlaceholdersWith:(Array with:str1 with:str2 with:str3 with:str4)
claus
parents: 384
diff changeset
   994
claus
parents: 384
diff changeset
   995
    "
claus
parents: 384
diff changeset
   996
     'do you prefer %1 or rather %2 (not talking about %3 or even %4) ?'
claus
parents: 384
diff changeset
   997
	bindWith:'smalltalk' with:'c++' with:'c' with:'assembler'
claus
parents: 384
diff changeset
   998
    "
claus
parents: 384
diff changeset
   999
!
claus
parents: 384
diff changeset
  1000
claus
parents: 384
diff changeset
  1001
bindWithArguments:anArrayOfStrings
claus
parents: 384
diff changeset
  1002
    "return a copy of the receiver, where a '%i' escape
claus
parents: 384
diff changeset
  1003
     is replaced by the coresponding string from the argument array.
claus
parents: 384
diff changeset
  1004
     'i' may be between 1 and 9 (i.e. a maximum of 9 placeholders is allowed).
claus
parents: 384
diff changeset
  1005
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
  1006
claus
parents: 384
diff changeset
  1007
    ^ self expandPlaceholdersWith:anArrayOfStrings
claus
parents: 384
diff changeset
  1008
claus
parents: 384
diff changeset
  1009
    "
claus
parents: 384
diff changeset
  1010
     'do you prefer %1 or rather %2 (not talking about %3) ?'
claus
parents: 384
diff changeset
  1011
	bindWithArguments:#('smalltalk' 'c++' 'c')
claus
parents: 384
diff changeset
  1012
    "
claus
parents: 384
diff changeset
  1013
!
claus
parents: 384
diff changeset
  1014
claus
parents: 384
diff changeset
  1015
subStrings
claus
parents: 384
diff changeset
  1016
    "return an array consisting of all words contained in the receiver.
claus
parents: 384
diff changeset
  1017
     Words are separated by whitespace.
claus
parents: 384
diff changeset
  1018
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
  1019
claus
parents: 384
diff changeset
  1020
    ^ self asCollectionOfWords
claus
parents: 384
diff changeset
  1021
claus
parents: 384
diff changeset
  1022
    "
claus
parents: 384
diff changeset
  1023
     'hello world, this is smalltalk' subStrings
claus
parents: 384
diff changeset
  1024
    "
claus
parents: 384
diff changeset
  1025
!
claus
parents: 384
diff changeset
  1026
claus
parents: 384
diff changeset
  1027
subStrings:separatorCharacter
claus
parents: 384
diff changeset
  1028
    "return an array consisting of all words contained in the receiver.
claus
parents: 384
diff changeset
  1029
     Words are separated by separatorCharacter.
claus
parents: 384
diff changeset
  1030
     This has been added for VisualAge compatibility."
claus
parents: 384
diff changeset
  1031
claus
parents: 384
diff changeset
  1032
    ^ self asCollectionOfSubstringsSeparatedBy:separatorCharacter
claus
parents: 384
diff changeset
  1033
claus
parents: 384
diff changeset
  1034
    "
claus
parents: 384
diff changeset
  1035
     'foo:bar:baz:smalltalk' subStrings:$:
claus
parents: 384
diff changeset
  1036
    "
claus
parents: 384
diff changeset
  1037
!
claus
parents: 384
diff changeset
  1038
claus
parents: 384
diff changeset
  1039
trimSeparators
claus
parents: 384
diff changeset
  1040
    "return a copy of the receiver without leading and trailing whiteSpace"
claus
parents: 384
diff changeset
  1041
claus
parents: 384
diff changeset
  1042
    ^ self withoutSeparators
claus
parents: 384
diff changeset
  1043
! !
claus
parents: 384
diff changeset
  1044
claus
parents: 384
diff changeset
  1045
!CharacterArray methodsFor:'Compatibility - ST/V'!
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1046
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1047
replChar:oldChar with:newChar
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1048
    "return a copy of the receiver, with all oldChars replaced
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1049
     by newChar.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1050
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1051
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1052
    ^ self copy replaceAll:oldChar by:newChar
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1053
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1054
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1055
     '12345678901234567890' replChar:$0 with:$* 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1056
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1057
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1058
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1059
replChar:oldChar withString:newString
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1060
    "return a copy of the receiver, with all oldChars replaced
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1061
     by newString (i.e. slice in the newString in place of the oldChar).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1062
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1063
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1064
    |tmpStream|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1065
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1066
    tmpStream := WriteStream on:(self class new).
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1067
    self do:[:element |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1068
	element = oldChar ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1069
	    tmpStream nextPutAll:newString
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1070
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1071
	    tmpStream nextPut:element 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1072
	].
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1073
    ].
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1074
    ^ tmpStream contents
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1075
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1076
   "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1077
     '12345678901234567890' replChar:$0 withString:'foo' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1078
     'a string with spaces' replChar:$  withString:' foo '  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1079
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1080
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1081
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1082
trimBlanks
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1083
    "return a copy of the receiver without leading
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1084
     and trailing spaces.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1085
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1086
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1087
    ^ self withoutSpaces
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1088
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1089
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1090
     '    spaces at beginning' trimBlanks     
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1091
     'spaces at end    ' trimBlanks           
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1092
     '    spaces at beginning and end     ' trimBlanks    
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1093
     'no spaces' trimBlanks              
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1094
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1095
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1096
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1097
byteAt:index put:aByte
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1098
    "store a byte at given index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1099
     This is an ST/V compatibility method."
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1100
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1101
    (aByte == 0) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1102
	"store a space instead"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1103
	^ super basicAt:index put:(Character space)
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1104
    ].
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1105
    ^ super at:index put:(Character value:aByte)
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1106
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1107
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1108
!CharacterArray methodsFor:'printing & storing'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1109
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1110
article
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1111
    "return an article string for the receiver."
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1112
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1113
    |firstChar|
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1114
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1115
    firstChar := (self at:1) asLowercase. 
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1116
    (firstChar isVowel or:[firstChar == $x]) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1117
	firstChar ~~ $u ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1118
	     ^ 'an'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1119
	]
82
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1120
    ].
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1121
    ^ 'a'
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1122
!
0147b4f725ae *** empty log message ***
claus
parents: 77
diff changeset
  1123
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1124
printOn:aStream
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1125
    "print the receiver on aStream"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1126
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1127
    aStream nextPutAll:self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1128
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1129
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1130
printString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1131
    "return a string for printing - thats myself"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1132
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1133
    ^ self
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1134
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1135
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1136
displayString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1137
    "return a string to display the receiver - use storeString to have
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1138
     quotes around."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1139
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1140
    ^ self storeString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1141
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1142
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1143
!CharacterArray methodsFor:'comparing'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1144
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1145
hash
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1146
    "return an integer useful as a hash-key"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1147
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1148
%{  /* NOCONTEXT */
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1149
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1150
    REGISTER int g, val;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1151
    REGISTER unsigned char *cp, *cp0;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1152
    int l;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1153
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1154
    cp = _stringVal(self);
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1155
    l = _stringSize(self);
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1156
    if (__qClass(self) != String) {
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1157
	int n = __OBJS2BYTES__(_intVal(_ClassInstPtr(__qClass(self))->c_ninstvars));
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1158
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1159
	cp += n;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1160
	l -= n;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1161
    }
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1162
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1163
    /*
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1164
     * this is the dragon-book algorithm with a funny start
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1165
     * value (to give short strings a number above 8192)
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1166
     */
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1167
    val = 12345;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1168
    for (cp0 = cp, cp += l - 1; cp >= cp0; cp--) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1169
	val = (val << 5) + (*cp & 0x1F);
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1170
	if (g = (val & 0x3E000000))
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1171
	    val ^= g >> 25 /* 23 */ /* 25 */;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1172
	val &= 0x3FFFFFFF;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1173
    }
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1174
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1175
    if (l) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1176
	l |= 1; 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1177
	val = (val * l) & 0x3FFFFFFF;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1178
    }
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1179
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1180
    RETURN ( _MKSMALLINT(val) );
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1181
%}
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1182
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1183
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1184
<= something
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1185
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1186
     receiver is less than or equal to the argument. Otherwise return false."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1187
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1188
    ^ (self > something) not
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1189
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1190
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1191
< something
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1192
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1193
     receiver is less than the argument. Otherwise return false."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1194
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1195
    ^ (something > self)
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1196
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1197
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1198
>= something
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1199
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1200
     receiver is greater than or equal to the argument.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1201
     Otherwise return false."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1202
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1203
    ^ (something > self) not
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1204
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1205
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1206
> aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1207
    "Compare the receiver with the argument and return true if the
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1208
     receiver is greater than the argument. Otherwise return false.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1209
     In contrast to ST-80, case differences are NOT ignored, thus
345
claus
parents: 343
diff changeset
  1210
     'foo' > 'Foo' will return true; use #sameAs: to compare ignoring cases.. 
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1211
     Since this is incompatible to ST-80, this may change."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1212
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1213
    |mySize    "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1214
     otherSize "{ Class: SmallInteger }" 
328
claus
parents: 327
diff changeset
  1215
     n         "{ Class: SmallInteger }" 
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1216
     c1 c2|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1217
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1218
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1219
    otherSize := aString size.
328
claus
parents: 327
diff changeset
  1220
    n := mySize min:otherSize.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1221
328
claus
parents: 327
diff changeset
  1222
    1 to:n do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1223
	c1 := self at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1224
	c2 := aString at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1225
	c1 > c2 ifTrue:[^ true].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1226
	c1 < c2 ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1227
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1228
    ^ mySize > otherSize
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1229
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1230
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1231
= aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1232
    "Compare the receiver with the argument and return true if the
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1233
     receiver is equal to the argument. Otherwise return false.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1234
     This compare does NOT ignore case differences, 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1235
     therefore 'foo' = 'Foo' will return false.
345
claus
parents: 343
diff changeset
  1236
     Since this is incompatible to ST-80 (at least, V2.x) , this may change."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1237
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1238
    |mySize    "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1239
     otherSize |
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1240
215
a1768b48c8af *** empty log message ***
claus
parents: 196
diff changeset
  1241
    aString species == self species ifFalse:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1242
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1243
    otherSize := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1244
    mySize == otherSize ifFalse:[^ false].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1245
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1246
    1 to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1247
	(self at:index) = (aString at:index) ifFalse:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1248
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1249
    ^ true
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1250
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1251
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1252
     'foo' = 'Foo'  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1253
     'foo' = 'bar'  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1254
     'foo' = 'foo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1255
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1256
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1257
345
claus
parents: 343
diff changeset
  1258
compareWith:aString
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1259
    "Compare the receiver with the argument and return 1 if the receiver is
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1260
     greater, 0 if equal and -1 if less than the argument. 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1261
     Case differences are NOT ignored, thus
345
claus
parents: 343
diff changeset
  1262
     'foo' compareWith: 'Foo' will return 1."
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1263
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1264
    |mySize    "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1265
     otherSize "{ Class: SmallInteger }" 
328
claus
parents: 327
diff changeset
  1266
     n         "{ Class: SmallInteger }" 
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1267
     c1 c2|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1268
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1269
    mySize := self size.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1270
    otherSize := aString size.
328
claus
parents: 327
diff changeset
  1271
    n := mySize min:otherSize.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1272
328
claus
parents: 327
diff changeset
  1273
    1 to:n do:[:index |
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1274
	c1 := self at:index.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1275
	c2 := aString at:index.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1276
	c1 > c2 ifTrue:[^ 1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1277
	c1 < c2 ifTrue:[^ -1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1278
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1279
    mySize > otherSize ifTrue:[^ 1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1280
    mySize < otherSize ifTrue:[^ -1].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1281
    ^ 0
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1282
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1283
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1284
sameAs:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1285
    "Compare the receiver with the argument like =, but ignore
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1286
     case differences. Return true or false."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1287
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1288
    |mySize "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1289
     otherSize c1 c2|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1290
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1291
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1292
    otherSize := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1293
    mySize == otherSize ifFalse:[^ false].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1294
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1295
    1 to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1296
	c1 := self at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1297
	c2 := aString at:index.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1298
	c1 == c2 ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1299
	    c1 asLowercase = c2 asLowercase ifFalse:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1300
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1301
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1302
    ^ true
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1303
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1304
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1305
     'foo' sameAs: 'Foo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1306
     'foo' sameAs: 'bar' 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1307
     'foo' sameAs: 'foo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1308
    "
345
claus
parents: 343
diff changeset
  1309
!
claus
parents: 343
diff changeset
  1310
claus
parents: 343
diff changeset
  1311
sameCharacters:aString
claus
parents: 343
diff changeset
  1312
    "count & return the number of characters which are the same
claus
parents: 343
diff changeset
  1313
     (ignoring case) in the receiver and the argument, aString."
claus
parents: 343
diff changeset
  1314
claus
parents: 343
diff changeset
  1315
    |n "{ Class: SmallInteger }"
claus
parents: 343
diff changeset
  1316
     otherSize c1 c2 cnt|
claus
parents: 343
diff changeset
  1317
claus
parents: 343
diff changeset
  1318
    n := self size.
claus
parents: 343
diff changeset
  1319
    n := n min:(aString size).
claus
parents: 343
diff changeset
  1320
claus
parents: 343
diff changeset
  1321
    cnt := 0.
claus
parents: 343
diff changeset
  1322
    1 to:n do:[:index |
claus
parents: 343
diff changeset
  1323
	c1 := self at:index.
claus
parents: 343
diff changeset
  1324
	c2 := aString at:index.
claus
parents: 343
diff changeset
  1325
	((c1 == c2)
claus
parents: 343
diff changeset
  1326
	or:[c1 asLowercase = c2 asLowercase]) ifTrue:[
claus
parents: 343
diff changeset
  1327
	    cnt := cnt + 1
claus
parents: 343
diff changeset
  1328
	]
claus
parents: 343
diff changeset
  1329
    ].
claus
parents: 343
diff changeset
  1330
    ^ cnt
claus
parents: 343
diff changeset
  1331
claus
parents: 343
diff changeset
  1332
    "
claus
parents: 343
diff changeset
  1333
     'foobarbaz' sameCharacters: 'foo'   
claus
parents: 343
diff changeset
  1334
     'foobarbaz' sameCharacters: 'Foo'   
claus
parents: 343
diff changeset
  1335
     'foobarbaz' sameCharacters: 'baz'   
claus
parents: 343
diff changeset
  1336
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1337
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1338
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1339
!CharacterArray methodsFor:'character searching'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1340
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1341
includesMatchCharacters
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1342
    "return true if the receiver includes any meta characters (i.e. $* or $#) 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1343
     for match operations; false if not"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1344
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1345
    ^ self includesAny:'*#['
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1346
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1347
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1348
indexOfSeparator
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1349
    "return the index of the first whitespace character"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1350
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1351
    ^ self indexOfSeparatorStartingAt:1
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1352
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1353
    "'hello world' indexOfSeparator"
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1354
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1355
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1356
indexOfSeparatorStartingAt:startIndex
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  1357
    "return the index of the next whitespace character"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1358
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1359
    |start  "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1360
     mySize "{ Class: SmallInteger }"|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1361
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1362
    start := startIndex.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1363
    mySize := self size.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1364
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1365
    start to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1366
	(self at:index) isSeparator ifTrue:[^ index]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1367
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1368
    ^ 0
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1369
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1370
    "'hello world' indexOfSeparatorStartingAt:3"
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1371
!
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1372
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1373
indexOfNonSeparatorStartingAt:startIndex
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1374
    "return the index of the next non-whitespace character"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1375
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1376
    |start  "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1377
     mySize "{ Class: SmallInteger }"|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1378
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1379
    start := startIndex.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1380
    mySize := self size.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1381
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1382
    start to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1383
	(self at:index) isSeparator ifFalse:[^ index]
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1384
    ].
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1385
    ^ 0
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1386
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1387
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1388
     '    hello world' indexOfNonSeparatorStartingAt:1 
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1389
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1390
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1391
     |s index1 index2|
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1392
     s := '   foo    bar      baz'.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1393
     index1 := s indexOfNonSeparatorStartingAt:1.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1394
     index2 := s indexOfSeparatorStartingAt:index1.
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1395
     s copyFrom:index1 to:index2 - 1
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1396
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1397
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1398
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1399
!CharacterArray methodsFor:'substring searching'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1400
368
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1401
findString:subString
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1402
    "find a substring. if found, return the index;
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1403
     if not found, return 0."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1404
368
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1405
    ^ self indexOfSubCollection:subString startingAt:1 ifAbsent:[0]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1406
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1407
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1408
     'hello world' findString:'llo'   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1409
     'hello world' findString:'ole'  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1410
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1411
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1412
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1413
findString:subString startingAt:index
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1414
    "find a substring, starting at index. if found, return the index;
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1415
     if not found, return 0."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1416
368
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1417
    ^ self indexOfSubCollection:subString startingAt:index ifAbsent:[0]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1418
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1419
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1420
     'hello yello' findString:'llo' startingAt:1   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1421
     'hello yello' findString:'llo' startingAt:5   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1422
     'hello yello' findString:'llo' startingAt:15   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1423
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1424
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1425
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1426
findString:subString startingAt:index ifAbsent:exceptionBlock
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1427
    "find a substring, starting at index. if found, return the index;
368
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1428
     if not found, return the result of evaluating exceptionBlock."
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1429
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1430
    ^ self indexOfSubCollection:subString startingAt:index ifAbsent:exceptionBlock
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1431
!
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1432
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1433
findString:subString ifAbsent:exceptionBlock
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1434
    "find a substring. If found, return the index;
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1435
     if not found, return the result of evaluating exceptionBlock."
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1436
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1437
    ^ self indexOfSubCollection:subString startingAt:1 ifAbsent:exceptionBlock
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1438
!
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1439
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1440
indexOfSubCollection:subString startingAt:index ifAbsent:exceptionBlock
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1441
    "find a substring, starting at index. if found, return the index;
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1442
     if not found, return the result of evaluating exceptionBlock.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1443
     This is a q&d hack - not very efficient"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1444
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1445
    |firstChar found
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1446
     startIndex "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1447
     subSize    "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1448
     mySize     "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1449
     runIdx     "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1450
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1451
    subSize := subString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1452
    subSize == 0 ifTrue:[^ index]. "empty string matches"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1453
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1454
    firstChar := subString at:1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1455
    startIndex := self indexOf:firstChar startingAt:index.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1456
    [startIndex == 0] whileFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1457
	runIdx := startIndex.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1458
	found := true.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1459
	1 to:subSize do:[:i |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1460
	    runIdx > mySize ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1461
		found := false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1462
	    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1463
		(subString at:i) ~~ (self at:runIdx) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1464
		    found := false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1465
		]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1466
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1467
	    runIdx := runIdx + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1468
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1469
	found ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1470
	    ^ startIndex
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1471
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1472
	startIndex := self indexOf:firstChar startingAt:(startIndex + 1)
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1473
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1474
    ^ exceptionBlock value
359
claus
parents: 357
diff changeset
  1475
!
claus
parents: 357
diff changeset
  1476
claus
parents: 357
diff changeset
  1477
includesString:aString
claus
parents: 357
diff changeset
  1478
    "return true, if a substring is contained in the receiver"
claus
parents: 357
diff changeset
  1479
368
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1480
    ^ (self indexOfSubCollection:aString startingAt:1 ifAbsent:[0]) ~~ 0
359
claus
parents: 357
diff changeset
  1481
claus
parents: 357
diff changeset
  1482
    "
claus
parents: 357
diff changeset
  1483
     'hello world' includesString:'hel' 
claus
parents: 357
diff changeset
  1484
     'hello world' includesString:'rld' 
claus
parents: 357
diff changeset
  1485
     'hello world' includesString:'llo'  
claus
parents: 357
diff changeset
  1486
     'hello world' includesString:'LLO'   
claus
parents: 357
diff changeset
  1487
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1488
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1489
328
claus
parents: 327
diff changeset
  1490
!CharacterArray class methodsFor:'pattern matching'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1491
328
claus
parents: 327
diff changeset
  1492
matchScanArrayFrom:aString
claus
parents: 327
diff changeset
  1493
    "scan a pattern string and decompose it into a scanArray.
claus
parents: 327
diff changeset
  1494
     This is processed faster (especially with character ranges), and
claus
parents: 327
diff changeset
  1495
     can also be reused later. (if the same pattern is to be searched again)"
308
f04744ef7b5d *** empty log message ***
claus
parents: 282
diff changeset
  1496
359
claus
parents: 357
diff changeset
  1497
    |coll 
claus
parents: 357
diff changeset
  1498
     idx "{ Class: SmallInteger }"
claus
parents: 357
diff changeset
  1499
     end c1 c2 matchSet previous|
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1500
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1501
    coll := OrderedCollection new.
328
claus
parents: 327
diff changeset
  1502
    idx := 1. end := aString size.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1503
    [idx <= end] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1504
	|char this|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1505
328
claus
parents: 327
diff changeset
  1506
	char := aString at:idx.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1507
	char == $* ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1508
	    previous ~~ #anyString ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1509
		this := #anyString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1510
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1511
	] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1512
	    char == $# ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1513
		previous ~~ #anyString ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1514
		    this := #any
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1515
		]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1516
	    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1517
		char == $[ ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1518
		    matchSet := IdentitySet new.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1519
		    idx := idx + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1520
		    idx > end ifTrue:[^ nil].
328
claus
parents: 327
diff changeset
  1521
		    char := aString at:idx.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1522
		    c1 := nil.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1523
		    [char ~~ $]] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1524
			((char == $-) and:[c1 notNil]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1525
			    idx := idx + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1526
			    idx > end ifTrue:[^ nil].
328
claus
parents: 327
diff changeset
  1527
			    c2 := aString at:idx.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1528
			    (c1 to:c2) do:[:c | matchSet add:c].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1529
			    c1 := nil.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1530
			    idx := idx + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1531
			] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1532
			    (char ~~ $]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1533
				matchSet add:char.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1534
				c1 := char.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1535
				idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1536
			    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1537
			].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1538
			idx > end ifTrue:[^ nil].
328
claus
parents: 327
diff changeset
  1539
			char := aString at:idx
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1540
		    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1541
		    this := matchSet asString
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1542
		] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1543
		    this := char
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1544
		]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1545
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1546
	].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1547
	this notNil ifTrue:[coll add:this. previous := this].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1548
	idx := idx + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1549
    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1550
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1551
    ^ coll asArray
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1552
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1553
    "
328
claus
parents: 327
diff changeset
  1554
     String matchScanArrayFrom:'*ute*'  
claus
parents: 327
diff changeset
  1555
     String matchScanArrayFrom:'**ute**'  
claus
parents: 327
diff changeset
  1556
     String matchScanArrayFrom:'*uter'   
claus
parents: 327
diff changeset
  1557
     String matchScanArrayFrom:'[cC]#mpute[rR]'  
claus
parents: 327
diff changeset
  1558
     String matchScanArrayFrom:'[abcd]*'      
claus
parents: 327
diff changeset
  1559
     String matchScanArrayFrom:'[a-k]*'      
claus
parents: 327
diff changeset
  1560
     String matchScanArrayFrom:'*some*compl*ern*' 
claus
parents: 327
diff changeset
  1561
     String matchScanArrayFrom:'[a-'  
claus
parents: 327
diff changeset
  1562
     String matchScanArrayFrom:'[a-zA-Z]'  
claus
parents: 327
diff changeset
  1563
     String matchScanArrayFrom:'[a-z01234A-Z]'  
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1564
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1565
!
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1566
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1567
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
  1568
    "helper for match; return true if the characters from start to stop in
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1569
     aString are matching the scan in matchScan from matchStart to matchStop.
328
claus
parents: 327
diff changeset
  1570
     The matchScan is as created by asMatchScanArray.
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1571
328
claus
parents: 327
diff changeset
  1572
     This algorithm is not at all the most efficient; 
claus
parents: 327
diff changeset
  1573
     for heavy duty pattern matching, an interface (primitive) to the regex 
claus
parents: 327
diff changeset
  1574
     pattern matching package should be added."
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1575
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1576
    |matchEntry 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1577
     mStart "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1578
     mStop  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1579
     sStart "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1580
     sStop  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1581
     mSize  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1582
     sSize  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1583
     index  "{ Class: SmallInteger }"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1584
     quickCheck matchLast
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1585
     matchSet checkChar included|
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1586
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1587
    mStart := matchStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1588
    mStop := matchStop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1589
    sStart := start.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1590
    sStop := stop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1591
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1592
    [true] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1593
	mSize := mStop - mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1594
	sSize := sStop - sStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1595
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1596
	"empty strings match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1597
	(mSize == 0) ifTrue:[^ (sSize == 0)].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1598
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1599
	matchEntry := matchScanArray at:mStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1600
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1601
	"/ the most common case first:
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1602
	(sSize ~~ 0 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1603
	and:[(checkChar := (aString at:sStart)) == matchEntry]) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1604
	    "advance by one and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1605
	    mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1606
	    sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1607
	] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1608
	    (matchEntry == #any) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1609
		"restString empty -> no match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1610
		(sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1611
		"# matches single character"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1612
		((sSize == 1) and:[mSize == 1]) ifTrue:[^ true].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1613
		"advance by one and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1614
		mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1615
		sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1616
	    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1617
		(matchEntry == #anyString) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1618
		    "* alone matches anything"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1619
		    (mSize == 1) ifTrue:[^ true].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1620
		    "restString empty & matchString not empty -> no match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1621
		    (sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1622
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1623
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1624
		     try to avoid some of the recursion by checking last
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1625
		     character and continue with shortened strings if possible
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1626
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1627
		    quickCheck := false.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1628
		    (mStop >= mStart) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1629
			matchLast := matchScanArray at:mStop.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1630
			(matchLast ~~ #anyString) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1631
			    (matchLast == #any) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1632
				quickCheck := true
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1633
			    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1634
				matchLast == (aString at:sStop) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1635
				    quickCheck := true
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1636
				] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1637
				    matchLast isString ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1638
					quickCheck := matchLast includes:(aString at:sStop)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1639
				    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1640
				]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1641
			    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1642
			]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1643
		    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1644
		    quickCheck ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1645
			"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1646
			 no quick check possible;
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1647
			 loop over all possible substrings
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1648
			"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1649
			index := sStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1650
			[index <= sStop] whileTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1651
			    (self matchScan:matchScanArray 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1652
				  from:(mStart + 1) 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1653
				  to:mStop 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1654
				  with:aString 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1655
				  from:index 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1656
				  to:stop 
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1657
				  ignoreCase:ignoreCase) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1658
				^ true
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1659
			    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1660
			    index := index + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1661
			].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1662
			^ false
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1663
		    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1664
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1665
		     quickCheck ok, advance from the right
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1666
		    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1667
		    mStop := mStop - 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1668
		    sStop := sStop - 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1669
		] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1670
		    (matchEntry isString) ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1671
			"testString empty -> no match"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1672
			(sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1673
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1674
			included := false.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1675
			"/ checkChar := aString at:sStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1676
			included := matchEntry includes:checkChar.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1677
			included ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1678
			    ignoreCase ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1679
				checkChar isUppercase ifTrue:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1680
				    included := matchEntry includes:checkChar asLowercase.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1681
				] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1682
				    included := matchEntry includes:checkChar asUppercase.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1683
				]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1684
			    ].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1685
			].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1686
			mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1687
			mSize := mSize - 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1688
			included ifFalse:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1689
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1690
			((sSize == 1) and:[mSize == 0]) ifTrue:[^ true].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1691
			"cut off 1st char and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1692
			sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1693
		    ] ifFalse:[
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1694
			"/ must be single character
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1695
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1696
			"testString empty ?"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1697
			(sSize == 0) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1698
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1699
			"first characters equal ?"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1700
			"/ checkChar := aString at:sStart.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1701
			ignoreCase ifFalse:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1702
			(checkChar asUppercase ~~ matchEntry asUppercase) ifTrue:[^ false].
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1703
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1704
			"advance and continue"
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1705
			mStart := mStart + 1.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1706
			sStart := sStart + 1
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1707
		    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1708
		]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1709
	    ]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1710
	]
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  1711
    ]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1712
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1713
328
claus
parents: 327
diff changeset
  1714
!CharacterArray methodsFor:'pattern matching'!
claus
parents: 327
diff changeset
  1715
claus
parents: 327
diff changeset
  1716
findMatchString:matchString
368
a3c21a89ec37 *** empty log message ***
claus
parents: 360
diff changeset
  1717
    "like findString/indexOfSubCollection, but allowing match patterns.
328
claus
parents: 327
diff changeset
  1718
     find matchstring; if found, return the index;
claus
parents: 327
diff changeset
  1719
     if not found, return 0."
claus
parents: 327
diff changeset
  1720
claus
parents: 327
diff changeset
  1721
    ^ self findMatchString:matchString startingAt:1 ignoreCase:false ifAbsent:[0] 
claus
parents: 327
diff changeset
  1722
!
claus
parents: 327
diff changeset
  1723
claus
parents: 327
diff changeset
  1724
findMatchString:matchString startingAt:index
claus
parents: 327
diff changeset
  1725
    "like findString, but allowing match patterns.
claus
parents: 327
diff changeset
  1726
     find matchstring, starting at index. if found, return the index;
claus
parents: 327
diff changeset
  1727
     if not found, return 0."
claus
parents: 327
diff changeset
  1728
claus
parents: 327
diff changeset
  1729
    ^ self findMatchString:matchString startingAt:index ignoreCase:false ifAbsent:[0] 
claus
parents: 327
diff changeset
  1730
!
claus
parents: 327
diff changeset
  1731
claus
parents: 327
diff changeset
  1732
findMatchString:matchString startingAt:index ignoreCase:ignoreCase ifAbsent:exceptionBlock
claus
parents: 327
diff changeset
  1733
    "like findString, but allowing match patterns.
claus
parents: 327
diff changeset
  1734
     find matchstring, starting at index. if found, return the index;
claus
parents: 327
diff changeset
  1735
     if not found, return the result of evaluating exceptionBlock.
claus
parents: 327
diff changeset
  1736
     This is a q&d hack - not very efficient"
claus
parents: 327
diff changeset
  1737
claus
parents: 327
diff changeset
  1738
    |firstChar 
claus
parents: 327
diff changeset
  1739
     startIndex "{ Class: SmallInteger }"
claus
parents: 327
diff changeset
  1740
     matchSize  "{ Class: SmallInteger }"
claus
parents: 327
diff changeset
  1741
     mySize     "{ Class: SmallInteger }"
claus
parents: 327
diff changeset
  1742
     realMatchString|
claus
parents: 327
diff changeset
  1743
claus
parents: 327
diff changeset
  1744
    matchSize := matchString size.
claus
parents: 327
diff changeset
  1745
    matchSize == 0 ifTrue:[^ index]. "empty string matches"
claus
parents: 327
diff changeset
  1746
claus
parents: 327
diff changeset
  1747
    realMatchString := matchString.
claus
parents: 327
diff changeset
  1748
    (realMatchString endsWith:$*) ifFalse:[
claus
parents: 327
diff changeset
  1749
	realMatchString := realMatchString , '*'.
claus
parents: 327
diff changeset
  1750
	matchSize := matchSize + 1
claus
parents: 327
diff changeset
  1751
    ].
claus
parents: 327
diff changeset
  1752
claus
parents: 327
diff changeset
  1753
    mySize := self size.
claus
parents: 327
diff changeset
  1754
    firstChar := realMatchString at:1.
claus
parents: 327
diff changeset
  1755
claus
parents: 327
diff changeset
  1756
    firstChar asString includesMatchCharacters ifTrue:[
claus
parents: 327
diff changeset
  1757
	index to:mySize do:[:col |
claus
parents: 327
diff changeset
  1758
	    (realMatchString match:self from:col to:mySize ignoreCase:ignoreCase)
claus
parents: 327
diff changeset
  1759
	    ifTrue:[^ col]
claus
parents: 327
diff changeset
  1760
	].
claus
parents: 327
diff changeset
  1761
	^ exceptionBlock value.
claus
parents: 327
diff changeset
  1762
    ].
claus
parents: 327
diff changeset
  1763
    startIndex := self indexOf:firstChar startingAt:index.
claus
parents: 327
diff changeset
  1764
    [startIndex == 0] whileFalse:[
claus
parents: 327
diff changeset
  1765
	(realMatchString match:self from:startIndex to:mySize ignoreCase:ignoreCase)
claus
parents: 327
diff changeset
  1766
	ifTrue:[^ startIndex].
claus
parents: 327
diff changeset
  1767
	startIndex := self indexOf:firstChar startingAt:(startIndex + 1)
claus
parents: 327
diff changeset
  1768
    ].
claus
parents: 327
diff changeset
  1769
    ^ exceptionBlock value
claus
parents: 327
diff changeset
  1770
claus
parents: 327
diff changeset
  1771
    "
claus
parents: 327
diff changeset
  1772
     'one two three four' findMatchString:'o[nu]'
claus
parents: 327
diff changeset
  1773
     'one two three four' findMatchString:'o[nu]' startingAt:3
claus
parents: 327
diff changeset
  1774
    "
claus
parents: 327
diff changeset
  1775
!
claus
parents: 327
diff changeset
  1776
claus
parents: 327
diff changeset
  1777
match:aString
claus
parents: 327
diff changeset
  1778
    "return true if aString matches self, where self may contain meta-match 
claus
parents: 327
diff changeset
  1779
     characters $* (to match any string) or $# (to match any character).
claus
parents: 327
diff changeset
  1780
     or [...] to match a set of characters.
345
claus
parents: 343
diff changeset
  1781
     Lower/uppercase are considered different.
claus
parents: 343
diff changeset
  1782
     NOTICE: match-meta character interpretation is like in unix-matching, 
claus
parents: 343
diff changeset
  1783
	     NOT the ST-80 meaning."
328
claus
parents: 327
diff changeset
  1784
claus
parents: 327
diff changeset
  1785
    ^ self match:aString from:1 to:aString size ignoreCase:false
claus
parents: 327
diff changeset
  1786
claus
parents: 327
diff changeset
  1787
    "
claus
parents: 327
diff changeset
  1788
     '*ute*' match:'computer' 
claus
parents: 327
diff changeset
  1789
     '*uter' match:'computer' 
claus
parents: 327
diff changeset
  1790
     'uter*' match:'computer' 
claus
parents: 327
diff changeset
  1791
     '*ute*' match:'' 
claus
parents: 327
diff changeset
  1792
     '[abcd]*' match:'computer' 
claus
parents: 327
diff changeset
  1793
     '[abcd]*' match:'komputer' 
claus
parents: 327
diff changeset
  1794
     '*some*compl*ern*' match:'this is some more complicated pattern match' 
claus
parents: 327
diff changeset
  1795
     '*some*compl*ern*' match:'this is another complicated pattern match' 
claus
parents: 327
diff changeset
  1796
    "
claus
parents: 327
diff changeset
  1797
!
claus
parents: 327
diff changeset
  1798
claus
parents: 327
diff changeset
  1799
match:aString ignoreCase:ignoreCase
claus
parents: 327
diff changeset
  1800
    "return true if aString matches self, where self may contain meta-match 
claus
parents: 327
diff changeset
  1801
     characters $* (to match any string) or $# (to match any character)
claus
parents: 327
diff changeset
  1802
     or [...] to match a set of characters.
345
claus
parents: 343
diff changeset
  1803
     If ignoreCase is true, lower/uppercase are considered the same.
claus
parents: 343
diff changeset
  1804
     NOTICE: match-meta character interpretation is like in unix-matching, 
claus
parents: 343
diff changeset
  1805
	     NOT the ST-80 meaning."
328
claus
parents: 327
diff changeset
  1806
claus
parents: 327
diff changeset
  1807
    ^ self match:aString from:1 to:aString size ignoreCase:ignoreCase
claus
parents: 327
diff changeset
  1808
claus
parents: 327
diff changeset
  1809
    "
claus
parents: 327
diff changeset
  1810
     '*ute*' match:'COMPUTER' ignoreCase:true  
claus
parents: 327
diff changeset
  1811
     '*uter' match:'COMPUTER' ignoreCase:false 
claus
parents: 327
diff changeset
  1812
     '[abcd]*' match:'computer' ignoreCase:false 
claus
parents: 327
diff changeset
  1813
     '[abcd]*' match:'Computer' ignoreCase:false 
claus
parents: 327
diff changeset
  1814
     '[a-k]*' match:'komputer' ignoreCase:false   
claus
parents: 327
diff changeset
  1815
     '[a-k]*' match:'zomputer' ignoreCase:false    
claus
parents: 327
diff changeset
  1816
     '[a-k]*' match:'Komputer' ignoreCase:false    
claus
parents: 327
diff changeset
  1817
     '[a-k]*' match:'Komputer' ignoreCase:true     
claus
parents: 327
diff changeset
  1818
     '*some*compl*ern*' match:'this is some more complicated pattern match' ignoreCase:true 
claus
parents: 327
diff changeset
  1819
     '*some*compl*ern*' match:'this is another complicated pattern match' ignoreCase:true 
claus
parents: 327
diff changeset
  1820
claus
parents: 327
diff changeset
  1821
     Time millisecondsToRun:[
claus
parents: 327
diff changeset
  1822
	Symbol allInstancesDo:[:sym |
claus
parents: 327
diff changeset
  1823
	    '[ab]*' match:sym ignoreCase:false
claus
parents: 327
diff changeset
  1824
	]
claus
parents: 327
diff changeset
  1825
     ]. 
claus
parents: 327
diff changeset
  1826
    "
claus
parents: 327
diff changeset
  1827
!
claus
parents: 327
diff changeset
  1828
claus
parents: 327
diff changeset
  1829
match:aString from:start to:stop ignoreCase:ignoreCase
claus
parents: 327
diff changeset
  1830
    "return true if part of aString matches myself, 
claus
parents: 327
diff changeset
  1831
     where self may contain meta-match 
claus
parents: 327
diff changeset
  1832
     characters $* (to match any string) or $# (to match any character)
claus
parents: 327
diff changeset
  1833
     or [...] to match a set of characters.
345
claus
parents: 343
diff changeset
  1834
     If ignoreCase is true, lower/uppercase are considered the same.
claus
parents: 343
diff changeset
  1835
     NOTICE: match-meta character interpretation is like in unix-matching, 
claus
parents: 343
diff changeset
  1836
	     NOT the ST-80 meaning."
328
claus
parents: 327
diff changeset
  1837
claus
parents: 327
diff changeset
  1838
    |matchScanArray|
claus
parents: 327
diff changeset
  1839
claus
parents: 327
diff changeset
  1840
    "
claus
parents: 327
diff changeset
  1841
     keep the matchScanArray from the most recent match -
claus
parents: 327
diff changeset
  1842
     avoids parsing the pattern over-and over if multiple searches
claus
parents: 327
diff changeset
  1843
     are done with the same pattern.
claus
parents: 327
diff changeset
  1844
    "
claus
parents: 327
diff changeset
  1845
    (PreviousMatch notNil
claus
parents: 327
diff changeset
  1846
    and:[PreviousMatch key = self]) ifTrue:[
claus
parents: 327
diff changeset
  1847
	matchScanArray := PreviousMatch value
claus
parents: 327
diff changeset
  1848
    ] ifFalse:[
claus
parents: 327
diff changeset
  1849
	matchScanArray := self class matchScanArrayFrom:self.
claus
parents: 327
diff changeset
  1850
	matchScanArray isNil ifTrue:[
356
claus
parents: 350
diff changeset
  1851
	    'CHARARRAY: invalid matchpattern:' infoPrint. self infoPrintNL.
328
claus
parents: 327
diff changeset
  1852
	    ^ false
claus
parents: 327
diff changeset
  1853
	].
claus
parents: 327
diff changeset
  1854
	PreviousMatch := self -> matchScanArray.
claus
parents: 327
diff changeset
  1855
    ].
claus
parents: 327
diff changeset
  1856
claus
parents: 327
diff changeset
  1857
    ^ self class
claus
parents: 327
diff changeset
  1858
	matchScan:matchScanArray 
claus
parents: 327
diff changeset
  1859
	from:1 to:matchScanArray size
claus
parents: 327
diff changeset
  1860
	with:aString 
claus
parents: 327
diff changeset
  1861
	from:start to:stop 
claus
parents: 327
diff changeset
  1862
	ignoreCase:ignoreCase
claus
parents: 327
diff changeset
  1863
claus
parents: 327
diff changeset
  1864
    "
claus
parents: 327
diff changeset
  1865
     '*ute*' match:'12345COMPUTER' from:1 to:5 ignoreCase:true 
claus
parents: 327
diff changeset
  1866
     '*ute*' match:'12345COMPUTER' from:6 to:13 ignoreCase:true  
claus
parents: 327
diff changeset
  1867
    "
359
claus
parents: 357
diff changeset
  1868
!
claus
parents: 357
diff changeset
  1869
claus
parents: 357
diff changeset
  1870
includesMatchString:matchString
claus
parents: 357
diff changeset
  1871
    "like includesString, but allowing match patterns.
claus
parents: 357
diff changeset
  1872
     find matchstring; if found, return true, otherwise return false"
claus
parents: 357
diff changeset
  1873
claus
parents: 357
diff changeset
  1874
    ^ (self findMatchString:matchString) ~~ 0
claus
parents: 357
diff changeset
  1875
claus
parents: 357
diff changeset
  1876
    "
claus
parents: 357
diff changeset
  1877
     'hello world' includesMatchString:'h*'
claus
parents: 357
diff changeset
  1878
     'hello world' includesMatchString:'h[aeiou]llo' 
claus
parents: 357
diff changeset
  1879
     'hello world' includesMatchString:'wor*'     
claus
parents: 357
diff changeset
  1880
     'hello world' includesMatchString:'woR*'     
claus
parents: 357
diff changeset
  1881
    "
328
claus
parents: 327
diff changeset
  1882
! !
claus
parents: 327
diff changeset
  1883
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  1884
!CharacterArray methodsFor:'testing'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1885
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1886
isBlank
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1887
    "return true, if the receiver contains spaces only"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1888
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1889
    self do:[:char |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1890
	char ~~ Character space ifTrue:[^ false].
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1891
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1892
    ^ true
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1893
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1894
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1895
isAlphaNumeric
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1896
    "return true, if the receiver is some alphanumeric word;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1897
     i.e. consists of a letter followed by letters or digits."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1898
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1899
    self size == 0 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1900
	"mhmh what is this ?"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1901
	^ false
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1902
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1903
    (self at:1) isLetter ifFalse:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1904
    self do:[:char |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1905
	char isLetterOrDigit ifFalse:[^ false].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1906
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1907
    ^ true
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1908
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1909
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1910
     'helloWorld' isAlphaNumeric  
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1911
     'foo1234' isAlphaNumeric    
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1912
     'f1234' isAlphaNumeric      
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1913
     '1234' isAlphaNumeric       
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1914
     '+' isAlphaNumeric         
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1915
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1916
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1917
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1918
countWords
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1919
    "return the number of words, which are separated by separators"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1920
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1921
    |tally "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1922
     start "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1923
     mySize "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1924
     stop ch|
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1925
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1926
    tally := 0.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1927
    start := 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1928
    mySize := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1929
    [start <= mySize] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1930
	ch := self at:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1931
	ch isSeparator ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1932
	    start := start + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1933
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1934
	    stop := self indexOfSeparatorStartingAt:start.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1935
	    (stop == 0) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1936
		stop := mySize + 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1937
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1938
	    tally := tally + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1939
	    start := stop
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1940
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1941
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1942
    ^ tally
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1943
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1944
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1945
     'hello world isnt this nice' countWords'
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1946
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1947
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1948
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1949
numArgs
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1950
    "treating the receiver as a message selector, return how many arguments would it take"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1951
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1952
    |binopChars|
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1953
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1954
    (self size > 2) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1955
	binopChars := '|&-+=*/\<>~@,'.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1956
	(self size == 1) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1957
	    ((binopChars occurrencesOf:(self at:1)) == 0) ifTrue:[^ 0].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1958
	    ^ 1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1959
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1960
	((binopChars occurrencesOf:(self at:1)) == 0) ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1961
	    ((binopChars occurrencesOf:(self at:2)) == 0) ifFalse:[^ 1]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1962
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1963
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1964
    ^ self occurrencesOf:$:
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1965
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1966
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1967
     'foo:bar:' numArgs  
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1968
     #foo:bar: numArgs    
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1969
     'hello' numArgs       
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1970
     '+' numArgs   
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1971
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1972
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1973
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1974
partsIfSelector
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1975
    "treat the receiver as a message selector, return a collection of parts."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1976
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1977
    |idx1 "{ Class: SmallInteger }"
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  1978
     coll idx2 sz|
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1979
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1980
    coll := OrderedCollection new.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1981
    idx1 := 1.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1982
    sz := self size.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1983
    [true] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1984
	idx2 := self indexOf:$: startingAt:idx1 + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1985
	(idx2 == 0 or:[idx2 == sz]) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1986
	    coll add:(self copyFrom:idx1).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1987
	    ^ coll
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1988
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1989
	coll add:(self copyFrom:idx1 to:idx2).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  1990
	idx1 := idx2 + 1
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1991
    ].
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1992
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1993
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1994
     'foo:bar:' partsIfSelector     
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1995
     #foo:bar: partsIfSelector     
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1996
     'hello' partsIfSelector       
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1997
     '+' partsIfSelector           
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1998
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  1999
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2000
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2001
levenshteinTo:aString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2002
    "return the levenshtein distance to the argument, aString;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2003
     this value corrensponds to the number of replacements that have to be
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2004
     made to get aString from the receiver.
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2005
     See IEEE transactions on Computers 1976 Pg 172 ff."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2006
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2007
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2008
     in the following, we assum that ommiting a character
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2009
     is less of an error than inserting an extra character.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2010
     Therefore the different insertion (i) and deletion (d)
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2011
     values.
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2012
    "
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2013
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2014
    ^ self levenshteinTo:aString s:4 c:1 i:2 d:6
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2015
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2016
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2017
     'ocmprt' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2018
     'computer' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2019
     'ocmputer' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2020
     'cmputer' levenshteinTo:'computer'
327
183f094cfd72 last with old match code
claus
parents: 326
diff changeset
  2021
     'computer' levenshteinTo:'cmputer'
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2022
     'Computer' levenshteinTo:'computer'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2023
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2024
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2025
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2026
levenshteinTo:aString s:substWeight c:caseWeight i:insrtWeight d:deleteWeight
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2027
    "parametrized levenshtein. 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2028
     return the levenshtein distance to the argument, aString;
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2029
     this value corrensponds to the number of replacements that have to be
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2030
     made to get aString from the receiver.
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2031
     The arguments are the costs for substitution, case-change, insertion and 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2032
     deletion of a character.
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2033
     See IEEE transactions on Computers 1976 Pg 172 ff"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2034
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2035
    |d  "delta matrix"
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2036
     len1 "{ Class: SmallInteger }"
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2037
     len2 "{ Class: SmallInteger }"
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2038
     dim  "{ Class: SmallInteger }"
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2039
     prevRow row col 
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2040
     dimPlus1 "{ Class: SmallInteger }"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2041
     min pp c1 c2|
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2042
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2043
    len1 := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2044
    len2 := aString size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2045
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2046
    "create the help-matrix"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2047
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2048
    dim := len1 max:len2.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2049
    dimPlus1 := dim + 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2050
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2051
    d := Array new:dimPlus1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2052
    1 to:dimPlus1 do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2053
	d at:i put:(Array new:dimPlus1)
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2054
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2055
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2056
    "init help-matrix"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2057
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2058
    (d at:1) at:1 put:0.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2059
    row := d at:1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2060
    1 to:dim do:[:j |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2061
	row at:(j + 1) put:( (row at:j) + insrtWeight )
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2062
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2063
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2064
    1 to:dim do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2065
	 (d at:(i + 1)) at:1 put:(  ((d at:i) at:1) + deleteWeight )
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2066
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2067
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2068
    1 to:len1 do:[:i |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2069
	c1 := self at:i.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2070
	1 to:len2 do:[:j |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2071
	    c2 := aString at:j.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2072
	    (c1 == c2) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2073
		pp := 0
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2074
	    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2075
		(c1 asLowercase == c2 asLowercase) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2076
		    pp := caseWeight
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2077
		] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2078
		    pp := substWeight
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2079
		]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2080
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2081
	    prevRow := d at:i.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2082
	    row := d at:(i + 1).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2083
	    col := j + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2084
	    min := (prevRow at:j) + pp.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2085
	    min := min min:( (row at:j) + insrtWeight).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2086
	    min := min min:( (prevRow at:col) + deleteWeight).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2087
	    row at:col put: min
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2088
	]
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2089
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2090
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2091
    ^ (d at:(len1 + 1)) at:(len2 + 1)
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2092
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2093
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2094
spellAgainst: aString 
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2095
    "return an integer between 0 and 100 indicating how similar 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2096
     the argument is to the receiver.  No case conversion is done.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2097
     This algorithm is much simpler (but also less exact) than the
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2098
     levenshtein distance. Experiment which is better for your
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2099
     application."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2100
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2101
    | i1     "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2102
      i2     "{ Class: SmallInteger }"
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2103
      next1  "{ Class: SmallInteger }"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2104
      next2  "{ Class: SmallInteger }"
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2105
      size1  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2106
      size2  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2107
      score  "{ Class: SmallInteger }"
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2108
      maxLen "{ Class: SmallInteger }" |
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2109
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2110
    size1 := self size.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2111
    size2 := aString size.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2112
    maxLen := size1 max:size2.
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2113
    score := 0.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2114
    i1 := i2 := 1.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2115
    [i1 <= size1 and: [i2 <= size2]] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2116
	next1 := i1 + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2117
	next2 := i2 + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2118
	(self at:i1) == (aString at:i2) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2119
	    score := score+1.             
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2120
	    i1 := next1.                    
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2121
	    i2 := next2
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2122
	] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2123
	    (i2 < size2 and: [(self at:i1) == (aString at:next2)]) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2124
		i2 := next2
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2125
	    ] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2126
		(i1 < size1 and: [(self at:next1) == (aString at:i2)]) ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2127
		    i1 := next1
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2128
		] ifFalse: [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2129
		    i1 := next1.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2130
		    i2 := next2
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2131
		] 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2132
	    ] 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2133
	] 
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2134
    ].
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2135
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2136
    score = maxLen ifTrue: [^ 100].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2137
    ^ 100 * score // maxLen
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2138
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2139
    " 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2140
     'Smalltalk' spellAgainst: 'Smalltlak' 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2141
     'Smalltalk' spellAgainst: 'smalltlak' 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2142
     'Smalltalk' spellAgainst: 'smalltalk' 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2143
     'Smalltalk' spellAgainst: 'smalltlk'  
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2144
     'Smalltalk' spellAgainst: 'Smalltolk'   
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2145
    "
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2146
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2147
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  2148
!CharacterArray methodsFor:'padded copying'!
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2149
505
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2150
paddedTo:newSize
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2151
     "return a new string consisting of the receivers characters,
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2152
     plus spaces up to length.
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2153
     If the receivers size is equal or greater than the length argument, 
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2154
     the original receiver is returned unchanged."
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2155
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2156
     ^ self paddedTo:newSize with:(Character space)
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2157
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2158
    "
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2159
     'foo' paddedTo:10            
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2160
     123 printString paddedTo:10 
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2161
    "
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2162
!
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2163
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2164
paddedTo:newSize with:padCharacter
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2165
    "return a new string consisting of the receivers characters,
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2166
     plus pad characters up to length.
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  2167
     If the receivers size is equal or greater than the length argument, 
505
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2168
     the  original receiver is returned unchanged."
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2169
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2170
    |s len|
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2171
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2172
    len := self size.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2173
    len < newSize ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2174
	s := self species new:newSize withAll:padCharacter.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2175
	s replaceFrom:1 to:len with:self.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2176
	^ s
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2177
    ]
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2178
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2179
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2180
     'foo' paddedTo:10 with:$.             
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2181
     123 printString paddedTo:10 with:$*   
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2182
     (Float pi printString) paddedTo:15 with:(Character space)  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2183
     (Float pi printString) paddedTo:15 with:$-  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2184
     (Float pi class name , ' ') paddedTo:15 with:$.  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2185
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2186
!
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2187
505
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2188
leftPaddedTo:size
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2189
    "return a new string of length size, which contains the receiver
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2190
     right-adjusted (i.e. padded on the left).
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2191
     Characters on the left are filled with spaces.
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2192
     If the receivers size is equal or greater than the length argument, 
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2193
     the original receiver is returned unchanged."
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2194
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2195
    ^ self leftPaddedTo:size with:(Character space)
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2196
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2197
    "
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2198
     'foo' leftPaddedTo:10  
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2199
     'fooBar' leftPaddedTo:5      
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2200
     123 printString leftPaddedTo:10        
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2201
    "
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2202
!
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2203
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2204
leftPaddedTo:size with:padCharacter
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2205
    "return a new string of length size, which contains the receiver
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2206
     right-adjusted (i.e. padded on the left).
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2207
     Characters on the left are filled with padCharacter.
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  2208
     If the receivers size is equal or greater than the length argument, 
505
708abddf38a7 added paddedTo: / leftPaddedTo: (pad with spaces)
Claus Gittinger <cg@exept.de>
parents: 443
diff changeset
  2209
     the original receiver is returned unchanged."
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2210
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2211
    |len s|
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2212
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2213
    len := self size.
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2214
    (len < size) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2215
	s := self species new:size withAll:padCharacter.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2216
	s replaceFrom:(size - len + 1) with:self.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
  2217
	^ s
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2218
    ]
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2219
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2220
    "
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2221
     'foo' leftPaddedTo:10 with:$.      
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2222
     'fooBar' leftPaddedTo:5 with:$.      
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2223
     123 printString leftPaddedTo:10 with:$.        
196
ab5727ae9e38 added asUppercaseFirst / asLowercaseFirst
claus
parents: 163
diff changeset
  2224
     (' ' , 123 printString) leftPaddedTo:10 with:$.        
92
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2225
     (Float pi printString) leftPaddedTo:15 with:(Character space)  
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2226
     (Float pi printString) leftPaddedTo:15 with:$-           
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2227
     (' ' , Float pi class name) leftPaddedTo:15 with:$.     
0c73b48551ac *** empty log message ***
claus
parents: 82
diff changeset
  2228
    "
68
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2229
! !
59faa75185ba *** empty log message ***
claus
parents: 64
diff changeset
  2230
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  2231
!CharacterArray methodsFor:'copying'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2232
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2233
concatenate:string1 and:string2
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2234
    "return the concatenation of myself and the arguments, string1 and string2.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2235
     This is equivalent to self , string1 , string2
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  2236
     - generated by compiler when such a construct is detected and the receiver
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  2237
     is known to be a string."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2238
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2239
    ^ self , string1 , string2
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2240
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2241
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2242
concatenate:string1 and:string2 and:string3
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2243
    "return the concatenation of myself and the string arguments.
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2244
     This is equivalent to self , string1 , string2 , string3
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  2245
     - generated by compiler when such a construct is detected and the receiver
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
  2246
     is known to be a string."
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2247
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2248
    ^ self , string1 , string2 , string3
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2249
! !
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2250
350
claus
parents: 345
diff changeset
  2251
!CharacterArray methodsFor:'displaying'!
claus
parents: 345
diff changeset
  2252
claus
parents: 345
diff changeset
  2253
displayOn:aGc x:x y:y
claus
parents: 345
diff changeset
  2254
    "display the receiver in a graphicsContext - this method allows
claus
parents: 345
diff changeset
  2255
     strings to be used like DisplayObjects."
claus
parents: 345
diff changeset
  2256
claus
parents: 345
diff changeset
  2257
    ^ aGc displayString:self x:x y:y.
claus
parents: 345
diff changeset
  2258
! !
claus
parents: 345
diff changeset
  2259
255
2b2c5c0facab *** empty log message ***
claus
parents: 247
diff changeset
  2260
!CharacterArray methodsFor:'queries'!
64
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2261
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2262
isString
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2263
    "return true, if the receiver is some kind of string;
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2264
     true is returned here - redefinition of Object>>isString."
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2265
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2266
    ^ true
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2267
!
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2268
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2269
encoding
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2270
    ^ #unknown
af7aeb79b25e Initial revision
claus
parents:
diff changeset
  2271
! !