ConstantNode.st
author Claus Gittinger <cg@exept.de>
Mon, 20 Oct 2008 17:10:47 +0200
changeset 2118 8ba726417c70
parent 1995 dad0adb22a38
child 2266 5e7bafbb37c0
permissions -rw-r--r--
halt
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     1
"
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
47
f861ad42703e *** empty log message ***
claus
parents: 33
diff changeset
     3
	      All Rights Reserved
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     4
7ad01559b262 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
7ad01559b262 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
7ad01559b262 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
7ad01559b262 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
7ad01559b262 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
7ad01559b262 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    11
"
1080
bd3f19f6009a category change
Claus Gittinger <cg@exept.de>
parents: 1035
diff changeset
    12
"{ Package: 'stx:libcomp' }"
bd3f19f6009a category change
Claus Gittinger <cg@exept.de>
parents: 1035
diff changeset
    13
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    14
PrimaryNode subclass:#ConstantNode
242
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    15
	instanceVariableNames:''
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    16
	classVariableNames:'TrueNode FalseNode NilNode Const0Node Const1Node Float0Node'
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    17
	poolDictionaries:''
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    18
	category:'System-Compiler-Support'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    19
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    20
20
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    21
!ConstantNode class methodsFor:'documentation'!
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    22
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    23
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    24
"
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    25
 COPYRIGHT (c) 1989 by Claus Gittinger
47
f861ad42703e *** empty log message ***
claus
parents: 33
diff changeset
    26
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    27
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    28
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    29
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    31
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    32
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    33
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    34
"
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    35
!
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    36
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    37
documentation
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    38
"
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    39
    node for parse-trees, representing literal constants
261
0372e948ca2d commentary
Claus Gittinger <cg@exept.de>
parents: 242
diff changeset
    40
    This is a helper class for the compiler.
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 261
diff changeset
    41
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 261
diff changeset
    42
    [author:]
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 261
diff changeset
    43
        Claus Gittinger
20
f8dd8ba75205 *** empty log message ***
claus
parents: 13
diff changeset
    44
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    45
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
    46
7ad01559b262 Initial revision
claus
parents:
diff changeset
    47
!ConstantNode class methodsFor:'instance creation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    48
7ad01559b262 Initial revision
claus
parents:
diff changeset
    49
type:t value:val
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
    50
    "some constant nodes are used so often, its worth caching them"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    51
    (t == #True) ifTrue:[
1348
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    52
        TrueNode isNil ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    53
            TrueNode := (self basicNew) type:t value:val
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    54
        ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    55
        ^ TrueNode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    56
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    57
    (t == #False) ifTrue:[
1348
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    58
        FalseNode isNil ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    59
            FalseNode := (self basicNew) type:t value:val
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    60
        ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    61
        ^ FalseNode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    62
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    63
    (t == #Nil) ifTrue:[
1348
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    64
        NilNode isNil ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    65
            NilNode := (self basicNew) type:t value:val
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    66
        ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    67
        ^ NilNode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    68
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    69
    (t == #Integer) ifTrue:[
1348
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    70
        (val == 0) ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    71
            Const0Node isNil ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    72
                Const0Node := (self basicNew) type:t value:val
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    73
            ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    74
            ^ Const0Node
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    75
        ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    76
        (val == 1) ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    77
            Const1Node isNil ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    78
                Const1Node := (self basicNew) type:t value:val
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    79
            ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    80
            ^ Const1Node
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    81
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    82
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    83
    (t == #Float) ifTrue:[
1348
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    84
        (val = 0.0) ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    85
            "/ care for negative0 (which compares = to 0.0)
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    86
            val isNegativeZero ifFalse:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    87
                Float0Node isNil ifTrue:[
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    88
                    Float0Node := (self basicNew) type:t value:val
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    89
                ].
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    90
                ^ Float0Node
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    91
            ]
d7cc3ebd5312 do not reuse node for -0.0
Claus Gittinger <cg@exept.de>
parents: 1080
diff changeset
    92
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    93
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    94
    ^ (self basicNew) type:t value:val
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    95
!
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    96
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    97
value:val
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    98
    ^ self type:(self typeOfConstant:val) value:val 
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    99
! !
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   100
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   101
!ConstantNode class methodsFor:'queries'!
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   102
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   103
typeOfConstant:anObject
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   104
    "return the constantNode type for an object"
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   105
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   106
    "the most common case first ..."
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   107
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   108
    (anObject isMemberOf:SmallInteger) ifTrue:[
1381
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   109
        ^ #Integer
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   110
    ].
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   111
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   112
    anObject isNil ifTrue:[
1381
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   113
        ^ #Nil
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   114
    ].
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   115
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   116
    anObject isNumber ifTrue:[
1381
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   117
        "the most common case first ..."
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   118
        (anObject isMemberOf:Float) ifTrue:[
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   119
            ^ #Float
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   120
        ].
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   121
        anObject isInteger ifTrue:[
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   122
            ^ #Integer
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   123
        ].
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   124
    ].
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   125
    (anObject == true) ifTrue:[
1381
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   126
        ^ #True
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   127
    ].
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   128
    (anObject == false) ifTrue:[
1381
695fa03a5795 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1348
diff changeset
   129
        ^ #False
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   130
    ].
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   131
    ^ #Literal
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   132
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   133
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   134
!ConstantNode methodsFor:'accessing'!
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   135
711
25b9a501b97d lineNr -> lineNumber
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   136
lineNumber:ignoredLineNumber
710
fc74f135494d ignore lineNumber assignment
Claus Gittinger <cg@exept.de>
parents: 612
diff changeset
   137
711
25b9a501b97d lineNr -> lineNumber
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   138
    "Created: / 14.5.1998 / 19:31:48 / cg"
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   139
! !
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   140
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   141
!ConstantNode methodsFor:'code generation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   142
1560
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   143
codeForSideEffectOn:aStream inBlock:b for:aCompiler
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   144
    "no code at all"
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   145
1995
dad0adb22a38 comment
Claus Gittinger <cg@exept.de>
parents: 1805
diff changeset
   146
    "/ but remember symbolic literals (such as #TODO)
1560
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   147
    value isSymbol ifTrue:[
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   148
        aCompiler addLiteral:value.
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   149
    ].
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   150
    ^ self
1995
dad0adb22a38 comment
Claus Gittinger <cg@exept.de>
parents: 1805
diff changeset
   151
dad0adb22a38 comment
Claus Gittinger <cg@exept.de>
parents: 1805
diff changeset
   152
    "Modified: / 04-03-2007 / 15:29:54 / cg"
1560
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   153
!
a3be357f8c4d symbolic literal constants are remeembered,
Claus Gittinger <cg@exept.de>
parents: 1552
diff changeset
   154
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   155
codeForSimpleReturnOn:aStream inBlock:b lineNumber:lineNrOrNil for:aCompiler
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   156
    lineNrOrNil notNil ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   157
        self codeLineNumber:lineNrOrNil on:aStream for:aCompiler
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   158
    ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   159
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   160
    (type == #Nil) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   161
        aStream nextPut:#retNil.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   162
        ^self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   163
    ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   164
    (type == #True) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   165
        aStream nextPut:#retTrue.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   166
        ^self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   167
    ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   168
    (type == #False) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   169
        aStream nextPut:#retFalse.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   170
        ^self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   171
    ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   172
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   173
    (type == #Integer) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   174
        (value between: -128 and:127) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   175
            (value == 0) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   176
                aStream nextPut:#ret0.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   177
                ^ self.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   178
            ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   179
            aStream nextPut:#retNum; nextPut:value.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   180
            ^ self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   181
        ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   182
    ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   183
1401
d9a2949c6229 Fix typos
Stefan Vogel <sv@exept.de>
parents: 1384
diff changeset
   184
    "/ anything else must be pushed, then top returned
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   185
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   186
    self codeOn:aStream inBlock:b for:aCompiler.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   187
    aStream nextPut:#retTop
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   188
!
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   189
104
claus
parents: 103
diff changeset
   190
codeOn:aStream inBlock:b for:aCompiler
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   191
    "generate code for the constant"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   192
104
claus
parents: 103
diff changeset
   193
    |code index|
96
claus
parents: 62
diff changeset
   194
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   195
    (type == #Integer) ifTrue:[
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   196
        (value between: -128 and:127) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   197
            (value == 0) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   198
                code := #push0
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   199
            ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   200
            (value == 1) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   201
                code := #push1.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   202
            ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   203
            (value == 2) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   204
                code := #push2.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   205
            ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   206
            (value == -1) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   207
                code := #pushMinus1.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   208
            ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   209
            code notNil ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   210
                aStream nextPut:code. ^ self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   211
            ].
96
claus
parents: 62
diff changeset
   212
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   213
            aStream nextPut:#pushNum; nextPut:value.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   214
            ^ self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   215
        ].
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   216
        (value between:16r-8000 and:16r7FFF) ifTrue:[
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   217
            aStream nextPut:#pushNum16; nextPut:value; nextPut:0. 
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   218
            ^ self
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   219
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   220
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   221
    (type == #Nil) ifTrue:[
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   222
        code := #pushNil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   223
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   224
    (type == #True) ifTrue:[
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   225
        code := #pushTrue.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   226
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   227
    (type == #False) ifTrue:[
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   228
        code := #pushFalse.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   229
    ].
96
claus
parents: 62
diff changeset
   230
    code notNil ifTrue:[
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   231
        aStream nextPut:code. ^ self
96
claus
parents: 62
diff changeset
   232
    ].
106
claus
parents: 104
diff changeset
   233
claus
parents: 104
diff changeset
   234
    "/ kludge for backward compatibility
claus
parents: 104
diff changeset
   235
    aCompiler isNil ifTrue:[
2118
Claus Gittinger <cg@exept.de>
parents: 1995
diff changeset
   236
        self halt:'strange literal constant'.
843
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   237
        aStream nextPut:#pushLit; nextPut:value.
522c116f86d9 boolean-return expression rewrite
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
   238
        ^ self.
106
claus
parents: 104
diff changeset
   239
    ].
claus
parents: 104
diff changeset
   240
1805
d8f8075615dc some code savers for common code-emit
Claus Gittinger <cg@exept.de>
parents: 1797
diff changeset
   241
    self emitPushLiteral:value on:aStream for:aCompiler
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   242
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   243
104
claus
parents: 103
diff changeset
   244
codeStoreOn:aStream inBlock:codeBlock valueNeeded:valueNeeded for:aCompiler
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   245
    "not sent - parser checks for this"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   246
7ad01559b262 Initial revision
claus
parents:
diff changeset
   247
    ^ self error:'assignment to literals not allowed'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   248
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   249
1035
8848672cb893 category rename
Claus Gittinger <cg@exept.de>
parents: 843
diff changeset
   250
!ConstantNode methodsFor:'enumerating'!
539
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   251
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   252
nodeDo:anEnumerator
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   253
    "helper for parse tree walking"
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   254
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   255
    ^ anEnumerator doLiteral:self value:value
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   256
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   257
    "Modified: 19.6.1997 / 16:40:59 / cg"
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   258
! !
69a1cd05c7d6 added node-walk facility (ST80 compatibility)
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
   259
1035
8848672cb893 category rename
Claus Gittinger <cg@exept.de>
parents: 843
diff changeset
   260
!ConstantNode methodsFor:'evaluation'!
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   261
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   262
evaluate
1384
0db9682870d9 evaluate -> evaluateIn:
Claus Gittinger <cg@exept.de>
parents: 1381
diff changeset
   263
    "exists for performance only"
0db9682870d9 evaluate -> evaluateIn:
Claus Gittinger <cg@exept.de>
parents: 1381
diff changeset
   264
    ^ value
0db9682870d9 evaluate -> evaluateIn:
Claus Gittinger <cg@exept.de>
parents: 1381
diff changeset
   265
!
0db9682870d9 evaluate -> evaluateIn:
Claus Gittinger <cg@exept.de>
parents: 1381
diff changeset
   266
0db9682870d9 evaluate -> evaluateIn:
Claus Gittinger <cg@exept.de>
parents: 1381
diff changeset
   267
evaluateIn:anEnvironment
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   268
    ^ value
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   269
!
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   270
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   271
store:aValue
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   272
    "not reached - parser checks for this"
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   273
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   274
    self error:'store not allowed'.
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   275
    ^ aValue
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   276
! !
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   277
1080
bd3f19f6009a category change
Claus Gittinger <cg@exept.de>
parents: 1035
diff changeset
   278
!ConstantNode methodsFor:'printing & storing'!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   279
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   280
displayString
612
2748896a66c8 comments
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   281
    "return a printed representation of the receiver for displaying"
2748896a66c8 comments
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   282
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   283
    ^ value displayString
612
2748896a66c8 comments
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   284
2748896a66c8 comments
Claus Gittinger <cg@exept.de>
parents: 539
diff changeset
   285
    "Modified: 20.9.1997 / 11:39:07 / cg"
13
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   286
!
30e69e21d1d1 *** empty log message ***
claus
parents: 10
diff changeset
   287
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   288
printOn:aStream indent:i
7ad01559b262 Initial revision
claus
parents:
diff changeset
   289
    value storeOn:aStream
7ad01559b262 Initial revision
claus
parents:
diff changeset
   290
! !
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   291
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   292
!ConstantNode methodsFor:'queries'!
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   293
242
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   294
canReuseAsArg:anotherNode
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   295
    |otherValue|
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   296
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   297
    anotherNode isConstant ifTrue:[
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   298
        anotherNode type ~~ type ifTrue:[^ false].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   299
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   300
        otherValue := anotherNode evaluate.
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   301
        (value isMemberOf:SmallInteger) ifTrue:[
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   302
            (value == 0) ifTrue:[^ false].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   303
            (value == 1) ifTrue:[^ false].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   304
            (value == 2) ifTrue:[^ false].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   305
            (value == -1) ifTrue:[^ false].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   306
            ^ otherValue == value
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   307
        ].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   308
        (value isMemberOf:Float) ifTrue:[
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   309
            ^ (otherValue isMemberOf:Float)
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   310
              and:[otherValue = value]
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   311
        ].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   312
        (value isMemberOf:Symbol) ifTrue:[
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   313
            ^ otherValue == value
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   314
        ].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   315
        (value isMemberOf:String) ifTrue:[
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   316
            ^ (otherValue isMemberOf:String)
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   317
              and:[otherValue = value]
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   318
        ].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   319
    ].
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   320
    ^ false
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   321
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   322
    "Created: 14.4.1996 / 00:43:14 / cg"
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   323
    "Modified: 14.4.1996 / 01:00:29 / cg"
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   324
!
3cca9ffd2620 use dup if possible when pushing args
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
   325
140
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   326
isConstant
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   327
    ^ true
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   328
! !
1ef1d1395146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   329
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 140
diff changeset
   330
!ConstantNode class methodsFor:'documentation'!
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 140
diff changeset
   331
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 140
diff changeset
   332
version
2118
Claus Gittinger <cg@exept.de>
parents: 1995
diff changeset
   333
    ^ '$Header: /cvs/stx/stx/libcomp/ConstantNode.st,v 1.43 2008-10-20 15:10:47 cg Exp $'
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 140
diff changeset
   334
! !