MessageSend.st
author Claus Gittinger <cg@exept.de>
Sat, 11 Nov 1995 16:28:41 +0100
changeset 530 07d0bce293c9
parent 383 8e3ec8164440
child 1183 e3d58d115e53
permissions -rw-r--r--
uff - version methods changed to return stings
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
344
claus
parents: 160
diff changeset
    14
	 instanceVariableNames:'receiver'
claus
parents: 160
diff changeset
    15
	 classVariableNames:''
claus
parents: 160
diff changeset
    16
	 poolDictionaries:''
claus
parents: 160
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
version
530
07d0bce293c9 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 383
diff changeset
    37
    ^ '$Header: /cvs/stx/stx/libbasic/MessageSend.st,v 1.7 1995-11-11 15:21:25 cg Exp $'
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    38
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
    39
4da5558d8141 Initial revision
claus
parents:
diff changeset
    40
documentation
4da5558d8141 Initial revision
claus
parents:
diff changeset
    41
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
    42
    Instances of MessageSend can be used for simulation programs.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    43
    They keep some receiver, selector and arguments and can be evaluated
4da5558d8141 Initial revision
claus
parents:
diff changeset
    44
    at any time later.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    45
    They can also be used as replacement for simple [self foo]-blocks.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    46
    Of course, they could also be replaced by blocks such as
4da5558d8141 Initial revision
claus
parents:
diff changeset
    47
    '[receiver perform:selector withArguments:arguments]', 
344
claus
parents: 160
diff changeset
    48
    but blocks are somewhat more expensive in their creation and require
claus
parents: 160
diff changeset
    49
    more storage.
claus
parents: 160
diff changeset
    50
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    51
    However, the send-operation itself is faster in a block, since it
4da5558d8141 Initial revision
claus
parents:
diff changeset
    52
    will use a better caching scheme (inline-cache) for its send, while
4da5558d8141 Initial revision
claus
parents:
diff changeset
    53
    sending here is done with a #perform:, which is not inline-cached. 
363
claus
parents: 344
diff changeset
    54
    Thus it is not sure, which one is actually better to use ...
claus
parents: 344
diff changeset
    55
claus
parents: 344
diff changeset
    56
    You can either store arguments in the messageSend object, or
claus
parents: 344
diff changeset
    57
    leave them undefined until the send is actually performed, and
claus
parents: 344
diff changeset
    58
    pass any arguments with the value:-messages.
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    59
344
claus
parents: 160
diff changeset
    60
    If you plan to write a simulator and want to queue cillions of blocks,
363
claus
parents: 344
diff changeset
    61
    try to use MessageSends instead of blocks
claus
parents: 344
diff changeset
    62
    (or even: message, if the receiver is constant);
claus
parents: 344
diff changeset
    63
    this will save you a lot of memory.
344
claus
parents: 160
diff changeset
    64
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    65
    Example:
4da5558d8141 Initial revision
claus
parents:
diff changeset
    66
4da5558d8141 Initial revision
claus
parents:
diff changeset
    67
       |m|
4da5558d8141 Initial revision
claus
parents:
diff changeset
    68
4da5558d8141 Initial revision
claus
parents:
diff changeset
    69
       m := MessageSend receiver:1 selector:#+ arguments:#(2).
363
claus
parents: 344
diff changeset
    70
       m value. 
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    71
344
claus
parents: 160
diff changeset
    72
       is almost the same as:
claus
parents: 160
diff changeset
    73
claus
parents: 160
diff changeset
    74
       |m|
claus
parents: 160
diff changeset
    75
claus
parents: 160
diff changeset
    76
       m := [1+2].
363
claus
parents: 344
diff changeset
    77
       m value. 
344
claus
parents: 160
diff changeset
    78
claus
parents: 160
diff changeset
    79
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    80
    Example2 (a simulation)
4da5558d8141 Initial revision
claus
parents:
diff changeset
    81
	|q|
4da5558d8141 Initial revision
claus
parents:
diff changeset
    82
4da5558d8141 Initial revision
claus
parents:
diff changeset
    83
	q := Queue new.
4da5558d8141 Initial revision
claus
parents:
diff changeset
    84
	...
4da5558d8141 Initial revision
claus
parents:
diff changeset
    85
	'put some action into the queue'
344
claus
parents: 160
diff changeset
    86
	q nextPut:(MessageSend receiver:someone selector:#foo arguments:#().
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
    87
	...
4da5558d8141 Initial revision
claus
parents:
diff changeset
    88
	'evaluate next action from the queue'
4da5558d8141 Initial revision
claus
parents:
diff changeset
    89
	q next value
4da5558d8141 Initial revision
claus
parents:
diff changeset
    90
	...
344
claus
parents: 160
diff changeset
    91
claus
parents: 160
diff changeset
    92
    if all sends are going to the same receiver, use:
claus
parents: 160
diff changeset
    93
	|q|
claus
parents: 160
diff changeset
    94
claus
parents: 160
diff changeset
    95
	q := Queue new.
claus
parents: 160
diff changeset
    96
	...
claus
parents: 160
diff changeset
    97
	'put some action into the queue'
claus
parents: 160
diff changeset
    98
	q nextPut:(Message selector:#foo arguments:#().
claus
parents: 160
diff changeset
    99
	...
claus
parents: 160
diff changeset
   100
	'evaluate next action from the queue'
claus
parents: 160
diff changeset
   101
	q next sendTo:someone
claus
parents: 160
diff changeset
   102
	...
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   103
"
4da5558d8141 Initial revision
claus
parents:
diff changeset
   104
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   105
4da5558d8141 Initial revision
claus
parents:
diff changeset
   106
!MessageSend class methodsFor:'instance creation'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   107
4da5558d8141 Initial revision
claus
parents:
diff changeset
   108
receiver:r selector:sel arguments:argArray
4da5558d8141 Initial revision
claus
parents:
diff changeset
   109
    |newMessage|
4da5558d8141 Initial revision
claus
parents:
diff changeset
   110
344
claus
parents: 160
diff changeset
   111
    newMessage := super new setSelector:sel arguments:argArray.
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   112
    newMessage receiver:r.
4da5558d8141 Initial revision
claus
parents:
diff changeset
   113
    ^ newMessage
4da5558d8141 Initial revision
claus
parents:
diff changeset
   114
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   115
4da5558d8141 Initial revision
claus
parents:
diff changeset
   116
!MessageSend methodsFor:'evaluation'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   117
4da5558d8141 Initial revision
claus
parents:
diff changeset
   118
value
160
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   119
    "evaluate the messagesend with the original arguments"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   120
4da5558d8141 Initial revision
claus
parents:
diff changeset
   121
    ^ receiver perform:selector withArguments:args
4da5558d8141 Initial revision
claus
parents:
diff changeset
   122
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   123
4da5558d8141 Initial revision
claus
parents:
diff changeset
   124
value:someArgument
4da5558d8141 Initial revision
claus
parents:
diff changeset
   125
    "evaluate the messagesend, with someArgument instead of the original"
4da5558d8141 Initial revision
claus
parents:
diff changeset
   126
 
4da5558d8141 Initial revision
claus
parents:
diff changeset
   127
    ^ receiver perform:selector with:someArgument
4da5558d8141 Initial revision
claus
parents:
diff changeset
   128
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   129
4da5558d8141 Initial revision
claus
parents:
diff changeset
   130
value:arg1 value:arg2
160
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   131
    "evaluate the messagesend, with arg1 and arg2 instead of the original
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   132
     arguments"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   133
4da5558d8141 Initial revision
claus
parents:
diff changeset
   134
    ^  receiver perform:selector with:arg1 with:arg2
4da5558d8141 Initial revision
claus
parents:
diff changeset
   135
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   136
4da5558d8141 Initial revision
claus
parents:
diff changeset
   137
value:arg1 value:arg2 value:arg3
160
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   138
    "evaluate the messagesend, with arg1, arg2 and arg3 instead of the original
5dae57a490bd *** empty log message ***
claus
parents: 96
diff changeset
   139
     arguments"
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   140
4da5558d8141 Initial revision
claus
parents:
diff changeset
   141
    ^  receiver perform:selector with:arg1 with:arg2 with:arg3
363
claus
parents: 344
diff changeset
   142
!
claus
parents: 344
diff changeset
   143
claus
parents: 344
diff changeset
   144
valueWithArguments:argArray
claus
parents: 344
diff changeset
   145
    "evaluate the messagesend, with arguments taken from argArray,
claus
parents: 344
diff changeset
   146
     instead of the original arguments"
claus
parents: 344
diff changeset
   147
claus
parents: 344
diff changeset
   148
    ^  receiver perform:selector withArguments:argArray
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   149
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   150
4da5558d8141 Initial revision
claus
parents:
diff changeset
   151
!MessageSend methodsFor:'accessing'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   152
4da5558d8141 Initial revision
claus
parents:
diff changeset
   153
receiver:r
4da5558d8141 Initial revision
claus
parents:
diff changeset
   154
    "set the receiver"
4da5558d8141 Initial revision
claus
parents:
diff changeset
   155
4da5558d8141 Initial revision
claus
parents:
diff changeset
   156
    receiver := r
4da5558d8141 Initial revision
claus
parents:
diff changeset
   157
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   158
4da5558d8141 Initial revision
claus
parents:
diff changeset
   159
receiver
4da5558d8141 Initial revision
claus
parents:
diff changeset
   160
    "return the receiver"
4da5558d8141 Initial revision
claus
parents:
diff changeset
   161
4da5558d8141 Initial revision
claus
parents:
diff changeset
   162
    ^ receiver
363
claus
parents: 344
diff changeset
   163
!
claus
parents: 344
diff changeset
   164
claus
parents: 344
diff changeset
   165
numArgs
claus
parents: 344
diff changeset
   166
    ^ selector numArgs
96
4da5558d8141 Initial revision
claus
parents:
diff changeset
   167
! !
4da5558d8141 Initial revision
claus
parents:
diff changeset
   168
4da5558d8141 Initial revision
claus
parents:
diff changeset
   169
!MessageSend methodsFor:'printing & storing'!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   170
4da5558d8141 Initial revision
claus
parents:
diff changeset
   171
displayString
4da5558d8141 Initial revision
claus
parents:
diff changeset
   172
    "return a string for display in inspectors etc."
4da5558d8141 Initial revision
claus
parents:
diff changeset
   173
4da5558d8141 Initial revision
claus
parents:
diff changeset
   174
    ^ 'MessageSend(' , receiver displayString , '>>' , selector , ')'
4da5558d8141 Initial revision
claus
parents:
diff changeset
   175
!
4da5558d8141 Initial revision
claus
parents:
diff changeset
   176
4da5558d8141 Initial revision
claus
parents:
diff changeset
   177
printOn:aStream
4da5558d8141 Initial revision
claus
parents:
diff changeset
   178
    "return a string for printing the receiver"
4da5558d8141 Initial revision
claus
parents:
diff changeset
   179
4da5558d8141 Initial revision
claus
parents:
diff changeset
   180
    receiver printOn:aStream.
4da5558d8141 Initial revision
claus
parents:
diff changeset
   181
    aStream nextPutAll:'>>'.
4da5558d8141 Initial revision
claus
parents:
diff changeset
   182
    selector printOn:aStream
4da5558d8141 Initial revision
claus
parents:
diff changeset
   183
! !