Character.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 02:21:27 +0100
changeset 607 a9a526c51233
parent 544 d78012b20769
child 699 12f456343eea
permissions -rw-r--r--
checkin from browser
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) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Magnitude subclass:#Character
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'asciivalue'
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:'Magnitude-General'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    20
!Character class methodsFor:'documentation'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    21
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    22
copyright
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    23
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    24
 COPYRIGHT (c) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
    25
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    26
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    27
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    28
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    30
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    31
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    32
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    33
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    34
!
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    35
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    36
version
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    37
    ^' $Header: /cvs/stx/stx/libbasic/Character.st,v 1.26 1995-11-14 19:01:21 cg Exp $'
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    38
!
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    39
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    40
documentation
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    41
"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    42
    Single byte Characters are unique; this means that for every asciiValue (0..255) there
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    43
    is exactly one instance of Character, which is shared.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    44
    Other characters (i.e. asciivalue > 255) are not shared.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    45
357
claus
parents: 345
diff changeset
    46
    This means: you may compare characters using #== iff you are certain,
claus
parents: 345
diff changeset
    47
    that the characters ranges is 0..255. Otherwise, you HAVE TO compare
claus
parents: 345
diff changeset
    48
    using #=. (if in doubt, always compare using #=).
claus
parents: 345
diff changeset
    49
    Sorry for this inconvenience.
claus
parents: 345
diff changeset
    50
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    51
    Methods marked as (JS) come from the manchester Character goody
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    52
    (CharacterComparing) by Jan Steinman, which allow Characters to be used as
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    53
    Interval elements (i.e. ($a to:$z) do:[...] ); some of these have been
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    54
    modified a bit.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    55
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    56
    WARNING: characters are known by compiler and runtime system -
357
claus
parents: 345
diff changeset
    57
	     do not change the instance layout. 
claus
parents: 345
diff changeset
    58
claus
parents: 345
diff changeset
    59
    Also, although you can create subclasses of Character, the compiler always
claus
parents: 345
diff changeset
    60
    creates instances of Character for literals ...
claus
parents: 345
diff changeset
    61
    ... and other classes are hard-wired ro always return instances of characters
claus
parents: 345
diff changeset
    62
    in some cases (i.e. String>>at:, Symbol>>at: etc.).
claus
parents: 345
diff changeset
    63
    Therefore, it may not make sense to create a character-subclass.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    64
"
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    65
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
!Character class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
basicNew
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
    "catch new - Characters cannot be created with new"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
    ^ self error:'Characters cannot be created with new'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
value:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
    "return a character with asciivalue anInteger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
    80
    INT ascii;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
249
claus
parents: 216
diff changeset
    82
    if (__isSmallInteger(anInteger)) {
claus
parents: 216
diff changeset
    83
	ascii = __intVal(anInteger);
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
    84
	if ((ascii & ~0xFF) == 0 /* (ascii >= 0) && (ascii <= 255) */)
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
    85
	    RETURN ( _MKCHARACTER(ascii) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
    (anInteger between:0 and:16rFF) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
    90
	^ CharacterTable at:(anInteger + 1)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
    (anInteger between:16r100 and:16rFFFF) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
    93
	^ super basicNew setAsciiValue:anInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
    ].
357
claus
parents: 345
diff changeset
    95
    "
claus
parents: 345
diff changeset
    96
     a characters ascii-code must be 0..16rFFFF.
claus
parents: 345
diff changeset
    97
     (i.e. only single-byte and twoByte characters are allowed.)
claus
parents: 345
diff changeset
    98
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
    self error:'invalid ascii code for character'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
digitValue:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
    "return a character that corresponds to anInteger.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
     0-9 map to $0-$9, 10-35 map to $A-$Z"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   106
    |val "{ Class: SmallInteger }" |
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   107
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   108
    val := anInteger.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   109
    (val between:0 and:9) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   110
	^ Character value:(val + ($0 asciiValue))
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   112
    (val between:10 and:35) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   113
	^ Character value:(val + ($A asciiValue - 10))
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
    ^self error:'value not in range 0 to 35'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
!Character class methodsFor:'primitive input'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
fromUser
357
claus
parents: 345
diff changeset
   121
    "return a character from the keyboard (C's standard input stream)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
     - this should only be used for emergency evaluators and the like."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
    int c;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    c = getchar();
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
    if (c < 0) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   129
	RETURN (nil);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
    RETURN ( _MKCHARACTER(c & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   135
!Character class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   136
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   137
isBuiltInClass
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   138
    "return true, if this classes instance layout cannot be changed
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   139
     - this class is known by the run-time-system (but not subclasses)"
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   140
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   141
    ^ self == Character
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   142
! !
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   143
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
!Character class methodsFor:'constants'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
bell
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
    "return the bell character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
    ^ Character value:7
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
backspace
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
    "return the backspace character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
    ^ Character value:8
a27a279701f8 Initial revision
claus
parents:
diff changeset
   156
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   157
345
claus
parents: 333
diff changeset
   158
del 
claus
parents: 333
diff changeset
   159
    "return the delete character"
claus
parents: 333
diff changeset
   160
claus
parents: 333
diff changeset
   161
    ^ Character value:16r7F 
claus
parents: 333
diff changeset
   162
!
claus
parents: 333
diff changeset
   163
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
nl
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
    "return the newline character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
    ^ Character value:10
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
lf
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
    "return the newline/linefeed character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
    ^ Character value:10
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
cr
359
claus
parents: 357
diff changeset
   177
    "return the lineEnd character 
claus
parents: 357
diff changeset
   178
     - actually (in unix) this is a newline character"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
    ^ Character value:10
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
359
claus
parents: 357
diff changeset
   183
return 
claus
parents: 357
diff changeset
   184
    "return the return character.
claus
parents: 357
diff changeset
   185
     In ST/X, this is different from cr - for Unix reasons."
claus
parents: 357
diff changeset
   186
claus
parents: 357
diff changeset
   187
    ^ Character value:13 
claus
parents: 357
diff changeset
   188
!
claus
parents: 357
diff changeset
   189
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
tab
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
    "return the tabulator character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
    ^ Character value:9
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
newPage
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
    "return the form-feed character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
    ^ Character value:12
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
ff
a27a279701f8 Initial revision
claus
parents:
diff changeset
   203
    "return the form-feed character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
    ^ Character value:12
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
space
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
    "return the blank character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
    ^ Character value:32
a27a279701f8 Initial revision
claus
parents:
diff changeset
   212
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
esc
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
    "return the escape character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
    ^ Character value:27
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
quote
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
    "return the single-quote character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
    ^ Character value:39
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
doubleQuote
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
    "return the double-quote character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
    ^ Character value:34
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
excla
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
    "return the exclamation-mark character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
    ^ $!!
345
claus
parents: 333
diff changeset
   235
!
claus
parents: 333
diff changeset
   236
claus
parents: 333
diff changeset
   237
maxValue 
claus
parents: 333
diff changeset
   238
    "return the maximum asciiValue a character can have"
claus
parents: 333
diff changeset
   239
claus
parents: 333
diff changeset
   240
    ^ 16rFFFF
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
!Character methodsFor:'copying'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   245
copy
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   246
    "return a copy of myself
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   247
     reimplemented since characters are unique"
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   248
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   249
     ^ self
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   250
!
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   251
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
shallowCopy
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
    "return a shallow copy of myself
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
     reimplemented since characters are unique"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
     ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   259
deepCopy
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   260
    "return a deep copy of myself
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   261
     reimplemented since characters are unique"
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   262
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   263
     ^ self
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   264
!
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   265
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   266
simpleDeepCopy
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   267
    "return a deep copy of myself
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   268
     reimplemented since characters are unique"
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   269
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   270
     ^ self
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   271
!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   272
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   273
deepCopyUsing:aDictionary
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   274
    "return a deep copy of myself
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
     reimplemented since characters are unique"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
     ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
!Character methodsFor:'private accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
setAsciiValue:anInteger
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   283
    "very private - set the ascii value. 
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   284
     - use this only for characters with codes > 16rFF.
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   285
     DANGER alert: funny things happen, if this is applied to
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   286
     one of the fixed-characters 0..255."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
    asciivalue := anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
! !
2
claus
parents: 1
diff changeset
   290
        
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
!Character methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
asciiValue
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   294
    "return the asciivalue of myself.
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   295
     PP has removed this methhod with 4.1 and providing
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   296
     asInteger instead."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
    ^asciivalue
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
instVarAt:index put:anObject
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   302
    "catch instvar access - asciivalue may not be changed"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   303
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
    self error:'Characters may not be modified'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
!Character methodsFor:'comparing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   308
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
= aCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
    "return true, if the argument, aCharacter is the same character
345
claus
parents: 333
diff changeset
   311
     Redefined to take care of 16bit characters."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
345
claus
parents: 333
diff changeset
   313
    self == aCharacter ifTrue:[^ true].
claus
parents: 333
diff changeset
   314
    aCharacter isCharacter ifFalse:[^ false].
claus
parents: 333
diff changeset
   315
    ^ (asciivalue = aCharacter asciiValue)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
~= aCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
    "return true, if the argument, aCharacter is not the same character
345
claus
parents: 333
diff changeset
   320
     Redefined to take care of 16bit characters."
claus
parents: 333
diff changeset
   321
claus
parents: 333
diff changeset
   322
    self == aCharacter ifTrue:[^ false].
claus
parents: 333
diff changeset
   323
    aCharacter isCharacter ifFalse:[^ true].
claus
parents: 333
diff changeset
   324
    ^ (asciivalue ~~ aCharacter asciiValue)
claus
parents: 333
diff changeset
   325
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
345
claus
parents: 333
diff changeset
   327
sameAs:aCharacter
claus
parents: 333
diff changeset
   328
    "return true, if the argument, aCharacter is the same character,
claus
parents: 333
diff changeset
   329
     ignoring case differences."
claus
parents: 333
diff changeset
   330
claus
parents: 333
diff changeset
   331
    self == aCharacter ifTrue:[^ true].
claus
parents: 333
diff changeset
   332
    ^ self asLowercase = aCharacter asLowercase
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
> aCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   336
    "return true, if the arguments asciiValue is less than mine"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
    ^ (asciivalue > aCharacter asciiValue)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
< aCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
    "return true, if the arguments asciiValue is greater than mine"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
    ^ (asciivalue < aCharacter asciiValue)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
<= aCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    "return true, if the arguments asciiValue is greater or equal to mine"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
    ^ (asciivalue <= aCharacter asciiValue)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
>= aCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
    "return true, if the arguments asciiValue is less or equal to mine"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
    ^ (asciivalue >= aCharacter asciiValue)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
identityHash
a27a279701f8 Initial revision
claus
parents:
diff changeset
   360
    "return an integer useful for hashing on identity"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   361
302
1f76060d58a4 *** empty log message ***
claus
parents: 249
diff changeset
   362
    asciivalue <= 255 ifTrue:[
1f76060d58a4 *** empty log message ***
claus
parents: 249
diff changeset
   363
	^ 4096 + asciivalue
1f76060d58a4 *** empty log message ***
claus
parents: 249
diff changeset
   364
    ].
1f76060d58a4 *** empty log message ***
claus
parents: 249
diff changeset
   365
    ^ super identityHash
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   366
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
!Character methodsFor: 'arithmetic'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
+ aMagnitude
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
    "Return the Character that is <aMagnitude> higher than the receiver. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
     Wrap if the resulting value is not a legal Character value. (JS)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
2
claus
parents: 1
diff changeset
   374
    ^ Character value:(asciivalue + aMagnitude asInteger \\ 256)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
- aMagnitude
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
    "Return the Character that is <aMagnitude> lower than the receiver.  
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   379
     Wrap if the resulting value is not a legal Character value. (JS)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   380
     claus: modified to return the difference as integer, if the argument
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   381
	    is another character"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   382
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   383
    aMagnitude isCharacter ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   384
	^ self asciiValue - aMagnitude asciiValue
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   385
    ].
2
claus
parents: 1
diff changeset
   386
    ^ Character value:(asciivalue - aMagnitude asInteger \\ 256)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   387
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   388
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   389
     $z - $a  
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   390
     $d - 3
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   391
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   392
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
// aMagnitude
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
    "Return the Character who's value is the receiver divided by <aMagnitude>. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
     Wrap if the resulting value is not a legal Character value. (JS)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
2
claus
parents: 1
diff changeset
   398
    ^ Character value:(asciivalue // aMagnitude asInteger \\ 256)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
\\ aMagnitude
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
    "Return the Character who's value is the receiver modulo <aMagnitude>.  
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
     Wrap if the resulting value is not a legal Character value. (JS)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
2
claus
parents: 1
diff changeset
   405
    ^ Character value:(asciivalue \\ aMagnitude asInteger \\ 256)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   406
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
!Character methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   410
isCharacter
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   411
    "return true,  if the receiver is some kind of character"
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   412
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   413
    ^ true
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   414
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   415
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
isDigit
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
    "return true, if I am a digit (i.e. $0 .. $9)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
    ^ asciivalue between:($0 asciiValue) and:($9 asciiValue)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
isDigitRadix:r
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
    "return true, if I am a digit of a base r number"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
    (asciivalue < $0 asciiValue) ifTrue:[^ false]. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
    (r > 10) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   427
	(asciivalue between:($0 asciiValue) and:($9 asciiValue)) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   428
	    ^ true
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   429
	].
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   430
	((asciivalue - $a asciiValue) between:0 and:(r - 10)) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   431
	    ^ true
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   432
	].
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   433
	^ (asciivalue - $A asciiValue) between:0 and:(r - 10)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   434
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   435
    (asciivalue - $0 asciiValue) < r ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   436
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
isLowercase
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
    "return true, if I am a lower-case letter"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
a27a279701f8 Initial revision
claus
parents:
diff changeset
   444
    REGISTER int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
    val = _intVal(_INST(asciivalue));
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   447
#ifndef OLD
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   448
    /* iso8859 puts national lower case characters at e0 .. ff */
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   449
    if ((val >= 0xE0) && (val <= 0xFF)) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   450
	RETURN(true);
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   451
    }
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   452
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
    RETURN ( ((val >= 'a') && (val <= 'z')) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
isUppercase
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    "return true, if I am an upper-case letter"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
    REGISTER int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
    val = _intVal(_INST(asciivalue));
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   465
#ifndef OLD
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   466
    /* iso8859 puts national upper case characters at c0 .. df */
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   467
    if ((val >= 0xC0) && (val <= 0xDF)) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   468
	RETURN(true);
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   469
    }
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   470
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
    RETURN ( ((val >= 'A') && (val <= 'Z')) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   474
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
isLetter
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   476
    "return true, if I am a letter 
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   477
     - use isNationalLetter, if you are interrested in those."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
%{  /*NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
    REGISTER int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   482
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
    val = _intVal(_INST(asciivalue));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   484
    RETURN ( (((val >= 'a') && (val <= 'z')) ||
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   485
	      ((val >= 'A') && (val <= 'Z'))) ? true : false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   489
isLetterOrDigit
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   490
    "return true, if I am a letter or a digit
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   491
     - use isNationalAlphaNumeric, if you are interrested in those."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
    REGISTER int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
a27a279701f8 Initial revision
claus
parents:
diff changeset
   497
    val = _intVal(_INST(asciivalue));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
    if ((val >= 'a') && (val <= 'z')) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   499
	RETURN ( true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
    if ((val >= 'A') && (val <= 'Z')) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   502
	RETURN ( true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
    if ((val >= '0') && (val <= '9')) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   505
	RETURN ( true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
    RETURN ( false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   509
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   510
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   511
isAlphaNumeric
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   512
    "return true, if I am a letter or a digit
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   513
     - same as isAlphaNumeric for compatibility reasons."
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   514
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   515
    ^ self isLetterOrDigit
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   516
!
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   517
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   518
isVowel
a27a279701f8 Initial revision
claus
parents:
diff changeset
   519
    "return true, if I am a vowel (lower- or uppercase)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   520
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
    (self == $a) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
    (self == $e) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   523
    (self == $i) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
    (self == $o) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   525
    (self == $u) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
    (self == $A) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
    (self == $E) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
    (self == $I) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
    (self == $O) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
    (self == $U) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
isSeparator
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
    "return true if I am a space, cr, tab, nl, or newPage"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
a27a279701f8 Initial revision
claus
parents:
diff changeset
   539
    REGISTER int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   540
a27a279701f8 Initial revision
claus
parents:
diff changeset
   541
    val = _intVal(_INST(asciivalue));
328
claus
parents: 314
diff changeset
   542
#ifndef NON_ASCII       /* i.e. EBCDIC ;-) */
claus
parents: 314
diff changeset
   543
    if (val <= ' ')
claus
parents: 314
diff changeset
   544
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   545
	if ((val == ' ')
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   546
	 || (val == '\n') 
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   547
	 || (val == '\t')
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   548
	 || (val == '\r')
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   549
	 || (val == '\f')) {
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   550
	    RETURN ( true );
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   551
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   552
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
isEndOfLineCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
    "return true if I am a line delimitting character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   561
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
    REGISTER int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
a27a279701f8 Initial revision
claus
parents:
diff changeset
   564
    val = _intVal(_INST(asciivalue));
328
claus
parents: 314
diff changeset
   565
    if ((val == '\n')
claus
parents: 314
diff changeset
   566
     || (val == '\r')
claus
parents: 314
diff changeset
   567
     || (val == '\f')) {
claus
parents: 314
diff changeset
   568
	RETURN ( true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
    ^ false
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   573
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   574
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   575
isPrintable
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   576
    "return true, if the receiver is a useful printable character
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   577
     (see fileBrowsers showFile:-method on how it can be used)"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   578
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   579
    (asciivalue between:32 and:127) ifTrue:[^ true].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   580
    asciivalue == 13 ifTrue:[^ true].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   581
    asciivalue == 9 ifTrue:[^ true].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   582
    asciivalue == 10 ifTrue:[^ true].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   583
    ^ self isNationalLetter
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
10
claus
parents: 5
diff changeset
   586
!Character methodsFor:'national testing'!
claus
parents: 5
diff changeset
   587
claus
parents: 5
diff changeset
   588
isNationalLetter
claus
parents: 5
diff changeset
   589
    "return true, if the receiver is a letter in the
claus
parents: 5
diff changeset
   590
     current language (Language variable)"
claus
parents: 5
diff changeset
   591
claus
parents: 5
diff changeset
   592
    "stupid - should be configurable from a table ...
claus
parents: 5
diff changeset
   593
     ... good thing is, that iso8859 puts all national
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   594
	 characters above 16rC0"
10
claus
parents: 5
diff changeset
   595
claus
parents: 5
diff changeset
   596
    self isLetter ifTrue:[^ true].
claus
parents: 5
diff changeset
   597
    ^ self asciiValue between:16rC0 and:16rFF
claus
parents: 5
diff changeset
   598
!
claus
parents: 5
diff changeset
   599
claus
parents: 5
diff changeset
   600
isNationalAlphaNumeric
claus
parents: 5
diff changeset
   601
    "return true, if the receiver is a letter in the
claus
parents: 5
diff changeset
   602
     current language (Language variable)"
claus
parents: 5
diff changeset
   603
claus
parents: 5
diff changeset
   604
    "stupid - should be configurable from a table ...
claus
parents: 5
diff changeset
   605
     ... good thing is, that iso8859 puts all national
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   606
	 characters above 16rC0"
10
claus
parents: 5
diff changeset
   607
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   608
    self isLetterOrDigit ifTrue:[^ true].
10
claus
parents: 5
diff changeset
   609
    ^ self asciiValue between:16rC0 and:16rFF
claus
parents: 5
diff changeset
   610
! !
claus
parents: 5
diff changeset
   611
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
!Character methodsFor:'converting'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
a27a279701f8 Initial revision
claus
parents:
diff changeset
   614
asLowercase
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   615
    "return a character with same letter as the receiver,
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   616
     but lowercase (the receiver if its lowercase or nonLetter)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   617
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
    self isUppercase ifFalse:[^ self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
    ^ Character value:(asciivalue + 32)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   620
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   621
a27a279701f8 Initial revision
claus
parents:
diff changeset
   622
asUppercase
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   623
    "return a character with same letter as the receiver,
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   624
     but uppercase (the receiver if its uppercase or nonLetter)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   625
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
    self isLowercase ifFalse:[^ self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   627
    ^ Character value:(asciivalue - 32)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   630
asCharacter
345
claus
parents: 333
diff changeset
   631
    "usually sent to integers, but redefined here to allow integers
claus
parents: 333
diff changeset
   632
     and characters to be used commonly without a need for a test."
claus
parents: 333
diff changeset
   633
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   634
    ^ self
345
claus
parents: 333
diff changeset
   635
claus
parents: 333
diff changeset
   636
    "
claus
parents: 333
diff changeset
   637
     32 asCharacter  
claus
parents: 333
diff changeset
   638
    "
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   639
!
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   640
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
asInteger
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   642
    "return an Integer with my ascii-value.
06dbdeeed4f9 *** empty log message ***
claus
parents: 37
diff changeset
   643
     OWST4.2 compatibility (sigh)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
    ^ asciivalue
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
a27a279701f8 Initial revision
claus
parents:
diff changeset
   648
asSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
    "return a unique symbol which prints like I print"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
a27a279701f8 Initial revision
claus
parents:
diff changeset
   651
    ^ Symbol internCharacter:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
asString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
    "return a string of len 1 with myself as contents"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
314
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   657
"/
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   658
"/    |newString|
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   659
"/
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   660
"/    newString := String new:1.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   661
"/    newString at:1 put:self.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   662
"/    ^ newString
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   663
"/
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   664
314
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   665
%{  /* NOCONTEXT */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   666
    char buffer[2];
314
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   667
    OBJ s;
521
70533ec40482 use new MKSTRING_L if length is known (avoids a useless strlen)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   668
    OBJ __MKSTRING_L();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
a27a279701f8 Initial revision
claus
parents:
diff changeset
   670
    buffer[0] = (char) _intVal(_characterVal(self));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
    buffer[1] = '\0';
521
70533ec40482 use new MKSTRING_L if length is known (avoids a useless strlen)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   672
    s = __MKSTRING_L(buffer, 1 COMMA_SND);
314
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   673
    if (s != nil) {
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   674
	RETURN (s);
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   675
    }
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   676
%}.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   677
    "
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   678
     memory allocation (for the new string) failed.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   679
     When we arrive here, there was no memory, even after a garbage collect.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   680
     This means, that the VM wanted to get some more memory from the
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   681
     OS, which was not kind enough to give it.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   682
     Bad luck - you should increase the swap space on your machine.
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   683
    "
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   684
    ^ ObjectMemory allocationFailureSignal raise.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   685
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   686
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   687
digitValue
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   688
    "return my digitValue for any base"
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   689
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   690
    |ascii "{ Class: SmallInteger }" |
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   691
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   692
    ascii := asciivalue.
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   693
    (ascii between:($0 asciiValue) and:($9 asciiValue)) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   694
	^ ascii - $0 asciiValue
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   695
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   696
    (ascii between:($a asciiValue) and:($z asciiValue)) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   697
	^ ascii + (10 - $a asciiValue)
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   698
    ]. 
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   699
    (ascii between:($A asciiValue) and:($Z asciiValue)) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   700
	^ ascii + (10 - $A asciiValue)
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   701
    ]. 
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   702
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   703
"remove error below for X3J20 conformance ... "
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   704
    self error:'bad character'.
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   705
" "
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   706
    ^ -1
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   707
!
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   708
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   709
to:aMagnitude
a27a279701f8 Initial revision
claus
parents:
diff changeset
   710
    "Return an Interval over the characters from the receiver to <aMagnitude>. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   711
     Wrap <aMagnitude> if it is not a legal Character value. (JS)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   712
a27a279701f8 Initial revision
claus
parents:
diff changeset
   713
    ^ Interval from:self to:(aMagnitude \\ 256)
2
claus
parents: 1
diff changeset
   714
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   715
216
a8abff749575 *** empty log message ***
claus
parents: 154
diff changeset
   716
!Character methodsFor:'enumerating'!
2
claus
parents: 1
diff changeset
   717
claus
parents: 1
diff changeset
   718
to:stopCharacter do:aBlock
claus
parents: 1
diff changeset
   719
    "evaluate aBlock for each character in self .. stopCharacter.
claus
parents: 1
diff changeset
   720
     This is somewhat stupid, since it depends on the ascii encoding
claus
parents: 1
diff changeset
   721
     (370-users watch out :-)"
claus
parents: 1
diff changeset
   722
claus
parents: 1
diff changeset
   723
    |runChar|
claus
parents: 1
diff changeset
   724
claus
parents: 1
diff changeset
   725
    runChar := self.
claus
parents: 1
diff changeset
   726
    [runChar <= stopCharacter] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   727
	aBlock value:runChar.
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   728
	runChar := runChar + 1
2
claus
parents: 1
diff changeset
   729
    ]
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   730
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   731
    "
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   732
     ($a to:$z) do:[:char | char printNL]
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   733
     $a to:$z do:[:char | char printNL].
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   734
    "
2
claus
parents: 1
diff changeset
   735
! !
claus
parents: 1
diff changeset
   736
357
claus
parents: 345
diff changeset
   737
!Character methodsFor:'binary storage'!
2
claus
parents: 1
diff changeset
   738
claus
parents: 1
diff changeset
   739
hasSpecialBinaryRepresentation
37
d9a302eaa3ef *** empty log message ***
claus
parents: 12
diff changeset
   740
    "return true, if the receiver has a special binary representation"
d9a302eaa3ef *** empty log message ***
claus
parents: 12
diff changeset
   741
2
claus
parents: 1
diff changeset
   742
    ^ true
claus
parents: 1
diff changeset
   743
!
claus
parents: 1
diff changeset
   744
357
claus
parents: 345
diff changeset
   745
storeBinaryOn:stream manager:manager
37
d9a302eaa3ef *** empty log message ***
claus
parents: 12
diff changeset
   746
    "store a binary representation of the receiver on stream;
357
claus
parents: 345
diff changeset
   747
     redefined, since single-byte characters are stored more compact
claus
parents: 345
diff changeset
   748
     with a special type-code followed by the asciiValue."
37
d9a302eaa3ef *** empty log message ***
claus
parents: 12
diff changeset
   749
357
claus
parents: 345
diff changeset
   750
    (asciivalue < 256) ifTrue:[
claus
parents: 345
diff changeset
   751
	stream nextPut:manager codeForCharacter.
claus
parents: 345
diff changeset
   752
	stream nextPut:asciivalue
claus
parents: 345
diff changeset
   753
    ] ifFalse:[
claus
parents: 345
diff changeset
   754
	stream nextPut:manager codeForTwoByteCharacter.
claus
parents: 345
diff changeset
   755
	stream nextPutShort:asciivalue MSB:true
claus
parents: 345
diff changeset
   756
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   757
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   758
a27a279701f8 Initial revision
claus
parents:
diff changeset
   759
!Character methodsFor:'printing & storing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   760
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   761
isLiteral
37
d9a302eaa3ef *** empty log message ***
claus
parents: 12
diff changeset
   762
    "return true, if the receiver can be used as a literal
d9a302eaa3ef *** empty log message ***
claus
parents: 12
diff changeset
   763
     (i.e. can be used in constant arrays)"
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   764
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   765
    ^ true
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   766
!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   767
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   768
printString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   769
    "return a string to print me"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   770
a27a279701f8 Initial revision
claus
parents:
diff changeset
   771
    ^ self asString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   772
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   773
a27a279701f8 Initial revision
claus
parents:
diff changeset
   774
printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   775
    "print myself on aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   776
a27a279701f8 Initial revision
claus
parents:
diff changeset
   777
    aStream nextPut:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   778
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   779
a27a279701f8 Initial revision
claus
parents:
diff changeset
   780
print
a27a279701f8 Initial revision
claus
parents:
diff changeset
   781
    "print myself on stdout"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   782
a27a279701f8 Initial revision
claus
parents:
diff changeset
   783
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   784
a27a279701f8 Initial revision
claus
parents:
diff changeset
   785
    putchar(_intVal(_INST(asciivalue)));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   786
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   787
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   788
a27a279701f8 Initial revision
claus
parents:
diff changeset
   789
displayString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   790
    "return a string used when the receiver is to be displayed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   791
     in an inspector kind-of-thing"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   792
a27a279701f8 Initial revision
claus
parents:
diff changeset
   793
    ^ self storeString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   794
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   795
a27a279701f8 Initial revision
claus
parents:
diff changeset
   796
storeOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   797
    "store myself on aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   798
333
claus
parents: 328
diff changeset
   799
    |special|
claus
parents: 328
diff changeset
   800
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   801
    (asciivalue between:33 and:127) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   802
	(self == Character space) ifTrue:[
333
claus
parents: 328
diff changeset
   803
	    special := '(Character space)'
claus
parents: 328
diff changeset
   804
	] ifFalse:[
claus
parents: 328
diff changeset
   805
	    (self == Character cr) ifTrue:[
345
claus
parents: 333
diff changeset
   806
		special := '(Character cr)'.
333
claus
parents: 328
diff changeset
   807
	    ] ifFalse:[
claus
parents: 328
diff changeset
   808
		(self == Character tab) ifTrue:[
345
claus
parents: 333
diff changeset
   809
		    special := '(Character tab)'.
333
claus
parents: 328
diff changeset
   810
		]
claus
parents: 328
diff changeset
   811
	    ]
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   812
	].
333
claus
parents: 328
diff changeset
   813
	special notNil ifTrue:[
claus
parents: 328
diff changeset
   814
	    aStream nextPutAll:special.
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   815
	    ^ self
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   816
	].
333
claus
parents: 328
diff changeset
   817
	aStream nextPutAll:'(Character value:'; 
claus
parents: 328
diff changeset
   818
		nextPutAll:(asciivalue printString); nextPutAll:')'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   819
    ] ifTrue:[
333
claus
parents: 328
diff changeset
   820
	aStream nextPut:$$; nextPut:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   821
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   822
! !