BlockContext.st
author claus
Fri, 28 Oct 1994 02:19:22 +0100
changeset 165 63341654cfb8
parent 154 d4236ec280a6
child 216 a8abff749575
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Context subclass:#BlockContext
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''  "do not add instvars here"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Kernel-Methods'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
BlockContext comment:'
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    21
COPYRIGHT (c) 1993 by Claus Gittinger
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    22
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    23
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/BlockContext.st,v 1.9 1994-10-28 01:19:07 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    25
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    27
!BlockContext class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    28
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    29
copyright
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    30
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    31
 COPYRIGHT (c) 1993 by Claus Gittinger
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    32
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    34
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    35
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    37
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    38
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    39
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    40
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    41
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    43
version
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    44
"
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/BlockContext.st,v 1.9 1994-10-28 01:19:07 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    46
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    47
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    48
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    49
documentation
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    50
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    51
    BlockContexts represent the stack context objects of blocks. 
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    52
    The layout is the same as for other contexts - this class has been added 
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    53
    to avoid a flag in an instance variable.
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    54
    (has become necessary with cheap blocks, which have no home).
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    55
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    56
    WARNING: layout and size known by compiler and runtime system - 
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    57
	     do not change.
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    58
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    59
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    60
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
!BlockContext methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    62
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
isBlockContext
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
    "return true, iff the receiver is a BlockContext, false otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
methodHome
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
    "return the method-home for block contexts"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
    |con h|
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
    home isNil ifTrue:[^ nil]. "XXX will change soon"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
    home isContext ifFalse:[^ nil]. "copying blocks have no method home"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
    con := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
    h := home.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
    [h notNil] whileTrue:[
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    80
	con := h.
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    81
	h := con home
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
    ^ con
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
home
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
    "return the immediate home of the receiver.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
     normally this is the methodcontext, where the block was created,
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
     for nested block contexts, this is the surrounding blocks context."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
    home isContext ifFalse:[^ nil]. "copying blocks have no home"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
    ^ home
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
selector
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
    "return the selector of the context - which is one of the value
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
     selectors"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
    |nargs|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   101
    nargs := self numArgs.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
    (nargs == 0) ifTrue:[^ #value].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
    (nargs == 1) ifTrue:[^ #value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
    (nargs == 2) ifTrue:[^ #value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
    (nargs == 3) ifTrue:[^ #value:value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
    (nargs == 4) ifTrue:[^ #value:value:value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
    (nargs == 5) ifTrue:[^ #value:value:value:value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   111
!BlockContext methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
receiverPrintString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
    home isNil ifTrue:[
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   115
	^ '[] optimized'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
    home isContext ifFalse:[
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   118
	"a copying block"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   120
	"receiverClassName := home selfValue class name."
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   121
	^ '[] optimized'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   124
    ^ '[] in ' , receiver class name , '-' , self methodHome selector printString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
printReceiver
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   128
    "print the contexts receiver on the standard output"
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   129
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    self receiverPrintString print
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
    
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
printString
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   134
    "return a string describing the context" 
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   135
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
    ^ self receiverPrintString , ' ' , self selector printString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
! !