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