MethodNode.st
author Claus Gittinger <cg@exept.de>
Thu, 25 Nov 2004 15:30:33 +0100
changeset 1561 175735dcd732
parent 1208 541338239952
child 1788 4674dfd67faf
permissions -rw-r--r--
do not check for endOfInput if parsing from a Stream
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
98
claus
parents:
diff changeset
     1
"
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents:
diff changeset
     3
	      All Rights Reserved
claus
parents:
diff changeset
     4
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
claus
parents:
diff changeset
    10
 hereby transferred.
claus
parents:
diff changeset
    11
"
claus
parents:
diff changeset
    12
1208
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    13
"{ Package: 'stx:libcomp' }"
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    14
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    15
ParseNode subclass:#MethodNode
1208
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    16
	instanceVariableNames:'selector arguments locals statements'
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    17
	classVariableNames:''
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    18
	poolDictionaries:''
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    19
	category:'System-Compiler ST-80-compatibility'
98
claus
parents:
diff changeset
    20
!
claus
parents:
diff changeset
    21
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    22
!MethodNode class methodsFor:'documentation'!
98
claus
parents:
diff changeset
    23
claus
parents:
diff changeset
    24
copyright
claus
parents:
diff changeset
    25
"
claus
parents:
diff changeset
    26
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents:
diff changeset
    27
	      All Rights Reserved
claus
parents:
diff changeset
    28
claus
parents:
diff changeset
    29
 This software is furnished under a license and may be used
claus
parents:
diff changeset
    30
 only in accordance with the terms of that license and with the
claus
parents:
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
claus
parents:
diff changeset
    32
 be provided or otherwise made available to, or used by, any
claus
parents:
diff changeset
    33
 other person.  No title to or ownership of the software is
claus
parents:
diff changeset
    34
 hereby transferred.
claus
parents:
diff changeset
    35
"
claus
parents:
diff changeset
    36
!
claus
parents:
diff changeset
    37
claus
parents:
diff changeset
    38
documentation
claus
parents:
diff changeset
    39
"
claus
parents:
diff changeset
    40
    This is a pure mimicri class.
claus
parents:
diff changeset
    41
    It is not used by ST/X, but provided to support limited
claus
parents:
diff changeset
    42
    compatibility for applications which build up codetrees,
claus
parents:
diff changeset
    43
    knowing internals of ST-80's compiler class hierarchy.
claus
parents:
diff changeset
    44
    This classes protocol is not (not meant to be) fully covering
claus
parents:
diff changeset
    45
    the corresponding ST-80's classes protocol. It maps ST-80 messages
claus
parents:
diff changeset
    46
    to corresponding ST/X messages (as far as possible).
claus
parents:
diff changeset
    47
claus
parents:
diff changeset
    48
    NO WARRANTY and GUARANTEE; this class may be removed without notice.
claus
parents:
diff changeset
    49
"
claus
parents:
diff changeset
    50
! !
claus
parents:
diff changeset
    51
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    52
!MethodNode methodsFor:'accessing'!
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    53
1208
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    54
selector
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    55
    ^ selector
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    56
!
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    57
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    58
selector:sel arguments:argVars locals:localVars statements:stats
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    59
    selector := sel. 
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    60
    arguments := argVars. 
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    61
    locals := localVars. 
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    62
    statements := stats.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    63
!
98
claus
parents:
diff changeset
    64
1208
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    65
statementCollection
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    66
    "returns an orderedColl for my linked statement list"
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    67
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    68
    |coll stat|
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    69
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    70
    coll := OrderedCollection new.
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    71
    stat := statements.
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    72
    [stat notNil] whileTrue:[
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    73
        coll add:stat.
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    74
        stat := stat nextStatement.
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    75
    ].
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    76
    ^ coll
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    77
!
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    78
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    79
statements
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
    80
    ^ statements 
98
claus
parents:
diff changeset
    81
! !
claus
parents:
diff changeset
    82
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    83
!MethodNode methodsFor:'code generation'!
98
claus
parents:
diff changeset
    84
106
claus
parents: 105
diff changeset
    85
emitEffect:aStream
98
claus
parents:
diff changeset
    86
    statements do:[:stat |
106
claus
parents: 105
diff changeset
    87
	stat codeForSideEffectOn:aStream inBlock:nil for:nil 
98
claus
parents:
diff changeset
    88
    ].
claus
parents:
diff changeset
    89
! !
claus
parents:
diff changeset
    90
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    91
!MethodNode methodsFor:'printing'!
98
claus
parents:
diff changeset
    92
claus
parents:
diff changeset
    93
printOn:aStream indent:i
claus
parents:
diff changeset
    94
    |n parts|
claus
parents:
diff changeset
    95
claus
parents:
diff changeset
    96
    n := selector numArgs.
claus
parents:
diff changeset
    97
    n == 0 ifTrue:[
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
    98
	aStream nextPutAll:selector printString.
98
claus
parents:
diff changeset
    99
    ] ifFalse:[
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   100
	parts := selector partsIfSelector.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   101
	parts with:arguments do:[:part :arg |
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   102
	    aStream nextPutAll:part.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   103
	    aStream space.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   104
	    aStream nextPutAll:arg name
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   105
	]
98
claus
parents:
diff changeset
   106
    ].
claus
parents:
diff changeset
   107
    aStream cr.
claus
parents:
diff changeset
   108
1106
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   109
    statements do:[:stat |
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   110
	aStream spaces:i+4.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   111
	stat printOn:aStream indent:i+4.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   112
	aStream nextPut:$..
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   113
	aStream cr.
97e2a6840142 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1105
diff changeset
   114
    ].
98
claus
parents:
diff changeset
   115
! !
1208
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
   116
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
   117
!MethodNode class methodsFor:'documentation'!
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
   118
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
   119
version
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
   120
    ^ '$Header: /cvs/stx/stx/libcomp/MethodNode.st,v 1.10 2001-11-05 15:37:44 james Exp $'
541338239952 st80 / squeak compatibility
james
parents: 1106
diff changeset
   121
! !