MessageSend.st
author Claus Gittinger <cg@exept.de>
Tue, 23 Apr 1996 16:54:20 +0200
changeset 1270 4e8058487ed3
parent 1269 77682b54144c
child 1293 02fb05148c98
permissions -rw-r--r--
commentary
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
     1
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1994 by Claus Gittinger
344
claus
parents: 160
diff changeset
     3
	      All Rights Reserved
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
     4
4da5558d8141 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
4da5558d8141 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
4da5558d8141 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
4da5558d8141 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
4da5558d8141 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
4da5558d8141 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    11
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
    12
4da5558d8141 Initial revision
claus
parents:
diff changeset
    13
Message subclass:#MessageSend
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    14
	instanceVariableNames:'receiver'
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    15
	classVariableNames:''
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    16
	poolDictionaries:''
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    17
	category:'Kernel-Methods'
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    18
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
    19
4da5558d8141 Initial revision
claus
parents:
diff changeset
    20
!MessageSend class methodsFor:'documentation'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
    21
4da5558d8141 Initial revision
claus
parents:
diff changeset
    22
copyright
4da5558d8141 Initial revision
claus
parents:
diff changeset
    23
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
    24
 COPYRIGHT (c) 1994 by Claus Gittinger
344
claus
parents: 160
diff changeset
    25
	      All Rights Reserved
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    26
4da5558d8141 Initial revision
claus
parents:
diff changeset
    27
 This software is furnished under a license and may be used
4da5558d8141 Initial revision
claus
parents:
diff changeset
    28
 only in accordance with the terms of that license and with the
4da5558d8141 Initial revision
claus
parents:
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
4da5558d8141 Initial revision
claus
parents:
diff changeset
    30
 be provided or otherwise made available to, or used by, any
4da5558d8141 Initial revision
claus
parents:
diff changeset
    31
 other person.  No title to or ownership of the software is
4da5558d8141 Initial revision
claus
parents:
diff changeset
    32
 hereby transferred.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    33
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
    34
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
    35
4da5558d8141 Initial revision
claus
parents:
diff changeset
    36
documentation
4da5558d8141 Initial revision
claus
parents:
diff changeset
    37
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
    38
    Instances of MessageSend can be used for simulation programs.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    39
    They keep some receiver, selector and arguments and can be evaluated
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    40
    at any time later. (basically, they are like MessageObjects, but keep
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    41
    the receiver in addition to the selector & arguments).
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    42
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    43
    They can also be used as replacement for simple [self foo]-blocks.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    44
    Of course, they could also be replaced by blocks such as
4da5558d8141 Initial revision
claus
parents:
diff changeset
    45
    '[receiver perform:selector withArguments:arguments]', 
344
claus
parents: 160
diff changeset
    46
    but blocks are somewhat more expensive in their creation and require
claus
parents: 160
diff changeset
    47
    more storage.
claus
parents: 160
diff changeset
    48
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    49
    If you plan to write a simulator and want to queue cillions of blocks,
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    50
    try to use MessageSends instead of blocks
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    51
    (or even: message, if the receiver is constant);
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    52
    this will save you a lot of memory.
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    53
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    54
    However, the send-operation itself is faster in a block, since it
4da5558d8141 Initial revision
claus
parents:
diff changeset
    55
    will use a better caching scheme (inline-cache) for its send, while
4da5558d8141 Initial revision
claus
parents:
diff changeset
    56
    sending here is done with a #perform:, which is not inline-cached. 
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    57
    Also, blocks are more flexible, in that they allow access to local
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    58
    variables of the defining method - and work without a need to define an
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    59
    extra visited method (read literature on visitor patterns).
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    60
363
claus
parents: 344
diff changeset
    61
    Thus it is not sure, which one is actually better to use ...
claus
parents: 344
diff changeset
    62
claus
parents: 344
diff changeset
    63
    You can either store arguments in the messageSend object, or
claus
parents: 344
diff changeset
    64
    leave them undefined until the send is actually performed, and
claus
parents: 344
diff changeset
    65
    pass any arguments with the value:-messages.
1270
4e8058487ed3 commentary
Claus Gittinger <cg@exept.de>
parents: 1269
diff changeset
    66
4e8058487ed3 commentary
Claus Gittinger <cg@exept.de>
parents: 1269
diff changeset
    67
    [See also:]
4e8058487ed3 commentary
Claus Gittinger <cg@exept.de>
parents: 1269
diff changeset
    68
        Block  Message
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    69
"
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    70
!
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    71
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    72
examples
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    73
"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    74
    Example:
4da5558d8141 Initial revision
claus
parents:
diff changeset
    75
4da5558d8141 Initial revision
claus
parents:
diff changeset
    76
       |m|
4da5558d8141 Initial revision
claus
parents:
diff changeset
    77
4da5558d8141 Initial revision
claus
parents:
diff changeset
    78
       m := MessageSend receiver:1 selector:#+ arguments:#(2).
363
claus
parents: 344
diff changeset
    79
       m value. 
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    80
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    81
    is almost the same as:
344
claus
parents: 160
diff changeset
    82
claus
parents: 160
diff changeset
    83
       |m|
claus
parents: 160
diff changeset
    84
claus
parents: 160
diff changeset
    85
       m := [1+2].
363
claus
parents: 344
diff changeset
    86
       m value. 
344
claus
parents: 160
diff changeset
    87
claus
parents: 160
diff changeset
    88
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    89
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    90
    Example2 (a simulation)
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    91
        |q|
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    92
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    93
        q := Queue new.
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    94
        ...
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    95
        'put some action into the queue'
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    96
        q nextPut:(MessageSend receiver:someone selector:#foo arguments:#().
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    97
        ...
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    98
        'evaluate next action from the queue'
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
    99
        q next value
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   100
        ...
344
claus
parents: 160
diff changeset
   101
claus
parents: 160
diff changeset
   102
    if all sends are going to the same receiver, use:
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   103
        |q|
344
claus
parents: 160
diff changeset
   104
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   105
        q := Queue new.
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   106
        ...
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   107
        'put some action into the queue'
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   108
        q nextPut:(Message selector:#foo arguments:#().
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   109
        ...
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   110
        'evaluate next action from the queue'
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   111
        q next sendTo:someone
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   112
        ...
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   113
"
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   114
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   115
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   116
4da5558d8141 Initial revision
claus
parents:
diff changeset
   117
!MessageSend class methodsFor:'instance creation'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   118
4da5558d8141 Initial revision
claus
parents:
diff changeset
   119
receiver:r selector:sel arguments:argArray
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   120
    "create & return a new instance which can be used to
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   121
     send sel with arguments to some receiver, r"
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   122
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   123
    |newMessage|
4da5558d8141 Initial revision
claus
parents:
diff changeset
   124
344
claus
parents: 160
diff changeset
   125
    newMessage := super new setSelector:sel arguments:argArray.
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   126
    newMessage receiver:r.
4da5558d8141 Initial revision
claus
parents:
diff changeset
   127
    ^ newMessage
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   128
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   129
    "Modified: 23.4.1996 / 16:52:33 / cg"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   130
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   131
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   132
!MessageSend methodsFor:'accessing'!
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   133
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   134
numArgs
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   135
    "return the number of arguments of the message"
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   136
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   137
    ^ selector numArgs
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   138
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   139
    "Modified: 23.4.1996 / 16:52:51 / cg"
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   140
!
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   141
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   142
receiver
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   143
    "return the receiver of the message"
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   144
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   145
    ^ receiver
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   146
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   147
    "Modified: 23.4.1996 / 16:52:59 / cg"
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   148
!
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   149
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   150
receiver:r
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   151
    "set the receiver of the message"
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   152
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   153
    receiver := r
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   154
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   155
    "Modified: 23.4.1996 / 16:53:04 / cg"
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   156
! !
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   157
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   158
!MessageSend methodsFor:'evaluation'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   159
4da5558d8141 Initial revision
claus
parents:
diff changeset
   160
value
160
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   161
    "evaluate the messagesend with the original arguments"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   162
4da5558d8141 Initial revision
claus
parents:
diff changeset
   163
    ^ receiver perform:selector withArguments:args
4da5558d8141 Initial revision
claus
parents:
diff changeset
   164
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   165
4da5558d8141 Initial revision
claus
parents:
diff changeset
   166
value:someArgument
4da5558d8141 Initial revision
claus
parents:
diff changeset
   167
    "evaluate the messagesend, with someArgument instead of the original"
4da5558d8141 Initial revision
claus
parents:
diff changeset
   168
 
4da5558d8141 Initial revision
claus
parents:
diff changeset
   169
    ^ receiver perform:selector with:someArgument
4da5558d8141 Initial revision
claus
parents:
diff changeset
   170
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   171
4da5558d8141 Initial revision
claus
parents:
diff changeset
   172
value:arg1 value:arg2
160
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   173
    "evaluate the messagesend, with arg1 and arg2 instead of the original
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   174
     arguments"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   175
4da5558d8141 Initial revision
claus
parents:
diff changeset
   176
    ^  receiver perform:selector with:arg1 with:arg2
4da5558d8141 Initial revision
claus
parents:
diff changeset
   177
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   178
4da5558d8141 Initial revision
claus
parents:
diff changeset
   179
value:arg1 value:arg2 value:arg3
160
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   180
    "evaluate the messagesend, with arg1, arg2 and arg3 instead of the original
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   181
     arguments"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   182
4da5558d8141 Initial revision
claus
parents:
diff changeset
   183
    ^  receiver perform:selector with:arg1 with:arg2 with:arg3
363
claus
parents: 344
diff changeset
   184
!
claus
parents: 344
diff changeset
   185
claus
parents: 344
diff changeset
   186
valueWithArguments:argArray
claus
parents: 344
diff changeset
   187
    "evaluate the messagesend, with arguments taken from argArray,
claus
parents: 344
diff changeset
   188
     instead of the original arguments"
claus
parents: 344
diff changeset
   189
claus
parents: 344
diff changeset
   190
    ^  receiver perform:selector withArguments:argArray
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   191
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   192
4da5558d8141 Initial revision
claus
parents:
diff changeset
   193
!MessageSend methodsFor:'printing & storing'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   194
4da5558d8141 Initial revision
claus
parents:
diff changeset
   195
displayString
4da5558d8141 Initial revision
claus
parents:
diff changeset
   196
    "return a string for display in inspectors etc."
4da5558d8141 Initial revision
claus
parents:
diff changeset
   197
4da5558d8141 Initial revision
claus
parents:
diff changeset
   198
    ^ 'MessageSend(' , receiver displayString , '>>' , selector , ')'
4da5558d8141 Initial revision
claus
parents:
diff changeset
   199
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   200
4da5558d8141 Initial revision
claus
parents:
diff changeset
   201
printOn:aStream
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   202
    "append a printed representation of the receiver to aStream"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   203
4da5558d8141 Initial revision
claus
parents:
diff changeset
   204
    receiver printOn:aStream.
4da5558d8141 Initial revision
claus
parents:
diff changeset
   205
    aStream nextPutAll:'>>'.
4da5558d8141 Initial revision
claus
parents:
diff changeset
   206
    selector printOn:aStream
1269
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   207
77682b54144c commentary
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   208
    "Modified: 23.4.1996 / 16:53:35 / cg"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   209
! !
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   210
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   211
!MessageSend class methodsFor:'documentation'!
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   212
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   213
version
1270
4e8058487ed3 commentary
Claus Gittinger <cg@exept.de>
parents: 1269
diff changeset
   214
    ^ '$Header: /cvs/stx/stx/libbasic/MessageSend.st,v 1.10 1996-04-23 14:54:20 cg Exp $'
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   215
! !