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