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