UnaryNd.st
author claus
Mon, 10 Oct 1994 01:58:23 +0100
changeset 45 e8331ba8ad5d
parent 33 8985ec2f9e82
child 63 c30ce56de7a8
permissions -rw-r--r--
*** empty log message ***
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
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
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
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    12
7ad01559b262 Initial revision
claus
parents:
diff changeset
    13
MessageNode subclass:#UnaryNode
7ad01559b262 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
7ad01559b262 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
7ad01559b262 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
7ad01559b262 Initial revision
claus
parents:
diff changeset
    17
       category:'System-Compiler-Support'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    18
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    19
7ad01559b262 Initial revision
claus
parents:
diff changeset
    20
UnaryNode comment:'
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    22
              All Rights Reserved
33
8985ec2f9e82 *** empty log message ***
claus
parents: 20
diff changeset
    23
45
e8331ba8ad5d *** empty log message ***
claus
parents: 33
diff changeset
    24
$Header: /cvs/stx/stx/libcomp/Attic/UnaryNd.st,v 1.10 1994-10-10 00:56:37 claus Exp $
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    25
'!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    26
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    27
!UnaryNode class methodsFor:'documentation'!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    28
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    29
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    30
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    31
 COPYRIGHT (c) 1989 by Claus Gittinger
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    32
              All Rights Reserved
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    33
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    34
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    35
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    37
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    38
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    39
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    40
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    41
!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    42
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    43
version
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    44
"
45
e8331ba8ad5d *** empty log message ***
claus
parents: 33
diff changeset
    45
$Header: /cvs/stx/stx/libcomp/Attic/UnaryNd.st,v 1.10 1994-10-10 00:56:37 claus Exp $
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    46
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    47
!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    48
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    49
documentation
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    50
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    51
    node for parse-trees, representing unary messages
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    52
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    53
! !
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    54
7ad01559b262 Initial revision
claus
parents:
diff changeset
    55
!UnaryNode class methodsFor:'instance creation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    56
7ad01559b262 Initial revision
claus
parents:
diff changeset
    57
receiver:r selector:s
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    58
    "return a new UnaryNode for sending selector s to receiver r.
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    59
     Fold constants."
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    60
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    61
    ^ self receiver:r selector:s fold:true
7ad01559b262 Initial revision
claus
parents:
diff changeset
    62
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    63
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    64
receiver:r selector:selectorString fold:folding
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    65
    "return a new UnaryNode for sending selector selectorString to receiver r.
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    66
     If folding is true, fold constant expressions."
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    67
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    68
    |result recVal selector|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    69
7ad01559b262 Initial revision
claus
parents:
diff changeset
    70
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    71
    The constant folding code can usually not optimize things - this may change
7ad01559b262 Initial revision
claus
parents:
diff changeset
    72
    when some kind of constant declaration is added to smalltalk.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    73
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    74
    folding ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    75
        "do constant folding ..."
7ad01559b262 Initial revision
claus
parents:
diff changeset
    76
        r isConstant ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    77
            "check if we can do it ..."
7ad01559b262 Initial revision
claus
parents:
diff changeset
    78
            recVal := r evaluate.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    79
            selectorString knownAsSymbol ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    80
                selector := selectorString asSymbol.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    81
                (recVal respondsTo:selector) ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    82
                    "
7ad01559b262 Initial revision
claus
parents:
diff changeset
    83
                     we could do much more here - but then, we need a dependency from
7ad01559b262 Initial revision
claus
parents:
diff changeset
    84
                     the folded selectors method to the method we generate code for ...
7ad01559b262 Initial revision
claus
parents:
diff changeset
    85
                     limit optimizations to those that will never change 
7ad01559b262 Initial revision
claus
parents:
diff changeset
    86
                     (or, if you change them, it will crash badly anyway ...)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    87
                    "
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    88
                    SignalSet anySignal "Number domainErrorSignal" handle:[:ex |
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    89
                        "in case of an error, abort fold and return original"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    90
                        ex return
7ad01559b262 Initial revision
claus
parents:
diff changeset
    91
                    ] do:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    92
                        recVal respondsToArithmetic ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    93
                            (#( negated abs asPoint degreesToRadians radiansToDegrees
7ad01559b262 Initial revision
claus
parents:
diff changeset
    94
                                exp ln log sqrt reciprocal 
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    95
                                arcCos arcSin arcTan sin cos tan) includes:selector)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    96
                            ifTrue:[
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
    97
                                result := recVal perform:selector.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    98
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    99
                                              value:result
7ad01559b262 Initial revision
claus
parents:
diff changeset
   100
                            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   101
                        ].
45
e8331ba8ad5d *** empty log message ***
claus
parents: 33
diff changeset
   102
                        recVal isCharacter ifTrue:[
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   103
                            (#( asciiValue asInteger digitValue) includes:selector) 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   104
                            ifTrue:[
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   105
                                result := recVal perform:selector.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   106
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   107
                                              value:result
7ad01559b262 Initial revision
claus
parents:
diff changeset
   108
                            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   109
                        ].
45
e8331ba8ad5d *** empty log message ***
claus
parents: 33
diff changeset
   110
                        recVal isString ifTrue:[
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   111
                            (selector == #withCRs) ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   112
                                result := recVal perform:selector.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   113
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   114
                                              value:result
7ad01559b262 Initial revision
claus
parents:
diff changeset
   115
                            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   116
                        ].
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   117
                        (recVal isMemberOf:Array) ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   118
                            (#(asFloatArray asDoubleArray) includes:selector) ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   119
                                result := recVal perform:selector.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   120
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   121
                                              value:result
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   122
                            ]
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   123
                        ].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   124
                        ^ (self basicNew) receiver:r selector:selector args:nil lineno:0
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   125
                    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   126
                    "when we reach here, something went wrong (something like 0.0 log)"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   127
                    ^ 'error occured when evaluating constant expression'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   128
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   129
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   130
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   131
    ].
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
   132
    ^ (self basicNew) receiver:r selector:selectorString args:nil lineno:0
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   133
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   134
7ad01559b262 Initial revision
claus
parents:
diff changeset
   135
!UnaryNode methodsFor:'queries'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   136
7ad01559b262 Initial revision
claus
parents:
diff changeset
   137
isUnaryMessage
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   138
    "return true, if this node is one for a unary message"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   139
    ^ true
7ad01559b262 Initial revision
claus
parents:
diff changeset
   140
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   141
7ad01559b262 Initial revision
claus
parents:
diff changeset
   142
!UnaryNode methodsFor:'checks'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   143
7ad01559b262 Initial revision
claus
parents:
diff changeset
   144
plausibilityCheck
7ad01559b262 Initial revision
claus
parents:
diff changeset
   145
    "check for funny selector - careful to do string compare instead
7ad01559b262 Initial revision
claus
parents:
diff changeset
   146
     of symbol identity compare: I dont want to introduce these as symbols
7ad01559b262 Initial revision
claus
parents:
diff changeset
   147
     into the system (would make the '... is nowhere implemented' warning
7ad01559b262 Initial revision
claus
parents:
diff changeset
   148
     go away."
7ad01559b262 Initial revision
claus
parents:
diff changeset
   149
7ad01559b262 Initial revision
claus
parents:
diff changeset
   150
    ((selector = 'self') or:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   151
     (selector = 'super') or:[
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   152
     (selector = 'thisContext') or:[
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   153
     (selector = 'true') or:[
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   154
     (selector = 'false') or:[
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   155
     (Smalltalk includesKey:selector)]]]]]) ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   156
        ^ 'funny selector; possible missing ''.'' or keyword'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   157
    ].
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   158
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   159
    "more to come ..."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   160
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   161
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   162
7ad01559b262 Initial revision
claus
parents:
diff changeset
   163
!UnaryNode methodsFor:'evaluating'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   164
7ad01559b262 Initial revision
claus
parents:
diff changeset
   165
evaluate
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   166
    "evaluate the expression represented by the receiver"
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   167
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
   168
    receiver isSuper ifTrue:[
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
   169
        ^ super evaluate
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
   170
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   171
    ^ (receiver evaluate) perform:selector
7ad01559b262 Initial revision
claus
parents:
diff changeset
   172
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   173
7ad01559b262 Initial revision
claus
parents:
diff changeset
   174
!UnaryNode methodsFor:'code generation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   175
7ad01559b262 Initial revision
claus
parents:
diff changeset
   176
codeOn:aStream inBlock:b
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   177
    "append bytecode for the receiver to aStream."
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   178
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   179
    "
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   180
     optimize 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   181
        (a == b) not -> (a ~~ b)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   182
        (a ~~ b) not -> (a == b)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   183
    "
7ad01559b262 Initial revision
claus
parents:
diff changeset
   184
    (selector == #not) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   185
        (receiver class == BinaryNode) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   186
            (receiver selector == #==) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   187
                (BinaryNode receiver:(receiver receiver)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   188
                            selector:#~~
7ad01559b262 Initial revision
claus
parents:
diff changeset
   189
                                 arg:(receiver arg)) codeOn:aStream inBlock:b.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   190
                ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   191
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   192
            (receiver selector == #~~) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   193
                (BinaryNode receiver:(receiver receiver)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   194
                            selector:#==
7ad01559b262 Initial revision
claus
parents:
diff changeset
   195
                                 arg:(receiver arg)) codeOn:aStream inBlock:b.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   196
                ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   197
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   198
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   199
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   200
7ad01559b262 Initial revision
claus
parents:
diff changeset
   201
    ^ super codeOn:aStream inBlock:b
7ad01559b262 Initial revision
claus
parents:
diff changeset
   202
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   203
7ad01559b262 Initial revision
claus
parents:
diff changeset
   204
!UnaryNode methodsFor:'printing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   205
7ad01559b262 Initial revision
claus
parents:
diff changeset
   206
printOn:aStream indent:i
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   207
    "prettyprint the expression represented by the receiver"
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   208
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   209
    |needParen|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   210
7ad01559b262 Initial revision
claus
parents:
diff changeset
   211
    needParen := false.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   212
    receiver isMessage ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   213
        receiver isUnaryMessage ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   214
            needParen := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
   215
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   216
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   217
    needParen ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   218
        aStream nextPutAll:'('
7ad01559b262 Initial revision
claus
parents:
diff changeset
   219
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   220
    receiver printOn:aStream.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   221
    needParen ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   222
        aStream nextPutAll:') '
7ad01559b262 Initial revision
claus
parents:
diff changeset
   223
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   224
    aStream space.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   225
    selector printString printOn:aStream.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   226
"    aStream space.     "
7ad01559b262 Initial revision
claus
parents:
diff changeset
   227
! !