Object.st
author claus
Sun, 13 Aug 1995 00:54:52 +0200
changeset 387 cdf48d5d7399
parent 384 cc3d110ea879
child 397 78bf17d9ac8e
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1988 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 143
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
Object subclass:#Object
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:'ErrorSignal HaltSignal 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    16
			   MessageNotUnderstoodSignal UserInterruptSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    17
			   RecursionInterruptSignal ExceptionInterruptSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    18
			   SubscriptOutOfBoundsSignal NonIntegerIndexSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    19
			   NotFoundSignal KeyNotFoundSignal ElementOutOfBoundsSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    20
			   InformationSignal PrimitiveFailureSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    21
			   DeepCopyErrorSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    22
			   AbortSignal
356
claus
parents: 348
diff changeset
    23
			   ErrorRecursion Dependencies
claus
parents: 348
diff changeset
    24
			   InfoPrinting'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
       category:'Kernel-Objects'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    27
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    28
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
Object comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    30
COPYRIGHT (c) 1988 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    31
	      All Rights Reserved
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    32
387
claus
parents: 384
diff changeset
    33
$Header: /cvs/stx/stx/libbasic/Object.st,v 1.60 1995-08-12 22:54:43 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    34
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    35
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    36
!Object class methodsFor:'documentation'!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    37
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    38
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    39
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    40
 COPYRIGHT (c) 1988 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    41
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    42
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    43
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    44
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    45
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    46
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    47
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    48
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    49
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    50
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    51
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    52
version
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    53
"
387
claus
parents: 384
diff changeset
    54
$Header: /cvs/stx/stx/libbasic/Object.st,v 1.60 1995-08-12 22:54:43 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    55
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    56
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    57
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    58
documentation
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    59
"
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    60
   Object is the superclass of all other classes. Protocol common to
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    61
   every object is defined here.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    62
   Also some utility stuff (like notify) and error handling is implemented here.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    63
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    64
   Object has no instance variables (and may not get any added). One reason is, that
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    65
   UndefinedObject and SmallInteger are also inheriting from Object - these two cannot have instance
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
    66
   variables (due to their implementation). The other reason is that the runtime system
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    67
   (VM) knows about the layout of some built-in classes (think of Class, Method, Block
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    68
   and also Integer or Float). If you where allowed to add instance variables to Object, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    69
   the VM had to be recompiled (and also rewritten in some places).
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    70
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    71
   Class variables:
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
    72
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    73
	ErrorSignal     <Signal>        Signal raised for error/error: messages
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    74
					also, parent of all other signals.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    75
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    76
	HaltSignal      <Signal>        Signal raised for halt/halt: messages
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    77
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    78
	MessageNotUnderstoodSignal      Signals raised for various error conditions
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    79
	UserInterruptSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    80
	RecursionInterruptSignal 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    81
	ExceptionInterruptSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    82
	SubscriptOutOfBoundsSignal 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    83
	NonIntegerIndexSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    84
	NotFoundSignal 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    85
	KeyNotFoundSignal 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    86
	ElementOutOfBoundsSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    87
	InformationSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    88
	DeepCopyErrorSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    89
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    90
	AbortSignal      <Signal>       Signal raised by debugger, to abort a computation
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    91
					BUT, the debugger will only raise it if it is handled.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    92
					By handling the abortSignal, you can control where the
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    93
					debuggers abort-function resumes execution in case of
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    94
					an error.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    95
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    96
	ErrorRecursion   <Boolean>      controls behavior when recursive errors occur (i.e. 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    97
					an error while handling an error).
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    98
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
    99
	Dependencies     <Dictionary>   keeps track of object dependencies
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   100
"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   101
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
!Object class methodsFor:'initialization'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
initialize
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
    "called only once - initialize signals"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
    ErrorSignal isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   109
	ErrorSignal := (Signal new) mayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   110
	ErrorSignal nameClass:self message:#errorSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   111
	ErrorSignal notifierString:'error encountered'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   112
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   113
	HaltSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   114
	HaltSignal nameClass:self message:#haltSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   115
	HaltSignal notifierString:'halt encountered'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   116
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   117
	MessageNotUnderstoodSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   118
	MessageNotUnderstoodSignal nameClass:self message:#messageNotUnderstoodSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   119
	MessageNotUnderstoodSignal notifierString:'message not understood'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   120
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   121
	PrimitiveFailureSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   122
	PrimitiveFailureSignal nameClass:self message:#primitiveFailureSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   123
	PrimitiveFailureSignal notifierString:'primitive failed'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   124
362
claus
parents: 359
diff changeset
   125
"/        UserInterruptSignal := ErrorSignal newSignalMayProceed:true.
claus
parents: 359
diff changeset
   126
	UserInterruptSignal := (Signal new) newSignalMayProceed:true.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   127
	UserInterruptSignal nameClass:self message:#userInterruptSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   128
	UserInterruptSignal notifierString:'user Interrupt'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   129
362
claus
parents: 359
diff changeset
   130
"/        RecursionInterruptSignal := ErrorSignal newSignalMayProceed:false.
claus
parents: 359
diff changeset
   131
	RecursionInterruptSignal := (Signal new) mayProceed:true.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   132
	RecursionInterruptSignal nameClass:self message:#recursionInterruptSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   133
	RecursionInterruptSignal notifierString:'recursion limit reached'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   134
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   135
	ExceptionInterruptSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   136
	ExceptionInterruptSignal nameClass:self message:#exceptionInterruptSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   137
	ExceptionInterruptSignal notifierString:'exception Interrupt'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   138
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   139
	SubscriptOutOfBoundsSignal := ErrorSignal newSignalMayProceed:false.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   140
	SubscriptOutOfBoundsSignal nameClass:self message:#subscriptOutOfBoundsSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   141
	SubscriptOutOfBoundsSignal notifierString:'subscript out of bounds'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   142
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   143
	ElementOutOfBoundsSignal := ErrorSignal newSignalMayProceed:false.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   144
	ElementOutOfBoundsSignal nameClass:self message:#elementOutOfBoundsSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   145
	ElementOutOfBoundsSignal notifierString:'element not appropriate or out of bounds'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   146
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   147
	NotFoundSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   148
	NotFoundSignal nameClass:self message:#notFoundSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   149
	NotFoundSignal notifierString:'no such element'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   150
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   151
	KeyNotFoundSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   152
	KeyNotFoundSignal nameClass:self message:#keyNotFoundSignal.
345
claus
parents: 343
diff changeset
   153
	KeyNotFoundSignal notifierString:'no such key:'.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   154
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   155
	NonIntegerIndexSignal := ErrorSignal newSignalMayProceed:false.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   156
	NonIntegerIndexSignal nameClass:self message:#nonIntegerIndexSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   157
	NonIntegerIndexSignal notifierString:'index must be integer'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   158
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   159
	InformationSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   160
	InformationSignal nameClass:self message:#informationSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   161
	InformationSignal notifierString:'information'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   162
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   163
	DeepCopyErrorSignal := ErrorSignal newSignalMayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   164
	DeepCopyErrorSignal nameClass:self message:#deepCopyErrorSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   165
	DeepCopyErrorSignal notifierString:'object cannot be deepCopy-ed'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   166
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   167
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   168
	 AbortSignal is not a child of ErrorSignal -
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   169
	 this would complicate abort from within a signal handler
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   170
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   171
	AbortSignal := Signal new mayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   172
	AbortSignal nameClass:self message:#abortSignal.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   173
	AbortSignal notifierString:'unhandled abort signal'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   174
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   175
	Dependencies isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   176
	    Dependencies := WeakIdentityDictionary new.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   177
	]
356
claus
parents: 348
diff changeset
   178
    ].
claus
parents: 348
diff changeset
   179
    InfoPrinting := true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
    "Object initialize"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
345
claus
parents: 343
diff changeset
   184
!Object class methodsFor:'Signal constants'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   185
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
errorSignal
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   187
    "return the signal used for error/error: - handling"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
    ^ ErrorSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
haltSignal
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   193
    "return the signal used for halt/halt: - handling"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
    ^ HaltSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
messageNotUnderstoodSignal
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   199
    "return the signal used for doesNotUnderstand: - error handling"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
    ^ MessageNotUnderstoodSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   203
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   204
privateMethodSignal
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   205
    "return the signal used for privateMethod - error handling"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   206
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   207
    ^ MessageNotUnderstoodSignal
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   208
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   209
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   210
primitiveFailureSignal
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   211
    "return the signal used for primitiveFailed - error handling"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   212
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   213
    ^ PrimitiveFailureSignal
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   214
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   215
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
userInterruptSignal
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   217
    "return the signal used for ^C interrupts handling"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
    ^ UserInterruptSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
recursionInterruptSignal 
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   223
    "return the signal used for recursion overflow error handling"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
    ^ RecursionInterruptSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
exceptionInterruptSignal
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   229
    "return the signal used for exception (display errors) error handling"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
    ^ ExceptionInterruptSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
2
claus
parents: 1
diff changeset
   234
subscriptOutOfBoundsSignal
claus
parents: 1
diff changeset
   235
    "return the signal used for subscript error reporting.
claus
parents: 1
diff changeset
   236
     (this signal is used for example when an array is accessed with an
claus
parents: 1
diff changeset
   237
      index less than 1 or greater than the array size)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
2
claus
parents: 1
diff changeset
   239
    ^ SubscriptOutOfBoundsSignal
claus
parents: 1
diff changeset
   240
!
claus
parents: 1
diff changeset
   241
claus
parents: 1
diff changeset
   242
elementOutOfBoundsSignal
claus
parents: 1
diff changeset
   243
    "return the signal used for element error reporting
claus
parents: 1
diff changeset
   244
     (this signal is used for example when a value not in 0..255 is to
claus
parents: 1
diff changeset
   245
      be put into a bytearray)"
claus
parents: 1
diff changeset
   246
claus
parents: 1
diff changeset
   247
    ^ ElementOutOfBoundsSignal
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
nonIntegerIndexSignal 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
    "return the signal used for bad subscript error reporting"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
    ^ NonIntegerIndexSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
2
claus
parents: 1
diff changeset
   256
notFoundSignal 
345
claus
parents: 343
diff changeset
   257
    "return the signal used for no element found error reporting"
2
claus
parents: 1
diff changeset
   258
claus
parents: 1
diff changeset
   259
    ^ NotFoundSignal
claus
parents: 1
diff changeset
   260
!
claus
parents: 1
diff changeset
   261
claus
parents: 1
diff changeset
   262
keyNotFoundSignal 
claus
parents: 1
diff changeset
   263
    "return the signal used for no such key error reporting"
claus
parents: 1
diff changeset
   264
claus
parents: 1
diff changeset
   265
    ^ KeyNotFoundSignal
claus
parents: 1
diff changeset
   266
!
claus
parents: 1
diff changeset
   267
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
informationSignal 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
    "return the signal used for informations"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
    ^ InformationSignal
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   272
!
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   273
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   274
deepCopyErrorSignal 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   275
    "return the signal raised when a deepcopy is asked for
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   276
     an object which cannot do this (for example, BlockClosures
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   277
     or Contexts)."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   278
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   279
    ^ DeepCopyErrorSignal
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   280
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   281
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   282
abortSignal 
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   283
    "return the signal used to abort user actions. This signal is only
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   284
     raised if cought (by the debugger), and will lead way out of the
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   285
     currently active doIt/printIt or inspectIt. (also some others use
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   286
     this for a save abort)"
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   287
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   288
    ^ AbortSignal
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
356
claus
parents: 348
diff changeset
   291
!Object class methodsFor:'info messages'!
claus
parents: 348
diff changeset
   292
claus
parents: 348
diff changeset
   293
infoPrinting:aBoolean
claus
parents: 348
diff changeset
   294
    "turn on/off printing of information messages.
claus
parents: 348
diff changeset
   295
     If the argument, aBoolean is false, infoPrint will not output
claus
parents: 348
diff changeset
   296
     messages. The default is true."
claus
parents: 348
diff changeset
   297
claus
parents: 348
diff changeset
   298
    InfoPrinting := aBoolean
375
claus
parents: 370
diff changeset
   299
!
claus
parents: 370
diff changeset
   300
claus
parents: 370
diff changeset
   301
infoPrinting
claus
parents: 370
diff changeset
   302
    "return the flag which controls information messages."
claus
parents: 370
diff changeset
   303
claus
parents: 370
diff changeset
   304
    ^ InfoPrinting
356
claus
parents: 348
diff changeset
   305
! !
claus
parents: 348
diff changeset
   306
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   307
!Object class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   308
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   309
isBuiltInClass
49
f1c2d75f2eb6 *** empty log message ***
claus
parents: 44
diff changeset
   310
    "return true, if this class is known by the run-time-system,
f1c2d75f2eb6 *** empty log message ***
claus
parents: 44
diff changeset
   311
     i.e. you cannot add/remove instance variables without recompiling
f1c2d75f2eb6 *** empty log message ***
claus
parents: 44
diff changeset
   312
     the VM."
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   313
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   314
    ^ self == Object
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   315
! !
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   316
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
!Object methodsFor:'initialization'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
initialize
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
    "just to ignore initialize to objects which do not need it"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
    ^ self
380
claus
parents: 379
diff changeset
   323
!
claus
parents: 379
diff changeset
   324
claus
parents: 379
diff changeset
   325
fromLiteralArrayEncoding:aSpecArray
claus
parents: 379
diff changeset
   326
    "read my values from a specArray. The argument is supposed to
claus
parents: 379
diff changeset
   327
     consist of setSelector/value pairs, which are sent to the receiver.
claus
parents: 379
diff changeset
   328
     Some classes (Point, Rectangle) redefine this for a slightly more compact
claus
parents: 379
diff changeset
   329
     literal representation.
claus
parents: 379
diff changeset
   330
     This was added to allow for VW windowSpecs to be parsed in ST/X;
claus
parents: 379
diff changeset
   331
     do not use if for general object printing/restoring."
claus
parents: 379
diff changeset
   332
384
claus
parents: 380
diff changeset
   333
    |sz "{Class: SmallInteger }"|
380
claus
parents: 379
diff changeset
   334
claus
parents: 379
diff changeset
   335
    sz := aSpecArray size.
claus
parents: 379
diff changeset
   336
    2 to:sz  by:2 do:[:i | 
claus
parents: 379
diff changeset
   337
	self perform:(aSpecArray at:i) with:(aSpecArray at:i+1)
claus
parents: 379
diff changeset
   338
    ]
claus
parents: 379
diff changeset
   339
claus
parents: 379
diff changeset
   340
    "
claus
parents: 379
diff changeset
   341
     (Association new) fromLiteralArrayEncoding:#(#dummy #key: 1 #value: 'one')
claus
parents: 379
diff changeset
   342
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   345
!Object methodsFor:'cleanup'!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   346
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   347
lowSpaceCleanup
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   348
    "ignored here - redefined in some classes to
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   349
     cleanup in low-memory situations"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   350
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   351
    ^ self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
!Object methodsFor:'system primitives'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
become:anotherObject
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   357
    "make all references to the receiver become references to anotherObject
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   358
     and vice-versa. This may be an expensive (i.e. slow) operation, 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   359
     since in the worst case, the whole memory has to be searched for 
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   360
     references to the two objects (although the primitive tries hard to
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   361
     limit the search, for acceptable performance in most cases). 
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   362
     In general, using become: should be avoided if possible, since it may 
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   363
     produce many strange effects (think of hashing in Sets).
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   364
     This method fails, if the receiver or the argument is a SmallInteger 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   365
     or nil, or is a context of a living method (i.e. one that has not already 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   366
     returned).
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   367
     (notice that become: is not used heavily by the system 
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   368
      - the Collection-classes have been rewritten to not use it.)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
%{
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   370
    if (__primBecome(self, anotherObject COMMA_CON))
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   371
	RETURN ( self );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
10
claus
parents: 5
diff changeset
   377
becomeNil
claus
parents: 5
diff changeset
   378
    "make all references to the receiver become nil - effectively getting
claus
parents: 5
diff changeset
   379
     rid of the receiver. This can be a very dangerous operation - be warned.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   380
     The receiver may not be a SmallInteger or a context of a living method."
10
claus
parents: 5
diff changeset
   381
claus
parents: 5
diff changeset
   382
%{
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   383
    if (__primBecomeNil(self COMMA_CON ))
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   384
	RETURN ( nil );
10
claus
parents: 5
diff changeset
   385
%}
claus
parents: 5
diff changeset
   386
.
claus
parents: 5
diff changeset
   387
    self primitiveFailed
claus
parents: 5
diff changeset
   388
!
claus
parents: 5
diff changeset
   389
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   390
changeClassTo:otherClass
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   391
    "changes the class of the receiver to the argument, otherClass.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   392
     This is only allowed (possible), if the receivers class and the argument
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   393
     have the same structure (i.e. number of named instance variables and
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   394
     type of indexed instance variables). 
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   395
     If the structures do not match, or any of the original class or new class
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   396
     is UndefinedObject or a Smallinteger, a primitive error is triggered."
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   397
85
claus
parents: 77
diff changeset
   398
    |myClass ok|
claus
parents: 77
diff changeset
   399
claus
parents: 77
diff changeset
   400
    "check for UndefinedObject/SmallInteger receiver or newClass"
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   401
%{
329
claus
parents: 325
diff changeset
   402
    if (__isNonNilObject(self) 
claus
parents: 325
diff changeset
   403
     && __isNonNilObject(otherClass)
85
claus
parents: 77
diff changeset
   404
     && (otherClass != UndefinedObject)
claus
parents: 77
diff changeset
   405
     && (otherClass != SmallInteger)) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   406
	ok = true;
85
claus
parents: 77
diff changeset
   407
    } else {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   408
	ok = false;
85
claus
parents: 77
diff changeset
   409
    }
claus
parents: 77
diff changeset
   410
%}.
claus
parents: 77
diff changeset
   411
    ok ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   412
	ok := false.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   413
	myClass := self class.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   414
	myClass flags == otherClass flags ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   415
	    myClass instSize == otherClass instSize ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   416
		"same instance layout and types: its ok to do it"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   417
		ok := true.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   418
	    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   419
		myClass isPointers ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   420
		    myClass isVariable ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   421
			ok := true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   422
		    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   423
		]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   424
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   425
	] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   426
	    myClass isPointers ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   427
		"if newClass is a variable class, with instSize <= my instsize,
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   428
		 we can do it (effectively mapping additional instvars into the
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   429
		 variable part) - usefulness is questionable, though"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   430
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   431
		otherClass isPointers ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   432
		    otherClass isVariable ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   433
			otherClass instSize <= (myClass instSize + self basicSize) 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   434
			ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   435
			    ok := true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   436
			]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   437
		    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   438
			otherClass instSize == (myClass instSize + self basicSize) 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   439
			ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   440
			    ok := true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   441
			]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   442
		    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   443
		] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   444
		    "it does not make sense to convert pointers to bytes ..."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   445
		]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   446
	    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   447
		"does it make sense, to convert bits ?"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   448
		"could allow byteArray->wordArray->longArray->floatArray->doubleArray here ..."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   449
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   450
	]
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   451
    ].
85
claus
parents: 77
diff changeset
   452
    ok ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   453
	"now, change the receivers class ..."
85
claus
parents: 77
diff changeset
   454
%{
329
claus
parents: 325
diff changeset
   455
	__qClass(self) = otherClass;
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   456
	__STORE(self, otherClass);
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   457
	RETURN ( self );
85
claus
parents: 77
diff changeset
   458
%}.
claus
parents: 77
diff changeset
   459
    ].
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   460
    self primitiveFailed
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   461
!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   462
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   463
changeClassToThatOf:anObject
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   464
    "changes the class of the receiver to that of the argument, anObject.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   465
     This is only allowed (possible), if the receivers class and the arguments
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   466
     class have the same structure (i.e. number of named instance variables and 
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   467
     type of indexed instance variables). If the structures do not match, or any
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   468
     of the objects is nil or a Smallinteger, a primitive error is triggered."
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   469
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   470
    self changeClassTo:(anObject class)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
!Object methodsFor:'queries'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   474
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
size
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
    "return the number of the receivers indexed instance variables;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
     this method may be redefined in subclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
    ^ self basicSize
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
a27a279701f8 Initial revision
claus
parents:
diff changeset
   482
basicSize
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   483
    "return the number of the receivers indexed instance variables,
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   484
     0 if it has none.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   485
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   486
     This method should NOT be redefined in any subclass"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
329
claus
parents: 325
diff changeset
   490
    REGISTER int nbytes;
claus
parents: 325
diff changeset
   491
    REGISTER OBJ myClass;
claus
parents: 325
diff changeset
   492
    REGISTER int flags;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
    /*
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   495
     * notice the missing test for self being a nonNilObject -
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
     * this can be done since basicSize is defined both in UndefinedObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   497
     * and SmallInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
     */
329
claus
parents: 325
diff changeset
   499
    myClass = __qClass(self);
claus
parents: 325
diff changeset
   500
    nbytes = __qSize(self) 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   501
	      - OHDR_SIZE 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   502
	      - __OBJS2BYTES__(_intVal(_ClassInstPtr(myClass)->c_ninstvars));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
329
claus
parents: 325
diff changeset
   504
    flags = _intVal(_ClassInstPtr(myClass)->c_flags) & ARRAYMASK;
claus
parents: 325
diff changeset
   505
    /*
claus
parents: 325
diff changeset
   506
     * replaced switch by open-if; this is slightly faster since
claus
parents: 325
diff changeset
   507
     * it avoids the range check and also checks the most common case first
claus
parents: 325
diff changeset
   508
     */
claus
parents: 325
diff changeset
   509
    if ((flags == POINTERARRAY)
claus
parents: 325
diff changeset
   510
     || (flags == WKPOINTERARRAY)) {
claus
parents: 325
diff changeset
   511
	RETURN ( _MKSMALLINT(__BYTES2OBJS__(nbytes)) );
claus
parents: 325
diff changeset
   512
    }
claus
parents: 325
diff changeset
   513
    if (flags == BYTEARRAY) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   514
	    RETURN ( _MKSMALLINT(nbytes / sizeof(char)) );
329
claus
parents: 325
diff changeset
   515
    }
claus
parents: 325
diff changeset
   516
    if (flags == FLOATARRAY) {
claus
parents: 325
diff changeset
   517
	RETURN ( _MKSMALLINT(nbytes / sizeof(float)) );
claus
parents: 325
diff changeset
   518
    }
claus
parents: 325
diff changeset
   519
    if (flags == DOUBLEARRAY) {
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   520
#ifdef NEED_DOUBLE_ALIGN
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   521
	    /*
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   522
	     * care for filler
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   523
	     */
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   524
	    nbytes -= sizeof(FILLTYPE);
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   525
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   526
	    RETURN ( _MKSMALLINT(nbytes / sizeof(double)) );
329
claus
parents: 325
diff changeset
   527
    }
claus
parents: 325
diff changeset
   528
    if (flags == LONGARRAY) {
claus
parents: 325
diff changeset
   529
	RETURN ( _MKSMALLINT(nbytes / sizeof(long)) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
    }
329
claus
parents: 325
diff changeset
   531
    if (flags == WORDARRAY) {
claus
parents: 325
diff changeset
   532
	RETURN ( _MKSMALLINT(nbytes / sizeof(short)) );
claus
parents: 325
diff changeset
   533
    }
claus
parents: 325
diff changeset
   534
%}.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
    ^ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
isVariable
a27a279701f8 Initial revision
claus
parents:
diff changeset
   539
    "return true if the receiver has indexed instance variables,
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   540
     false otherwise."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   541
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
    ^ self class isVariable
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   544
a27a279701f8 Initial revision
claus
parents:
diff changeset
   545
isFixedSize
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
   546
    "return true if the receiver cannot grow easily 
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
   547
     (i.e. a grow may be expensive, since it involves a become:)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   548
a27a279701f8 Initial revision
claus
parents:
diff changeset
   549
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   550
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   551
a27a279701f8 Initial revision
claus
parents:
diff changeset
   552
class
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
    "return the receivers class"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
329
claus
parents: 325
diff changeset
   557
    RETURN ( __Class(self) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
a27a279701f8 Initial revision
claus
parents:
diff changeset
   561
species
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
    "return a class which is similar to (or the same as) the receivers class.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
     This is used to create an appropriate object when creating derived
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   564
     copies in the collection classes (sometimes redefined)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   565
a27a279701f8 Initial revision
claus
parents:
diff changeset
   566
    ^ self class
a27a279701f8 Initial revision
claus
parents:
diff changeset
   567
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   568
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
yourself
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
    "return the receiver - used for cascades to return self at the end"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   573
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
isBehavior
a27a279701f8 Initial revision
claus
parents:
diff changeset
   576
    "return true, if the receiver is some kind of class (i.e. behavior);
259
   577
     false is returned here - the method is only redefined in Behavior."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   578
a27a279701f8 Initial revision
claus
parents:
diff changeset
   579
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   580
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   581
2
claus
parents: 1
diff changeset
   582
isClass
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   583
    "return true, if the receiver is some kind of class (real class, 
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   584
     not just behavior);
259
   585
     false is returned here - the method is only redefined in Class."
2
claus
parents: 1
diff changeset
   586
claus
parents: 1
diff changeset
   587
    ^ false
claus
parents: 1
diff changeset
   588
!
claus
parents: 1
diff changeset
   589
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   590
isMeta
a27a279701f8 Initial revision
claus
parents:
diff changeset
   591
    "return true, if the receiver is some kind of metaclass;
259
   592
     false is returned here - the method is only redefined in Metaclass."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   593
a27a279701f8 Initial revision
claus
parents:
diff changeset
   594
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   596
a27a279701f8 Initial revision
claus
parents:
diff changeset
   597
isBlock
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   598
    "return true, if the receiver is some kind of block;
259
   599
     false returned here - the method is only redefined in Block."
   600
   601
    ^ false
   602
!
   603
   604
isMethod
   605
    "return true, if the receiver is some kind of method;
   606
     false returned here - the method is only redefined in Method."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   607
a27a279701f8 Initial revision
claus
parents:
diff changeset
   608
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   610
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
isContext
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   612
    "return true, if the receiver is some kind of context;
259
   613
     false returned here - the method is only redefined in Context."
   614
   615
    ^ false
   616
!
   617
   618
isSignal
   619
    "return true, if the receiver is some kind of signal;
   620
     false returned here - the method is only redefined in Signal."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   621
a27a279701f8 Initial revision
claus
parents:
diff changeset
   622
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   623
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   624
a27a279701f8 Initial revision
claus
parents:
diff changeset
   625
isStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
    "return true, if the receiver is some kind of stream;
259
   627
     false is returned here - the method is only redefined in Stream."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   630
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   631
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   632
isFileStream
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   633
    "return true, if the receiver is some kind of fileStream;
259
   634
     false is returned here - the method is only redefined in FileStream."
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   635
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   636
    ^false
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   637
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   638
259
   639
isCollection
   640
    "return true, if the receiver is some kind of collection;
   641
     false is returned here - the method is only redefined in Collection."
   642
   643
    ^ false
   644
!
   645
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   646
isSequenceable
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   647
    "return true, if the receiver is some kind of sequenceable collection;
259
   648
     false is returned here - the method is only redefined in SequenceableCollection."
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   649
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   650
    ^ false
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   651
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   652
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   653
isSequenceableCollection
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   654
    "OBSOLETE: use isSequenceable for ST-80 compatibility.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   655
     This method is a historic leftover and will be removed soon ..."
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   656
359
claus
parents: 357
diff changeset
   657
    self obsoleteMethodWarning:'use #isSequenceable'.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   658
    ^ false
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   659
!
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   660
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   661
isColor
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   662
    "return true, if the receiver is some kind of color;
259
   663
     false is returned here - the method is only redefined in Color."
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   664
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   665
    ^ false
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   666
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   667
370
claus
parents: 369
diff changeset
   668
isArray
claus
parents: 369
diff changeset
   669
    "return true, if the receiver is some kind of array (or weakArray etc);
claus
parents: 369
diff changeset
   670
     false is returned here - the method is only redefined in Array."
claus
parents: 369
diff changeset
   671
claus
parents: 369
diff changeset
   672
    ^ false
claus
parents: 369
diff changeset
   673
!
claus
parents: 369
diff changeset
   674
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   675
isString
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   676
    "return true, if the receiver is some kind of string;
259
   677
     false is returned here - the method is only redefined in String."
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   678
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   679
    ^ false
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   680
!
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   681
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   682
isSymbol
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   683
    "return true, if the receiver is some kind of symbol;
259
   684
     false is returned here - the method is only redefined in Symbol."
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   685
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   686
    ^ false
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   687
!
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   688
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   689
isCharacter
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   690
    "return true, if the receiver is some kind of character;
259
   691
     false is returned here - the method is only redefined in Character."
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   692
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   693
    ^ false
2
claus
parents: 1
diff changeset
   694
!
claus
parents: 1
diff changeset
   695
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   696
isNumber
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   697
    "return true, if the receiver is some kind of number;
259
   698
     false is returned here - the method is only redefined in Number."
   699
   700
    ^ false
   701
!
   702
   703
isFraction
   704
    "return true, if the receiver is some kind of fraction;
   705
     false is returned here - the method is only redefined in Fraction."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   706
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   707
    ^ false
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   708
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   709
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   710
isInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   711
    "return true, if the receiver is some kind of integer number;
259
   712
     false is returned here - the method is only redefined in Integer."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   713
a27a279701f8 Initial revision
claus
parents:
diff changeset
   714
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   715
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   716
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   717
isPoint
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   718
    "return true, if the receiver is some kind of point;
259
   719
     false is returned here - the method is only redefined in Point."
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   720
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   721
    ^ false
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   722
!
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   723
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   724
isRectangle
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   725
    "return true, if the receiver is some kind of rectangle;
259
   726
     false is returned here - the method is only redefined in Rectangle."
   727
   728
    ^ false
   729
!
   730
339
claus
parents: 332
diff changeset
   731
isLayout
claus
parents: 332
diff changeset
   732
    "return true, if the receiver is some kind of layout;
claus
parents: 332
diff changeset
   733
     false is returned here - the method is only redefined in Layout."
claus
parents: 332
diff changeset
   734
claus
parents: 332
diff changeset
   735
    ^ false
claus
parents: 332
diff changeset
   736
!
claus
parents: 332
diff changeset
   737
259
   738
isForm
   739
    "return true, if the receiver is some kind of form;
   740
     false is returned here - the method is only redefined in Form."
   741
   742
    ^ false
   743
!
   744
   745
isImage
   746
    "return true, if the receiver is some kind of image;
   747
     false is returned here - the method is only redefined in Image."
   748
   749
    ^ false
   750
!
   751
   752
isImageOrForm
   753
    "return true, if the receiver is some kind of image or form;
   754
     false is returned here - the method is only redefined in Image and Form."
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   755
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   756
    ^ false
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   757
!
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
   758
329
claus
parents: 325
diff changeset
   759
isView
claus
parents: 325
diff changeset
   760
    "return true, if the receiver is some kind of view;
claus
parents: 325
diff changeset
   761
     false is returned here - the method is only redefined in View."
claus
parents: 325
diff changeset
   762
claus
parents: 325
diff changeset
   763
    ^ false
claus
parents: 325
diff changeset
   764
!
claus
parents: 325
diff changeset
   765
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   766
isLiteral
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   767
    "return true, if the receiver can be represented as a constant in ST syntax;
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   768
     false is returned here - the method is redefined in some classes."
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   769
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   770
    ^ false
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   771
!
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
   772
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   773
isMemberOf:aClass
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   774
    "return true, if the receiver is an instance of aClass, false otherwise.
259
   775
     Advice: 
   776
	use of this to check objects for certain attributes/protocoll should
   777
	be avoided; it limits the reusability of your classes by limiting use
   778
	to instances of a certain class.
   779
	Use check-methods to check an object for a certain attributes/protocol
   780
	(such as #isXXX, #respondsTo: or #isNumber);
   781
   782
	Using #isMemberOf: is considered BAD STYLE."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   783
a27a279701f8 Initial revision
claus
parents:
diff changeset
   784
    ^ (self class) == aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
   785
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   786
a27a279701f8 Initial revision
claus
parents:
diff changeset
   787
isKindOf:aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
   788
    "return true, if the receiver is an instance of aClass or one of its
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   789
     subclasses, false otherwise.
259
   790
     Advice: 
   791
	use of this to check objects for certain attributes/protocoll should
   792
	be avoided; it limits the reusability of your classes by limiting use
   793
	to instances of certain classes and fences you into a specific inheritance 
   794
	hierarchy.
   795
	Use check-methods to check an object for a certain attributes/protocol
   796
	(such as #isXXXX, #respondsTo: or #isNumber).
   797
   798
	Using #isKindOf: is considered BAD STYLE.
   799
   800
     Advice2:
325
claus
parents: 324
diff changeset
   801
	Be aware, that using an #isXXX method is usually much faster than 
claus
parents: 324
diff changeset
   802
	using #isKindOf:; because isKindOf: has to walk up all the superclass 
claus
parents: 324
diff changeset
   803
	hierarchy, comparing every class on the way. 
claus
parents: 324
diff changeset
   804
	Due to caching in the VM, a call to #isXXX is normally reached via
claus
parents: 324
diff changeset
   805
	a single function call.
259
   806
     "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   807
a27a279701f8 Initial revision
claus
parents:
diff changeset
   808
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   809
    register OBJ thisClass;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   810
329
claus
parents: 325
diff changeset
   811
    thisClass = __Class(self);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   812
    while (thisClass != nil) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   813
	if (thisClass == aClass) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   814
	    RETURN ( true );
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   815
	}
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   816
	thisClass = _ClassInstPtr(thisClass)->c_superclass;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   817
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   818
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   819
.
85
claus
parents: 77
diff changeset
   820
"/
claus
parents: 77
diff changeset
   821
"/  the above code is equivalent to:
claus
parents: 77
diff changeset
   822
"/
claus
parents: 77
diff changeset
   823
"/  thisClass := self class.
claus
parents: 77
diff changeset
   824
"/  [thisClass notNil] whileTrue:[
claus
parents: 77
diff changeset
   825
"/      thisClass == aClass ifTrue:[^ true].
claus
parents: 77
diff changeset
   826
"/      thisClass := thisClass superclass
claus
parents: 77
diff changeset
   827
"/  ]
claus
parents: 77
diff changeset
   828
"/
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   829
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   830
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   831
a27a279701f8 Initial revision
claus
parents:
diff changeset
   832
respondsTo:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
   833
    "return true, if the receiver implements a method with selector equal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   834
     to aSelector; i.e. if there is a method for aSelector in either the
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   835
     receivers class or one of its superclasses.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   836
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   837
     Notice, that this does not imply, that such a message can be sent without
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   838
     an error being raised. For example, an implementation could send
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   839
     #shouldNotImplement or #subclassResponsibility."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   840
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   841
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   842
     should we go via the cache, or search (by class) ?
259
   843
     The first is faster, most of the time; while the 2nd fills
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   844
     the cache with useless data if this is sent in a loop over all objects.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   845
     For now, use the cache ...
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   846
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   847
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   848
362
claus
parents: 359
diff changeset
   849
    extern OBJ __lookup();
claus
parents: 359
diff changeset
   850
claus
parents: 359
diff changeset
   851
    if (__lookup(__Class(self), aSelector) == nil) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   852
	RETURN ( false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   853
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   854
    RETURN ( true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   855
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   856
.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   857
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   858
    ^ self class canUnderstand:aSelector
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   859
"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   860
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   861
    "'aString' respondsTo:#+"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   862
    "'aString' respondsTo:#,"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   863
    "'aString' respondsTo:#collect:"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   864
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   865
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   866
respondsToArithmetic
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   867
    "return true, if the receiver responds to arithmetic messages.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   868
     false is returned here - the method is redefined in ArithmeticValue."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   869
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
   870
    ^ false
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   871
! !
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   872
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   873
!Object methodsFor:'special queries'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   874
a27a279701f8 Initial revision
claus
parents:
diff changeset
   875
references:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   876
    "return true, if the receiver refers to the argument, anObject.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   877
     - for debugging only"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   878
a27a279701f8 Initial revision
claus
parents:
diff changeset
   879
    |myClass 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   880
     numInst "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   881
369
claus
parents: 362
diff changeset
   882
%{
claus
parents: 362
diff changeset
   883
    /*
claus
parents: 362
diff changeset
   884
     * a little optimization: use the fact that all old objects
claus
parents: 362
diff changeset
   885
     * refering to a new object are on the remSet; if I am not,
claus
parents: 362
diff changeset
   886
     * a trivial reject is possible, if anObject is a newbee
claus
parents: 362
diff changeset
   887
     */
claus
parents: 362
diff changeset
   888
    if (__isNonNilObject(self) && __isNonNilObject(anObject)) {
claus
parents: 362
diff changeset
   889
	if ((__qSpace(self) <= OLDSPACE) && !__isRemembered(self)) {
claus
parents: 362
diff changeset
   890
	    int spc;
claus
parents: 362
diff changeset
   891
claus
parents: 362
diff changeset
   892
	    if (((spc = __qSpace(anObject)) == NEWSPACE) || (spc == SURVSPACE)) {
claus
parents: 362
diff changeset
   893
		RETURN (false);
claus
parents: 362
diff changeset
   894
	    }
claus
parents: 362
diff changeset
   895
	}
claus
parents: 362
diff changeset
   896
    }
claus
parents: 362
diff changeset
   897
%}.
claus
parents: 362
diff changeset
   898
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   899
    myClass := self class.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   900
a27a279701f8 Initial revision
claus
parents:
diff changeset
   901
    "check the class"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   902
    (myClass == anObject) ifTrue:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   903
a27a279701f8 Initial revision
claus
parents:
diff changeset
   904
    "check the instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   905
    numInst := myClass instSize.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   906
    1 to:numInst do:[:i | 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   907
	((self instVarAt:i) == anObject) ifTrue:[^ true]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   908
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   909
a27a279701f8 Initial revision
claus
parents:
diff changeset
   910
    "check the indexed variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   911
    myClass isVariable ifTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   912
	myClass isPointers ifFalse:[
369
claus
parents: 362
diff changeset
   913
	    "/
claus
parents: 362
diff changeset
   914
	    "/ we could argue about the following unconditional return:
claus
parents: 362
diff changeset
   915
	    "/ it says that a non pointer array never has a reference to the
claus
parents: 362
diff changeset
   916
	    "/ corresponding object - not mimicing a reference to a copy of the
claus
parents: 362
diff changeset
   917
	    "/ integer. However, it avoids useless searches in huge byteArray
claus
parents: 362
diff changeset
   918
	    "/ like objects when searching for owners. If in doubt, remove it.
claus
parents: 362
diff changeset
   919
	    "/ A consequence of the return below is that #[1 2 3] will say that it
claus
parents: 362
diff changeset
   920
	    "/ does not refer to the number 2 (think of keeping a copy instead)
claus
parents: 362
diff changeset
   921
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   922
	    ^ false.
369
claus
parents: 362
diff changeset
   923
claus
parents: 362
diff changeset
   924
	    "/ alternative:
claus
parents: 362
diff changeset
   925
	    "/  anObject isNumber ifFalse:[^ false].
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   926
	].
369
claus
parents: 362
diff changeset
   927
claus
parents: 362
diff changeset
   928
	"/
claus
parents: 362
diff changeset
   929
	"/ because arrays are so common, and those have a highly tuned
claus
parents: 362
diff changeset
   930
	"/ idenitytIndex method, use it
claus
parents: 362
diff changeset
   931
	"/
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   932
	myClass == Array ifTrue:[
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   933
	    ^ (self identityIndexOf:anObject) ~~ 0
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   934
	].
369
claus
parents: 362
diff changeset
   935
claus
parents: 362
diff changeset
   936
	"/
claus
parents: 362
diff changeset
   937
	"/ otherwise, do it the slow way
claus
parents: 362
diff changeset
   938
	"/
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   939
	numInst := self basicSize.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   940
	1 to:numInst do:[:i | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   941
	    ((self basicAt:i) == anObject) ifTrue:[^ true]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
   942
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   943
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   944
    ^ false
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   945
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   946
    "
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   947
     |v|
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   948
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   949
     v := View new initialize.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   950
     v references:Display. 
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   951
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   952
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   953
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   954
referencesInstanceOf:aClass
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   955
    "return true, if the receiver refers to an instance of
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   956
     the argument, aClass.This method exists
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   957
     to support searching for users of a class."
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   958
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   959
    |myClass 
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   960
     numInst "{ Class: SmallInteger }" |
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   961
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   962
    myClass := self class.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   963
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   964
    "check the class"
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   965
    (myClass isMemberOf:aClass) ifTrue:[^ true].
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   966
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   967
    "check the instance variables"
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   968
    numInst := myClass instSize.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   969
    1 to:numInst do:[:i | 
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   970
	((self instVarAt:i) isMemberOf:aClass) ifTrue:[^ true]
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   971
    ].
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   972
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   973
    "check the indexed variables"
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   974
    myClass isVariable ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   975
	myClass isPointers ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   976
	    "no need to search in non-pointer indexed fields"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   977
	    myClass isLongs ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   978
		(aClass == SmallInteger or:[aClass == LargeInteger]) ifFalse:[^ false].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   979
	    ] ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   980
		myClass isFloats ifTrue:[^ aClass == Float].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   981
		myClass isDoubles ifTrue:[^ aClass == Float].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   982
		^ aClass == SmallInteger
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   983
	    ]
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   984
	].
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   985
	numInst := self basicSize.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   986
	1 to:numInst do:[:i | 
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   987
	    ((self basicAt:i) isMemberOf:aClass) ifTrue:[^ true]
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   988
	]
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   989
    ].
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   990
    ^ false
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   991
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   992
    "
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   993
     (1 @ 3.4) referencesInstanceOf:Float     
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   994
     (1 @ 3.4) referencesInstanceOf:Fraction    
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
   995
     View new initialize referencesInstanceOf:(Display class)  
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   996
    "
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   997
!
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   998
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
   999
referencesDerivedInstanceOf:aClass
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1000
    "return true, if the receiver refers to an instance of
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1001
     the argument, aClass or its subclass. This method exists
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1002
     to support searching for users of a class."
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1003
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1004
    |myClass 
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1005
     numInst "{ Class: SmallInteger }" |
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1006
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1007
    myClass := self class.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1008
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1009
    "check the class"
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1010
    (myClass isKindOf:aClass) ifTrue:[^ true].
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1011
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1012
    "check the instance variables"
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1013
    numInst := myClass instSize.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1014
    1 to:numInst do:[:i | 
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1015
	((self instVarAt:i) isKindOf:aClass) ifTrue:[^ true]
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1016
    ].
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1017
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1018
    "check the indexed variables"
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1019
    myClass isVariable ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1020
	myClass isPointers ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1021
	    "no need to search in non pointer fields"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1022
	    ((aClass == Number) or:[aClass isSubclassOf:Number]) ifFalse:[^ false].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1023
	].
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1024
	numInst := self basicSize.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1025
	1 to:numInst do:[:i | 
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1026
	    ((self basicAt:i) isKindOf:aClass) ifTrue:[^ true]
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1027
	]
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1028
    ].
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1029
    ^ false
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1030
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1031
    "
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1032
     (1 @ 3.4) referencesDerivedInstanceOf:Number  
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1033
     (1 @ 3.4) referencesDerivedInstanceOf:Array   
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1034
     View new initialize referencesDerivedInstanceOf:DeviceWorkstation  
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1035
    "
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1036
!
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  1037
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1038
allOwners
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1039
    "return a collection of all objects referencing the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1040
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1041
    ^ ObjectMemory whoReferences:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1042
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1043
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1044
!Object methodsFor:'misc'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1045
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1046
-> anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1047
    "return an association with the receiver as key and
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1048
     the argument as value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1049
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1050
    ^ Association key:self value:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1051
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1052
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1053
!Object methodsFor:'evaluation'!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1054
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1055
value
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1056
    "this allows every object to be used where blocks are typically used.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1057
     Time will show, if this is a good idea or leads to sloppy programming
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1058
     style ... (the idea was borrowed from the Self language).
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1059
     WARNING: dont 'optimize' away ifXXX: blocks - the compilers will 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1060
	      only generate inline code for the if, if the argument(s) are blocks.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1061
	      It will work, but run slower instead."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1062
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1063
    ^ self
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1064
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1065
    "
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1066
     #(1 2 3 4) indexOf:5 ifAbsent:0 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1067
    "
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1068
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1069
    "DO NOT DO THIS (its slower)
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1070
     (1 > 4) ifTrue:'oops' ifFalse:'ok'
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1071
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1072
     USE (the compiler optimizes blocks in if/while):
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1073
     (1 > 4) ifTrue:['oops'] ifFalse:['ok']
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1074
    "
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1075
! !
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1076
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1077
!Object methodsFor:'copying'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1078
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1079
copy
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1080
    "return a copy of the receiver - defaults to shallowcopy here.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1081
     Notice, that copy does not copy dependents."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1082
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1083
    ^ self shallowCopy postCopy
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1084
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1085
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1086
shallowCopyForFinalization
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1087
    "this is used to aquire a copy to be used for finalization -
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1088
     (the copy will get a dispose-notification; see the documentation in the Registry class)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1089
     This method can be redefined for more efficient copying - especially for large objects."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1090
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1091
    ^ self shallowCopy
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1092
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1093
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1094
shallowCopy
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1095
    "return a copy of the object with shared subobjects (a shallow copy)
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1096
     i.e. the copy shares referenced instvars with its original."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1097
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1098
    |myClass aCopy 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1099
     sz "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1100
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1101
    myClass := self class.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1102
    myClass isVariable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1103
	sz := self basicSize.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1104
	aCopy := myClass basicNew:sz.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1105
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1106
	"copy the indexed variables"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1107
	1 to:sz do:[:i | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1108
	    aCopy basicAt:i put:(self basicAt:i) 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1109
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1110
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1111
	aCopy := myClass basicNew
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1112
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1113
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1114
    "copy the instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1115
    sz := myClass instSize.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1116
    1 to:sz do:[:i | 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1117
	aCopy instVarAt:i put:(self instVarAt:i) 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1118
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1119
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1120
    ^ aCopy
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1121
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1122
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1123
postCopy
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1124
    "this is for compatibility with ST-80 code, which uses postCopy for
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1125
     cleanup after copying, while ST/X passes the original in postCopyFrom:
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1126
     (see there)"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1127
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1128
    ^ self
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1129
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1130
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1131
postCopyFrom:original
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1132
    "sent to a freshly deep-copied object to give it a chance to adjust things.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1133
     (a font could flush its device-handle for example). 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1134
     Notice, that for Sets/Dicts etc. a rehash is not needed, since the deepCopy
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1135
     will have the same hash key as the receiver (as long as ST/X provides the 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1136
     setHash: functionality)."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1137
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1138
    "for ST-80 compatibility, we try postCopy here ..."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1139
    ^ self postCopy
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1140
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1141
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1142
deepCopy
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1143
    "return a copy of the object with all subobjects also copied.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1144
     This method DOES handle cycles/self-refs; however the receivers
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1145
     class is not copied (to avoid the 'total' copy).
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1146
     This deepCopy is a bit slower than the old (unsecure) one, since it
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1147
     keeps track of already copied objects. If you are sure, that your
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1148
     copied object does not include dublicates (or you do not care) and
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1149
     no cycles, you can use the old simpleDeepCopy, which avoids this overhead,
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1150
     but may run into trouble.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1151
     Notice, that copy does not copy dependents."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1152
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1153
    ^ self deepCopyUsing:(IdentityDictionary new)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1154
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1155
    "an example which is not handled by the old deepCopy:
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1156
    
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1157
     |a|
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1158
     a := Array new:3.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1159
     a at:3 put:a.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1160
     a deepCopy inspect
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1161
    "
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1162
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1163
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1164
deepCopyError
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1165
    "raise a signal, that deepCopy is not allowed for this object"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1166
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1167
    ^ DeepCopyErrorSignal raise
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1168
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1169
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1170
deepCopyUsing:aDictionary
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1171
    "a helper for deepCopy; return a copy of the object with 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1172
     all subobjects also copied. If the to-be-copied object is in the dictionary, 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1173
     use the value found there. The class of the receiver is not copied.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1174
     This method DOES handle cycles/self references."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1175
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1176
    |myClass aCopy
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1177
     sz "{ Class: SmallInteger }" 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1178
     iOrig iCopy|
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1179
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1180
    myClass := self class.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1181
    myClass isVariable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1182
	sz := self basicSize.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1183
	aCopy := myClass basicNew:sz.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1184
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1185
	sz := 0.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1186
	aCopy := myClass basicNew
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1187
    ].
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1188
    aCopy setHashFrom:self.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1189
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1190
    aDictionary at:self put:aCopy.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1191
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1192
    "
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1193
     copy indexed instvars - if any
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1194
    "
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1195
    sz ~~ 0 ifTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1196
	myClass isBits ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1197
	    "block-copy indexed instvars"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1198
	    aCopy replaceFrom:1 to:sz with:self startingAt:1
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1199
	] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1200
	    "individual deep copy the indexed variables"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1201
	    1 to:sz do:[:i | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1202
		iOrig := self basicAt:i.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1203
		iOrig notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1204
		    (aDictionary includesKey:iOrig) ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1205
			iCopy := aDictionary at:iOrig
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1206
		    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1207
			iCopy := iOrig deepCopyUsing:aDictionary.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1208
		    ].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1209
		    aCopy basicAt:i put:iCopy
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1210
		]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1211
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1212
	]
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1213
    ].
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1214
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1215
    "
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1216
     copy the instance variables
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1217
    "
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1218
    sz := myClass instSize.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1219
    sz ~~ 0 ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1220
	1 to:sz do:[:i |
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1221
	    iOrig := self instVarAt:i.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1222
	    iOrig notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1223
		(aDictionary includesKey:iOrig) ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1224
		    iCopy := aDictionary at:iOrig
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1225
		] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1226
		    iCopy := iOrig deepCopyUsing:aDictionary.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1227
		].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1228
		aCopy instVarAt:i put:iCopy
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1229
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1230
	].
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1231
    ].
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1232
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1233
    ^ aCopy
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1234
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1235
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1236
simpleDeepCopy
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1237
    "return a copy of the object with all subobjects also copied.
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  1238
     This method does NOT handle cycles - but is included to allow this 
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  1239
     slightly faster copy in situations where it is known that
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  1240
     no recursive references occur (LargeIntegers for example).
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1241
     NOTICE: you will run into trouble, when trying this with recursive
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  1242
     objects (usually recursionInterrupt or memory-alert).
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  1243
     This method corresponds to the 'traditional' deepCopy found in
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  1244
     the Blue book."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1245
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1246
    |myClass aCopy 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1247
     sz "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1248
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1249
    myClass := self class.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1250
    myClass isVariable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1251
	sz := self basicSize.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1252
	aCopy := myClass basicNew:sz.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1253
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1254
	"copy the indexed variables"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1255
	1 to:sz do:[:i | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1256
	    aCopy basicAt:i put:((self basicAt:i) simpleDeepCopy)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1257
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1258
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1259
	aCopy := myClass basicNew 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1260
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1261
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1262
    "copy the instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1263
    sz := myClass instSize.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1264
    1 to:sz do:[:i | 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1265
	aCopy instVarAt:i put:((self instVarAt:i) simpleDeepCopy)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1266
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1267
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1268
    ^ aCopy
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1269
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1270
    "a bad example (but ST/X should survive ...)"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1271
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1272
     |a|
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1273
     a := Array new:3.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1274
     a at:3 put:a.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1275
     a simpleDeepCopy
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1276
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1277
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1278
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1279
setHashFrom:anObject
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1280
    "set my identity-hash key to be the same as anObjects hash key. 
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1281
     This is an ST/X speciality, which is NOT available in other (especially OT based) 
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1282
     Smalltalks, and may not be available in future ST/X versions.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1283
     DO NEVER use this for normal application code."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1284
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1285
%{  /* NOCONTEXT */
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1286
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1287
    REGISTER unsigned h;
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1288
329
claus
parents: 325
diff changeset
  1289
    if (__isNonNilObject(self) && __isNonNilObject(anObject)) {
375
claus
parents: 370
diff changeset
  1290
	h = __GET_HASH(anObject);
claus
parents: 370
diff changeset
  1291
	__SET_HASH(self, h);
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1292
	RETURN (self);
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1293
    }
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1294
%}
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1295
.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1296
    self primitiveFailed    "neither receiver not arg may be nil or SmallInteger"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1297
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1298
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1299
!Object methodsFor:'comparing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1300
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1301
== anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1302
    "return true, if the receiver and the arg are the same object"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1303
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1304
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1305
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1306
    RETURN ( (self == anObject) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1307
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1308
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1309
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1310
~~ anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1311
    "return true, if the receiver and the arg are not the same object"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1312
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1313
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1314
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1315
    RETURN ( (self == anObject) ? false : true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1316
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1317
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1318
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1319
= anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1320
    "return true, if the receiver and the arg have the same structure"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1321
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1322
    ^ self == anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1323
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1324
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1325
~= anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1326
    "return true, if the receiver and the arg do not have the same structure"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1327
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1328
    ^ (self = anObject) not
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1329
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1330
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1331
isNil
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1332
    "return true, if the receiver is nil"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1333
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1334
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1335
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1336
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1337
notNil
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1338
    "return true, if the receiver is not nil"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1339
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1340
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1341
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1342
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1343
hash
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1344
    "return an Integer useful as a hash key for the receiver.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1345
     This hash should return same values for objects with same
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1346
     contents (i.e. use this to hash on structure)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1347
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1348
    ^ self identityHash
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1349
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1350
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1351
identityHash
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1352
    "return an Integer useful as a hash key for the receiver.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1353
     This hash should return same values for the same object (i.e. use
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1354
     this to hash on identity of objects).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1355
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1356
     We cannot use the Objects address (as other smalltalks do) since
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1357
     no object-table exists and the hashval must not change when objects
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1358
     are moved by the collector. Therefore we assign each object a unique
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1359
     Id in the object header itself as its hashed upon.
370
claus
parents: 369
diff changeset
  1360
     (luckily we have 11 bits spare to do this - unluckily its only 11 bits).
claus
parents: 369
diff changeset
  1361
     Time will show, if 11 bits are enough; if not, another entry in the
2
claus
parents: 1
diff changeset
  1362
     object header will be needed, adding 4 bytes to every object. Alternatively,
claus
parents: 1
diff changeset
  1363
     hashed-upon objects could add an instvar containing the hash value."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1364
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1365
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1366
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1367
    REGISTER unsigned hash;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1368
    static unsigned nextHash = 0;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1369
    OBJ cls;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1370
329
claus
parents: 325
diff changeset
  1371
    if (__isNonNilObject(self)) {
375
claus
parents: 370
diff changeset
  1372
	hash = __GET_HASH(self);
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1373
	if (hash == 0) {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1374
	    hash = nextHash++;
375
claus
parents: 370
diff changeset
  1375
	    __SET_HASH(self, hash);
claus
parents: 370
diff changeset
  1376
	    hash = __GET_HASH(self);
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1377
	    if (hash == 0) {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1378
		hash = nextHash++;
375
claus
parents: 370
diff changeset
  1379
		__SET_HASH(self, hash);
claus
parents: 370
diff changeset
  1380
		hash = __GET_HASH(self);
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1381
	    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1382
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1383
359
claus
parents: 357
diff changeset
  1384
	/*
370
claus
parents: 369
diff changeset
  1385
	 * now, we got 11 bits for hashing;
359
claus
parents: 357
diff changeset
  1386
	 * make it as large as possible; since most hashers use the returned
claus
parents: 357
diff changeset
  1387
	 * key and take it modulu some prime number, this will allow for
claus
parents: 357
diff changeset
  1388
	 * better distribution (i.e. bigger empty spaces) in hashed collection.
claus
parents: 357
diff changeset
  1389
	 * we could shift it up to the 30 bit limit - not making it negative.
claus
parents: 357
diff changeset
  1390
	 */
370
claus
parents: 369
diff changeset
  1391
	RETURN ( _MKSMALLINT(hash << __HASH_SHIFT__) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1392
    }
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1393
%}.
356
claus
parents: 348
diff changeset
  1394
    ^ 0 "never reached, since redefined in UndefinedObject and SmallInteger"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1395
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1396
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1397
!Object methodsFor:'interrupt handling'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1398
2
claus
parents: 1
diff changeset
  1399
internalError:msg
claus
parents: 1
diff changeset
  1400
    "this is triggered, when system hits some bad error,
claus
parents: 1
diff changeset
  1401
     such as corrupted class, corrupted method/selector array
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  1402
     etc. The argument string gives some more information on what happened.
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  1403
     (for example, if you set an objects class to a smallInteger, nil etc). 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1404
     Its not guaranteed, that the system is in a working condition once
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1405
     this error occurred ...."
2
claus
parents: 1
diff changeset
  1406
85
claus
parents: 77
diff changeset
  1407
    ^ self error:msg
2
claus
parents: 1
diff changeset
  1408
!
claus
parents: 1
diff changeset
  1409
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1410
userInterrupt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1411
    "user (^c) interrupt - enter debugger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1412
10
claus
parents: 5
diff changeset
  1413
    UserInterruptSignal raise
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1414
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1415
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1416
ioInterrupt
10
claus
parents: 5
diff changeset
  1417
    "I/O (SIGIO/SIGPOLL) interrupt and no handler - enter debugger"
claus
parents: 5
diff changeset
  1418
claus
parents: 5
diff changeset
  1419
    self error:'I/O Interrupt - but no handler'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1420
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1421
2
claus
parents: 1
diff changeset
  1422
childSignalInterrupt
claus
parents: 1
diff changeset
  1423
    "death of a child process (unix process) - do nothing"
claus
parents: 1
diff changeset
  1424
claus
parents: 1
diff changeset
  1425
    ^ self
claus
parents: 1
diff changeset
  1426
!
claus
parents: 1
diff changeset
  1427
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1428
spyInterrupt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1429
    "spy interrupt and no handler - enter debugger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1430
10
claus
parents: 5
diff changeset
  1431
    self error:'spy Interrupt - but no handler'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1432
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1433
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1434
timerInterrupt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1435
    "timer interrupt and no handler - enter debugger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1436
10
claus
parents: 5
diff changeset
  1437
    self error:'timer Interrupt - but no handler'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1438
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1439
375
claus
parents: 370
diff changeset
  1440
errorInterrupt:errorID with:aParameter
claus
parents: 370
diff changeset
  1441
    "subsystem error. The arguments errorID and aParameter are the values passed
claus
parents: 370
diff changeset
  1442
     to the 'errorInterruptWithIDAndParameter(id, param)' function, 
claus
parents: 370
diff changeset
  1443
     which can be called from C subsystems to raise an (asynchronous)
claus
parents: 370
diff changeset
  1444
     error exception.
345
claus
parents: 343
diff changeset
  1445
claus
parents: 343
diff changeset
  1446
     Currently, this is used to map XErrors to smalltalk errors, but can be
375
claus
parents: 370
diff changeset
  1447
     used from other C subsystems too, to upcast errors.
claus
parents: 370
diff changeset
  1448
     Especially, for subsystems which call errorHandler functions asynchronously.
345
claus
parents: 343
diff changeset
  1449
     IDs (currently) used:
claus
parents: 343
diff changeset
  1450
	#DisplayError ..... x-error interrupt
348
claus
parents: 345
diff changeset
  1451
	#XtError      ..... xt-error interrupt (Xt interface is not yet published)
345
claus
parents: 343
diff changeset
  1452
    "
claus
parents: 343
diff changeset
  1453
claus
parents: 343
diff changeset
  1454
    |handler|
claus
parents: 343
diff changeset
  1455
claus
parents: 343
diff changeset
  1456
    handler := ObjectMemory registeredErrorInterruptHandlers at:errorID ifAbsent:nil.
claus
parents: 343
diff changeset
  1457
    handler notNil ifTrue:[
375
claus
parents: 370
diff changeset
  1458
	"/
claus
parents: 370
diff changeset
  1459
	"/ handler found; let it do whatever it wants ...
claus
parents: 370
diff changeset
  1460
	"/
claus
parents: 370
diff changeset
  1461
	handler errorInterrupt:errorID with:aParameter.
345
claus
parents: 343
diff changeset
  1462
	^ self
claus
parents: 343
diff changeset
  1463
    ].
claus
parents: 343
diff changeset
  1464
375
claus
parents: 370
diff changeset
  1465
    "/
claus
parents: 370
diff changeset
  1466
    "/ no handler - raise errorSignal passing the errorId as parameter
claus
parents: 370
diff changeset
  1467
    "/
345
claus
parents: 343
diff changeset
  1468
    ^ ErrorSignal 
claus
parents: 343
diff changeset
  1469
	raiseRequestWith:errorID 
claus
parents: 343
diff changeset
  1470
	errorString:('Subsystem error. ErrorID = ' , errorID printString)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1471
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1472
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1473
memoryInterrupt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1474
    "out-of-memory interrupt and no handler - enter debugger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1475
345
claus
parents: 343
diff changeset
  1476
    ^ self error:'almost out of memory'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1477
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1478
387
claus
parents: 384
diff changeset
  1479
customInterrupt
claus
parents: 384
diff changeset
  1480
    "a custom interrupt"
claus
parents: 384
diff changeset
  1481
claus
parents: 384
diff changeset
  1482
    ^ self error:'custom interrupt'
claus
parents: 384
diff changeset
  1483
!
claus
parents: 384
diff changeset
  1484
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1485
fpExceptionInterrupt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1486
    "a floating point exception occured - this one
113
0403779c8fe3 return value of signal raise;
claus
parents: 110
diff changeset
  1487
     has to be handled differently since it comes asynchronous
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1488
     on some machines (for example, on machines with a separate FPU
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1489
     or superscalar architectures. Also, errors from within primitive code
113
0403779c8fe3 return value of signal raise;
claus
parents: 110
diff changeset
  1490
     (or library functions such as GL) are sent via the Unix-signal
0403779c8fe3 return value of signal raise;
claus
parents: 110
diff changeset
  1491
     mechanism this way."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1492
113
0403779c8fe3 return value of signal raise;
claus
parents: 110
diff changeset
  1493
    ^ Float domainErrorSignal raise
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1494
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1495
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1496
signalInterrupt:signalNumber
2
claus
parents: 1
diff changeset
  1497
    "unix signal occured - some signals are handled as Smalltalk Exceptions (SIGPIPE),
claus
parents: 1
diff changeset
  1498
     others (SIGBUS) are rather fatal ..."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1499
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1500
    |box name here sig ignorable titles actions badContext|
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1501
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1502
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1503
     special case - since SIGPIPE has an ST-signal associated
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1504
    "
2
claus
parents: 1
diff changeset
  1505
    (signalNumber == 13) ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1506
	"SIGPIPE - write on a pipe with no one to read"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1507
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1508
	^ PipeStream brokenPipeSignal raise.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1509
    ].
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1510
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1511
    "if there has been an ST-signal installed, use it ..."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1512
113
0403779c8fe3 return value of signal raise;
claus
parents: 110
diff changeset
  1513
    sig := OperatingSystem operatingSystemSignal:signalNumber.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1514
    sig notNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1515
	^ sig raise
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1516
    ].
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1517
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1518
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1519
     ... otherwise , bring up a box asking for what to do ...
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1520
    "
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  1521
    name := OperatingSystem nameForSignal:signalNumber.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1522
    here := thisContext.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1523
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1524
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1525
     the context, in which the signal occurred:
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1526
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1527
    badContext := here sender.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1528
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1529
    "
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1530
     ungrab - in case it happened in a box/popupview
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1531
     otherwise display stays locked
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1532
    "
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1533
    Display notNil ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1534
	Display ungrabPointer.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1535
    ].
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1536
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1537
    "
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1538
     SIGBUS, SIGSEGV and SIGILL do not make sense to ignore (i.e. continue)
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1539
     since the system will retry the faulty instruction, which leads to
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1540
     another signal - to avoid frustration, better not offer this option.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1541
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1542
    ignorable := (signalNumber ~~ OperatingSystem sigBUS)
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1543
		  and:[signalNumber ~~ OperatingSystem sigILL
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1544
		  and:[signalNumber ~~ OperatingSystem sigSEGV]].
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1545
110
7093adf38df2 check for recursive signal
claus
parents: 102
diff changeset
  1546
    ignorable ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1547
	here isRecursive ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1548
	    'fatal: signal ' errorPrint. signalNumber errorPrintNL.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1549
	    MiniDebugger enterWithMessage:'recursive signal'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1550
	    ^ self
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1551
	].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1552
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1553
	 a hard signal - go into debugger immediately
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1554
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1555
	Debugger enter:here withMessage:('Signal ', name). 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1556
	badContext return.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1557
	^ nil.
110
7093adf38df2 check for recursive signal
claus
parents: 102
diff changeset
  1558
    ].
7093adf38df2 check for recursive signal
claus
parents: 102
diff changeset
  1559
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  1560
    OptionBox isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1561
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1562
	 a system without GUI ...
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1563
	 go into minidebugger (if there is one)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1564
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1565
	MiniDebugger isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1566
	    "
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1567
	     a system without debugging facilities
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1568
	     (i.e. a standalone system)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1569
	     output a message and exit.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1570
	    "
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1571
	    ('exit due to Signal ' , name) errorPrintNL.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1572
	    Smalltalk exit.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1573
	].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1574
	MiniDebugger enterWithMessage:'Signal cought (' , name, ')'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1575
	^ self
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  1576
    ].
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  1577
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1578
    box := OptionBox 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1579
		title:'Signal cought (' , name, ')'
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1580
		numberOfOptions:(ignorable ifTrue:[5] ifFalse:[4]).
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1581
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1582
    titles := #('return' 'debug' 'dump' 'exit').
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1583
    actions := Array 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1584
		 with:[badContext return]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1585
		 with:[Debugger enter:here withMessage:('Signal ', name). ^nil]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1586
		 with:[Smalltalk fatalAbort]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1587
		 with:[Smalltalk exit].
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1588
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1589
    ignorable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1590
	titles := #('ignore') , titles.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1591
	actions := (Array with:[^ nil]) , actions.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1592
    ].
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1593
    box buttonTitles:titles.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1594
    box actions:actions.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1595
    box showAtPointer
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1596
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1597
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1598
recursionInterrupt
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1599
    "recursion limit (actually: stack overflow) interrupt.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1600
     This interrupt is triggered, when a process stack grows above
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1601
     its stackLimit - usually, this leads into the debugger, but
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1602
     could be cought and the stackLimit increased in the handler.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1603
     At the time we arrive here, the system has still some stack 
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1604
     as a reserve so we can continue to do some useful work or cleanup or
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1605
     debugging for a while.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1606
     If the signal is ignored, and the stack continues to grow, there
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1607
     will be a few more chances (and more interrupts) before the VM
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  1608
     hard-terminates the process."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1609
33
50cf0f6bc0ad *** empty log message ***
claus
parents: 27
diff changeset
  1610
    thisContext isRecursive ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1611
	^ RecursionInterruptSignal raise
33
50cf0f6bc0ad *** empty log message ***
claus
parents: 27
diff changeset
  1612
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1613
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1614
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1615
exceptionInterrupt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1616
    "exception interrupt - enter debugger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1617
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1618
    self error:'exception Interrupt'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1619
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1620
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1621
!Object methodsFor:'error handling'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1622
2
claus
parents: 1
diff changeset
  1623
subscriptBoundsError
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1624
    "report error that some index is out of bounds.
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1625
     (when accessing indexable collections)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1626
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1627
    ^ SubscriptOutOfBoundsSignal raiseIn:thisContext sender
2
claus
parents: 1
diff changeset
  1628
!
claus
parents: 1
diff changeset
  1629
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1630
subscriptBoundsError:anIndex
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1631
    "report error that anIndex is out of bounds.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1632
     (when accessing indexable collections)"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1633
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1634
    ^ SubscriptOutOfBoundsSignal raiseRequestWith:anIndex in:thisContext sender
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1635
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1636
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1637
indexNotInteger
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1638
    "report error that index is not an Integer.
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1639
     (when accessing collections indexed by an integer key)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1640
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1641
    ^ NonIntegerIndexSignal raiseIn:thisContext sender
2
claus
parents: 1
diff changeset
  1642
!
claus
parents: 1
diff changeset
  1643
claus
parents: 1
diff changeset
  1644
errorNotFound
345
claus
parents: 343
diff changeset
  1645
    "report error that no element was found in a collection"
2
claus
parents: 1
diff changeset
  1646
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1647
    ^ NotFoundSignal raiseIn:thisContext sender
2
claus
parents: 1
diff changeset
  1648
!
claus
parents: 1
diff changeset
  1649
345
claus
parents: 343
diff changeset
  1650
errorKeyNotFound:aKey
2
claus
parents: 1
diff changeset
  1651
    "report error that a key was not found in a collection"
claus
parents: 1
diff changeset
  1652
345
claus
parents: 343
diff changeset
  1653
    ^ KeyNotFoundSignal raiseRequestWith:aKey in:thisContext sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1654
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1655
10
claus
parents: 5
diff changeset
  1656
elementBoundsError
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1657
    "report error that badElement is out of bounds 
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1658
     (i.e. cannot be put into that collection)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1659
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1660
    ^ ElementOutOfBoundsSignal raiseIn:thisContext sender
10
claus
parents: 5
diff changeset
  1661
!
claus
parents: 5
diff changeset
  1662
claus
parents: 5
diff changeset
  1663
elementNotInteger
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1664
    "report error that object to be stored is not Integer.
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1665
     (in collections that store integers only)"
10
claus
parents: 5
diff changeset
  1666
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1667
    ^ ElementOutOfBoundsSignal raiseIn:thisContext sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1668
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1669
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1670
elementNotCharacter
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1671
    "report error that object to be stored is no Character.
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1672
     (usually when storing into Strings)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1673
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1674
    ^ ElementOutOfBoundsSignal raiseIn:thisContext sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1675
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1676
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1677
mustBeRectangle
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1678
    "report an argument-not-rectangle-error"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1679
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1680
    ^ self error:'argument must be a Rectangle'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1681
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1682
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1683
mustBeString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1684
    "report an argument-not-string-error"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1685
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1686
    ^ self error:'argument must be a String'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1687
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1688
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1689
notIndexed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1690
    "report error that receiver has no indexed instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1691
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1692
    ^ self error:'receiver has no indexed variables'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1693
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1694
2
claus
parents: 1
diff changeset
  1695
integerCheckError
claus
parents: 1
diff changeset
  1696
    "generated when a variable declared with an integer type gets a bad
claus
parents: 1
diff changeset
  1697
     value assigned"
claus
parents: 1
diff changeset
  1698
claus
parents: 1
diff changeset
  1699
    ^ self error:'bad assign of ' , self printString , 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1700
		  ' (' , self class name , ') to integer-typed variable'
2
claus
parents: 1
diff changeset
  1701
!
claus
parents: 1
diff changeset
  1702
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1703
typeCheckError
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1704
    "generated when a variable declared with a type hint gets a bad
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1705
     value assigned"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1706
2
claus
parents: 1
diff changeset
  1707
    ^ self error:'bad assign of ' , self printString ,
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1708
		  ' (' , self class name , ') to typed variable'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1709
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1710
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1711
primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1712
    "report error that primitive code failed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1713
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1714
    ^ PrimitiveFailureSignal raiseIn:(thisContext sender)
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1715
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1716
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1717
implementedBySubclass
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1718
    "this is sent by ST/V code - its the same as #subclassResponsibility"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1719
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1720
    ^ self subclassResponsibility
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1721
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1722
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1723
invalidMessage 
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1724
    "this is sent by ST/V code - its the same as #shouldNotImplement"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1725
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1726
    ^ self shouldNotImplement
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1727
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1728
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1729
subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1730
    "report error that this message should have been reimplemented in a
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1731
     subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1732
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1733
    ^ self error:'method must be reimplemented in subclass'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1734
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1735
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1736
shouldNotImplement
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1737
    "report error that this message should not be implemented"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1738
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1739
    ^ self error:'method not appropriate for this class'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1740
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1741
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1742
halt
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1743
    "enter debugger with halt-message"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1744
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1745
    ^ HaltSignal raiseIn:thisContext sender.
27
d98f9dd437f7 *** empty log message ***
claus
parents: 25
diff changeset
  1746
!
d98f9dd437f7 *** empty log message ***
claus
parents: 25
diff changeset
  1747
d98f9dd437f7 *** empty log message ***
claus
parents: 25
diff changeset
  1748
halt:aString
d98f9dd437f7 *** empty log message ***
claus
parents: 25
diff changeset
  1749
    "enter debugger with halt-message"
d98f9dd437f7 *** empty log message ***
claus
parents: 25
diff changeset
  1750
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1751
    ^ HaltSignal raiseRequestWith:#halt: 
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1752
		      errorString:aString
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1753
			       in:thisContext sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1754
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1755
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1756
error
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1757
    "report error that an error occured"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1758
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1759
    ^ ErrorSignal raiseIn:thisContext sender 
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1760
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1761
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1762
error:aString
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1763
    "enter debugger with error-message aString"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1764
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1765
    ^ ErrorSignal raiseRequestWith:#error: 
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1766
		       errorString:aString
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1767
				in:thisContext sender
2
claus
parents: 1
diff changeset
  1768
!
claus
parents: 1
diff changeset
  1769
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1770
doesNotUnderstand:aMessage
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1771
    "this message is sent by the runtime system (VM) when
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1772
     a message is not understood by some object (i.e. there
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1773
     is no method for that selector). The original message has
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1774
     been packed into aMessage (i.e. the receiver, selector and
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1775
     any arguments) and the original receiver is then sent the
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1776
     #doesNotUnderstand: message.
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1777
     Here, we raise another signal which usually enters the debugger.
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1778
     You can of course redefine #doesNotUnderstand: in your classes
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1779
     to implement message delegation."
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1780
359
claus
parents: 357
diff changeset
  1781
    |sel errorString cls sender|
claus
parents: 357
diff changeset
  1782
claus
parents: 357
diff changeset
  1783
    (sel := aMessage selector) isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1784
	"happens when things go mad, or a method has been
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1785
	 called by valueWithReceiver: with a wrong receiver"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1786
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1787
	sel := '(nil)'
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1788
    ].
356
claus
parents: 348
diff changeset
  1789
    Smalltalk isInitialized ifFalse:[
claus
parents: 348
diff changeset
  1790
	sel printNL
claus
parents: 348
diff changeset
  1791
    ].
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1792
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1793
    "the new errorString gives more information ..."
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  1794
"/    errorString := 'Message not understood: ' , sel.
359
claus
parents: 357
diff changeset
  1795
    sender := thisContext sender.
claus
parents: 357
diff changeset
  1796
    cls := sender searchClass.
324
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  1797
    cls isNil ifTrue:[
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  1798
	"it was NOT a super or directed send ..."
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  1799
	cls := self class
314
7581a5c57224 *** empty log message ***
claus
parents: 308
diff changeset
  1800
    ].
324
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  1801
    errorString := cls name , ' does not understand: ' , sel.
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1802
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1803
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1804
     this only happens, when YOU play around with my classvars ...
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1805
    "
85
claus
parents: 77
diff changeset
  1806
    MessageNotUnderstoodSignal isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1807
	^ self enterDebuggerWith:nil
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1808
			 message:'oops - MessageNotUnderstoodSignal is gone'.
85
claus
parents: 77
diff changeset
  1809
    ].
113
0403779c8fe3 return value of signal raise;
claus
parents: 110
diff changeset
  1810
    ^ MessageNotUnderstoodSignal
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1811
		raiseRequestWith:aMessage
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1812
		     errorString:errorString
359
claus
parents: 357
diff changeset
  1813
			      in:sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1814
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1815
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1816
appropriateDebugger:aSelector
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1817
    "return an appropriate debugger to use.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1818
     If there is already a debugger active on the stack, and it is
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1819
     the DebugView, return MiniDebugger (as a last chance) otherwise abort."
85
claus
parents: 77
diff changeset
  1820
claus
parents: 77
diff changeset
  1821
    |context|
claus
parents: 77
diff changeset
  1822
claus
parents: 77
diff changeset
  1823
    context := thisContext.
claus
parents: 77
diff changeset
  1824
    context := context sender.
claus
parents: 77
diff changeset
  1825
    [context notNil] whileTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1826
	((context receiver class == Debugger) 
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1827
	 and:[context selector == aSelector]) ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1828
	    "we are already in some Debugger"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1829
	    (Debugger == MiniDebugger) ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1830
		"we are already in the MiniDebugger"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1831
		ErrorRecursion ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1832
		    Smalltalk fatalAbort:'recursive error ...'
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1833
		]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1834
	    ].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1835
	    MiniDebugger isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1836
		Smalltalk fatalAbort:'no debugger'
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1837
	    ].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1838
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1839
	    "ok, an error occured while in the graphical debugger;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1840
	     lets try MiniDebugger"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1841
	    ^ MiniDebugger
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1842
	].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1843
	context := context sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1844
    ].
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1845
    "not within Debugger - no problem"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1846
    ^ Debugger
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1847
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1848
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1849
enterDebuggerWith:anException message:aString
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1850
    "enter the debugger with error-message aString"
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1851
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1852
    ^ self enterDebuggerWith:anException 
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1853
		     message:aString 
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1854
			   on:anException suspendedContext
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1855
!
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1856
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1857
enterDebuggerWith:anException message:aString on:aContext 
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1858
    "enter the debugger with error-message aString.
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1859
     The first visible context shown there is aContext 
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1860
     (this allows intermediate helpers to hide themselfes from what is
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1861
     presented to the user)"
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1862
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1863
    |debugger|
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1864
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1865
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1866
     if there is no debugger, exit smalltalk
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1867
    "
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1868
    Debugger isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1869
	'error: ' errorPrint. aString errorPrintNL.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1870
	Smalltalk fatalAbort:'no Debugger defined'
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1871
    ].
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1872
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1873
     find an appropriate debugger to use
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1874
    "
255
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1875
    debugger := self appropriateDebugger:#'enter:withMessage:'.
2b2c5c0facab *** empty log message ***
claus
parents: 253
diff changeset
  1876
    ^ debugger enter:aContext withMessage:aString.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1877
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1878
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1879
!Object methodsFor:'debugging'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1880
342
claus
parents: 340
diff changeset
  1881
obsoleteMethodWarning:message from:aContext
260
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1882
    "in methods which are going to be obsoleted, a self send to
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1883
     this method is used to tell programmers that a method is
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1884
     used which is going to be removed in later ST/X versions.
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1885
     Find all methods which will be obsolete soon by looking at senders
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1886
     of this."
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1887
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1888
    |m spec w|
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1889
342
claus
parents: 340
diff changeset
  1890
    m := aContext method.
260
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1891
    spec := m displayString.
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1892
    m notNil ifTrue:[
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1893
	w := m who.
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1894
	w notNil ifTrue:[
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1895
	    spec := (w at:1) name , '>>' , (w at:2)
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1896
	]
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1897
    ].
340
claus
parents: 339
diff changeset
  1898
    ('WARNING: the ''' , spec , ''' method is obsolete.') errorPrintNL.
claus
parents: 339
diff changeset
  1899
    ('         And may not be present in future ST/X versions.') errorPrintNL.
342
claus
parents: 340
diff changeset
  1900
    ('         called from ' , aContext sender printString) errorPrintNL.
340
claus
parents: 339
diff changeset
  1901
    message notNil ifTrue:[
claus
parents: 339
diff changeset
  1902
	'------>  ' errorPrint. message errorPrintNL
claus
parents: 339
diff changeset
  1903
    ]
claus
parents: 339
diff changeset
  1904
!
claus
parents: 339
diff changeset
  1905
342
claus
parents: 340
diff changeset
  1906
obsoleteMethodWarning:message
claus
parents: 340
diff changeset
  1907
    "in methods which are going to be obsoleted, a self send to
claus
parents: 340
diff changeset
  1908
     this method is used to tell programmers that a method is
claus
parents: 340
diff changeset
  1909
     used which is going to be removed in later ST/X versions.
claus
parents: 340
diff changeset
  1910
     Find all methods which will be obsolete soon by looking at senders
claus
parents: 340
diff changeset
  1911
     of this."
claus
parents: 340
diff changeset
  1912
claus
parents: 340
diff changeset
  1913
    self obsoleteMethodWarning:message from:thisContext sender
claus
parents: 340
diff changeset
  1914
!
claus
parents: 340
diff changeset
  1915
340
claus
parents: 339
diff changeset
  1916
obsoleteMethodWarning
claus
parents: 339
diff changeset
  1917
    "in methods which are going to be obsoleted, a self send to
claus
parents: 339
diff changeset
  1918
     this method is used to tell programmers that a method is
claus
parents: 339
diff changeset
  1919
     used which is going to be removed in later ST/X versions.
claus
parents: 339
diff changeset
  1920
     Find all methods which will be obsolete soon by looking at senders
claus
parents: 339
diff changeset
  1921
     of this."
claus
parents: 339
diff changeset
  1922
342
claus
parents: 340
diff changeset
  1923
    self obsoleteMethodWarning:nil from:thisContext sender
260
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1924
!
cefb485445a7 *** empty log message ***
claus
parents: 259
diff changeset
  1925
325
claus
parents: 324
diff changeset
  1926
mustBeKindOf:aClass
claus
parents: 324
diff changeset
  1927
    "for compatibility & debugging support: 
claus
parents: 324
diff changeset
  1928
     check if the receiver isKindOf:aClass and raise an error if not.
claus
parents: 324
diff changeset
  1929
     Notice:
claus
parents: 324
diff changeset
  1930
	it is VERY questionable, if it makes sense to add manual
claus
parents: 324
diff changeset
  1931
	type checks to a dynamically typed language like smalltalk. 
claus
parents: 324
diff changeset
  1932
	It will, at least, slow down performance,
claus
parents: 324
diff changeset
  1933
	make your code less reusable and clutter your code with stupid sends
claus
parents: 324
diff changeset
  1934
	of this selector. Also, read the comment in isKindOf:, regarding the
claus
parents: 324
diff changeset
  1935
	use of isXXX check methods.
claus
parents: 324
diff changeset
  1936
     You see: The author does not like this at all ..."
claus
parents: 324
diff changeset
  1937
claus
parents: 324
diff changeset
  1938
    (self isKindOf:aClass) ifFalse:[
claus
parents: 324
diff changeset
  1939
	self error:'argument is not of expected type'
claus
parents: 324
diff changeset
  1940
    ]
claus
parents: 324
diff changeset
  1941
!
claus
parents: 324
diff changeset
  1942
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1943
notify:aString
362
claus
parents: 359
diff changeset
  1944
    "launch a Notifier, showing top stack telling user something
claus
parents: 359
diff changeset
  1945
     and give a chance to enter debugger."
claus
parents: 359
diff changeset
  1946
369
claus
parents: 362
diff changeset
  1947
    |info con sender|
362
claus
parents: 359
diff changeset
  1948
claus
parents: 359
diff changeset
  1949
    Dialog isNil ifTrue:[
claus
parents: 359
diff changeset
  1950
	"
claus
parents: 359
diff changeset
  1951
	 on systems without GUI, simply show
claus
parents: 359
diff changeset
  1952
	 the message on the Transcript.
claus
parents: 359
diff changeset
  1953
	"
claus
parents: 359
diff changeset
  1954
	Transcript showCr:aString.
claus
parents: 359
diff changeset
  1955
	^ self
claus
parents: 359
diff changeset
  1956
    ].
claus
parents: 359
diff changeset
  1957
    Dialog autoload.        "in case its autoloaded"
claus
parents: 359
diff changeset
  1958
"/    Dialog information:aString
claus
parents: 359
diff changeset
  1959
369
claus
parents: 362
diff changeset
  1960
    con := sender := thisContext sender.
362
claus
parents: 359
diff changeset
  1961
    info := aString , Character cr asString , Character cr asString.
claus
parents: 359
diff changeset
  1962
    1 to:5 do:[:n |
claus
parents: 359
diff changeset
  1963
	con notNil ifTrue:[
claus
parents: 359
diff changeset
  1964
	    info := info , con printString , Character cr asString.
claus
parents: 359
diff changeset
  1965
	    con := con sender
claus
parents: 359
diff changeset
  1966
	]
claus
parents: 359
diff changeset
  1967
    ].
claus
parents: 359
diff changeset
  1968
claus
parents: 359
diff changeset
  1969
    (Dialog choose:info 
claus
parents: 359
diff changeset
  1970
	   labels:#('proceed' 'debug')
claus
parents: 359
diff changeset
  1971
	   values:#(#proceed #debug)
claus
parents: 359
diff changeset
  1972
	   default:#debug) == #debug
claus
parents: 359
diff changeset
  1973
    ifTrue:[
369
claus
parents: 362
diff changeset
  1974
	Debugger enter:sender withMessage:aString
362
claus
parents: 359
diff changeset
  1975
    ]
claus
parents: 359
diff changeset
  1976
claus
parents: 359
diff changeset
  1977
    "
claus
parents: 359
diff changeset
  1978
     nil notify:'hello there'
claus
parents: 359
diff changeset
  1979
     self notify:'hello there'
claus
parents: 359
diff changeset
  1980
    "
claus
parents: 359
diff changeset
  1981
!
claus
parents: 359
diff changeset
  1982
claus
parents: 359
diff changeset
  1983
information:aString
claus
parents: 359
diff changeset
  1984
    "launch an InfoBox, telling user something"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1985
298
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  1986
    Dialog isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1987
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1988
	 on systems without GUI, simply show
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1989
	 the message on the Transcript.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1990
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1991
	Transcript showCr:aString.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  1992
	^ self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1993
    ].
298
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  1994
    Dialog autoload.        "in case its autoloaded"
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  1995
    Dialog information:aString
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  1996
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1997
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1998
     nil information:'hello there'
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  1999
     self information:'hello there'
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2000
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2001
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2002
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2003
warn:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2004
    "launch a WarningBox, telling user something"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2005
298
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  2006
    Dialog isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2007
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2008
	 on systems without GUI, simply show
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2009
	 the message on the Transcript.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2010
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2011
	Transcript showCr:aString.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2012
	^ self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2013
    ].
298
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  2014
    Dialog autoload.        "in case its autoloaded"
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  2015
    Dialog warn:aString
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2016
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2017
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2018
     nil warn:'hello there'
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2019
     self warn:'hello there'
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2020
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2021
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2022
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2023
confirm:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2024
    "launch a confirmer, which allows user to enter yes or no.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2025
     return true for yes, false for no"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2026
298
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  2027
    Dialog isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2028
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2029
	 on systems without GUI, output a message
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2030
	 and return true (as if yes was answered)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2031
	 Q: should we ask user by reading Stdin ?
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2032
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2033
	Transcript showCr:aString.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2034
	Transcript showCr:'continue, assuming <yes>'.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2035
	^ true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2036
    ].
298
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  2037
    Dialog autoload.        "in case its autoloaded"
962712d27c2d *** empty log message ***
claus
parents: 293
diff changeset
  2038
    ^ Dialog confirm:aString
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2039
        
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2040
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2041
     nil confirm:'hello'
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2042
     self confirm:'hello'
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2043
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2044
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2045
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2046
basicInspect
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2047
    "launch an inspector on the receiver.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2048
     this method should NOT be redefined in subclasses."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2049
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2050
    Inspector isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2051
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2052
	 for systems without GUI
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2053
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2054
	Transcript showCr:'no Inspector'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2055
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2056
	Inspector openOn:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2057
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2058
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2059
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2060
inspect
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2061
    "launch an inspector on the receiver.
282
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2062
     this method (or better: inspectorClass) can be redefined in subclasses 
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2063
     to start special inspectors."
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2064
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2065
    |cls|
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2066
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2067
    cls := self inspectorClass.
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2068
    cls isNil ifTrue:[
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2069
	^ self basicInspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2070
    ].
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2071
    cls openOn:self
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2072
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2073
    "
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2074
     Object new inspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2075
     (1 @ 2) inspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2076
     Smalltalk inspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2077
     #(1 2 3) asOrderedCollection inspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2078
     (Color red) inspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2079
     (Image fromFile:'bitmaps/garfield.gif') inspect
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2080
    "
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2081
!
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2082
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2083
inspectorClass
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2084
    "return the class to use for inspect. 
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2085
     Can (should) be redefined in classes for which a better inspector is available"
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2086
94f5c3a6230d *** empty log message ***
claus
parents: 272
diff changeset
  2087
    ^ Inspector
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2088
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2089
324
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2090
!Object methodsFor:'converting'!
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2091
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2092
asValue
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2093
    "return a valueHolder for for the receiver"
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2094
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2095
    ^ ValueHolder with:self
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2096
! !
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  2097
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2098
!Object methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2099
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2100
at:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2101
    "return the indexed instance variable with index, anInteger;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2102
     this method can be redefined in subclasses."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2103
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2104
    ^ self basicAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2105
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2106
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2107
basicAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2108
    "return the indexed instance variable with index, anInteger.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2109
     Trigger an error if the receiver has no indexed instance variables.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2110
     This method should NOT be redefined in any subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2111
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2112
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2113
329
claus
parents: 325
diff changeset
  2114
    REGISTER int nbytes, indx;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2115
    OBJ myClass;
329
claus
parents: 325
diff changeset
  2116
    REGISTER char *pFirst;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2117
    unsigned char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2118
    unsigned short *sp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2119
    long *lp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2120
    OBJ *op;
329
claus
parents: 325
diff changeset
  2121
/*    int nInstBytes, nInstVars, flags; */
claus
parents: 325
diff changeset
  2122
    REGISTER int n;
228
22bcd39b30bb makeLarge rename
claus
parents: 216
diff changeset
  2123
    extern OBJ _MKLARGEINT();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2124
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2125
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2126
    /*
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  2127
     * notice the missing test for self being a nonNilObject -
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2128
     * this can be done since basicAt: is defined both in UndefinedObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2129
     * and SmallInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2130
     */
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  2131
    if (__isSmallInteger(index)) {
329
claus
parents: 325
diff changeset
  2132
	myClass = __qClass(self);
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2133
	indx = _intVal(index) - 1;
329
claus
parents: 325
diff changeset
  2134
	n /* nInstVars */ = _intVal(_ClassInstPtr(myClass)->c_ninstvars);
claus
parents: 325
diff changeset
  2135
	n /* nInstBytes */ = OHDR_SIZE + __OBJS2BYTES__(n /* nInstVars */);
claus
parents: 325
diff changeset
  2136
	nbytes = __qSize(self) - n /* nInstBytes */;
claus
parents: 325
diff changeset
  2137
	pFirst = (char *)(_InstPtr(self)) + n /* nInstBytes */;
claus
parents: 325
diff changeset
  2138
claus
parents: 325
diff changeset
  2139
	/* 
claus
parents: 325
diff changeset
  2140
	 * replaced switch by open-coded if; this is slightly faster 
claus
parents: 325
diff changeset
  2141
	 * since it avoids the range check and also handles the most common case first
claus
parents: 325
diff changeset
  2142
	 */
claus
parents: 325
diff changeset
  2143
	n = _intVal(_ClassInstPtr(myClass)->c_flags) & ARRAYMASK;
claus
parents: 325
diff changeset
  2144
	if ((n == POINTERARRAY) || (n == WKPOINTERARRAY)) {
claus
parents: 325
diff changeset
  2145
	    if ((indx >= 0) && (indx < (__BYTES2OBJS__(nbytes)))) {
claus
parents: 325
diff changeset
  2146
		op = (OBJ *)pFirst + indx;
claus
parents: 325
diff changeset
  2147
		RETURN ( *op );
claus
parents: 325
diff changeset
  2148
	    }
claus
parents: 325
diff changeset
  2149
	} else if (n == BYTEARRAY) {
claus
parents: 325
diff changeset
  2150
	    if ((indx >= 0) && (indx < (nbytes / sizeof(char)))) {
claus
parents: 325
diff changeset
  2151
		cp = (unsigned char *)pFirst + indx;
claus
parents: 325
diff changeset
  2152
		RETURN ( _MKSMALLINT(*cp & 0xFF) );
claus
parents: 325
diff changeset
  2153
	    }
claus
parents: 325
diff changeset
  2154
	} else if (n == FLOATARRAY) {
claus
parents: 325
diff changeset
  2155
	    if ((indx >= 0) && (indx < (nbytes / sizeof(float)))) {
claus
parents: 325
diff changeset
  2156
		float *fp;
claus
parents: 325
diff changeset
  2157
claus
parents: 325
diff changeset
  2158
		fp = (float *)pFirst + indx;
claus
parents: 325
diff changeset
  2159
		RETURN ( _MKFLOAT((double)(*fp)) COMMA_CON );
claus
parents: 325
diff changeset
  2160
	    }
claus
parents: 325
diff changeset
  2161
	} else if (n == DOUBLEARRAY) {
claus
parents: 325
diff changeset
  2162
	    if ((indx >= 0) && (indx < (nbytes / sizeof(double)))) {
claus
parents: 325
diff changeset
  2163
		double *dp;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2164
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  2165
#ifdef NEED_DOUBLE_ALIGN
329
claus
parents: 325
diff changeset
  2166
		/*
claus
parents: 325
diff changeset
  2167
		 * care for filler
claus
parents: 325
diff changeset
  2168
		 */
claus
parents: 325
diff changeset
  2169
		pFirst += sizeof(FILLTYPE);
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  2170
#endif
329
claus
parents: 325
diff changeset
  2171
		dp = (double *)pFirst + indx;
claus
parents: 325
diff changeset
  2172
		RETURN ( _MKFLOAT(*dp) COMMA_CON );
claus
parents: 325
diff changeset
  2173
	    }
claus
parents: 325
diff changeset
  2174
	} else if (n == LONGARRAY) {
claus
parents: 325
diff changeset
  2175
	    if ((indx >= 0) && (indx < (nbytes / sizeof(long)))) {
claus
parents: 325
diff changeset
  2176
		lp = (long *)pFirst + indx;
claus
parents: 325
diff changeset
  2177
		if ((*lp >= _MIN_INT) && (*lp <= _MAX_INT))
claus
parents: 325
diff changeset
  2178
		    RETURN ( _MKSMALLINT(*lp) );
claus
parents: 325
diff changeset
  2179
		RETURN ( _MKLARGEINT(*lp) );
claus
parents: 325
diff changeset
  2180
	    }
claus
parents: 325
diff changeset
  2181
	} else if (n == WORDARRAY) {
claus
parents: 325
diff changeset
  2182
	    if ((indx >= 0) && (indx < (nbytes / sizeof(short)))) {
claus
parents: 325
diff changeset
  2183
		sp = (unsigned short *)pFirst + indx;
claus
parents: 325
diff changeset
  2184
		RETURN ( _MKSMALLINT(*sp & 0xFFFF) );
claus
parents: 325
diff changeset
  2185
	    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2186
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2187
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2188
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2189
.
10
claus
parents: 5
diff changeset
  2190
    index isInteger ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2191
	^ self indexNotInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2192
    ].
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2193
    ^ self subscriptBoundsError:index
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2194
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2195
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2196
at:index put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2197
    "store the 2nd arg, anObject as indexed instvar with index, anInteger.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2198
     this method can be redefined in subclasses."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2199
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2200
    ^ self basicAt:index put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2201
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2202
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2203
basicAt:index put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2204
    "store the 2nd arg, anObject as indexed instvar with index, anInteger.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2205
     Trigger an error if the receiver has no indexed instance variables.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2206
     This method should NOT be redefined in any subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2207
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2208
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2209
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2210
    register int nbytes, indx;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2211
    OBJ myClass;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2212
    register char *pFirst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2213
    char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2214
    short *sp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2215
    long *lp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2216
    OBJ *op;
329
claus
parents: 325
diff changeset
  2217
/*    int nInstBytes, ninstvars, flags; */
claus
parents: 325
diff changeset
  2218
    REGISTER int n;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2219
    int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2220
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  2221
    /* notice the missing test for self being a nonNilObject -
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  2222
       this can be done since basicAt: is defined both in UndefinedObject
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2223
       and SmallInteger */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2224
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  2225
    if (__isSmallInteger(index)) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2226
	indx = _intVal(index) - 1;
329
claus
parents: 325
diff changeset
  2227
	myClass = __qClass(self);
claus
parents: 325
diff changeset
  2228
	n /* ninstvars */ = _intVal(_ClassInstPtr(myClass)->c_ninstvars);
claus
parents: 325
diff changeset
  2229
	n /* nInstBytes */ = OHDR_SIZE + __OBJS2BYTES__(n /* ninstvars */);
claus
parents: 325
diff changeset
  2230
	nbytes = __qSize(self) - n /* nInstBytes */;
claus
parents: 325
diff changeset
  2231
	pFirst = (char *)(_InstPtr(self)) + n /* nInstBytes */;
claus
parents: 325
diff changeset
  2232
claus
parents: 325
diff changeset
  2233
	n = _intVal(_ClassInstPtr(myClass)->c_flags) & ARRAYMASK;
claus
parents: 325
diff changeset
  2234
	if ((n == POINTERARRAY) || (n == WKPOINTERARRAY)) {
claus
parents: 325
diff changeset
  2235
	    if ((indx >= 0) && (indx < (__BYTES2OBJS__(nbytes)))) {
claus
parents: 325
diff changeset
  2236
		op = (OBJ *)pFirst + indx;
claus
parents: 325
diff changeset
  2237
		*op = anObject;
claus
parents: 325
diff changeset
  2238
		__STORE(self, anObject);
claus
parents: 325
diff changeset
  2239
		RETURN ( anObject );
claus
parents: 325
diff changeset
  2240
	    }
claus
parents: 325
diff changeset
  2241
	} else if (n == BYTEARRAY) {
claus
parents: 325
diff changeset
  2242
	    if (__isSmallInteger(anObject)) {
claus
parents: 325
diff changeset
  2243
		val = _intVal(anObject);
claus
parents: 325
diff changeset
  2244
		if ((val & ~0xFF) == 0 /* i.e. (val >= 0) && (val <= 255) */) {
claus
parents: 325
diff changeset
  2245
		    if ((indx >= 0) && (indx < (nbytes / sizeof(char)))) {
claus
parents: 325
diff changeset
  2246
			cp = pFirst + indx;
claus
parents: 325
diff changeset
  2247
			*cp = val;
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2248
			RETURN ( anObject );
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2249
		    }
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2250
		}
329
claus
parents: 325
diff changeset
  2251
	    }
claus
parents: 325
diff changeset
  2252
	} else if (n == FLOATARRAY) {
claus
parents: 325
diff changeset
  2253
	    if ((indx >= 0) && (indx < (nbytes / sizeof(float)))) {
claus
parents: 325
diff changeset
  2254
		float *fp;
claus
parents: 325
diff changeset
  2255
claus
parents: 325
diff changeset
  2256
		fp = (float *)pFirst + indx;
claus
parents: 325
diff changeset
  2257
		if (__isFloatLike(anObject)) {
claus
parents: 325
diff changeset
  2258
		    *fp = _floatVal(anObject);
claus
parents: 325
diff changeset
  2259
		    RETURN ( anObject );
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2260
		}
329
claus
parents: 325
diff changeset
  2261
		if (__isSmallInteger(anObject)) {
claus
parents: 325
diff changeset
  2262
		    *fp = (float) _intVal(anObject);
claus
parents: 325
diff changeset
  2263
		    RETURN ( anObject );
claus
parents: 325
diff changeset
  2264
		}
claus
parents: 325
diff changeset
  2265
	    }
claus
parents: 325
diff changeset
  2266
	} else if (n == DOUBLEARRAY) {
claus
parents: 325
diff changeset
  2267
	    if ((indx >= 0) && (indx < (nbytes / sizeof(double)))) {
claus
parents: 325
diff changeset
  2268
		double *dp;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2269
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  2270
#ifdef NEED_DOUBLE_ALIGN
329
claus
parents: 325
diff changeset
  2271
		/*
claus
parents: 325
diff changeset
  2272
		 * care for filler
claus
parents: 325
diff changeset
  2273
		 */
claus
parents: 325
diff changeset
  2274
		pFirst += sizeof(FILLTYPE);
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  2275
#endif
329
claus
parents: 325
diff changeset
  2276
		dp = (double *)pFirst + indx;
claus
parents: 325
diff changeset
  2277
		if (__isFloatLike(anObject)) {
claus
parents: 325
diff changeset
  2278
		    *dp = _floatVal(anObject);
claus
parents: 325
diff changeset
  2279
		    RETURN ( anObject );
claus
parents: 325
diff changeset
  2280
		}
claus
parents: 325
diff changeset
  2281
		if (__isSmallInteger(anObject)) {
claus
parents: 325
diff changeset
  2282
		    *dp = (double) _intVal(anObject);
claus
parents: 325
diff changeset
  2283
		    RETURN ( anObject );
claus
parents: 325
diff changeset
  2284
		}
claus
parents: 325
diff changeset
  2285
	    }
claus
parents: 325
diff changeset
  2286
	} else if (n == LONGARRAY) {
claus
parents: 325
diff changeset
  2287
	    if (__isSmallInteger(anObject)) {
claus
parents: 325
diff changeset
  2288
		if ((indx >= 0) && (indx < (nbytes / sizeof(long)))) {
claus
parents: 325
diff changeset
  2289
		    lp = (long *)pFirst + indx;
claus
parents: 325
diff changeset
  2290
		    *lp = _intVal(anObject);
claus
parents: 325
diff changeset
  2291
		    RETURN ( anObject );
claus
parents: 325
diff changeset
  2292
		}
claus
parents: 325
diff changeset
  2293
	    }
claus
parents: 325
diff changeset
  2294
	    /* XXX
claus
parents: 325
diff changeset
  2295
	     * XXX must add possibility to put in a large number here
claus
parents: 325
diff changeset
  2296
	     * XXX
claus
parents: 325
diff changeset
  2297
	     */
claus
parents: 325
diff changeset
  2298
	} else if (n == WORDARRAY) {
claus
parents: 325
diff changeset
  2299
	    if (__isSmallInteger(anObject)) {
claus
parents: 325
diff changeset
  2300
		val = _intVal(anObject);
claus
parents: 325
diff changeset
  2301
		if ((val >= 0) && (val <= 0xFFFF)) {
claus
parents: 325
diff changeset
  2302
		    if ((indx >= 0) && (indx < (nbytes / sizeof(short)))) {
339
claus
parents: 332
diff changeset
  2303
			sp = (short *)pFirst + indx;
claus
parents: 332
diff changeset
  2304
			*sp = val;
claus
parents: 332
diff changeset
  2305
			RETURN ( anObject );
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2306
		    }
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2307
		}
329
claus
parents: 325
diff changeset
  2308
	    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2309
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2310
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2311
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2312
.
10
claus
parents: 5
diff changeset
  2313
    index isInteger ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2314
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2315
	 the index should be an integer number
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2316
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2317
	^ self indexNotInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2318
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2319
    (index between:1 and:self size) ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2320
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2321
	 the index is less than 1 or greater than the size of the
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  2322
	 receiver collection
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2323
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2324
	^ self subscriptBoundsError:index
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2325
    ].
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2326
    (self class isFloats) ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2327
	anObject isNumber ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2328
	    ^ self basicAt:index put:(anObject asFloat)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2329
	]
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2330
    ].
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2331
    (self class isDoubles) ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2332
	anObject isNumber ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2333
	    ^ self basicAt:index put:(anObject asFloat)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2334
	]
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2335
    ].
10
claus
parents: 5
diff changeset
  2336
    anObject isInteger ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2337
	"
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  2338
	 the object to put into the receiver collection
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2339
	 should be an integer number
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2340
	"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2341
	^ self elementNotInteger
2
claus
parents: 1
diff changeset
  2342
    ].
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2343
    "
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  2344
     the object to put into the receiver collection
362
claus
parents: 359
diff changeset
  2345
     is not an instance of the expected element class,
claus
parents: 359
diff changeset
  2346
     or the value is  not within the elements valid range.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2347
    "
2
claus
parents: 1
diff changeset
  2348
    ^ self elementBoundsError
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2349
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2350
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2351
instVarAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2352
    "return a non-indexed instance variable;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2353
     peeking into an object this way is not very object oriented 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2354
     - use with care (needed for copy, inspector etc.)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2355
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2356
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2357
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2358
    OBJ myClass;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2359
    int idx, ninstvars;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2360
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  2361
    if (__isSmallInteger(index)) {
329
claus
parents: 325
diff changeset
  2362
	myClass = __Class(self);
357
claus
parents: 356
diff changeset
  2363
	idx = _intVal(index) - 1;
claus
parents: 356
diff changeset
  2364
	/*
claus
parents: 356
diff changeset
  2365
	 * do not allow return of non-object fields.
claus
parents: 356
diff changeset
  2366
	 * if subclass did not make privisions for that,
claus
parents: 356
diff changeset
  2367
	 * we wont do so here ...
claus
parents: 356
diff changeset
  2368
	 */
claus
parents: 356
diff changeset
  2369
	if (((INT)(_ClassInstPtr(myClass)->c_flags) & _MASKSMALLINT(NONOBJECT_INSTS))) {
claus
parents: 356
diff changeset
  2370
	    if (idx == 0) {
claus
parents: 356
diff changeset
  2371
		RETURN ( nil )
claus
parents: 356
diff changeset
  2372
	    }
claus
parents: 356
diff changeset
  2373
	}
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2374
	ninstvars = _intVal(_ClassInstPtr(myClass)->c_ninstvars);
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2375
	if ((idx >= 0) && (idx < ninstvars)) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2376
	    RETURN ( _InstPtr(self)->i_instvars[idx] );
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2377
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2378
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2379
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2380
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2381
    index isInteger ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2382
	^ self indexNotInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2383
    ].
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2384
    ^ self subscriptBoundsError:index
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2385
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2386
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2387
instVarAt:index put:value
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2388
    "change a non-indexed instance variable;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2389
     peeking into an object this way is not very object oriented 
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2390
     - use with care (needed for copy, inspector etc.)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2391
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2392
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2393
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2394
    OBJ myClass;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2395
    int idx, ninstvars;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2396
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  2397
    if (__isSmallInteger(index)) {
329
claus
parents: 325
diff changeset
  2398
	myClass = __Class(self);
357
claus
parents: 356
diff changeset
  2399
	idx = _intVal(index) - 1;
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2400
	ninstvars = _intVal(_ClassInstPtr(myClass)->c_ninstvars);
357
claus
parents: 356
diff changeset
  2401
	/*
claus
parents: 356
diff changeset
  2402
	 * do not allow setting of non-object fields.
claus
parents: 356
diff changeset
  2403
	 * if subclass did not make privisions for that,
claus
parents: 356
diff changeset
  2404
	 * we wont do so here ...
claus
parents: 356
diff changeset
  2405
	 */
claus
parents: 356
diff changeset
  2406
	if (((INT)(_ClassInstPtr(myClass)->c_flags) & _MASKSMALLINT(NONOBJECT_INSTS))) {
claus
parents: 356
diff changeset
  2407
	    if (idx == 0) {
claus
parents: 356
diff changeset
  2408
		RETURN ( nil )
claus
parents: 356
diff changeset
  2409
	    }
claus
parents: 356
diff changeset
  2410
	}
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2411
	if ((idx >= 0) && (idx < ninstvars)) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2412
	    _InstPtr(self)->i_instvars[idx] = value;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2413
	    __STORE(self, value);
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2414
	    RETURN ( value );
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2415
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2416
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2417
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2418
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2419
    index isInteger ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2420
	^ self indexNotInteger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2421
    ].
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2422
    ^ self subscriptBoundsError:index
359
claus
parents: 357
diff changeset
  2423
!
claus
parents: 357
diff changeset
  2424
claus
parents: 357
diff changeset
  2425
instVarNamed:name 
claus
parents: 357
diff changeset
  2426
    "return a non-indexed instance variables value by name;
claus
parents: 357
diff changeset
  2427
     peeking into an object this way is not very object oriented 
claus
parents: 357
diff changeset
  2428
     - use with care (provided for inspectors)"
claus
parents: 357
diff changeset
  2429
claus
parents: 357
diff changeset
  2430
    ^ self instVarAt:(self class instVarOffsetOf:name)
claus
parents: 357
diff changeset
  2431
!
claus
parents: 357
diff changeset
  2432
claus
parents: 357
diff changeset
  2433
instVarNamed:name put:value
claus
parents: 357
diff changeset
  2434
    "set a non-indexed instance variable by name;
claus
parents: 357
diff changeset
  2435
     peeking into an object this way is not very object oriented 
claus
parents: 357
diff changeset
  2436
     - use with care (provided for inspectors)"
claus
parents: 357
diff changeset
  2437
claus
parents: 357
diff changeset
  2438
    ^ self instVarAt:(self class instVarOffsetOf:name) put:value
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2439
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2440
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2441
!Object methodsFor:'dependents access'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2442
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2443
dependents
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2444
    "return a Collection of dependents - nil if there is none.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2445
     The default implementation here uses a global Dictionary to store
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2446
     dependents which may be too slow for high frequency change&update.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2447
     Therefore, some classes (Model) redefine this for better performance."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2448
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2449
    ^ Dependencies at:self ifAbsent:[nil]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2450
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2451
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2452
dependents:aCollection
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2453
    "set the collection of dependents.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2454
     The default implementation here uses a global Dictionary to store
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2455
     dependents which may be too slow for high frequency change&update.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2456
     Therefore, some classes (Model) redefine this for better performance."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2457
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2458
    (aCollection isNil or:[aCollection isEmpty]) ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2459
	Dependencies removeKey:self ifAbsent:[]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2460
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2461
	Dependencies at:self put:aCollection
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2462
    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2463
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2464
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2465
dependentsDo:aBlock
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2466
    "evaluate aBlock for all of my dependents"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2467
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2468
    |deps|
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2469
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2470
    deps := self dependents.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2471
    deps notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2472
	deps do:aBlock 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2473
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2474
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2475
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2476
addDependent:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2477
    "make the argument, anObject be a dependent of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2478
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2479
    |deps|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2480
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2481
    deps := self dependents.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2482
    deps isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2483
	self dependents:(WeakIdentitySet with:anObject)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2484
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2485
	deps add:anObject
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2486
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2487
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2488
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2489
removeDependent:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2490
    "make the argument, anObject be independent of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2491
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2492
    |deps|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2493
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2494
    deps := self dependents.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2495
    deps notNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2496
	deps remove:anObject ifAbsent:[].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2497
	deps isEmpty ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2498
	    self dependents:nil
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2499
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2500
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2501
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2502
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2503
release
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2504
    "remove all dependencies from the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2505
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2506
    self dependents:nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2507
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2508
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2509
!Object methodsFor:'change and update'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2510
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2511
changeRequest
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2512
    "the receiver wants to change - check if all dependents
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2513
     grant the request, and return true if so"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2514
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2515
    self dependentsDo:[:dependent | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2516
	dependent updateRequest ifFalse:[^ false].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2517
    ].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2518
    ^ true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2519
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2520
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2521
changeRequest:aParameter
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2522
    "the receiver wants to change - check if all dependents
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2523
     grant the request, and return true if so"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2524
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2525
    self dependentsDo:[:dependent | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2526
	(dependent updateRequest:aParameter) ifFalse:[^ false].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2527
    ].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2528
    ^ true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2529
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2530
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2531
changeRequestFrom:anObject
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2532
    "the receiver wants to change - check if all dependents
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2533
     except anObject grant the request, and return true if so.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2534
     The argument anObject is typically going to be the one who is
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2535
     about to send the change request."
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2536
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2537
    self dependentsDo:[:dependent | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2538
	dependent == anObject ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2539
	    (dependent updateRequest) ifFalse:[^ false].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2540
	]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2541
    ].
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2542
    ^ true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2543
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2544
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2545
changeRequest:aParameter from:anObject
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2546
    "the receiver wants to change - check if all dependents
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2547
     except anObject grant the request, and return true if so.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2548
     The argument anObject is typically going to be the one who is
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2549
     about to send the change request."
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2550
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2551
    self dependentsDo:[:dependent | 
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2552
	dependent == anObject ifFalse:[
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2553
	    (dependent updateRequest:aParameter) ifFalse:[^ false].
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2554
	]
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2555
    ].
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2556
    ^ true
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2557
!
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2558
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2559
changed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2560
    "notify all dependents that the receiver has changed.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2561
     Each dependent gets a '#update:'-message with the original
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2562
     receiver as argument."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2563
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2564
    self changed:nil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2565
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2566
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2567
changed:aParameter
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2568
    "notify all dependents that the receiver has changed somehow.
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2569
     Each dependent gets a '#update:'-message with aParameter
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2570
     as argument."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2571
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2572
    self changed:aParameter with:nil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2573
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2574
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2575
changed:aParameter with:anArgument
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2576
    "notify all dependents that the receiver has changed somehow.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2577
     Each dependent gets a  '#update:with:from:'-message, with aParameter
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2578
     and anArgument as arguments."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2579
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2580
    self dependentsDo:[:dependent | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2581
	dependent update:aParameter with:anArgument from:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2582
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2583
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2584
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2585
broadcast:aSelectorSymbol
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2586
    "send a message with selector aSelectorSymbol to all my dependents"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2587
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2588
    self dependentsDo:[:dependent | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2589
	dependent perform:aSelectorSymbol
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2590
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2591
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2592
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2593
broadcast:aSelectorSymbol with:anArgument
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2594
    "send a message with selector aSelectorSymbol with an additional
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2595
     argument anArgument to all my dependents."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2596
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2597
    self dependentsDo:[:dependent | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2598
	dependent perform:aSelectorSymbol with:anArgument
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2599
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2600
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2601
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2602
update:aParameter
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2603
    "the message is sent to a dependent, when one of the objects
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2604
     on whom the receiver depends, has changed. The argument aParameter
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2605
     is either the changed object or the argument to the #changed: message.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2606
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2607
     Default behavior here is to do nothing"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2608
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2609
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2610
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2611
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2612
update:aParameter with:anArgument
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2613
    "dependent is notified of some change -
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2614
     Default is to try update:"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2615
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2616
    ^ self update:aParameter
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2617
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2618
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2619
update:aParameter with:anArgument from:sender
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2620
    "dependent is notified of some change -
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2621
     Default is to try update:with:"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2622
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2623
    ^ self update:aParameter with:anArgument
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2624
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2625
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2626
updateRequest
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2627
    "return true, if an update request is granted.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2628
     Default here is to grant updates - may be used
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2629
     to lock updates if someone is making other changes
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2630
     from within an update. Or if someone has locked its
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2631
     state and does not want others to change things.
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2632
     However, these dependents must all honor the
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2633
     changeRequest - ifTrue - change protocol. I.e. they
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2634
     must first ask all others via changeRequest, and only do the change
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2635
     it returns true. The others must decide in updateRequest and
40ca7cc6fb9c *** empty log message ***
claus
parents: 179
diff changeset
  2636
     return true if they think a change is ok."
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2637
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2638
    ^ true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2639
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2640
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2641
updateRequest:aSymbol
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2642
    "return true, if an update request is granted.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2643
     Default here a simple updateRequest"
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2644
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2645
    ^ self updateRequest
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2646
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2647
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2648
!Object methodsFor:'secure message sending'!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2649
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2650
askFor:aSelector
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2651
    "try to send the receiver the message, aSelector.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2652
     If it does not understand it, return false. Otherwise
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2653
     the real value returned.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2654
     Useful to send messages such as: 'isColor' to unknown
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2655
     receivers."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2656
143
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2657
    ^ self perform:aSelector ifNotUnderstood:[false]
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2658
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2659
    "
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2660
     1 askFor:#isColor
5ebe463ba109 got rid of globals;
claus
parents: 113
diff changeset
  2661
    "
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2662
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2663
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2664
perform:aSelector ifNotUnderstood:exceptionBlock
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2665
    "try to send message aSelector to the receiver.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2666
     If its understood, return the methods returned value,
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2667
     otherwise return the value of the exceptionBlock"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2668
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2669
    |val|
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2670
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2671
    MessageNotUnderstoodSignal handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2672
	^ exceptionBlock value
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2673
    ] do:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2674
	val := self perform:aSelector
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2675
    ].
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2676
    ^ val
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2677
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2678
    "
325
claus
parents: 324
diff changeset
  2679
     1.2345 perform:#foo ifNotUnderstood:['sorry'] 
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2680
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2681
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2682
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2683
perform:aSelector with:argument ifNotUnderstood:exceptionBlock
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2684
    "try to send message aSelector to the receiver.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2685
     If its understood, return the methods returned value,
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2686
     otherwise return the value of the exceptionBlock"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2687
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2688
    |val|
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2689
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2690
    MessageNotUnderstoodSignal handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2691
	^ exceptionBlock value
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2692
    ] do:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2693
	val := self perform:aSelector with:argument
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2694
    ].
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2695
    ^ val
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2696
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2697
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2698
     |unknown|
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2699
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2700
     unknown := 1.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2701
     (unknown perform:#+ with:2 ifNotUnderstood:['sorry']) printNewline.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2702
     unknown := 'high there'.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2703
     (unknown perform:#+ with:2 ifNotUnderstood:['sorry']) printNewline.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2704
    "
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2705
! !
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2706
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2707
!Object methodsFor:'message sending'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2708
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2709
perform:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2710
    "send the message aSelector to the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2711
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2712
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2713
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
  2714
#if !defined(hppa) && !defined(mips)
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2715
#define PRE_2_11
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  2716
#endif
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  2717
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2718
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2719
    static struct inlineCache ilc = _ILC0;
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2720
    struct inlineCache lilc = _DUMMYILC0;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2721
#else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2722
    static struct inlineCache ilc = _DUMMYILC0;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2723
    struct inlineCache lilc;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2724
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2725
    static OBJ lastSelector = nil;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2726
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2727
#if defined(THIS_CONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2728
    /*
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2729
     * must set lineno in sender by hand here ... (because of NOCONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2730
     */
329
claus
parents: 325
diff changeset
  2731
    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2732
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2733
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2734
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2735
    if (aSelector != lastSelector) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2736
	ilc.ilc_func = _SEND0;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2737
	lastSelector = aSelector;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2738
    }
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2739
#else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2740
    lilc = ilc;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2741
#endif
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2742
329
claus
parents: 325
diff changeset
  2743
#if !defined(TRADITIONAL_STACK_FRAME)
claus
parents: 325
diff changeset
  2744
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
claus
parents: 325
diff changeset
  2745
#endif
claus
parents: 325
diff changeset
  2746
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2747
#if defined(xxTHIS_CONTEXT)
85
claus
parents: 77
diff changeset
  2748
# ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2749
    ilc.ilc_lineNo = __pilc->ilc_lineNo;
85
claus
parents: 77
diff changeset
  2750
# else
claus
parents: 77
diff changeset
  2751
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
claus
parents: 77
diff changeset
  2752
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2753
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2754
85
claus
parents: 77
diff changeset
  2755
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2756
    RETURN ( (*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &ilc) );
85
claus
parents: 77
diff changeset
  2757
#else
claus
parents: 77
diff changeset
  2758
    RETURN ( (*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &lilc) );
claus
parents: 77
diff changeset
  2759
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2760
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2761
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2762
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2763
perform:aSelector with:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2764
    "send the one-arg-message aSelector to the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2765
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2766
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2767
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2768
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2769
    static struct inlineCache ilc = _ILC1;
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2770
    struct inlineCache lilc = _DUMMYILC1;
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2771
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2772
    static OBJ lastSelector = nil;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2773
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2774
# if defined(THIS_CONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2775
    /*
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2776
     * must set lineno in sender by hand here ... (because of NOCONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2777
     */
329
claus
parents: 325
diff changeset
  2778
    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2779
# endif
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2780
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2781
    if (aSelector != lastSelector) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2782
	ilc.ilc_func = _SEND1;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2783
	lastSelector = aSelector;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2784
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2785
    ilc.ilc_lineNo = __pilc->ilc_lineNo;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2786
    RETURN ( (*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &ilc, anObject) );
85
claus
parents: 77
diff changeset
  2787
#else
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2788
    static struct inlineCache ilc = _DUMMYILC1;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2789
    struct inlineCache lilc;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2790
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2791
# if defined(THIS_CONTEXT)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2792
    /*
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2793
     * must set lineno in sender by hand here ... (because of NOCONTEXT)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2794
     */
329
claus
parents: 325
diff changeset
  2795
    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2796
# endif
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2797
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2798
    lilc = ilc;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2799
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
85
claus
parents: 77
diff changeset
  2800
    RETURN ( (*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &lilc, anObject) );
claus
parents: 77
diff changeset
  2801
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2802
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2803
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2804
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2805
perform:aSelector with:firstObject with:secondObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2806
    "send the two-arg-message aSelector to the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2807
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2808
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2809
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2810
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2811
    static struct inlineCache ilc = _ILC2;
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2812
    struct inlineCache lilc = _DUMMYILC2;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2813
#else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2814
    static struct inlineCache ilc = _DUMMYILC2;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2815
    struct inlineCache lilc;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2816
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2817
    static OBJ lastSelector = nil;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2818
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2819
#if defined(THIS_CONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2820
    /*
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2821
     * must set lineno in sender by hand here ... (because of NOCONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2822
     */
329
claus
parents: 325
diff changeset
  2823
   _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2824
#endif
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2825
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2826
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2827
    if (aSelector != lastSelector) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2828
	ilc.ilc_func = _SEND2;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2829
	lastSelector = aSelector;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2830
    }
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2831
#else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2832
    lilc = ilc;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2833
#endif
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2834
329
claus
parents: 325
diff changeset
  2835
#if !defined(TRADITIONAL_STACK_FRAME)
claus
parents: 325
diff changeset
  2836
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
claus
parents: 325
diff changeset
  2837
#endif
claus
parents: 325
diff changeset
  2838
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2839
#if defined(xxTHIS_CONTEXT)
85
claus
parents: 77
diff changeset
  2840
# ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2841
    ilc.ilc_lineNo = __pilc->ilc_lineNo;
85
claus
parents: 77
diff changeset
  2842
# else
claus
parents: 77
diff changeset
  2843
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
claus
parents: 77
diff changeset
  2844
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2845
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2846
85
claus
parents: 77
diff changeset
  2847
# ifdef PRE_2_11
claus
parents: 77
diff changeset
  2848
    RETURN ((*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &ilc, firstObject, secondObject));
claus
parents: 77
diff changeset
  2849
# else
claus
parents: 77
diff changeset
  2850
    RETURN ((*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &lilc, firstObject, secondObject));
claus
parents: 77
diff changeset
  2851
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2852
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2853
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2854
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2855
perform:aSelector with:firstObject with:secondObject with:thirdObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2856
    "send the three-arg-message aSelector to the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2857
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2858
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2859
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2860
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2861
    static struct inlineCache ilc = _ILC3;
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2862
    struct inlineCache lilc = _DUMMYILC3;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2863
#else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2864
    static struct inlineCache ilc = _DUMMYILC3;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2865
    struct inlineCache lilc;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2866
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2867
    static OBJ lastSelector = nil;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2868
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2869
#if defined(THIS_CONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2870
    /*
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2871
     * must set lineno in sender by hand here ... (because of NOCONTEXT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2872
     */
329
claus
parents: 325
diff changeset
  2873
    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2874
#endif
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2875
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2876
#ifdef PRE_2_11
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2877
    if (aSelector != lastSelector) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2878
	ilc.ilc_func = _SEND3;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2879
	lastSelector = aSelector;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2880
    }
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2881
#else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2882
    lilc = ilc;
329
claus
parents: 325
diff changeset
  2883
# if !defined(TRADITIONAL_STACK_FRAME)
claus
parents: 325
diff changeset
  2884
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
claus
parents: 325
diff changeset
  2885
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2886
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2887
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2888
#if defined(xxTHIS_CONTEXT)
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2889
# ifdef PRE_2_11
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2890
    ilc.ilc_lineNo = __pilc->ilc_lineNo;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2891
# else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2892
    lilc.ilc_lineNo = __pilc->ilc_lineNo;
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2893
# endif
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2894
#endif
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2895
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2896
# ifdef PRE_2_11
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2897
    RETURN ((*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &ilc, firstObject, secondObject, thirdObject));
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2898
# else
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2899
    RETURN ((*ilc.ilc_func)(self, aSelector, CON_COMMA nil, &lilc, firstObject, secondObject, thirdObject));
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2900
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2901
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2902
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2903
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2904
perform:aSelector withArguments:argArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2905
    "send the message aSelector with all args taken from argArray 
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  2906
     to the receiver."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2907
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  2908
    |numberOfArgs a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 a14 a15|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2909
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2910
    numberOfArgs := argArray size.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2911
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2912
    extern OBJ Array;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2913
    REGISTER OBJ *argP;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2914
    int nargs, i;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2915
    static OBJ last0 = nil; static struct inlineCache ilc0 = _ILC0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2916
    static OBJ last1 = nil; static struct inlineCache ilc1 = _ILC1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2917
    static OBJ last2 = nil; static struct inlineCache ilc2 = _ILC2;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2918
    static OBJ last3 = nil; static struct inlineCache ilc3 = _ILC3;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2919
    static OBJ last4 = nil; static struct inlineCache ilc4 = _ILC4;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2920
    static OBJ last5 = nil; static struct inlineCache ilc5 = _ILC5;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2921
    static OBJ last6 = nil; static struct inlineCache ilc6 = _ILC6;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2922
    static OBJ last7 = nil; static struct inlineCache ilc7 = _ILC7;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2923
    static OBJ last8 = nil; static struct inlineCache ilc8 = _ILC8;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2924
    static OBJ last9 = nil; static struct inlineCache ilc9 = _ILC9;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2925
    static OBJ last10 = nil; static struct inlineCache ilc10 = _ILC10;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2926
    static OBJ last11 = nil; static struct inlineCache ilc11 = _ILC11;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2927
    static OBJ last12 = nil; static struct inlineCache ilc12 = _ILC12;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2928
    static OBJ last13 = nil; static struct inlineCache ilc13 = _ILC13;
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2929
    static OBJ last14 = nil; static struct inlineCache ilc14 = _ILC14;
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2930
    static OBJ last15 = nil; static struct inlineCache ilc15 = _ILC15;
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2931
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2932
#if defined(xxxTHIS_CONTEXT)
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2933
    /*
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2934
     * must set lineno in sender by hand here ... (because of NOCONTEXT)
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2935
     */
329
claus
parents: 325
diff changeset
  2936
    _ContextInstPtr(__sender)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2937
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2938
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  2939
    if (__isSmallInteger(numberOfArgs)) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2940
	nargs = _intVal(numberOfArgs);
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2941
	if (nargs == 0) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2942
	    if (aSelector != last0) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2943
		ilc0.ilc_func = _SEND0;
332
claus
parents: 329
diff changeset
  2944
		if (ilc0.ilc_poly) {
339
claus
parents: 332
diff changeset
  2945
		    __flushPolyCache(ilc0.ilc_poly);
claus
parents: 332
diff changeset
  2946
		    ilc0.ilc_poly = 0;
claus
parents: 332
diff changeset
  2947
		}
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2948
		last0 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2949
	    }
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2950
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2951
	    ilc0.ilc_lineNo = __pilc->ilc_lineNo;
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  2952
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2953
	    RETURN ((*ilc0.ilc_func)(self, aSelector, CON_COMMA nil, &ilc0));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2954
	}
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2955
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2956
	if (__isArray(argArray)) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2957
	    argP = _ArrayInstPtr(argArray)->a_element;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2958
	} else {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2959
	    argP = (OBJ *)(&a1);
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2960
	    for (i=1; i <= nargs; i++) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2961
		*argP++ = _AT_(argArray, CON_COMMA _MKSMALLINT(i));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2962
	    }
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2963
	}
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2964
	switch (nargs) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2965
	    case 1: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2966
		if (aSelector != last1) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2967
		    ilc1.ilc_func = _SEND1;
332
claus
parents: 329
diff changeset
  2968
		    if (ilc1.ilc_poly) {
339
claus
parents: 332
diff changeset
  2969
			__flushPolyCache(ilc1.ilc_poly);
claus
parents: 332
diff changeset
  2970
			ilc1.ilc_poly = 0;
claus
parents: 332
diff changeset
  2971
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2972
		    last1 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2973
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2974
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2975
		ilc1.ilc_lineNo = __pilc->ilc_lineNo;
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  2976
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2977
		RETURN ( (*ilc1.ilc_func)(self, aSelector, CON_COMMA nil, &ilc1, argP[0]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2978
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2979
	    case 2: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2980
		if (aSelector != last2) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2981
		    ilc2.ilc_func = _SEND2;
332
claus
parents: 329
diff changeset
  2982
		    if (ilc2.ilc_poly) {
339
claus
parents: 332
diff changeset
  2983
			__flushPolyCache(ilc2.ilc_poly);
claus
parents: 332
diff changeset
  2984
			ilc2.ilc_poly = 0;
claus
parents: 332
diff changeset
  2985
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2986
		    last2 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2987
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  2988
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2989
		ilc2.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  2990
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2991
		RETURN ( (*ilc2.ilc_func)(self, aSelector, CON_COMMA nil, &ilc2, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2992
						argP[0], argP[1]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2993
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2994
	    case 3: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2995
		if (aSelector != last3) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  2996
		    ilc3.ilc_func = _SEND3;
332
claus
parents: 329
diff changeset
  2997
		    if (ilc3.ilc_poly) {
339
claus
parents: 332
diff changeset
  2998
			__flushPolyCache(ilc3.ilc_poly);
claus
parents: 332
diff changeset
  2999
			ilc3.ilc_poly = 0;
claus
parents: 332
diff changeset
  3000
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3001
		    last3 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3002
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3003
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3004
		ilc3.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3005
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3006
		RETURN ( (*ilc3.ilc_func)(self, aSelector, CON_COMMA nil, &ilc3, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3007
						argP[0], argP[1], argP[2]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3008
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3009
	    case 4: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3010
		if (aSelector != last4) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3011
		    ilc4.ilc_func = _SEND4;
332
claus
parents: 329
diff changeset
  3012
		    if (ilc4.ilc_poly) {
339
claus
parents: 332
diff changeset
  3013
			__flushPolyCache(ilc4.ilc_poly);
claus
parents: 332
diff changeset
  3014
			ilc4.ilc_poly = 0;
claus
parents: 332
diff changeset
  3015
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3016
		    last4 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3017
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3018
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3019
		ilc4.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3020
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3021
		RETURN ( (*ilc4.ilc_func)(self, aSelector, CON_COMMA nil, &ilc4,
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3022
						argP[0], argP[1], argP[2], argP[3]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3023
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3024
	    case 5: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3025
		if (aSelector != last5) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3026
		    ilc5.ilc_func = _SEND5;
332
claus
parents: 329
diff changeset
  3027
		    if (ilc5.ilc_poly) {
339
claus
parents: 332
diff changeset
  3028
			__flushPolyCache(ilc5.ilc_poly);
claus
parents: 332
diff changeset
  3029
			ilc5.ilc_poly = 0;
claus
parents: 332
diff changeset
  3030
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3031
		    last5 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3032
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3033
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3034
		ilc5.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3035
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3036
		RETURN ( (*ilc5.ilc_func)(self, aSelector, CON_COMMA nil, &ilc5, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3037
						argP[0], argP[1], argP[2], argP[3], argP[4]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3038
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3039
	    case 6: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3040
		if (aSelector != last6) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3041
		    ilc6.ilc_func = _SEND6;
332
claus
parents: 329
diff changeset
  3042
		    if (ilc6.ilc_poly) {
339
claus
parents: 332
diff changeset
  3043
			__flushPolyCache(ilc6.ilc_poly);
claus
parents: 332
diff changeset
  3044
			ilc6.ilc_poly = 0;
claus
parents: 332
diff changeset
  3045
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3046
		    last6 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3047
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3048
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3049
		ilc6.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3050
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3051
		RETURN ( (*ilc6.ilc_func)(self, aSelector, CON_COMMA nil, &ilc6, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3052
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3053
						argP[5]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3054
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3055
	    case 7: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3056
		if (aSelector != last7) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3057
		    ilc7.ilc_func = _SEND7;
332
claus
parents: 329
diff changeset
  3058
		    if (ilc7.ilc_poly) {
339
claus
parents: 332
diff changeset
  3059
			__flushPolyCache(ilc7.ilc_poly);
claus
parents: 332
diff changeset
  3060
			ilc7.ilc_poly = 0;
claus
parents: 332
diff changeset
  3061
		    }
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3062
		    last7 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3063
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3064
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3065
		ilc7.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3066
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3067
		RETURN ( (*ilc7.ilc_func)(self, aSelector, CON_COMMA nil, &ilc7, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3068
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3069
						argP[5], argP[6]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3070
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3071
	    case 8:
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3072
		if (aSelector != last8) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3073
		    ilc8.ilc_func = _SEND8;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3074
		    last8 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3075
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3076
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3077
		ilc8.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3078
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3079
		RETURN ( (*ilc8.ilc_func)(self, aSelector, CON_COMMA nil, &ilc8, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3080
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3081
						argP[5], argP[6], argP[7]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3082
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3083
	    case 9: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3084
		if (aSelector != last9) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3085
		    ilc9.ilc_func = _SEND9;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3086
		    last9 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3087
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3088
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3089
		ilc9.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3090
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3091
		RETURN ( (*ilc9.ilc_func)(self, aSelector, CON_COMMA nil, &ilc9, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3092
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3093
						argP[5], argP[6], argP[7], argP[8]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3094
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3095
	    case 10: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3096
		if (aSelector != last10) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3097
		    ilc10.ilc_func = _SEND10;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3098
		    last10 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3099
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3100
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3101
		ilc10.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3102
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3103
		RETURN ( (*ilc10.ilc_func)(self, aSelector, CON_COMMA nil, &ilc10, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3104
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3105
						argP[5], argP[6], argP[7], argP[8], argP[9]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3106
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3107
	    case 11: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3108
		if (aSelector != last11) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3109
		    ilc11.ilc_func = _SEND11;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3110
		    last11 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3111
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3112
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3113
		ilc11.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3114
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3115
		RETURN ( (*ilc11.ilc_func)(self, aSelector, CON_COMMA nil, &ilc11, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3116
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3117
						argP[5], argP[6], argP[7], argP[8], argP[9],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3118
						argP[10]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3119
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3120
	    case 12: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3121
		if (aSelector != last12) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3122
		    ilc12.ilc_func = _SEND12;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3123
		    last12 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3124
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3125
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3126
		ilc12.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3127
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3128
		RETURN ( (*ilc12.ilc_func)(self, aSelector, CON_COMMA nil, &ilc12, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3129
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3130
						argP[5], argP[6], argP[7], argP[8], argP[9],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3131
						argP[10], argP[11]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3132
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3133
	    case 13: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3134
		if (aSelector != last13) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3135
		    ilc13.ilc_func = _SEND13;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3136
		    last13 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3137
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3138
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3139
		ilc13.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3140
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3141
		RETURN ( (*ilc13.ilc_func)(self, aSelector, CON_COMMA nil, &ilc13, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3142
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3143
						argP[5], argP[6], argP[7], argP[8], argP[9],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3144
						argP[10], argP[11], argP[12]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3145
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3146
	    case 14: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3147
		if (aSelector != last14) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3148
		    ilc14.ilc_func = _SEND14;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3149
		    last14 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3150
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3151
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3152
		ilc14.ilc_lineNo = __pilc->ilc_lineNo;
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3153
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3154
		RETURN ( (*ilc14.ilc_func)(self, aSelector, CON_COMMA nil, &ilc14, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3155
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3156
						argP[5], argP[6], argP[7], argP[8], argP[9],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3157
						argP[10], argP[11], argP[12], argP[13]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3158
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3159
	    case 15: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3160
		if (aSelector != last15) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3161
		    ilc15.ilc_func = _SEND15;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3162
		    last15 = aSelector;
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3163
		}
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3164
#ifdef xxTHIS_CONTEXT
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3165
		ilc15.ilc_lineNo = __pilc->ilc_lineNo;
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  3166
#endif
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3167
		RETURN ( (*ilc15.ilc_func)(self, aSelector, CON_COMMA nil, &ilc15, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3168
						argP[0], argP[1], argP[2], argP[3], argP[4],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3169
						argP[5], argP[6], argP[7], argP[8], argP[9],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3170
						argP[10], argP[11], argP[12], argP[13],
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3171
						argP[14]));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3172
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3173
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3174
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3175
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3176
    ^ self primitiveFailed
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3177
!
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3178
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3179
perform:aSelector inClass:aClass withArguments:argArray
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3180
    "send the message aSelector with all args taken from argArray 
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3181
     to the receiver as a super-send message.
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3182
     This is actually more flexible than the normal super-send, since it allows
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3183
     to execute a method in ANY superclass of the receiver (not just the
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3184
     immediate superclass).
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3185
     Thus, it is (theoretically) possible to do 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3186
	 '5 perform:#< inClass:Magnitude withArguments:#(6)'
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3187
     and evaluate Magnitudes compare method even if there was one in Number.
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3188
     This method is used by the interpreter to evaluate super sends
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3189
     and could be used for very special behavior (language extension ?).
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3190
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3191
     WARNING: this is an ST/X feature - probably not found in other smalltalks."
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3192
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  3193
    |numberOfArgs a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 a14 a15|
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3194
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3195
    "
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3196
     check, if aClass is really a superclass of the receiver
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
  3197
    "
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3198
    (self class isSubclassOf:aClass) ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3199
	self error:'class argument is not a superclass of the receiver'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3200
	^ nil
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3201
    ].
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3202
    numberOfArgs := argArray size.
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3203
%{
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3204
    extern OBJ Array;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3205
    REGISTER OBJ *argP;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3206
    int nargs, i;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3207
    static struct inlineCache ilc0 = _DUMMYILC0;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3208
    static struct inlineCache ilc1 = _DUMMYILC1;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3209
    static struct inlineCache ilc2 = _DUMMYILC2;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3210
    static struct inlineCache ilc3 = _DUMMYILC3;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3211
    static struct inlineCache ilc4 = _DUMMYILC4;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3212
    static struct inlineCache ilc5 = _DUMMYILC5;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3213
    static struct inlineCache ilc6 = _DUMMYILC6;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3214
    static struct inlineCache ilc7 = _DUMMYILC7;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3215
    static struct inlineCache ilc8 = _DUMMYILC8;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3216
    static struct inlineCache ilc9 = _DUMMYILC9;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3217
    static struct inlineCache ilc10 = _DUMMYILC10;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3218
    static struct inlineCache ilc11 = _DUMMYILC11;
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3219
    static struct inlineCache ilc12 = _DUMMYILC12;
77
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  3220
    static struct inlineCache ilc13 = _DUMMYILC13;
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  3221
    static struct inlineCache ilc14 = _DUMMYILC14;
6c38ca59927f *** empty log message ***
claus
parents: 71
diff changeset
  3222
    static struct inlineCache ilc15 = _DUMMYILC15;
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3223
253
30daee717a53 *** empty log message ***
claus
parents: 228
diff changeset
  3224
    if (__isSmallInteger(numberOfArgs)) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3225
	nargs = _intVal(numberOfArgs);
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3226
	if (nargs == 0) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3227
	    RETURN (_SEND0(self, aSelector, CON_COMMA aClass, &ilc0));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3228
	}
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3229
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3230
	argP = (OBJ *)(&a1);
329
claus
parents: 325
diff changeset
  3231
	if (__Class(argArray) == Array) {
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3232
	    for (i=0; i < nargs; i++) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3233
		*argP++ = _ArrayInstPtr(argArray)->a_element[i];
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3234
	    }
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3235
	} else {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3236
	    for (i=1; i <= nargs; i++) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3237
		*argP++ = _AT_(argArray, CON_COMMA _MKSMALLINT(i));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3238
	    }
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3239
	}
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3240
	switch (nargs) {
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3241
	    case 1: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3242
		RETURN ( _SEND1(self, aSelector, CON_COMMA aClass, &ilc1, a1));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3243
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3244
	    case 2: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3245
		RETURN ( _SEND2(self, aSelector, CON_COMMA aClass, &ilc2, a1, a2));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3246
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3247
	    case 3: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3248
		RETURN ( _SEND3(self, aSelector, CON_COMMA aClass, &ilc3, a1, a2, a3));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3249
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3250
	    case 4: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3251
		RETURN ( _SEND4(self, aSelector, CON_COMMA aClass, &ilc4, a1, a2, a3, a4));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3252
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3253
	    case 5: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3254
		RETURN ( _SEND5(self, aSelector, CON_COMMA aClass, &ilc5, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3255
				a1, a2, a3, a4, a5));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3256
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3257
	    case 6: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3258
		RETURN ( _SEND6(self, aSelector, CON_COMMA aClass, &ilc6, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3259
				a1, a2, a3, a4, a5, a6));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3260
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3261
	    case 7: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3262
		RETURN ( _SEND7(self, aSelector, CON_COMMA aClass, &ilc7, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3263
				a1, a2, a3, a4, a5, a6, a7));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3264
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3265
	    case 8: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3266
		RETURN ( _SEND8(self, aSelector, CON_COMMA aClass, &ilc8, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3267
				a1, a2, a3, a4, a5, a6, a7, a8));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3268
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3269
	    case 9: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3270
		RETURN ( _SEND9(self, aSelector, CON_COMMA aClass, &ilc9, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3271
				a1, a2, a3, a4, a5, a6, a7, a8, a9));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3272
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3273
	    case 10: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3274
		RETURN ( _SEND10(self, aSelector, CON_COMMA aClass, &ilc10, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3275
				 a1, a2, a3, a4, a5, a6, a7, a8, a9, a10));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3276
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3277
	    case 11: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3278
		RETURN ( _SEND11(self, aSelector, CON_COMMA aClass, &ilc11, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3279
				 a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3280
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3281
	    case 12: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3282
		RETURN ( _SEND12(self, aSelector, CON_COMMA aClass, &ilc12, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3283
				 a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3284
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3285
	    case 13: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3286
		RETURN ( _SEND13(self, aSelector, CON_COMMA aClass, &ilc13, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3287
				 a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3288
				 a13));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3289
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3290
	    case 14: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3291
		RETURN ( _SEND14(self, aSelector, CON_COMMA aClass, &ilc14, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3292
				 a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3293
				 a13, a14));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3294
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3295
	    case 15: 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3296
		RETURN ( _SEND15(self, aSelector, CON_COMMA aClass, &ilc15, 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3297
				 a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12,
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3298
				 a13, a14, a15));
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3299
	}
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3300
    }
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3301
%}
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3302
.
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3303
    ^ self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3304
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3305
2
claus
parents: 1
diff changeset
  3306
!Object methodsFor:'binary storage'!
claus
parents: 1
diff changeset
  3307
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3308
storeBinaryOn:aStream
2
claus
parents: 1
diff changeset
  3309
    "Writes a description of the receiver onto aStream, in a way that allows
claus
parents: 1
diff changeset
  3310
     the object's structure to be reconstructed from the stream's contents"
claus
parents: 1
diff changeset
  3311
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3312
    BinaryOutputManager store:self on:aStream
2
claus
parents: 1
diff changeset
  3313
!
claus
parents: 1
diff changeset
  3314
claus
parents: 1
diff changeset
  3315
hasSpecialBinaryRepresentation
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3316
    "return true, if the receiver has a special binary representation;
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3317
     default here is false, but can be redefined in class which provide
343
claus
parents: 342
diff changeset
  3318
     their own storeBinary/readBinary methods.
claus
parents: 342
diff changeset
  3319
claus
parents: 342
diff changeset
  3320
     Normal user classes should not use this, it is meant as a hook for
claus
parents: 342
diff changeset
  3321
     special classes such as True, False, UndefinedObject or SmallInteger.
claus
parents: 342
diff changeset
  3322
claus
parents: 342
diff changeset
  3323
     If your instances should be stored in a special way, see
claus
parents: 342
diff changeset
  3324
     #representBinaryOn: and #readBinaryContentsFromdata:manager:."
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3325
2
claus
parents: 1
diff changeset
  3326
    ^ false
claus
parents: 1
diff changeset
  3327
!
claus
parents: 1
diff changeset
  3328
343
claus
parents: 342
diff changeset
  3329
representBinaryOn:manager
claus
parents: 342
diff changeset
  3330
    "this method is called by the storage manager to ask objects
claus
parents: 342
diff changeset
  3331
     if they wish to provide their own binary representation.
claus
parents: 342
diff changeset
  3332
claus
parents: 342
diff changeset
  3333
     If they want to do so, they should return an array containing all
claus
parents: 342
diff changeset
  3334
     instance variables (named & indexed pointer) to be stored. 
claus
parents: 342
diff changeset
  3335
     If not redefined, this method returns nil which means that all 
claus
parents: 342
diff changeset
  3336
     instance variables are to be stored.
claus
parents: 342
diff changeset
  3337
362
claus
parents: 359
diff changeset
  3338
     It should be redefined in objects which do not want all instance variables
343
claus
parents: 342
diff changeset
  3339
     to be stored (for example: objects which keep references to a view etc.).
claus
parents: 342
diff changeset
  3340
claus
parents: 342
diff changeset
  3341
     If this is redefined returning non-nil, the corresponding class needs
claus
parents: 342
diff changeset
  3342
     a redefined instance method named #readBinaryContentsFromData:manager:
claus
parents: 342
diff changeset
  3343
     which has to fill the receivers named (and optionally indexed pointer)
claus
parents: 342
diff changeset
  3344
     instance variables with corresponding values from a data array."
claus
parents: 342
diff changeset
  3345
claus
parents: 342
diff changeset
  3346
    ^ nil
claus
parents: 342
diff changeset
  3347
362
claus
parents: 359
diff changeset
  3348
    "typical implementation:  
claus
parents: 359
diff changeset
  3349
     (see also comment in #readBinaryContentsFromData:manager:)
claus
parents: 359
diff changeset
  3350
     for an object with foo, bar and baz as instance variables,
claus
parents: 359
diff changeset
  3351
     which does not want to store baz:
claus
parents: 359
diff changeset
  3352
claus
parents: 359
diff changeset
  3353
     representBinaryOn:manager
343
claus
parents: 342
diff changeset
  3354
	|data|
claus
parents: 342
diff changeset
  3355
claus
parents: 342
diff changeset
  3356
	data := Array new:2.
claus
parents: 342
diff changeset
  3357
	data at:1 put:foo.
claus
parents: 342
diff changeset
  3358
	data at:2 put:bar.
362
claus
parents: 359
diff changeset
  3359
	^ data
343
claus
parents: 342
diff changeset
  3360
    "
claus
parents: 342
diff changeset
  3361
!
claus
parents: 342
diff changeset
  3362
claus
parents: 342
diff changeset
  3363
readBinaryContentsFromData:instvarArray manager:manager
claus
parents: 342
diff changeset
  3364
    "reconstruct the receivers instance variables by filling instance
claus
parents: 342
diff changeset
  3365
     variables with values from instvarArray. This array contains the instvars
claus
parents: 342
diff changeset
  3366
     as specified in #representBinaryOn: when the object was stored.
claus
parents: 342
diff changeset
  3367
     It is the receivers responsibility to set its instance variables in the
claus
parents: 342
diff changeset
  3368
     same order from that array."
claus
parents: 342
diff changeset
  3369
claus
parents: 342
diff changeset
  3370
    ^ self subclassResponsibility
claus
parents: 342
diff changeset
  3371
claus
parents: 342
diff changeset
  3372
    "typical implementation (see also comment in #representBinaryOn:)
claus
parents: 342
diff changeset
  3373
     (for an object with foo, bar and baz as instance variables,
claus
parents: 342
diff changeset
  3374
      which did not store baz and wants baz to be reinitialized to
claus
parents: 342
diff changeset
  3375
      some constant string)
claus
parents: 342
diff changeset
  3376
claus
parents: 342
diff changeset
  3377
	foo := instvarArray at:1.
claus
parents: 342
diff changeset
  3378
	bar := instvarArray at:2.
claus
parents: 342
diff changeset
  3379
	baz := 'aConstant'.
claus
parents: 342
diff changeset
  3380
    "
claus
parents: 342
diff changeset
  3381
!
claus
parents: 342
diff changeset
  3382
claus
parents: 342
diff changeset
  3383
storeBinaryContentsFromData:instvarArray on:stream manager:manager
claus
parents: 342
diff changeset
  3384
    "store the instvars (both named & indexed pointer)
claus
parents: 342
diff changeset
  3385
     as returned by #representBinaryOn:."
claus
parents: 342
diff changeset
  3386
claus
parents: 342
diff changeset
  3387
    |size "{ Class: SmallInteger }"|
claus
parents: 342
diff changeset
  3388
claus
parents: 342
diff changeset
  3389
    size := instvarArray size.
claus
parents: 342
diff changeset
  3390
    1 to:size do:[:i |
claus
parents: 342
diff changeset
  3391
	manager putIdOf:(instvarArray at:i) on:stream
claus
parents: 342
diff changeset
  3392
    ].
claus
parents: 342
diff changeset
  3393
!
claus
parents: 342
diff changeset
  3394
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3395
readBinaryContentsFrom:stream manager:manager
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3396
    "reconstruct the receivers instance variables by reading a binary
343
claus
parents: 342
diff changeset
  3397
     binary representation from stream. 
324
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  3398
     This is a general implementation, walking over instances 
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  3399
     and loading each recursively using manager.
343
claus
parents: 342
diff changeset
  3400
     Redefined by some classes to read a more compact representations
claus
parents: 342
diff changeset
  3401
     (see String, SmallInteger etc).
claus
parents: 342
diff changeset
  3402
claus
parents: 342
diff changeset
  3403
     Notice, that the object is already recreated as an empty corps
claus
parents: 342
diff changeset
  3404
     with instance variables all nil and bit-instances (bytes, words etc.) 
claus
parents: 342
diff changeset
  3405
     already read and restored.
claus
parents: 342
diff changeset
  3406
claus
parents: 342
diff changeset
  3407
     Also notice: this method is not called for if a private representation
claus
parents: 342
diff changeset
  3408
     has been stored (see representBinaryOn:). 
claus
parents: 342
diff changeset
  3409
     In that case, #readBinaryContentsFromData:manager: is called, which
claus
parents: 342
diff changeset
  3410
     has to be reimplemented in the objects class."
claus
parents: 342
diff changeset
  3411
claus
parents: 342
diff changeset
  3412
    |size "{ Class: SmallInteger }"
claus
parents: 342
diff changeset
  3413
     instvarArray|
claus
parents: 342
diff changeset
  3414
claus
parents: 342
diff changeset
  3415
    stream next == 1 ifTrue:[
claus
parents: 342
diff changeset
  3416
	"/
claus
parents: 342
diff changeset
  3417
	"/ special representation ...
claus
parents: 342
diff changeset
  3418
	"/
claus
parents: 342
diff changeset
  3419
	instvarArray := Array new:(size := stream nextNumber:3).
claus
parents: 342
diff changeset
  3420
	1 to:size do:[:i |
claus
parents: 342
diff changeset
  3421
	    instvarArray basicAt:i put:(manager nextObject)
claus
parents: 342
diff changeset
  3422
	].
claus
parents: 342
diff changeset
  3423
	self readBinaryContentsFromData:instvarArray manager:manager.
claus
parents: 342
diff changeset
  3424
	^ self
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3425
    ].
343
claus
parents: 342
diff changeset
  3426
claus
parents: 342
diff changeset
  3427
    "/
claus
parents: 342
diff changeset
  3428
    "/ standard representation
claus
parents: 342
diff changeset
  3429
    "/
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3430
    size := self basicSize.
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
  3431
    size ~~ 0 ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3432
	self class isPointers ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3433
	    1 to:size do:[:i |
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3434
		self basicAt:i put:(manager nextObject)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3435
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3436
	]
343
claus
parents: 342
diff changeset
  3437
    ].
claus
parents: 342
diff changeset
  3438
    size := self class instSize.
claus
parents: 342
diff changeset
  3439
    1 to:size do:[:i |
claus
parents: 342
diff changeset
  3440
	self instVarAt:i put:(manager nextObject)
claus
parents: 342
diff changeset
  3441
    ].
2
claus
parents: 1
diff changeset
  3442
!
claus
parents: 1
diff changeset
  3443
343
claus
parents: 342
diff changeset
  3444
storeBinaryContentsOn:stream manager:manager
claus
parents: 342
diff changeset
  3445
    "store the receivers instance variables in a binary representation
claus
parents: 342
diff changeset
  3446
     on a stream using manager.
claus
parents: 342
diff changeset
  3447
     This is a general implementation, walking over instances 
claus
parents: 342
diff changeset
  3448
     and storing each recursively using manager.
claus
parents: 342
diff changeset
  3449
claus
parents: 342
diff changeset
  3450
     Notice, that the objects definition and bit-instances (bytes, words etc.) 
claus
parents: 342
diff changeset
  3451
     are already stored. 
claus
parents: 342
diff changeset
  3452
     Here, we only have to deal with indexed-pointer and named instance variables.
claus
parents: 342
diff changeset
  3453
claus
parents: 342
diff changeset
  3454
     Also notice: this method is not called for if a private representation
claus
parents: 342
diff changeset
  3455
     has been stored (see representBinaryOn:). 
claus
parents: 342
diff changeset
  3456
     In that case, #storeBinaryContentsFromData:manager: is called."
claus
parents: 342
diff changeset
  3457
claus
parents: 342
diff changeset
  3458
    |size "{ Class: SmallInteger }"|
claus
parents: 342
diff changeset
  3459
claus
parents: 342
diff changeset
  3460
    size := self basicSize.
claus
parents: 342
diff changeset
  3461
    size ~~ 0 ifTrue:[
claus
parents: 342
diff changeset
  3462
	self class isPointers ifTrue:[
claus
parents: 342
diff changeset
  3463
	    1 to:size do:[:i |
claus
parents: 342
diff changeset
  3464
		manager putIdOf:(self basicAt:i) on:stream
claus
parents: 342
diff changeset
  3465
	    ].
claus
parents: 342
diff changeset
  3466
	].
claus
parents: 342
diff changeset
  3467
    ].
claus
parents: 342
diff changeset
  3468
    size := self class instSize.
claus
parents: 342
diff changeset
  3469
    1 to:size do:[:i |
claus
parents: 342
diff changeset
  3470
	manager putIdOf:(self instVarAt:i) on:stream
claus
parents: 342
diff changeset
  3471
    ].
claus
parents: 342
diff changeset
  3472
!
claus
parents: 342
diff changeset
  3473
claus
parents: 342
diff changeset
  3474
storeBinaryDefinitionOn:stream manager:manager
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3475
    "append a binary representation of the receiver onto stream.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3476
     This method first stores the class, then the body, which is done
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3477
     in a separate method to allow redefinition of the bodies format.
324
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  3478
     Can be redefined in subclasses to write more compact representations
290cfb34ec93 *** empty log message ***
claus
parents: 314
diff changeset
  3479
     (see String, SmallInteger etc)."
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3480
343
claus
parents: 342
diff changeset
  3481
    manager putIdOfClass:(self class) on:stream.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3482
    self storeBinaryDefinitionBodyOn:stream manager:manager
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3483
!
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3484
343
claus
parents: 342
diff changeset
  3485
storeBinaryDefinitionBodyOn:stream manager:manager
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3486
    "append a binary representation of the receivers body onto stream.
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3487
     This is a general implementation walking over instances storing
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3488
     each recursively as an ID using manager.
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3489
     Can be redefined in subclasses."
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3490
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3491
    |basicSize "{ Class: SmallInteger }"
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3492
     instSize  "{ Class: SmallInteger }"
343
claus
parents: 342
diff changeset
  3493
     myClass specialRep|
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3494
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3495
    myClass := self class.
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3496
    instSize := myClass instSize.
343
claus
parents: 342
diff changeset
  3497
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3498
    myClass isPointers ifTrue:[
343
claus
parents: 342
diff changeset
  3499
	"/
claus
parents: 342
diff changeset
  3500
	"/ inst size not needed - if you uncomment the line below,
claus
parents: 342
diff changeset
  3501
	"/ also uncomment the corresponding line in
claus
parents: 342
diff changeset
  3502
	"/ Object>>binaryDefinitionFrom:manager:
claus
parents: 342
diff changeset
  3503
	"/
claus
parents: 342
diff changeset
  3504
	"/ stream nextPut:instSize. "mhmh this limits us to 255 named instvars"
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3505
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3506
	myClass isVariable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3507
	    stream nextNumber:3 put:(basicSize := self basicSize)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3508
	] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3509
	    basicSize := 0
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3510
	].
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3511
    ] ifFalse: [
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3512
	stream nextNumber:4 put:(basicSize := self basicSize).
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3513
	myClass isBytes ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3514
	    1 to:basicSize do:[:i |
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3515
		stream nextPut:(self basicAt:i)
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3516
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3517
	] ifFalse:[
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3518
	    myClass isWords ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3519
		1 to:basicSize do:[:i |
343
claus
parents: 342
diff changeset
  3520
		    stream nextNumber:2 put:(self basicAt: i)
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3521
		]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3522
	    ] ifFalse:[
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3523
		myClass isLongs ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3524
		    1 to:basicSize do:[:i |
343
claus
parents: 342
diff changeset
  3525
			stream nextNumber:4 put:(self basicAt: i)
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3526
		    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3527
		] ifFalse:[
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3528
		    myClass isFloats ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3529
			"could do it in one big write on machines which use IEEE floats ..."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3530
			1 to:basicSize do:[:i |
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3531
			    Float storeBinaryIEEESingle:(self basicAt:i) on:stream
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3532
			]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3533
		    ] ifFalse:[
179
51c8ee007268 *** empty log message ***
claus
parents: 159
diff changeset
  3534
			myClass isDoubles ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3535
			    "could do it in one big write on machines which use IEEE doubles ..."
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3536
			    1 to:basicSize do:[:i |
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3537
				Float storeBinaryIEEEDouble:(self basicAt:i) on:stream
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3538
			    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3539
			] ifFalse:[
343
claus
parents: 342
diff changeset
  3540
			    "/ should never be reached ...
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3541
			    1 to:basicSize do:[:i |
343
claus
parents: 342
diff changeset
  3542
				manager putIdOf:(self basicAt:i) on:stream
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3543
			    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3544
			]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3545
		    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3546
		]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3547
	    ]
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3548
	].
343
claus
parents: 342
diff changeset
  3549
    ].
claus
parents: 342
diff changeset
  3550
claus
parents: 342
diff changeset
  3551
    specialRep := self representBinaryOn:manager.
claus
parents: 342
diff changeset
  3552
    specialRep notNil ifTrue:[
362
claus
parents: 359
diff changeset
  3553
	stream nextPut:1.     "/ means: private representation follows
343
claus
parents: 342
diff changeset
  3554
	stream nextNumber:3 put:(specialRep basicSize).
claus
parents: 342
diff changeset
  3555
	self storeBinaryContentsFromData:specialRep on:stream manager:manager
claus
parents: 342
diff changeset
  3556
    ] ifFalse:[
362
claus
parents: 359
diff changeset
  3557
	stream nextPut:0.     "/ means: full representation follows
343
claus
parents: 342
diff changeset
  3558
	self storeBinaryContentsOn:stream manager:manager
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3559
    ]
2
claus
parents: 1
diff changeset
  3560
!
claus
parents: 1
diff changeset
  3561
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3562
storeBinaryOn:stream manager:manager
39
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3563
    "append a binary representation of the receiver onto stream."
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3564
bcf183a31bbb *** empty log message ***
claus
parents: 33
diff changeset
  3565
    manager putIdOf:self on:stream
2
claus
parents: 1
diff changeset
  3566
! !
claus
parents: 1
diff changeset
  3567
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3568
!Object methodsFor:'printing & storing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3569
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3570
className
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3571
    "return the classname of the receivers class"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3572
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3573
    ^ self class name
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3574
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3575
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3576
     1 className
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3577
     1 class className   'this may change ...'
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3578
     $a className
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3579
     $a class className  'this may change ...'
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3580
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3581
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3582
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3583
classNameWithArticle
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3584
    "return a string consisting of classname preceeded by an article.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3585
     (dont expect me to write national variants for this ... :-)
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3586
     If you have special preferences, redefine it ..."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3587
85
claus
parents: 77
diff changeset
  3588
    |classname|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3589
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3590
    classname := self class displayString.
85
claus
parents: 77
diff changeset
  3591
    ^ classname article , ' ' , classname
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3592
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3593
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3594
     1 classNameWithArticle
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3595
     (1->2) classNameWithArticle
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3596
     XWorkstation basicNew classNameWithArticle
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3597
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3598
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3599
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3600
printOn:aStream
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3601
    "print the receiver on the argument-stream.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3602
     The default here is to output the receivers class name.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3603
     BUT: this method is heavily redefined for objects which
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3604
     can print prettier."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3605
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3606
    aStream nextPutAll:self classNameWithArticle
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3607
!
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3608
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3609
print
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3610
    "print the receiver on the standard output stream"
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3611
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3612
    self printOn:Stdout
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3613
!
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3614
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3615
printNewline
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3616
    "print the receiver followed by a cr on the standard output stream"
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3617
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3618
    self printOn:Stdout.
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3619
    Stdout cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3620
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3621
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3622
printNL
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3623
    "print the receiver followed by a cr on the standard output stream
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3624
     - for GNU Smalltalk compatibility"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3625
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3626
    ^ self printNewline
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3627
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3628
356
claus
parents: 348
diff changeset
  3629
infoPrint
claus
parents: 348
diff changeset
  3630
    "print the receiver on the standard error stream.
claus
parents: 348
diff changeset
  3631
     This is meant for information messages which are not warnings
claus
parents: 348
diff changeset
  3632
     or fatal messages.
claus
parents: 348
diff changeset
  3633
     These messages can be turned on/off by 'Object infoPrinting:true/false'"
claus
parents: 348
diff changeset
  3634
claus
parents: 348
diff changeset
  3635
    InfoPrinting ifTrue:[
claus
parents: 348
diff changeset
  3636
	self printOn:Stderr
claus
parents: 348
diff changeset
  3637
    ]
claus
parents: 348
diff changeset
  3638
!
claus
parents: 348
diff changeset
  3639
claus
parents: 348
diff changeset
  3640
infoPrintNL
claus
parents: 348
diff changeset
  3641
    "print the receiver followed by a cr on the standard error stream.
claus
parents: 348
diff changeset
  3642
     This is meant for information messages which are not warnings
claus
parents: 348
diff changeset
  3643
     or fatal messages.
claus
parents: 348
diff changeset
  3644
     These messages can be turned on/off by 'Object infoPrinting:true/false'"
claus
parents: 348
diff changeset
  3645
claus
parents: 348
diff changeset
  3646
    InfoPrinting ifTrue:[
claus
parents: 348
diff changeset
  3647
	self errorPrintNewline
claus
parents: 348
diff changeset
  3648
    ]
claus
parents: 348
diff changeset
  3649
!
claus
parents: 348
diff changeset
  3650
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3651
errorPrint
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3652
    "print the receiver on the standard error stream."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3653
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3654
    self printOn:Stderr
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3655
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3656
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3657
errorPrintNewline
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3658
    "print the receiver followed by a cr on the standard error stream"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3659
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3660
    self printOn:Stderr.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3661
    Stderr cr
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3662
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3663
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3664
errorPrintNL
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3665
    "print the receiver followed by a cr on the standard error stream"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3666
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3667
    ^ self errorPrintNewline
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3668
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3669
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3670
printString
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3671
    "return a string for printing the receiver.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3672
     Since we now use printOn: as the basic print mechanism,
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3673
     we have to create a stream and print into it."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3674
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3675
    |s|
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3676
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3677
    s := WriteStream on:(String new:30).
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3678
    self printOn:s.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3679
    ^ s contents
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3680
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3681
369
claus
parents: 362
diff changeset
  3682
printStringPaddedTo:size with:padCharacter ifLarger:alternative
claus
parents: 362
diff changeset
  3683
    "return a printed representation of the receiver,
claus
parents: 362
diff changeset
  3684
     padded with padCharacter (at the right) up to size.
claus
parents: 362
diff changeset
  3685
     If the resulting printString is too large, 
claus
parents: 362
diff changeset
  3686
     return the result from evaluating alternative."
claus
parents: 362
diff changeset
  3687
claus
parents: 362
diff changeset
  3688
    |s|
claus
parents: 362
diff changeset
  3689
claus
parents: 362
diff changeset
  3690
    s := self printString.
claus
parents: 362
diff changeset
  3691
    s size > size ifTrue:[^ alternative value].
claus
parents: 362
diff changeset
  3692
    ^ s paddedTo:size with:padCharacter
claus
parents: 362
diff changeset
  3693
claus
parents: 362
diff changeset
  3694
    "
claus
parents: 362
diff changeset
  3695
     123   printStringPaddedTo:3 with:$. ifLarger:['***']
claus
parents: 362
diff changeset
  3696
     12345 printStringPaddedTo:3 with:$. ifLarger:['***']
claus
parents: 362
diff changeset
  3697
    "
claus
parents: 362
diff changeset
  3698
!
claus
parents: 362
diff changeset
  3699
2
claus
parents: 1
diff changeset
  3700
printStringPaddedTo:size with:padCharacter
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3701
    "return a printed representation of the receiver,
369
claus
parents: 362
diff changeset
  3702
     padded with padCharacter (at the right) up to size.
claus
parents: 362
diff changeset
  3703
     If the printString is longer than size, 
claus
parents: 362
diff changeset
  3704
     it is returned unchanged (i.e. not truncated)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3705
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3706
    ^ (self printString) paddedTo:size with:padCharacter
2
claus
parents: 1
diff changeset
  3707
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3708
    "
369
claus
parents: 362
diff changeset
  3709
     123  printStringPaddedTo:10 with:$.
claus
parents: 362
diff changeset
  3710
     123  printStringPaddedTo:10 with:$*
claus
parents: 362
diff changeset
  3711
     123  printStringPaddedTo:3 with:$*   
claus
parents: 362
diff changeset
  3712
     1234 printStringPaddedTo:3 with:$*   
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3713
    "
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3714
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3715
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3716
printStringPaddedTo:size
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3717
    "return a printed representation of the receiver,
369
claus
parents: 362
diff changeset
  3718
     padded with spaces (at the right) up to size.
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3719
     If the printString is longer than size, 
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3720
     it is returned unchanged (i.e. not truncated)"
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3721
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3722
    ^ self printStringPaddedTo:size with:(Character space)
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3723
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3724
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3725
     123 printStringPaddedTo:10    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3726
     1234567890123456 printStringPaddedTo:10  
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3727
     'hello' printStringPaddedTo:10   
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3728
    "
2
claus
parents: 1
diff changeset
  3729
!
claus
parents: 1
diff changeset
  3730
369
claus
parents: 362
diff changeset
  3731
printStringPaddedTo:size ifLarger:alternative
claus
parents: 362
diff changeset
  3732
    "return a printed representation of the receiver,
claus
parents: 362
diff changeset
  3733
     padded with spaces (at the right) up to size.
claus
parents: 362
diff changeset
  3734
     If the resulting printString is too large, 
claus
parents: 362
diff changeset
  3735
     return the result from evaluating alternative."
claus
parents: 362
diff changeset
  3736
claus
parents: 362
diff changeset
  3737
    ^ self printStringPaddedTo:size with:(Character space) ifLarger:alternative
claus
parents: 362
diff changeset
  3738
claus
parents: 362
diff changeset
  3739
    "
claus
parents: 362
diff changeset
  3740
     12   printStringPaddedTo:3 ifLarger:['***']   
claus
parents: 362
diff changeset
  3741
     123  printStringPaddedTo:3 ifLarger:['***']   
claus
parents: 362
diff changeset
  3742
     1234 printStringPaddedTo:3 ifLarger:['***']   
claus
parents: 362
diff changeset
  3743
    "
claus
parents: 362
diff changeset
  3744
!
claus
parents: 362
diff changeset
  3745
2
claus
parents: 1
diff changeset
  3746
printStringZeroPaddedTo:size
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3747
    "return a printed representation of the receiver, 
369
claus
parents: 362
diff changeset
  3748
     padded with zero (at the right) characters up to size.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3749
     Usually used with float numbers."
2
claus
parents: 1
diff changeset
  3750
claus
parents: 1
diff changeset
  3751
    ^ self printStringPaddedTo:size with:$0
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3752
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3753
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3754
     123.0 printStringZeroPaddedTo:10 
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3755
    "
2
claus
parents: 1
diff changeset
  3756
!
claus
parents: 1
diff changeset
  3757
369
claus
parents: 362
diff changeset
  3758
printStringLeftPaddedTo:size with:padCharacter ifLarger:alternative
claus
parents: 362
diff changeset
  3759
    "return my printString as a right-adjusted string of length size;
claus
parents: 362
diff changeset
  3760
     characters on the left are filled with padCharacter.
claus
parents: 362
diff changeset
  3761
     If the printString is larger than size,
claus
parents: 362
diff changeset
  3762
     return the result from evaluating alternative."
claus
parents: 362
diff changeset
  3763
claus
parents: 362
diff changeset
  3764
    |s|
claus
parents: 362
diff changeset
  3765
claus
parents: 362
diff changeset
  3766
    s := self printString.
claus
parents: 362
diff changeset
  3767
    s size > size ifTrue:[^ alternative value].
claus
parents: 362
diff changeset
  3768
    ^ s leftPaddedTo:size with:padCharacter
claus
parents: 362
diff changeset
  3769
claus
parents: 362
diff changeset
  3770
    "
claus
parents: 362
diff changeset
  3771
     12   printStringLeftPaddedTo:3 with:$. ifLarger:['***']   
claus
parents: 362
diff changeset
  3772
     123  printStringLeftPaddedTo:3 with:$. ifLarger:['***']   
claus
parents: 362
diff changeset
  3773
     1234 printStringLeftPaddedTo:3 with:$. ifLarger:['***']   
claus
parents: 362
diff changeset
  3774
    "
claus
parents: 362
diff changeset
  3775
!
claus
parents: 362
diff changeset
  3776
2
claus
parents: 1
diff changeset
  3777
printStringLeftPaddedTo:size with:padCharacter
claus
parents: 1
diff changeset
  3778
    "return my printString as a right-adjusted string of length size;
369
claus
parents: 362
diff changeset
  3779
     characters on the left are filled with padCharacter.
claus
parents: 362
diff changeset
  3780
     If the printString is longer than size, 
claus
parents: 362
diff changeset
  3781
     it is returned unchanged (i.e. not truncated)"
2
claus
parents: 1
diff changeset
  3782
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3783
    ^ (self printString) leftPaddedTo:size with:padCharacter
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3784
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3785
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3786
     123 printStringLeftPaddedTo:10 with:$.   
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3787
     1 printStringLeftPaddedTo:10 with:$.      
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3788
     (Float pi) printStringLeftPaddedTo:20 with:$*
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3789
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3790
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3791
369
claus
parents: 362
diff changeset
  3792
printStringLeftPaddedTo:size ifLarger:alternative
claus
parents: 362
diff changeset
  3793
    "return my printString as a right-adjusted string of length size;
claus
parents: 362
diff changeset
  3794
     characters on the left are filled with spaces.
claus
parents: 362
diff changeset
  3795
     If the printString is larger than size,
claus
parents: 362
diff changeset
  3796
     return the result from evaluating alternative."
claus
parents: 362
diff changeset
  3797
claus
parents: 362
diff changeset
  3798
    ^ self printStringLeftPaddedTo:size with:(Character space) ifLarger:alternative
claus
parents: 362
diff changeset
  3799
claus
parents: 362
diff changeset
  3800
    "
claus
parents: 362
diff changeset
  3801
     12   printStringLeftPaddedTo:3 ifLarger:['***']
claus
parents: 362
diff changeset
  3802
     123  printStringLeftPaddedTo:3 ifLarger:['***']
claus
parents: 362
diff changeset
  3803
     1234 printStringLeftPaddedTo:3 ifLarger:['***']
claus
parents: 362
diff changeset
  3804
    "
claus
parents: 362
diff changeset
  3805
!
claus
parents: 362
diff changeset
  3806
2
claus
parents: 1
diff changeset
  3807
printStringLeftPaddedTo:size
claus
parents: 1
diff changeset
  3808
    "return my printString as a right-adjusted string of length size;
369
claus
parents: 362
diff changeset
  3809
     characters on the left are filled with spaces.
claus
parents: 362
diff changeset
  3810
     If the printString is longer than size, 
claus
parents: 362
diff changeset
  3811
     it is returned unchanged (i.e. not truncated)"
2
claus
parents: 1
diff changeset
  3812
claus
parents: 1
diff changeset
  3813
    ^ self printStringLeftPaddedTo:size with:(Character space)
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  3814
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3815
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3816
     10 printStringLeftPaddedTo:10
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3817
     1 printStringLeftPaddedTo:10
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3818
    "
2
claus
parents: 1
diff changeset
  3819
!
claus
parents: 1
diff changeset
  3820
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3821
printOn:aStream paddedTo:size with:padCharacter
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3822
    "print the receiver on aStream, padding with padCharacter up to size"
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3823
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3824
    aStream nextPutAll:(self printStringPaddedTo:size with:padCharacter).
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3825
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3826
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3827
     123 printOn:Transcript paddedTo:10 with:$_ . Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3828
     123 printOn:Transcript paddedTo:10 with:$. . Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3829
    "
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3830
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3831
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3832
printOn:aStream zeroPaddedTo:size
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3833
    "print the receiver on aStream, padding with zeros up to size.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3834
     Usually used with float numbers."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3835
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3836
    self printOn:aStream paddedTo:size with:$0.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3837
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3838
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3839
     123.0 printOn:Transcript zeroPaddedTo:10
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3840
    "
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3841
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3842
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3843
printOn:aStream paddedTo:size
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3844
    "print the receiver on aStream, padding with spaces up to size."
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3845
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3846
    self printOn:aStream paddedTo:size with:(Character space)
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3847
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3848
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3849
     123.0 printOn:Transcript paddedTo:10. Transcript nextPut:$|. Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3850
    "
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3851
!
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3852
2
claus
parents: 1
diff changeset
  3853
printOn:aStream leftPaddedTo:size with:padCharacter
claus
parents: 1
diff changeset
  3854
    "print the receiver on aStream, padding with padCharacters up to size.
claus
parents: 1
diff changeset
  3855
     padding is done on the left."
claus
parents: 1
diff changeset
  3856
claus
parents: 1
diff changeset
  3857
    aStream nextPutAll:(self printStringLeftPaddedTo:size with:padCharacter)
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3858
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3859
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3860
     123 printOn:Transcript leftPaddedTo:10 with:$_ . Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3861
     123 printOn:Transcript leftPaddedTo:10 with:$. . Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3862
    "
2
claus
parents: 1
diff changeset
  3863
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3864
2
claus
parents: 1
diff changeset
  3865
printOn:aStream leftPaddedTo:size
claus
parents: 1
diff changeset
  3866
    "print the receiver on aStream, padding with spaces up to size.
claus
parents: 1
diff changeset
  3867
     padding is done on the left."
claus
parents: 1
diff changeset
  3868
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3869
    self printOn:aStream leftPaddedTo:size with:(Character space)
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3870
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3871
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3872
     123 printOn:Transcript leftPaddedTo:10. Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3873
     123 printOn:Transcript leftPaddedTo:2. Transcript cr
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3874
    "
2
claus
parents: 1
diff changeset
  3875
!
claus
parents: 1
diff changeset
  3876
claus
parents: 1
diff changeset
  3877
printStringRightAdjustLen:size
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3878
    "obsolete - just a name confusion.
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3879
     This method will go away ..."
2
claus
parents: 1
diff changeset
  3880
claus
parents: 1
diff changeset
  3881
    ^ self printStringLeftPaddedTo:size
claus
parents: 1
diff changeset
  3882
!
claus
parents: 1
diff changeset
  3883
claus
parents: 1
diff changeset
  3884
printRightAdjustLen:size
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3885
    "obsolete - just a name confusion.
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3886
     This method will go away ..."
2
claus
parents: 1
diff changeset
  3887
claus
parents: 1
diff changeset
  3888
    (self printStringLeftPaddedTo:size) printOn:Stdout
claus
parents: 1
diff changeset
  3889
!
claus
parents: 1
diff changeset
  3890
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3891
displayString
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  3892
    "return a string used when displaying the receiver in a view;
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3893
     for example an Inspector. This is usually the same as printString,
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3894
     but sometimes redefined for a better look."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3895
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3896
    ^ self printString
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3897
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3898
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3899
     #(1 2 3) printString    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3900
     #(1 2 3) displayString  
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3901
     #(1 2 3) storeString
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3902
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3903
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3904
308
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3905
displayOn:aGc x:x y:y
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3906
    "display the receiver in a graphicsContext - this method allows
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3907
     for any object to be displayed in a ListView - for example."
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3908
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3909
    ^ aGc displayString:(self displayString) x:x y:y.
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3910
!
f04744ef7b5d *** empty log message ***
claus
parents: 298
diff changeset
  3911
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3912
storeOn:aStream
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3913
    "store the receiver on aStream; i.e. print an expression which will
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3914
     reconstruct the receiver.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3915
     Notice, that no self referencing or cyclic objects can be represented
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3916
     in this format.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3917
     Use storeBinaryOn:, which handles these cases correctly."
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3918
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3919
    |myClass hasSemi sz "{ Class: SmallInteger }" |
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3920
25
e34a6267c79b *** empty log message ***
claus
parents: 13
diff changeset
  3921
    thisContext isRecursive ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3922
	Transcript showCr:'Error: storeString of self referencing object.'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3923
	aStream nextPutAll:'#("recursive")'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3924
	^ self
25
e34a6267c79b *** empty log message ***
claus
parents: 13
diff changeset
  3925
    ].
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3926
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3927
    myClass := self class.
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3928
    aStream nextPut:$(.
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3929
    aStream nextPutAll:self class name.
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3930
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3931
    hasSemi := false.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3932
    myClass isVariable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3933
	aStream nextPutAll:' basicNew:'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3934
	self basicSize printOn:aStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3935
    ] ifFalse:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3936
	aStream nextPutAll:' basicNew'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3937
    ].
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3938
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3939
    sz := myClass instSize.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3940
    1 to:sz do:[:i | 
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3941
	aStream nextPutAll:' instVarAt:'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3942
	i printOn:aStream.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3943
	aStream nextPutAll:' put:'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3944
	(self instVarAt:i) storeOn:aStream.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3945
	aStream nextPut:$;.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3946
	hasSemi := true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3947
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3948
    myClass isVariable ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3949
	sz := self basicSize.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3950
	1 to:sz do:[:i | 
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3951
	    aStream nextPutAll:' basicAt:'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3952
	    i printOn:aStream.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3953
	    aStream nextPutAll:' put:'.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3954
	    (self basicAt:i) storeOn:aStream.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3955
	    aStream nextPut:$;.
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3956
	    hasSemi := true
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3957
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3958
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3959
    hasSemi ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 143
diff changeset
  3960
	aStream nextPutAll:' yourself'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3961
    ].
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3962
    aStream nextPut:$).
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3963
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3964
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3965
     |s|
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3966
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3967
     s := WriteStream on:(String new).
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3968
     ('hello' -> 'world') storeOn:s.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3969
     s := ReadStream on:(s contents).
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3970
     (Object readFrom:s) inspect
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3971
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3972
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3973
     |s|
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3974
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3975
     s := 'data' asFilename writeStream.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3976
     ('hello' -> 'world') storeOn:s.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3977
     s close.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3978
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3979
     s := 'data' asFilename readStream.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3980
     (Object readFrom:s) inspect
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3981
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3982
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3983
    "does not work example:"
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3984
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3985
     |s a|
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3986
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3987
     a := Array new:2.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3988
     a at:1 put:a.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3989
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3990
     s := 'data' asFilename writeStream.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3991
     a storeOn:s.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3992
     s close.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3993
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3994
     s := 'data' asFilename readStream.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3995
     (Object readFrom:s) inspect
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  3996
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3997
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3998
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  3999
storeString
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  4000
    "return a string representing an expression to reconstruct the receiver.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  4001
     Notice, that no self referencing or cyclic objects can be represented
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  4002
     in this format.
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  4003
     Use storeBinaryOn:, which handles these cases correctly."
56
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  4004
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  4005
    |s|
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  4006
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  4007
    s := WriteStream on:(String new:50).
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  4008
    self storeOn:s.
be0ed17e6f85 *** empty log message ***
claus
parents: 49
diff changeset
  4009
    ^ s contents
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4010
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4011
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4012
store
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  4013
    "store the receiver on standard output.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  4014
     this method is useless, but included for compatibility."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4015
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4016
    self storeOn:Stdout
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4017
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4018
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4019
storeNl
71
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  4020
    "store the receiver on standard output; append a newline.
a42874820e27 *** empty log message ***
claus
parents: 56
diff changeset
  4021
     this method is useless, but included for compatibility."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4022
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4023
    self store.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4024
    Character nl print
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4025
! !