StringCollection.st
author claus
Thu, 10 Aug 1995 20:36:34 +0200
changeset 383 8e3ec8164440
parent 381 dcb27b0c7e42
child 530 07d0bce293c9
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    13
VariableArray subclass:#StringCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Collections-Text'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    20
StringCollection comment:'
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
    22
	      All Rights Reserved
97
b876f90648aa *** empty log message ***
claus
parents: 89
diff changeset
    23
383
claus
parents: 381
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/StringCollection.st,v 1.16 1995-08-10 18:36:30 claus Exp $
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    25
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    27
!StringCollection class methodsFor:'documentation'!
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    28
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    29
copyright
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    30
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    31
 COPYRIGHT (c) 1989 by Claus Gittinger
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
    32
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    34
 This software is furnished under a license and may be used
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    35
 only in accordance with the terms of that license and with the
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    37
 be provided or otherwise made available to, or used by, any
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    38
 other person.  No title to or ownership of the software is
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    39
 hereby transferred.
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    40
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    41
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    43
version
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    44
"
383
claus
parents: 381
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/StringCollection.st,v 1.16 1995-08-10 18:36:30 claus Exp $
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    46
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    47
!
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    48
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    49
documentation
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    50
"
262
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
    51
    StringCollection is an variable sized array of lines which are strings.
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
    52
    WARNING:
203
3d88fa870de0 *** empty log message ***
claus
parents: 160
diff changeset
    53
	This class is temporary (a historic leftover) - it may change or
3d88fa870de0 *** empty log message ***
claus
parents: 160
diff changeset
    54
	even vanish in the future. Use OrderedCollections or other standard
3d88fa870de0 *** empty log message ***
claus
parents: 160
diff changeset
    55
	classes to represent collections of strings.
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    56
262
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
    57
    StringCollection used to be called Text, but this is a very bad name
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
    58
     - there is something totally different also named Text in ST-80 ...
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    59
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    60
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    62
!StringCollection class methodsFor:'instance creation'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
from:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
    "return a new text object with lines taken from the argument, aString"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
    ^ (self new:1) from:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
fromArray:anArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
    "return a new text object with lines taken from the argument, an array
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
     of strings"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    74
    |newStringCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
     size "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
    size := anArray size.
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    78
    newStringCollection := self new:size.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
    1 to:size do:[:line |
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    80
	newStringCollection at:line put:(anArray at:line)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
    ].
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    82
    ^ newStringCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
    85
!StringCollection methodsFor:'growing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
grow:newSize
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
    "grow to newsize - new elements are initialized with empty strings -
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
     not nil"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
    |oldSize "{ Class:SmallInteger }"|
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
    oldSize := tally.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
    super grow:newSize.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
    (oldSize < newSize) ifTrue:[
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
    96
	contentsArray from:(oldSize + 1) to:newSize put:''
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
add:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
    "append the argument, aString to myself -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
     we increase physical size by 50 to avoid lots of copying around"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
    |oldSize "{ Class:SmallInteger }"|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
    oldSize := tally.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
    super grow:(oldSize + 50).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
    tally := oldSize + 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
    contentsArray at:tally put:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
   112
!StringCollection methodsFor:'converting'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
asString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
    "return myself as a string with embedded cr's"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
262
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
   117
    ^ self asStringWith:Character cr
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
   118
		   from:1 to:(self size) 
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
   119
	   compressTabs:false 
39f91e7b1ab1 *** empty log message ***
claus
parents: 246
diff changeset
   120
		  final:Character cr
87
a0cc38a72871 *** empty log message ***
claus
parents: 10
diff changeset
   121
!
a0cc38a72871 *** empty log message ***
claus
parents: 10
diff changeset
   122
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
from:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
    "setup my contents from the argument, aString"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
    |numberOfLines "{ Class:SmallInteger }"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
     start         "{ Class:SmallInteger }"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
     stop          "{ Class:SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    numberOfLines := aString occurrencesOf:(Character cr).
203
3d88fa870de0 *** empty log message ***
claus
parents: 160
diff changeset
   131
    (aString endsWith:(Character cr)) ifFalse:[
3d88fa870de0 *** empty log message ***
claus
parents: 160
diff changeset
   132
	numberOfLines := numberOfLines + 1.
3d88fa870de0 *** empty log message ***
claus
parents: 160
diff changeset
   133
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
    self grow:numberOfLines.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
    start := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
    1 to:numberOfLines do:[:lineNr |
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   137
	stop := aString indexOf:(Character cr) startingAt:start.
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   138
	stop == 0 ifTrue:[
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   139
	    stop := aString size
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   140
	] ifFalse: [
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   141
	    stop := stop - 1.
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   142
	].
10
claus
parents: 5
diff changeset
   143
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   144
	(stop < start) ifTrue: [
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   145
	    self at:lineNr put:(String new:0)
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   146
	] ifFalse: [
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   147
	    self at:lineNr put:(aString copyFrom:start to:stop)
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   148
	].
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   149
	start := stop + 2
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
   153
asStringCollection
284
af1f7d255587 *** empty log message ***
claus
parents: 262
diff changeset
   154
    "return the receiver as a stringCollection - thats easy"
af1f7d255587 *** empty log message ***
claus
parents: 262
diff changeset
   155
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   156
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   157
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
   159
!StringCollection methodsFor:'printing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
printString
284
af1f7d255587 *** empty log message ***
claus
parents: 262
diff changeset
   162
    "return the receivers printString"
af1f7d255587 *** empty log message ***
claus
parents: 262
diff changeset
   163
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
    ^ self asString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
246
f13be3ba45a0 Text <-> StringCollection
claus
parents: 235
diff changeset
   167
!StringCollection methodsFor:'searching'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
indexOfLineStartingWith:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
    "return the index of the first line starting with the argument, aString"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
    |index "{ Class:SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
    index := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
    [index <= self size] whileTrue:[
160
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   176
	((self at:index) startsWith:aString) ifTrue:[
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   177
	    ^ index
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   178
	].
5dae57a490bd *** empty log message ***
claus
parents: 97
diff changeset
   179
	index := index + 1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
    ^ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
! !