UnaryNode.st
author claus
Sun, 09 Jan 1994 22:30:29 +0100
changeset 11 60691e5007e3
parent 4 f6fd83437415
child 13 30e69e21d1d1
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:'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    21
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1989 by Claus Gittinger
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
7ad01559b262 Initial revision
claus
parents:
diff changeset
    24
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    25
$Header: /cvs/stx/stx/libcomp/UnaryNode.st,v 1.4 1994-01-09 21:30:25 claus Exp $
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    26
'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    27
7ad01559b262 Initial revision
claus
parents:
diff changeset
    28
!UnaryNode class methodsFor:'instance creation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    29
7ad01559b262 Initial revision
claus
parents:
diff changeset
    30
receiver:r selector:s
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    31
    "return a new UnaryNode for sending selector s to receiver r.
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    32
     Fold constants."
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    33
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    34
    ^ self receiver:r selector:s fold:true
7ad01559b262 Initial revision
claus
parents:
diff changeset
    35
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    36
7ad01559b262 Initial revision
claus
parents:
diff changeset
    37
receiver:r selector:s fold:folding
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    38
    "return a new UnaryNode for sending selector s to receiver r.
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    39
     If folding is true, fold constant expressions."
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
    40
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    41
    |result recVal sym|
7ad01559b262 Initial revision
claus
parents:
diff changeset
    42
7ad01559b262 Initial revision
claus
parents:
diff changeset
    43
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    44
    The constant folding code can usually not optimize things - this may change
7ad01559b262 Initial revision
claus
parents:
diff changeset
    45
    when some kind of constant declaration is added to smalltalk.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    46
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    47
    folding ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    48
        "do constant folding ..."
7ad01559b262 Initial revision
claus
parents:
diff changeset
    49
        r isConstant ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    50
            "check if we can do it ..."
7ad01559b262 Initial revision
claus
parents:
diff changeset
    51
            recVal := r evaluate.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    52
            s knownAsSymbol ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    53
                (recVal respondsTo:sym) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    54
                    "
7ad01559b262 Initial revision
claus
parents:
diff changeset
    55
                     we could do much more here - but then, we need a dependency from
7ad01559b262 Initial revision
claus
parents:
diff changeset
    56
                     the folded selectors method to the method we generate code for ...
7ad01559b262 Initial revision
claus
parents:
diff changeset
    57
                     limit optimizations to those that will never change 
7ad01559b262 Initial revision
claus
parents:
diff changeset
    58
                     (or, if you change them, it will crash badly anyway ...)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    59
                    "
7ad01559b262 Initial revision
claus
parents:
diff changeset
    60
                    Number domainErrorSignal handle:[:ex |
7ad01559b262 Initial revision
claus
parents:
diff changeset
    61
                        ex return
7ad01559b262 Initial revision
claus
parents:
diff changeset
    62
                    ] do:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    63
                        sym := s asSymbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    64
                        recVal respondsToArithmetic ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    65
                            (#( negated abs asPoint degreesToRadians radiansToDegrees
7ad01559b262 Initial revision
claus
parents:
diff changeset
    66
                                exp ln log sqrt reciprocal 
7ad01559b262 Initial revision
claus
parents:
diff changeset
    67
                                arcCos arcSin arcTan sin cos tan) includes:sym)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    68
                            ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    69
                                result := recVal perform:sym.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    70
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    71
                                              value:result
7ad01559b262 Initial revision
claus
parents:
diff changeset
    72
                            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    73
                        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    74
                        (recVal isMemberOf:Character) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    75
                            (#( asciiValue asInteger digitValue) includes:sym) 
7ad01559b262 Initial revision
claus
parents:
diff changeset
    76
                            ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    77
                                result := recVal perform:sym.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    78
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    79
                                              value:result
7ad01559b262 Initial revision
claus
parents:
diff changeset
    80
                            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    81
                        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    82
                        (recVal isMemberOf:String) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    83
                            (sym == #withCRs) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    84
                                result := recVal perform:sym.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    85
                                ^ ConstantNode type:(ConstantNode typeOfConstant:result)
7ad01559b262 Initial revision
claus
parents:
diff changeset
    86
                                              value:result
7ad01559b262 Initial revision
claus
parents:
diff changeset
    87
                            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    88
                        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    89
                        ^ (self basicNew) receiver:r selector:s args:nil lineno:0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    90
                    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    91
                    "when we reach here, something went wrong (something like 0.0 log)"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    92
                    ^ 'error occured when evaluating constant expression'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    93
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    94
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    95
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    96
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    97
    ^ (self basicNew) receiver:r selector:s args:nil lineno:0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    98
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
    99
7ad01559b262 Initial revision
claus
parents:
diff changeset
   100
!UnaryNode methodsFor:'queries'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   101
7ad01559b262 Initial revision
claus
parents:
diff changeset
   102
isUnaryMessage
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   103
    "return true, if this node is one for a unary message"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   104
    ^ true
7ad01559b262 Initial revision
claus
parents:
diff changeset
   105
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   106
7ad01559b262 Initial revision
claus
parents:
diff changeset
   107
!UnaryNode methodsFor:'checks'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   108
7ad01559b262 Initial revision
claus
parents:
diff changeset
   109
plausibilityCheck
7ad01559b262 Initial revision
claus
parents:
diff changeset
   110
    "check for funny selector - careful to do string compare instead
7ad01559b262 Initial revision
claus
parents:
diff changeset
   111
     of symbol identity compare: I dont want to introduce these as symbols
7ad01559b262 Initial revision
claus
parents:
diff changeset
   112
     into the system (would make the '... is nowhere implemented' warning
7ad01559b262 Initial revision
claus
parents:
diff changeset
   113
     go away."
7ad01559b262 Initial revision
claus
parents:
diff changeset
   114
7ad01559b262 Initial revision
claus
parents:
diff changeset
   115
    ((selector = 'self') or:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   116
     (selector = 'super') or:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   117
     (Smalltalk includesKey:selector)]]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   118
        ^ 'funny selector; possible missing ''.'' or keyword'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   119
    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   120
    "more to come ..."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   121
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   122
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   123
7ad01559b262 Initial revision
claus
parents:
diff changeset
   124
!UnaryNode methodsFor:'evaluating'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   125
7ad01559b262 Initial revision
claus
parents:
diff changeset
   126
evaluate
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   127
    "evaluate the expression represented by the receiver"
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   128
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   129
    ^ (receiver evaluate) perform:selector
7ad01559b262 Initial revision
claus
parents:
diff changeset
   130
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   131
7ad01559b262 Initial revision
claus
parents:
diff changeset
   132
!UnaryNode methodsFor:'code generation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   133
7ad01559b262 Initial revision
claus
parents:
diff changeset
   134
codeOn:aStream inBlock:b
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   135
    "append bytecode for the receiver to aStream."
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   136
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   137
    "
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   138
     optimize 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   139
        (a == b) not -> (a ~~ b)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   140
        (a ~~ b) not -> (a == b)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   141
    "
7ad01559b262 Initial revision
claus
parents:
diff changeset
   142
    (selector == #not) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   143
        (receiver class == BinaryNode) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   144
            (receiver selector == #==) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   145
                (BinaryNode receiver:(receiver receiver)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   146
                            selector:#~~
7ad01559b262 Initial revision
claus
parents:
diff changeset
   147
                                 arg:(receiver arg)) codeOn:aStream inBlock:b.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   148
                ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   149
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   150
            (receiver selector == #~~) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   151
                (BinaryNode receiver:(receiver receiver)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   152
                            selector:#==
7ad01559b262 Initial revision
claus
parents:
diff changeset
   153
                                 arg:(receiver arg)) codeOn:aStream inBlock:b.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   154
                ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   155
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   156
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   157
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   158
7ad01559b262 Initial revision
claus
parents:
diff changeset
   159
    ^ super codeOn:aStream inBlock:b
7ad01559b262 Initial revision
claus
parents:
diff changeset
   160
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   161
7ad01559b262 Initial revision
claus
parents:
diff changeset
   162
!UnaryNode methodsFor:'printing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   163
7ad01559b262 Initial revision
claus
parents:
diff changeset
   164
printOn:aStream indent:i
11
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   165
    "prettyprint the expression represented by the receiver"
60691e5007e3 *** empty log message ***
claus
parents: 4
diff changeset
   166
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   167
    |needParen|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   168
7ad01559b262 Initial revision
claus
parents:
diff changeset
   169
    needParen := false.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   170
    receiver isMessage ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   171
        receiver isUnaryMessage ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   172
            needParen := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
   173
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   174
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   175
    needParen ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   176
        aStream nextPutAll:'('
7ad01559b262 Initial revision
claus
parents:
diff changeset
   177
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   178
    receiver printOn:aStream.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   179
    needParen ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   180
        aStream nextPutAll:') '
7ad01559b262 Initial revision
claus
parents:
diff changeset
   181
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   182
    aStream space.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   183
    selector printString printOn:aStream.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   184
"    aStream space.     "
7ad01559b262 Initial revision
claus
parents:
diff changeset
   185
! !