Class.st
author Claus Gittinger <cg@exept.de>
Tue, 14 Nov 1995 20:02:34 +0100
changeset 544 d78012b20769
parent 527 7eedfdb0db62
child 555 d63400e20718
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
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
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
    13
'From Smalltalk/X, Version:2.10.8 on 29-oct-1995 at 19:51:30'                   !
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
    14
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
ClassDescription subclass:#Class
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
    16
	 instanceVariableNames:'classvars comment subclasses classFilename package revision
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
    17
		history'
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
    18
	 classVariableNames:'UpdatingChanges LockChangesFile FileOutErrorSignal CatchMethodRedefinitions
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
    19
		MethodRedefinitionSignal UpdateChangeFileQuerySignal'
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
    20
	 poolDictionaries:''
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
    21
	 category:'Kernel-Classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    24
!Class class methodsFor:'documentation'!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    25
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    26
copyright
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    27
"
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    28
 COPYRIGHT (c) 1989 by Claus Gittinger
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    29
	       All Rights Reserved
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    30
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    31
 This software is furnished under a license and may be used
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    32
 only in accordance with the terms of that license and with the
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    33
 inclusion of the above copyright notice.   This software may not
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    34
 be provided or otherwise made available to, or used by, any
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    35
 other person.  No title to or ownership of the software is
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    36
 hereby transferred.
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    37
"
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    38
!
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    39
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    40
version
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
    41
    ^ '$Header: /cvs/stx/stx/libbasic/Class.st,v 1.70 1995-11-14 19:01:36 cg Exp $'
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
    42
!
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    43
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    44
documentation
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    45
"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    46
    Class adds more functionality to classes; minimum stuff has already
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    47
    been defined in Behavior and ClassDescription; this adds naming, categories etc.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    48
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    49
    Also change management and recompilation is defined here (since the superclasses
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    50
    do not have enough symbolic information to support compilation).
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    51
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    52
    For production code, the stc compiler is planned to (optionally) generate classes 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    53
    as subclasses of Behavior - to excludes all name, source info etc., 
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    54
    however, normally all classes are subclasses of Class.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    55
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    56
    Instance variables:
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    57
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    58
	classvars       <String>        the names of the class variables
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    59
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    60
	comment         <String>        the classes comment; either a string,
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    61
					a number specifying the offset in classFilename, or nil
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    62
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    63
	subclasses      <Collection>    cached collection of subclasses
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    64
					(currently unused - but will be soon)
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    65
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    66
	classFilename   <String>        the file (or nil) where the classes
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    67
					sources are found 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    68
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    69
	package         <Symbol>        the package, in which the class was defined
385
claus
parents: 384
diff changeset
    70
					(inserted by compilers)
claus
parents: 384
diff changeset
    71
391
claus
parents: 385
diff changeset
    72
	revision        <String>        revision string - inserted by stc
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    73
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    74
	history         <any>           a place for a history string (not currently used)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    75
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    76
    Class variables:
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    77
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    78
	UpdatingChanges <Boolean>       true if the changes-file shall be updated
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    79
					(except during startup and when filing in, this flag
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    80
					 is usually true)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    81
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
    82
	LockChangesFile <Boolean>       if true, the change file is locked for updates.
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
    83
					Required when multiple users operate on a common
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
    84
					change file.
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
    85
					This is an experimental new feature, being evaluated.
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
    86
421
claus
parents: 415
diff changeset
    87
	UpdateChangeFileQuerySignal     used as an upQuery from the change management.
claus
parents: 415
diff changeset
    88
					Whenever a changeRecord is to be written,
claus
parents: 415
diff changeset
    89
					this signal is raised and a handler (if present)
claus
parents: 415
diff changeset
    90
					is supposed to return true or false.
claus
parents: 415
diff changeset
    91
					If unhandled, the value of the global
claus
parents: 415
diff changeset
    92
					UpdatingChanges is returned for backward
claus
parents: 415
diff changeset
    93
					compatibility (which means that the old
claus
parents: 415
diff changeset
    94
					mechanism is used if no query-handler
claus
parents: 415
diff changeset
    95
					is present).
claus
parents: 415
diff changeset
    96
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    97
	FileOutErrorSignal              raised when an error occurs during fileOut
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    98
362
claus
parents: 360
diff changeset
    99
	CatchMethodRedefinitions        if true, classes protect themself 
claus
parents: 360
diff changeset
   100
	MethodRedefinitionSignal        (by raising MethodRedefinitionSignal)
claus
parents: 360
diff changeset
   101
					from redefining any existing methods,
claus
parents: 360
diff changeset
   102
					which are defined in another package.
claus
parents: 360
diff changeset
   103
					(i.e. a signal will be raised, if you
claus
parents: 360
diff changeset
   104
					 fileIn something which redefines an
claus
parents: 360
diff changeset
   105
					 existing method and the packages do not
claus
parents: 360
diff changeset
   106
					 match).
claus
parents: 360
diff changeset
   107
					The default is (currently) true.
claus
parents: 360
diff changeset
   108
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   109
    WARNING: layout known by compiler and runtime system
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   110
"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   111
! !
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   112
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
!Class class methodsFor:'initialization'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
initialize
28
4606b818d646 *** empty log message ***
claus
parents: 22
diff changeset
   116
    "the classvariable 'UpdatingChanges' controls if changes are put
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
     into the changes-file; normally this variable is set to true, but
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   118
     (for example) during fileIn or when changes are applied, it is set to false
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   119
     to avoid putting too much junk into the changes-file."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
     
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   121
    UpdatingChanges := true.
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   122
    LockChangesFile := false.
362
claus
parents: 360
diff changeset
   123
    CatchMethodRedefinitions := true.
claus
parents: 360
diff changeset
   124
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   125
    FileOutErrorSignal isNil ifTrue:[
421
claus
parents: 415
diff changeset
   126
	FileOutErrorSignal := ErrorSignal newSignalMayProceed:false.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   127
	FileOutErrorSignal nameClass:self message:#fileOutErrorSignal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   128
	FileOutErrorSignal notifierString:'error during fileOut'.
362
claus
parents: 360
diff changeset
   129
421
claus
parents: 415
diff changeset
   130
	MethodRedefinitionSignal := ErrorSignal newSignalMayProceed:true.
362
claus
parents: 360
diff changeset
   131
	MethodRedefinitionSignal nameClass:self message:#methodRedefinitionSignal.
claus
parents: 360
diff changeset
   132
	MethodRedefinitionSignal notifierString:'attempt to redefine method from different package'.
421
claus
parents: 415
diff changeset
   133
claus
parents: 415
diff changeset
   134
	UpdateChangeFileQuerySignal := QuerySignal new mayProceed:true.
claus
parents: 415
diff changeset
   135
	UpdateChangeFileQuerySignal nameClass:self message:#updateChangeFileQuerySignal.
claus
parents: 415
diff changeset
   136
	UpdateChangeFileQuerySignal notifierString:'asking if changeFile update is wanted'.
claus
parents: 415
diff changeset
   137
	UpdateChangeFileQuerySignal handlerBlock:[:ex | ex proceedWith:UpdatingChanges].
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   138
    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   139
! !
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   140
345
claus
parents: 333
diff changeset
   141
!Class class methodsFor:'Signal constants'!
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   142
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   143
updateChangeFileQuerySignal
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   144
    "return the signal used as an upQuery if the changeFile should be updated.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   145
     If unhandled, the value of UpdatingChanges is returned by the signals
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   146
     static handler."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   147
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   148
    ^ UpdateChangeFileQuerySignal
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   149
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   150
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   151
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   152
fileOutErrorSignal
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   153
    "return the signal raised when an error occurs while fileing out.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   154
     This is signalled to allow browsers some user feed back in case
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   155
     a fileout fails (for example due to disk-full errors)"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   156
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   157
    ^ FileOutErrorSignal
362
claus
parents: 360
diff changeset
   158
!
claus
parents: 360
diff changeset
   159
claus
parents: 360
diff changeset
   160
methodRedefinitionSignal
claus
parents: 360
diff changeset
   161
    "return the signal raised when a method is about to be installed
claus
parents: 360
diff changeset
   162
     which redefines an existing method and the methods packages are not
claus
parents: 360
diff changeset
   163
     equal. This helps when filing in alien code, to prevent existing
claus
parents: 360
diff changeset
   164
     methods to be overwritten or redefined by incompatible methods"
claus
parents: 360
diff changeset
   165
claus
parents: 360
diff changeset
   166
    ^ MethodRedefinitionSignal
claus
parents: 360
diff changeset
   167
! !
claus
parents: 360
diff changeset
   168
claus
parents: 360
diff changeset
   169
!Class class methodsFor:'accessing - flags'!
claus
parents: 360
diff changeset
   170
claus
parents: 360
diff changeset
   171
updateChanges:aBoolean
claus
parents: 360
diff changeset
   172
    "turn on/off changes management. Return the prior value of the flag."
claus
parents: 360
diff changeset
   173
claus
parents: 360
diff changeset
   174
    |prev|
claus
parents: 360
diff changeset
   175
claus
parents: 360
diff changeset
   176
    prev := UpdatingChanges.
claus
parents: 360
diff changeset
   177
    UpdatingChanges := aBoolean.
claus
parents: 360
diff changeset
   178
    ^ prev
claus
parents: 360
diff changeset
   179
!
claus
parents: 360
diff changeset
   180
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   181
lockChangesFile:aBoolean
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   182
    "turn on/off change-file-locking. Return the previous value of the flag."
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   183
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   184
    |prev|
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   185
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   186
    prev := LockChangesFile.
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   187
    LockChangesFile := aBoolean.
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   188
    ^ prev
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   189
!
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   190
362
claus
parents: 360
diff changeset
   191
catchMethodRedefinitions:aBoolean
claus
parents: 360
diff changeset
   192
    "turn on/off redefinition catching. Return the prior value of the flag."
claus
parents: 360
diff changeset
   193
claus
parents: 360
diff changeset
   194
    |prev|
claus
parents: 360
diff changeset
   195
claus
parents: 360
diff changeset
   196
    prev := CatchMethodRedefinitions.
claus
parents: 360
diff changeset
   197
    CatchMethodRedefinitions := aBoolean.
claus
parents: 360
diff changeset
   198
    ^ prev
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   199
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   200
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   201
updatingChanges
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   202
    "return true if changes are recorded"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   203
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   204
    ^ UpdatingChanges
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   205
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   206
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   207
lockChangesFile
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   208
    "return true, if the change file is locked during update"
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   209
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   210
    ^ LockChangesFile
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   211
!
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
   212
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   213
catchMethodRedefinitions
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   214
    "return the redefinition catching flag."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   215
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   216
    ^ CatchMethodRedefinitions
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   219
!Class class methodsFor:'enumeration '!
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   220
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   221
allClassesInCategory:aCategory do:aBlock
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   222
    "evaluate aBlock for all classes in aCategory;
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   223
     no specific order is defined."
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   224
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   225
    Smalltalk allBehaviorsDo:[:aClass |
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   226
	aClass isMeta ifFalse:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   227
	    (aClass category = aCategory) ifTrue:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   228
		aBlock value:aClass
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   229
	    ]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   230
	].
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   231
    ]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   232
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   233
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   234
     Class allClassesInCategory:'Kernel-Classes' 
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   235
			     do:[:class |Transcript showCr:class name]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   236
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   237
!
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   238
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   239
allClassesInCategory:aCategory inOrderDo:aBlock
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   240
    "evaluate aBlock for all classes in aCategory;
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   241
     superclasses come first - then subclasses."
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   242
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   243
    |classes|
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   244
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   245
    classes := OrderedCollection new.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   246
    Smalltalk allBehaviorsDo:[:aClass |
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   247
	aClass isMeta ifFalse:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   248
	    (aClass category = aCategory) ifTrue:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   249
		classes add:aClass
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   250
	    ]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   251
	]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   252
    ].
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   253
    classes topologicalSort:[:a :b | b isSubclassOf:a].
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   254
    classes do:aBlock
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   255
! !
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   256
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
!Class methodsFor:'ST/V subclass creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   259
subclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   260
    "this method allows fileIn of ST/V classes 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
     (which seem to have no category)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
    ^ self subclass:t 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   264
	   instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   265
	   classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   266
	   poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   267
	   category:'ST/V classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   270
variableByteSubclass:t classVariableNames:d poolDictionaries:s
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   271
    "this method allows fileIn of ST/V variable byte classes 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
     (which seem to have no category and no instvars)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
    ^ self variableByteSubclass:t 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   275
	   instanceVariableNames:''
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   276
	   classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   277
	   poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   278
	   category:'ST/V classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   281
variableSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   282
    "this method allows fileIn of ST/V variable pointer classes 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
     (which seem to have no category)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   284
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    ^ self variableSubclass:t 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   286
	   instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   287
	   classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   288
	   poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   289
	   category:'ST/V classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
!Class methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   294
allClassVarNames
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   295
    "return a collection of all the class variable name-strings
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   296
     this includes all superclass-class variables"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   297
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   298
    ^ self addAllClassVarNamesTo:(OrderedCollection new)
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   299
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   300
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   301
     Float allClassVarNames
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   302
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   303
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   304
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
classVarNames
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   306
    "return a collection of the class variable name-strings.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   307
     Only names of class variables defined in this class are included
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   308
     in the returned collection - use allClassVarNames, to get all known names."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
10
claus
parents: 5
diff changeset
   310
    classvars isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   311
	^ OrderedCollection new
10
claus
parents: 5
diff changeset
   312
    ].
claus
parents: 5
diff changeset
   313
    ^ classvars asCollectionOfWords
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   314
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   315
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   316
     Object classVarNames 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   317
     Float classVarNames
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   318
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   319
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   320
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   321
classVariableString:aString
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   322
    "set the classes classvarnames string; 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   323
     Initialize new class variables with nil, clear and remove old ones. 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   324
     No change record is written and no classes are recompiled."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   325
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   326
    |prevVarNames varNames any|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   327
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   328
    "ignore for metaclasses except the one"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   329
    (self isMeta) ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   330
	(self == Metaclass) ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   331
	    ^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   332
	]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   333
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   334
    (classvars = aString) ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   335
	prevVarNames := self classVarNames.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   336
	classvars := aString.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   337
	varNames := self classVarNames.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   338
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   339
	"new ones get initialized to nil;
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   340
	 - old ones are nilled and removed from Smalltalk"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   341
	any := false.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   342
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   343
	varNames do:[:aName |
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   344
	    (prevVarNames includes:aName) ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   345
		"a new one"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   346
		self classVarAt:aName put:nil.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   347
		any := true.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   348
	    ] ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   349
		prevVarNames remove:aName
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   350
	    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   351
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   352
	"left overs are gone"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   353
	prevVarNames do:[:aName |
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   354
	    self classVarAt:aName put:nil.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   355
	    Smalltalk removeKey:(self name , ':' , aName) asSymbol.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   356
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   357
	any ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   358
	    Smalltalk changed:#classVariables with:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   359
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   360
    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   361
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   362
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   363
setComment:com category:categoryStringOrSymbol
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   364
    "set the comment and category of the class;
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   365
     do NOT create a change record"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   366
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   367
    |cat|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   368
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   369
    comment := com.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   370
    categoryStringOrSymbol isNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   371
	cat := ''
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   372
    ] ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   373
	cat := categoryStringOrSymbol
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   374
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   375
    category := cat asSymbol
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   376
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   377
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   378
revision
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   379
    "return the revision-ID of the class which corresponds to the
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   380
     rcs-id of the source from which this class was compiled.
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   381
     This is always valid for stc-compiled classes which include a version method,
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   382
     since stc extracts this info and places it into an instance variable.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   383
     Alternatively, the code below tries to extract it from the revisionString directly,
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   384
     this is used with filed-In classes (non stc-compiled).
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   385
     To check if a source corresponds to a compiled binary, compare this 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   386
     ID with the one found in the version-methods comment."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   387
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   388
    |vsnString words|
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   389
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   390
    revision notNil ifTrue:[ ^ revision].
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   391
    vsnString := self revisionString.
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   392
    vsnString notNil ifTrue:[
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   393
	words := vsnString asCollectionOfWords.
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   394
	"/
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   395
	"/ supported formats:
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   396
	"/
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   397
	"/ $-Header: pathName rev date time user state $
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   398
	"/ $-Revision: rev $
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   399
	"/ $-Id: fileName rev date time user state $
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   400
	"/
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   401
	((words at:1) = '$Header:') ifTrue:[
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   402
	    ^ words at:3
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   403
	].
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   404
	((words at:1) = '$Revision:') ifTrue:[
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   405
	    ^ words at:2 
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   406
	].
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   407
	((words at:1) = '$Id:') ifTrue:[
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   408
	    ^ words at:3 
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   409
	].
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   410
    ].
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   411
    ^ nil
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   412
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   413
    "
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   414
     Object revision 
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   415
    "
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   416
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
   417
    "Created: 11.11.1995 / 14:27:20 / cg"
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   418
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   419
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   420
classVariableString
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   421
    "return a string of the class variables names.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   422
     Only names of class variables defined in this class are in the
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   423
     returned string."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   424
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   425
    classvars isNil ifTrue:[^ ''].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   426
    ^ classvars
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   427
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   428
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   429
     Object classVariableString 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   430
     Float classVariableString  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   431
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   432
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   433
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   434
comment
a27a279701f8 Initial revision
claus
parents:
diff changeset
   435
    "return the comment (aString) of the class"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   436
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   437
    |stream string|
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   438
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   439
    "the comment is either a string, or an integer specifying the
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   440
     position within the classes sourcefile ...
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   441
    "
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   442
    comment isNumber ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   443
	classFilename notNil ifTrue:[
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   444
	    stream := self sourceStream. "/ Smalltalk sourceFileStreamFor:classFilename.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   445
	    stream notNil ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   446
		stream position:comment.
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   447
		string := String readFrom:stream onError:''.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   448
		stream close.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   449
		^ string
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   450
	    ]
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   451
	]
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   452
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
    ^ comment
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   454
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   455
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   456
     Object comment 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   457
    "
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   458
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   459
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   460
classVarAt:aSymbol
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   461
    "return the value of a class variable.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   462
     Currently, this returns nil if there is no such classvar -
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   463
     this may change."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   464
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   465
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   466
     this hides the (current) implementation of classVariables
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   467
     from the outside world. Currently, classvars are stored in
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   468
     the Smalltalk dictionary with a funny name, since there are
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   469
     no classPools yet.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   470
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   471
    ^ Smalltalk at:(self name , ':' , aSymbol) asSymbol
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   472
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   473
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   474
classVarAt:aSymbol put:something
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   475
    "store something in a classvariable.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   476
     Currently this creates a global with a funny name if no such
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   477
     classVar exists - this may change."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   478
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   479
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   480
     this hides the (current) implementation of classVariables
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   481
     from the outside world. Currently, classvars are stored in
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   482
     the Smalltalk dictionary with a funny name, since there are
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   483
     no classPools yet.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   484
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   485
    Smalltalk at:(self name , ':' , aSymbol) asSymbol put:something.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   486
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
setComment:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
    "set the comment of the class to be the argument, aString;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
     do NOT create a change record"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
    comment := aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
comment:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
    "set the comment of the class to be the argument, aString;
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   497
     create a change record and notify dependents."
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   498
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   499
    |oldComment|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
10
claus
parents: 5
diff changeset
   501
    comment ~= aString ifTrue:[
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   502
	oldComment := self comment.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   503
	comment := aString.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   504
	self changed:#comment with:oldComment.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   505
	self updateRevisionString.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   506
	self addChangeRecordForClassComment:self.
10
claus
parents: 5
diff changeset
   507
    ]
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   508
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   509
    "Created: 29.10.1995 / 19:41:24 / cg"
10
claus
parents: 5
diff changeset
   510
!
claus
parents: 5
diff changeset
   511
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   512
package
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   513
    "return the package of the class"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   514
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   515
    ^ package
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   516
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   517
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   518
     Object package  
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   519
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   520
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   521
484
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   522
package:aStringOrSymbol
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   523
    "set the package of the class."
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   524
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   525
    package := aStringOrSymbol
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   526
!
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   527
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   528
setPackage:aStringOrSymbol
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   529
    "set the package of the class."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   530
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   531
    package := aStringOrSymbol
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   532
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   533
385
claus
parents: 384
diff changeset
   534
revision:aString
claus
parents: 384
diff changeset
   535
    "set the revision-ID.
claus
parents: 384
diff changeset
   536
     This should normally not be done in the running system, as the source-manager
claus
parents: 384
diff changeset
   537
     will need this to validate sourcefiles being correct for a given binary
claus
parents: 384
diff changeset
   538
     (and optionally: extracting the required sourcefile from the rcs source)"
claus
parents: 384
diff changeset
   539
claus
parents: 384
diff changeset
   540
    revision := aString
claus
parents: 384
diff changeset
   541
!
claus
parents: 384
diff changeset
   542
484
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   543
sourceCodeInfo
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   544
    "return the sourceCodeInfo, which defines the module and the subdirectory
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   545
     in which the receiver class was built. 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   546
     The info returned consists of a dictionary
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   547
     filled with (at least) values at: #module, #directory and #library.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   548
     If no such info is present in the class, nil is returned.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   549
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   550
     By convention, this info is encoded in the classes package
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   551
     string (which is given as argument to stc) as the last word in parenthesis. 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   552
     The info consists of 1 to 3 subcomponents, separated by colons.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   553
     The first defines the classes module (i.e. some application identifier), 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   554
     the second defines the subdirectory within that module, the third
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   555
     defines the name of the class library. 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   556
     If left blank, the module info defaults to 'stx',
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   557
     the directory info defaults to library name.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   558
     The library name may not be left blank.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   559
     (this is done for backward compatibility,)
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   560
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   561
     For example: 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   562
	'....(libbasic)'                         -> module: stx directory: libbasic library: libbasic
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   563
	'....(stx:libbasic)'                     -> module: stx directory: libbasic library: libbasic
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   564
	'....(aeg:libIECInterface)'              -> module: aeg directory: libIECInterface library:libIECInterface
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   565
	'....(stx:goodies/persistency:libdbase)' -> module: stx directory: goodies/persistency library:libdbase 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   566
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   567
     The way how the sourceCodeManager uses this to find the source location
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   568
     depends on the scheme used. For CVS, the module is taken as the -d arg,
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   569
     while the directory is prepended to the file name.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   570
     Other schemes may do things differently - these are not yet specified.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   571
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   572
     Caveat:
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   573
	Encoding this info in the package string seems somewhat kludgy.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   574
    "
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   575
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   576
    |sourceInfo packageString idx1 idx2 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   577
     moduleString directoryString libraryString components|
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   578
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   579
    package isNil ifTrue:[^ nil].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   580
484
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   581
    packageString := package asString.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   582
    idx1 := packageString lastIndexOf:$(.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   583
    idx1 ~~ 0 ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   584
	idx2 := packageString indexOf:$) startingAt:idx1+1.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   585
	idx2 ~~ 0 ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   586
	    sourceInfo := packageString copyFrom:idx1 + 1 to:idx2 - 1
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   587
	]
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   588
    ].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   589
    sourceInfo isNil ifTrue:[^ nil].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   590
    components := sourceInfo asCollectionOfSubstringsSeparatedBy:$:.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   591
    components size == 0 ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   592
	moduleString := 'stx'.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   593
	directoryString := libraryString := ''.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   594
	^ nil
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   595
    ] ifFalse:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   596
	components size == 1 ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   597
	    "/ a single name given - the module becomes 'stx',
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   598
	    "/ if the component includes slashes, its the directory
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   599
	    "/ otherwise the library
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   600
	    "/ 
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   601
	    moduleString := 'stx'.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   602
	    directoryString := libraryString := components at:1.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   603
	    (libraryString includes:$/) ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   604
		libraryString := libraryString asFilename baseName
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   605
	    ]
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   606
	] ifFalse:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   607
	    components size == 2 ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   608
		"/ two components - assume its the directory and the library
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   609
		moduleString := 'stx'.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   610
		directoryString := components at:1.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   611
		libraryString := components at:2.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   612
	    ] ifFalse:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   613
		"/ all components given
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   614
		moduleString := components at:1.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   615
		directoryString := components at:2.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   616
		libraryString := components at:3.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   617
	    ]
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   618
	]
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   619
    ].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   620
    libraryString isEmpty ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   621
	directoryString notEmpty ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   622
	    libraryString := directoryString asFilename baseName
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   623
	].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   624
	libraryString isEmpty ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   625
	    "/ lets extract the library from the liblist file ...
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   626
	    libraryString := Smalltalk libraryFileNameOfClass:self.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   627
	    libraryString isNil ifTrue:[^ nil].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   628
	]
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   629
    ].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   630
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   631
    moduleString isEmpty ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   632
	moduleString := 'stx'.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   633
    ].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   634
    directoryString isEmpty ifTrue:[
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   635
	directoryString := libraryString.
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   636
    ].
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   637
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   638
    ^ IdentityDictionary
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   639
	with:(#module->moduleString)
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   640
	with:(#directory->directoryString)
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   641
	with:(#library->libraryString)
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   642
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   643
    "
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   644
     Object sourceCodeInfo     
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   645
     View sourceCodeInfo    
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   646
     Model sourceCodeInfo  
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   647
     BinaryObjectStorage sourceCodeInfo  
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   648
     MemoryMonitor sourceCodeInfo  
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   649
     ClockView sourceCodeInfo  
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   650
    "
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   651
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   652
    "Created: 4.11.1995 / 20:36:53 / cg"
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   653
!
12f066c0ac29 method to extract sourceInfo from package string added
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
   654
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   655
history 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   656
    "return the history  of the class"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   657
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   658
    ^ history 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   659
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   660
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   661
     Object history   
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   662
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   663
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   664
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   665
setHistory:aString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   666
    "set the history of the class."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   667
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   668
    history  := aString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   669
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   670
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   671
primitiveDefinitionsString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   672
    "return the primitiveDefinition string or nil"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   673
357
claus
parents: 356
diff changeset
   674
    ^ self getPrimitiveSpecsAt:1
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   675
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   676
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   677
     Object primitiveDefinitionsString 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   678
     String primitiveDefinitionsString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   679
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   680
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   681
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   682
primitiveVariablesString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   683
    "return the primitiveVariables string or nil"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   684
357
claus
parents: 356
diff changeset
   685
    ^ self getPrimitiveSpecsAt:2 
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   686
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   687
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   688
primitiveFunctionsString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   689
    "return the primitiveFunctions string or nil"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   690
357
claus
parents: 356
diff changeset
   691
    ^ self getPrimitiveSpecsAt:3 
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   692
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   693
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   694
history:aString
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   695
    "set the history of the class."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   696
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   697
    history  := aString
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   698
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   699
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   700
primitiveSpec
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   701
    "return the primitiveSpec or nil"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   702
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   703
    ^  primitiveSpec
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   704
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   705
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   706
primitiveSpec:anArrayOf3ElementsOrNil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   707
    "set the primitiveSpec or nil"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   708
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   709
    primitiveSpec := anArrayOf3ElementsOrNil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   710
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   711
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   712
primitiveDefinitions:aString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   713
    "set the primitiveDefinition string"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   714
360
claus
parents: 359
diff changeset
   715
    self setPrimitiveSpecsAt:1 to:aString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   716
    self addChangeRecordForPrimitiveDefinitions:self.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   717
    self updateRevisionString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   718
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   719
    "Created: 29.10.1995 / 19:41:39 / cg"
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   720
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   721
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   722
primitiveVariables:aString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   723
    "set the primitiveVariable string"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   724
360
claus
parents: 359
diff changeset
   725
    self setPrimitiveSpecsAt:2 to:aString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   726
    self addChangeRecordForPrimitiveVariables:self.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   727
    self updateRevisionString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   728
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   729
    "Created: 29.10.1995 / 19:41:58 / cg"
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   730
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   731
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   732
primitiveFunctions:aString
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   733
    "set the primitiveFunction string"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   734
360
claus
parents: 359
diff changeset
   735
    self setPrimitiveSpecsAt:3 to:aString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   736
    self addChangeRecordForPrimitiveFunctions:self.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   737
    self updateRevisionString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   738
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   739
    "Created: 29.10.1995 / 19:41:48 / cg"
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   740
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   741
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   742
classFilename
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   743
    "return the name of the file from which the class was compiled.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   744
     This is currently NOT used."
10
claus
parents: 5
diff changeset
   745
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   746
    ^ classFilename
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   747
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   748
423
claus
parents: 421
diff changeset
   749
setClassFilename:aFilename
claus
parents: 421
diff changeset
   750
    "set the classes filename. 
claus
parents: 421
diff changeset
   751
     This is a dangerous (low level) operation, since the 
claus
parents: 421
diff changeset
   752
     comment and primitiveSpecs may no longer be accessable, if a wrong filename
claus
parents: 421
diff changeset
   753
     is set here."
claus
parents: 421
diff changeset
   754
claus
parents: 421
diff changeset
   755
    classFilename := aFilename
claus
parents: 421
diff changeset
   756
claus
parents: 421
diff changeset
   757
    "Modified: 8.9.1995 / 14:16:48 / claus"
claus
parents: 421
diff changeset
   758
!
claus
parents: 421
diff changeset
   759
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   760
definition
a27a279701f8 Initial revision
claus
parents:
diff changeset
   761
    "return an expression-string to define myself"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   762
a27a279701f8 Initial revision
claus
parents:
diff changeset
   763
    |s|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   764
a27a279701f8 Initial revision
claus
parents:
diff changeset
   765
    s := WriteStream on:(String new).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   766
    self fileOutDefinitionOn:s.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   767
    ^ s contents
a27a279701f8 Initial revision
claus
parents:
diff changeset
   768
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   769
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   770
     Object definition 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   771
     Point definition  
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   772
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   773
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   774
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   775
source
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   776
    "return the classes full source code"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   777
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   778
    |code aStream|
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   779
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   780
" this is too slow for big classes ...
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   781
    code := String new:1000.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   782
    aStream := WriteStream on:code.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   783
    self fileOutOn:aStream
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   784
"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   785
    aStream := FileStream newFileNamed:'__temp'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   786
    aStream isNil ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   787
	self notify:'cannot create temporary file.'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   788
	^ nil
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   789
    ].
399
claus
parents: 391
diff changeset
   790
    FileOutErrorSignal handle:[:ex |
claus
parents: 391
diff changeset
   791
	aStream nextPutAll:'"no source available"'.
claus
parents: 391
diff changeset
   792
    ] do:[
403
claus
parents: 399
diff changeset
   793
	self fileOutOn:aStream.
399
claus
parents: 391
diff changeset
   794
    ].
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   795
    aStream close.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   796
    aStream := FileStream oldFileNamed:'__temp'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   797
    aStream isNil ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   798
	self notify:'oops - cannot reopen temp file'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   799
	^ nil
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   800
    ].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   801
    code := aStream contents.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   802
    aStream close.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   803
    OperatingSystem removeFile:'__temp'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   804
    ^ code
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   805
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   806
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   807
sourceStream
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   808
    "return an open stream on my sourcefile, nil if that is not available"
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   809
524
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   810
    |source fileName aStream cls|
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   811
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   812
    classFilename notNil ifTrue:[
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   813
	source := classFilename
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   814
    ] ifFalse:[
524
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   815
	self isMeta ifTrue:[
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   816
	    cls := self soleInstance
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   817
	] ifFalse:[
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   818
	    cls := self
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   819
	].
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   820
	source := (Smalltalk fileNameForClass:cls) , '.st'
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   821
    ].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   822
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   823
    fileName := Smalltalk getSourceFileName:source.
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   824
    fileName isNil ifTrue:[
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   825
	fileName := source
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   826
    ].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   827
    aStream := fileName asFilename readStream.
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   828
    aStream isNil ifTrue:[
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   829
	"/      
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   830
	"/ hard case - there is no source file for this class
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   831
	"/ (neither in the source-dir-path, nor in the current directory).
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   832
	"/      
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   833
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   834
	"/      
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   835
	"/ look if my binary is from a dynamically loaded module,
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   836
	"/ and, if so, look in the modules directory for the
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   837
	"/ source file.
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   838
	"/      
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   839
	ObjectFileLoader notNil ifTrue:[
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   840
	    ObjectFileLoader loadedObjectHandlesDo:[:h |
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   841
		|f|
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   842
524
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   843
		aStream isNil ifTrue:[
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   844
		    (h classes includes:self) ifTrue:[
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   845
			f := h pathName.
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   846
			f := f asFilename directory.
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   847
			f := f construct:source.
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   848
			f exists ifTrue:[
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   849
			    aStream := f readStream.
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   850
			].
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   851
		    ].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   852
		]
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   853
	    ].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   854
	].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   855
    ].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   856
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   857
    aStream isNil ifTrue:[
524
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   858
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   859
	"/ mhmh - still no source file.
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   860
	"/ If there is a SourceCodeManager, ask it to aquire the
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   861
	"/ the source for my class, and return an open stream on it. 
524
1a5c3e68bd6a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 523
diff changeset
   862
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   863
	SourceCodeManager notNil ifTrue:[
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   864
	    aStream := SourceCodeManager sourceStreamFor:self.
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   865
	]
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   866
    ].
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   867
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   868
    ^ aStream
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   869
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   870
    "
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   871
     Object sourceStream
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   872
     Clock sourceStream
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   873
    "
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   874
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   875
    "Created: 10.11.1995 / 21:05:13 / cg"
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   876
!
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
   877
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   878
addClassVarName:aString
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   879
    "add a class variable if not already there and initialize it with nil.
391
claus
parents: 385
diff changeset
   880
     Also writes a change record and notifies dependents.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   881
     BUG: Currently, no recompilation is done - this will change."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   882
a27a279701f8 Initial revision
claus
parents:
diff changeset
   883
    (self classVarNames includes:aString) ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   884
	self classVariableString:(self classVariableString , ' ' , aString).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   885
	self addChangeRecordForClass:self.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   886
	self updateRevisionString.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   887
	self changed:#definition.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   888
    ]
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   889
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   890
    "Created: 29.10.1995 / 19:40:51 / cg"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   891
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   892
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   893
sharedPools
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   894
    "ST/X does not (currently) support pools"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   895
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   896
    ^ #()
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   897
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   898
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   899
setClassVariableString:aString
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   900
    "set the classes classvarnames string. 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   901
     This is a dangerous (low level) operation, since the 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   902
     classvariables are not really created or updated. Also,
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   903
     NO change record is written."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   904
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   905
    classvars := aString
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   906
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
   907
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   908
removeClassVarName:aString
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   909
    "remove a class variable if not already there.
391
claus
parents: 385
diff changeset
   910
     Also writes a change record and notifies dependents.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   911
     BUG: Currently, no recompilation is done - this will change."
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   912
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   913
    |names newNames|
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   914
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   915
    names := self classVarNames.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   916
    (names includes:aString) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   917
	newNames := ''.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   918
	names do:[:nm | nm ~= aString ifTrue:[newNames := newNames , nm , ' ']].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   919
	self classVariableString:newNames withoutSpaces.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   920
	self addChangeRecordForClass:self.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   921
	self updateRevisionString.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   922
	self changed:#definition.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   923
    ]
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   924
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   925
    "Created: 29.10.1995 / 19:42:08 / cg"
85
claus
parents: 77
diff changeset
   926
!
claus
parents: 77
diff changeset
   927
claus
parents: 77
diff changeset
   928
renameCategory:oldCategory to:newCategory
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   929
    "rename a category (changes category of those methods).
391
claus
parents: 385
diff changeset
   930
     Appends a change record and notifies dependents."
85
claus
parents: 77
diff changeset
   931
claus
parents: 77
diff changeset
   932
    |any|
claus
parents: 77
diff changeset
   933
claus
parents: 77
diff changeset
   934
    any := false.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   935
    methodArray do:[:aMethod |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   936
	aMethod category = oldCategory ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   937
	    aMethod category:newCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   938
	    any := true.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   939
	]
85
claus
parents: 77
diff changeset
   940
    ].
claus
parents: 77
diff changeset
   941
    any ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   942
	self addChangeRecordForRenameCategory:oldCategory to:newCategory.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   943
	self updateRevisionString.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   944
	self changed:#methodCategory.
85
claus
parents: 77
diff changeset
   945
    ]
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   946
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   947
    "Created: 29.10.1995 / 19:42:15 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   948
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   949
a27a279701f8 Initial revision
claus
parents:
diff changeset
   950
!Class methodsFor:'adding/removing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   951
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   952
addSelector:newSelector withMethod:newMethod
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   953
    "add the method given by 2nd argument under the selector given by
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   954
     1st argument to the methodDictionary. 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   955
     Append a change record to the changes file and tell dependents."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   956
362
claus
parents: 360
diff changeset
   957
    |oldMethod|
claus
parents: 360
diff changeset
   958
claus
parents: 360
diff changeset
   959
    CatchMethodRedefinitions ifTrue:[
claus
parents: 360
diff changeset
   960
	"check for attempts to redefine a method
claus
parents: 360
diff changeset
   961
	 in a different package. Signal a resumable error if so.
claus
parents: 360
diff changeset
   962
	 This allows tracing redefinitions of existing system methods
claus
parents: 360
diff changeset
   963
	 when filing in alien code ....
claus
parents: 360
diff changeset
   964
	 (which we may want to forbit sometimes)
claus
parents: 360
diff changeset
   965
	"
claus
parents: 360
diff changeset
   966
	oldMethod := self compiledMethodAt:newSelector.
claus
parents: 360
diff changeset
   967
	oldMethod notNil ifTrue:[
claus
parents: 360
diff changeset
   968
	    oldMethod package ~= newMethod package ifTrue:[
claus
parents: 360
diff changeset
   969
		"
claus
parents: 360
diff changeset
   970
		 attempt to redefine an existing method, which was
claus
parents: 360
diff changeset
   971
		 defined in another package.
claus
parents: 360
diff changeset
   972
		 If you continue in the debugger, the new method gets installed.
claus
parents: 360
diff changeset
   973
		 Otherwise, the existing (old) method remains valid.
claus
parents: 360
diff changeset
   974
claus
parents: 360
diff changeset
   975
		 You can turn of the catching of redefinitions by setting
claus
parents: 360
diff changeset
   976
		   CatchMethodRedefinitions to false
claus
parents: 360
diff changeset
   977
		 (also found in the NewLaunchers 'settings-misc' menu)
claus
parents: 360
diff changeset
   978
		"
406
claus
parents: 403
diff changeset
   979
		MethodRedefinitionSignal 
claus
parents: 403
diff changeset
   980
		    raiseErrorString:(' ' , name , '>>' , newSelector) 
362
claus
parents: 360
diff changeset
   981
	    ]
claus
parents: 360
diff changeset
   982
	]
claus
parents: 360
diff changeset
   983
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   984
    (super addSelector:newSelector withMethod:newMethod) ifTrue:[
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   985
	self updateRevisionString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   986
	self addChangeRecordForMethod:newMethod.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   987
    ]
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   988
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
   989
    "Created: 29.10.1995 / 19:42:42 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   990
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   991
a27a279701f8 Initial revision
claus
parents:
diff changeset
   992
removeSelector:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
   993
    "remove the selector, aSelector and its associated method 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   994
     from the methodDictionary.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   995
     Append a change record to the changes file and tell dependents."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   996
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   997
    (super removeSelector:aSelector) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   998
	self addChangeRecordForRemoveSelector:aSelector.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
   999
	self updateRevisionString.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1000
	self changed:#methodDictionary with:aSelector.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1001
    ]
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1002
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1003
    "Created: 29.10.1995 / 19:42:47 / cg"
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1004
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1005
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1006
unload
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1007
    "if the receiver was autoloaded, unload and reinstall it as
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1008
     autoloaded. Can be used to get rid of no longer needed autoloaded
328
claus
parents: 326
diff changeset
  1009
     classes. 
claus
parents: 326
diff changeset
  1010
     (maybe, autoloaded classes should unload themselfes when no
claus
parents: 326
diff changeset
  1011
      longer needed - for example, after some delay when the last instance 
claus
parents: 326
diff changeset
  1012
      is gone ...)"
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1013
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1014
    |nm|
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1015
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1016
    self wasAutoloaded ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1017
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1018
	"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1019
	 can it be done ?
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1020
	"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1021
	self methodArray do:[:aMethod |
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1022
	    aMethod source isNil ifTrue:[^false].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1023
	    aMethod hasPrimitiveCode ifTrue:[^ false].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1024
	].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1025
    ].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1026
283
a897d331b4c1 *** empty log message ***
claus
parents: 278
diff changeset
  1027
    self allSubclassesDo:[:aClass |
a897d331b4c1 *** empty log message ***
claus
parents: 278
diff changeset
  1028
	aClass unload
a897d331b4c1 *** empty log message ***
claus
parents: 278
diff changeset
  1029
    ].
a897d331b4c1 *** empty log message ***
claus
parents: 278
diff changeset
  1030
    Transcript showCr:'unloading ' , name.
a897d331b4c1 *** empty log message ***
claus
parents: 278
diff changeset
  1031
359
claus
parents: 357
diff changeset
  1032
    Autoload removeClass:self.    
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1033
    nm := name.
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1034
    Smalltalk at:nm put:nil.
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1035
    name := nm , ' (leftover)'.
288
88283f196381 *** empty log message ***
claus
parents: 283
diff changeset
  1036
    ObjectMemory flushInlineCaches.
88283f196381 *** empty log message ***
claus
parents: 283
diff changeset
  1037
    ObjectMemory flushMethodCache.
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1038
    Autoload addClass:nm inCategory:category.
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1039
    ^ true
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1040
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1041
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1042
     Clock open.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1043
     Clock unload.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1044
     ClockView unload.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1045
     Clock open
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1046
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1047
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1048
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1049
!Class methodsFor:'binary storage'!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1050
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1051
addGlobalsTo: globalDictionary manager: manager
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1052
"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1053
    classPool == nil ifFalse: [
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1054
	classPool associationsDo: [:assoc|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1055
	    globalDictionary at: assoc put: self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1056
	]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1057
    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1058
"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1059
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1060
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1061
storeBinaryDefinitionOn: stream manager: manager
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1062
    "classes will store the name, signature and instvar names.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1063
     They restore by looking for that name in the Smalltalk dictionary.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1064
     However, using the signature, a check for being valid is made at
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1065
     restore time."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1066
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1067
    |varnames n sz|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1068
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1069
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1070
     output the signature
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1071
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1072
    stream nextNumber:4 put:self signature.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1073
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1074
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1075
     output the instance variable name string
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1076
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1077
    varnames := self allInstVarNames.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1078
    n := varnames size.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1079
    n == 0 ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1080
	sz := 0
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1081
    ] ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1082
	sz := varnames inject:0 into:[:sum :nm | sum + nm size].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1083
	sz := sz + n - 1.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1084
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1085
    stream nextNumber:2 put:sz.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1086
    varnames keysAndValuesDo:[:i :nm |
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1087
	nm do:[:c |
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1088
	    stream nextPut:c asciiValue
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1089
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1090
	i ~~ n ifTrue:[stream nextPut:(Character space asciiValue)]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1091
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1092
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1093
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1094
     output my name
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1095
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1096
    stream nextNumber:2 put:name size.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1097
    name do:[:c| 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1098
	stream nextPut:c asciiValue
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1099
    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1100
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1101
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1102
     |s|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1103
     s := WriteStream on:ByteArray new.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1104
     Rectangle storeBinaryOn:s.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1105
     Object readBinaryFrom:(ReadStream on:s contents)  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1106
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1107
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1108
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1109
storeBinaryDefinitionOf: anAssociation on: stream manager: manager
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1110
    "not usable at the moment - there are no classpools currently"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1111
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1112
    | string |
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1113
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1114
    string := self name, ' classPool at: ', anAssociation key storeString.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1115
    stream nextNumber: 2 put: string size.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1116
    string do: [:char| stream nextPut: char asciiValue]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1117
! !
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1118
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1119
!Class methodsFor:'c function interfacing'!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1120
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1121
cInterfaceFunction:selector calling:cFunctionNameString args:argTypeArray returning:returnType
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1122
    "create an interface to an existing (i.e. already linked in) c function.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1123
     The function can be called by sending selector to the receiver class.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1124
     The c-function has the name cFunctionNameString, and expects parameters as specified in
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1125
     argTypeArray. The functions return value has a type as specified by returnType.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1126
     WARNING: 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1127
	this interface is EXPERIMENTAL - it may change or even be removed."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1128
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1129
    StubGenerator isNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1130
	^ self error:'this system does not support dynamic C Interface functions'.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1131
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1132
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1133
    StubGenerator 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1134
	createStubFor:selector 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1135
	calling:cFunctionNameString 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1136
	args:argTypeArray 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1137
	returning:returnType
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1138
	in:self                          
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1139
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1140
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1141
     Object subclass:#CInterface
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1142
	    instanceVariableNames:''
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1143
	    classVariableNames:''
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1144
	    poolDictionaries:''
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1145
	    category:'Examples'.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1146
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1147
     CInterface cInterfaceFunction:#printfOn:format:withFloat: 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1148
			   calling:'fprintf' 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1149
			      args:#(ExternalStream String Float) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1150
			 returning:#SmallInteger.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1151
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1152
     CInterface printfOn:Stdout format:'this is a float: %g' withFloat:(Float pi). Stdout cr  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1153
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1154
! !
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1155
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1156
!Class methodsFor:'changes management'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1157
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1158
addChangeRecordForMethod:aMethod to:aStream
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1159
    "append a method-change-record to aStream"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1160
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1161
    self fileOutMethod:aMethod on:aStream.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1162
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1163
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1164
changesStream
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1165
    "return a Stream for the writing changes file - or nil if no update is wanted"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1166
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1167
    |streamType aStream fileName|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1168
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1169
    (UpdateChangeFileQuerySignal raise) ifTrue:[
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1170
	fileName := ObjectMemory nameForChanges.
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1171
        
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1172
	LockChangesFile ifTrue:[
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1173
	    streamType := LockedFileStream. 
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1174
	] ifFalse:[
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1175
	    streamType := FileStream.
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1176
	].
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1177
	aStream := streamType oldFileNamed:fileName.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1178
	aStream isNil ifTrue:[
488
1677ee52d630 hooks for change-file-locking. Experimental
Claus Gittinger <cg@exept.de>
parents: 484
diff changeset
  1179
	    aStream := streamType newFileNamed:fileName.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1180
	    aStream isNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1181
		self warn:'cannot create/update the changes file'.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1182
		^ nil
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1183
	    ]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1184
	].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1185
	aStream setToEnd
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1186
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1187
    ^ aStream
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1188
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1189
    "Created: 28.10.1995 / 16:53:43 / cg"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1190
    "Modified: 28.10.1995 / 16:55:03 / cg"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1191
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1192
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1193
writingChangeDo:aBlock
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1194
    "common helper to write a change record.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1195
     Opens the changefile and executes aBlock passing the stream
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1196
     as argument. WriteErrors are cought and will lead to a warning.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1197
     The changefile is not kept open, to force the change to go to disk
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1198
     as soon as possible - thus, in case of a crash, no changes should
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1199
     be lost due to buffering."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1200
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1201
    |aStream|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1202
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1203
    aStream := self changesStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1204
    aStream notNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1205
	FileStream writeErrorSignal handle:[:ex |
355
2d96938a5081 *** empty log message ***
claus
parents: 345
diff changeset
  1206
	    self warn:('could not update the changes-file\\' , ex errorString) withCRs.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1207
	    ex return
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1208
	] do:[
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1209
	    aBlock value:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1210
	    aStream cr.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1211
	].
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1212
	aStream close
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1213
    ]
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1214
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1215
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1216
writingChangePerform:aSelector with:anArgument
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1217
    self writingChangeDo:[:stream |
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1218
	self perform:aSelector with:anArgument with:stream.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1219
    ]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1220
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1221
    "Created: 28.10.1995 / 16:50:48 / cg"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1222
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1223
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1224
withoutUpdatingChangesDo:aBlock
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1225
    "turn off change file update while evaluating aBlock.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1226
     This method makes sure, that the update-flag is correctly restored
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1227
     in case of an abort or other error."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1228
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1229
    UpdateChangeFileQuerySignal handle:[:ex | 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1230
	ex proceedWith:false
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1231
    ] do:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1232
	aBlock value
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1233
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1234
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1235
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1236
addChangeRecordForMethod:aMethod
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1237
    "add a method-change-record to the changes file"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1238
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1239
    (UpdateChangeFileQuerySignal raise) "UpdatingChanges" ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1240
	self writingChangePerform:#addChangeRecordForMethod:to: with:aMethod.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1241
	"this test allows a smalltalk without Projects/ChangeSets"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1242
	Project notNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1243
	    Project addMethodChange:aMethod in:self
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1244
	]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1245
    ]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1246
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1247
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1248
sourcesStream
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1249
    "return a stream for writing the sources file.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1250
     Notice, in ST/X, it is noncommon to use a single
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1251
     source file; typically each classes source is kept
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1252
     in a separate file."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1253
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1254
    |aStream fileName|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1255
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1256
    fileName := ObjectMemory nameForSources.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1257
    aStream := FileStream oldFileNamed:fileName.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1258
    aStream isNil ifTrue:[
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1259
	aStream := FileStream newFileNamed:fileName.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1260
	aStream isNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1261
	    Transcript showCr:'cannot update sources file'.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1262
	    ^ nil
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1263
	]
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1264
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1265
    aStream setToEnd.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1266
    ^ aStream
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1267
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1268
    "Created: 28.10.1995 / 16:53:17 / cg"
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1269
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1270
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1271
addChangeRecordForRemoveSelector:aSelector to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1272
    "append a method-remove-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1273
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1274
    self printClassNameOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1275
    aStream nextPutAll:(' removeSelector:#' , aSelector).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1276
    aStream nextPutChunkSeparator.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1277
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1278
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1279
addChangeRecordForMethodCategory:aMethod category:newCategory to:aStream
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1280
    "append a methodCategory-change-record to aStream"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1281
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1282
    |selector|
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1283
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1284
    selector := aMethod selector.
326
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
  1285
    selector notNil ifTrue:[
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
  1286
	aStream nextPutAll:'('.
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
  1287
	self printClassNameOn:aStream.
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
  1288
	aStream nextPutAll:(' compiledMethodAt:' , selector storeString).
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
  1289
	aStream nextPutAll:(') category:' , newCategory storeString).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1290
	aStream nextPutChunkSeparator.
326
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
  1291
    ]
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1292
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1293
414
claus
parents: 412
diff changeset
  1294
addChangeRecordForMethodPrivacy:aMethod to:aStream
claus
parents: 412
diff changeset
  1295
    "append a method-privacy-change-record to aStream"
claus
parents: 412
diff changeset
  1296
claus
parents: 412
diff changeset
  1297
    |selector|
claus
parents: 412
diff changeset
  1298
claus
parents: 412
diff changeset
  1299
    selector := aMethod selector.
claus
parents: 412
diff changeset
  1300
    selector notNil ifTrue:[
claus
parents: 412
diff changeset
  1301
	aStream nextPutAll:'('.
claus
parents: 412
diff changeset
  1302
	self printClassNameOn:aStream.
claus
parents: 412
diff changeset
  1303
	aStream nextPutAll:(' compiledMethodAt:' , selector storeString).
claus
parents: 412
diff changeset
  1304
	aStream nextPutAll:(') privacy:' , aMethod privacy storeString).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1305
	aStream nextPutChunkSeparator.
414
claus
parents: 412
diff changeset
  1306
    ]
claus
parents: 412
diff changeset
  1307
claus
parents: 412
diff changeset
  1308
    "Modified: 27.8.1995 / 22:59:56 / claus"
claus
parents: 412
diff changeset
  1309
!
claus
parents: 412
diff changeset
  1310
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1311
addChangeRecordForClass:aClass to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1312
    "append a class-definition-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1313
403
claus
parents: 399
diff changeset
  1314
    aClass isLoaded ifTrue:[
claus
parents: 399
diff changeset
  1315
	aClass fileOutDefinitionOn:aStream.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1316
	aStream nextPutChunkSeparator.
403
claus
parents: 399
diff changeset
  1317
    ]
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1318
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1319
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1320
addChangeRecordForClassInstvars:aClass to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1321
    "append a class-instvars-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1322
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1323
    aClass fileOutClassInstVarDefinitionOn:aStream.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1324
    aStream nextPutChunkSeparator.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1325
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1326
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1327
addChangeRecordForClassComment:aClass to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1328
    "append a class-comment-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1329
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1330
    aClass fileOutCommentOn:aStream.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1331
    aStream nextPutChunkSeparator.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1332
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1333
360
claus
parents: 359
diff changeset
  1334
addChangeRecordForPrimitiveVariables:aClass to:aStream
claus
parents: 359
diff changeset
  1335
    "append a primitiveVariables-record to aStream"
claus
parents: 359
diff changeset
  1336
claus
parents: 359
diff changeset
  1337
    aStream nextPutAll:aClass name 
435
claus
parents: 432
diff changeset
  1338
			, ' primitiveVariables:' 
360
claus
parents: 359
diff changeset
  1339
			, aClass primitiveVariablesString storeString.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1340
    aStream nextPutChunkSeparator.
360
claus
parents: 359
diff changeset
  1341
!
claus
parents: 359
diff changeset
  1342
claus
parents: 359
diff changeset
  1343
addChangeRecordForPrimitiveDefinitions:aClass to:aStream
claus
parents: 359
diff changeset
  1344
    "append a primitiveDefinitions-record to aStream"
claus
parents: 359
diff changeset
  1345
claus
parents: 359
diff changeset
  1346
    aStream nextPutAll:aClass name 
435
claus
parents: 432
diff changeset
  1347
			, ' primitiveDefinitions:' 
360
claus
parents: 359
diff changeset
  1348
			, aClass primitiveDefinitionsString storeString.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1349
    aStream nextPutChunkSeparator.
360
claus
parents: 359
diff changeset
  1350
!
claus
parents: 359
diff changeset
  1351
claus
parents: 359
diff changeset
  1352
addChangeRecordForPrimitiveFunctions:aClass to:aStream
claus
parents: 359
diff changeset
  1353
    "append a primitiveFunctions-record to aStream"
claus
parents: 359
diff changeset
  1354
claus
parents: 359
diff changeset
  1355
    aStream nextPutAll:aClass name 
435
claus
parents: 432
diff changeset
  1356
			, ' primitiveFunctions:' 
360
claus
parents: 359
diff changeset
  1357
			, aClass primitiveFunctionsString storeString.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1358
    aStream nextPutChunkSeparator.
360
claus
parents: 359
diff changeset
  1359
!
claus
parents: 359
diff changeset
  1360
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1361
addChangeRecordForClassRename:oldName to:newName to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1362
    "append a class-rename-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1363
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1364
    aStream nextPutAll:('Smalltalk renameClass:' , oldName , ' to:''' , newName , '''').
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1365
    aStream nextPutChunkSeparator.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1366
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1367
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1368
addChangeRecordForClassRemove:oldName to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1369
    "append a class-remove-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1370
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1371
    aStream nextPutAll:('Smalltalk removeClass:' , oldName).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1372
    aStream nextPutChunkSeparator.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1373
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1374
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1375
addChangeRecordForRenameCategory:oldCategory to:newCategory to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1376
    "append a category-rename record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1377
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1378
    self printClassNameOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1379
    aStream nextPutAll:(' renameCategory:' , oldCategory storeString).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1380
    aStream nextPutAll:(' to:' , newCategory storeString).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1381
    aStream nextPutChunkSeparator.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1382
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1383
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1384
addInfoRecord:aMessage to:aStream
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1385
    "append an info-record (snapshot, class fileOut etc.) to aStream"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1386
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1387
    aStream nextPutAll:('''---- ' , aMessage , ' ',
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1388
			Date today printString , ' ' ,
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1389
			Time now printString ,
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1390
			' ----''').
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1391
    aStream nextPutChunkSeparator.
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1392
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1393
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1394
addChangeRecordForChangeCategory:category to:aStream
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1395
    "append a category change record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1396
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1397
    self printClassNameOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1398
    aStream nextPutAll:(' category:' , category storeString).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1399
    aStream nextPutChunkSeparator.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1400
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1401
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1402
addChangeRecordForClass:aClass
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1403
    "add a class-definition-record to the changes file"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1404
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1405
    self writingChangePerform:#addChangeRecordForClass:to: with:aClass.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1406
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1407
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1408
addChangeRecordForSnapshot:aFileName to:aStream
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1409
    "add a snapshot-record to aStream"
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1410
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1411
    self addInfoRecord:('snapshot ' , aFileName) to:aStream
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1412
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1413
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1414
addChangeRecordForRemoveSelector:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1415
    "add a method-remove-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1416
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1417
    self writingChangePerform:#addChangeRecordForRemoveSelector:to: with:aSelector.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1418
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1419
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1420
addChangeRecordForMethodCategory:aMethod category:aString
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1421
    "add a methodCategory-change-record to the changes file"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1422
421
claus
parents: 415
diff changeset
  1423
    (UpdateChangeFileQuerySignal raise) "UpdatingChanges" ifTrue:[
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1424
	self writingChangeDo:[:aStream |
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1425
	    self addChangeRecordForMethodCategory:aMethod category:aString to:aStream.
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1426
	].
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1427
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1428
	"this test allows a smalltalk without Projects/ChangeSets"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1429
	Project notNil ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1430
	    Project addMethodCategoryChange:aMethod category:aString in:self
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1431
	]
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1432
    ]
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1433
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1434
414
claus
parents: 412
diff changeset
  1435
addChangeRecordForMethodPrivacy:aMethod
claus
parents: 412
diff changeset
  1436
    "add a method-privacy-change-record to the changes file"
claus
parents: 412
diff changeset
  1437
421
claus
parents: 415
diff changeset
  1438
    (UpdateChangeFileQuerySignal raise) "UpdatingChanges" ifTrue:[
414
claus
parents: 412
diff changeset
  1439
	self writingChangePerform:#addChangeRecordForMethodPrivacy:to: with:aMethod.
claus
parents: 412
diff changeset
  1440
	"this test allows a smalltalk without Projects/ChangeSets"
claus
parents: 412
diff changeset
  1441
	Project notNil ifTrue:[
claus
parents: 412
diff changeset
  1442
	    Project addMethodPrivacyChange:aMethod in:self
claus
parents: 412
diff changeset
  1443
	]
claus
parents: 412
diff changeset
  1444
    ]
claus
parents: 412
diff changeset
  1445
claus
parents: 412
diff changeset
  1446
    "Modified: 27.8.1995 / 22:47:32 / claus"
claus
parents: 412
diff changeset
  1447
!
claus
parents: 412
diff changeset
  1448
2
claus
parents: 1
diff changeset
  1449
addChangeRecordForClassInstvars:aClass
claus
parents: 1
diff changeset
  1450
    "add a class-instvars-record to the changes file"
claus
parents: 1
diff changeset
  1451
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1452
    self writingChangePerform:#addChangeRecordForClassInstvars:to: with:aClass.
2
claus
parents: 1
diff changeset
  1453
!
claus
parents: 1
diff changeset
  1454
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1455
addChangeRecordForClassComment:aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1456
    "add a class-comment-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1457
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1458
    self writingChangePerform:#addChangeRecordForClassComment:to: with:aClass.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1459
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1460
360
claus
parents: 359
diff changeset
  1461
addChangeRecordForPrimitiveVariables:aClass
claus
parents: 359
diff changeset
  1462
    "add a primitiveVariables-record to the changes file"
claus
parents: 359
diff changeset
  1463
claus
parents: 359
diff changeset
  1464
    self writingChangePerform:#addChangeRecordForPrimitiveVariables:to: with:aClass.
claus
parents: 359
diff changeset
  1465
!
claus
parents: 359
diff changeset
  1466
claus
parents: 359
diff changeset
  1467
addChangeRecordForPrimitiveDefinitions:aClass
claus
parents: 359
diff changeset
  1468
    "add a primitiveDefinitions-record to the changes file"
claus
parents: 359
diff changeset
  1469
claus
parents: 359
diff changeset
  1470
    self writingChangePerform:#addChangeRecordForPrimitiveDefinitions:to: with:aClass.
claus
parents: 359
diff changeset
  1471
!
claus
parents: 359
diff changeset
  1472
claus
parents: 359
diff changeset
  1473
addChangeRecordForPrimitiveFunctions:aClass
claus
parents: 359
diff changeset
  1474
    "add a primitiveFunctions-record to the changes file"
claus
parents: 359
diff changeset
  1475
claus
parents: 359
diff changeset
  1476
    self writingChangePerform:#addChangeRecordForPrimitiveFunctions:to: with:aClass.
claus
parents: 359
diff changeset
  1477
!
claus
parents: 359
diff changeset
  1478
10
claus
parents: 5
diff changeset
  1479
addChangeRecordForClassRename:oldName to:newName
claus
parents: 5
diff changeset
  1480
    "add a class-rename-record to the changes file"
claus
parents: 5
diff changeset
  1481
421
claus
parents: 415
diff changeset
  1482
    self writingChangeDo:[:aStream |
claus
parents: 415
diff changeset
  1483
	self addChangeRecordForClassRename:oldName to:newName to:aStream
10
claus
parents: 5
diff changeset
  1484
    ]
claus
parents: 5
diff changeset
  1485
!
claus
parents: 5
diff changeset
  1486
claus
parents: 5
diff changeset
  1487
addChangeRecordForClassRemove:oldName
claus
parents: 5
diff changeset
  1488
    "add a class-remove-record to the changes file"
claus
parents: 5
diff changeset
  1489
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1490
    self writingChangePerform:#addChangeRecordForClassRemove:to: with:oldName.
10
claus
parents: 5
diff changeset
  1491
!
claus
parents: 5
diff changeset
  1492
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1493
addInfoRecord:aMessage
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1494
    "add an info-record (snapshot, class fileOut etc.) to the changes file"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1495
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1496
    self writingChangePerform:#addInfoRecord:to: with:aMessage.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1497
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1498
85
claus
parents: 77
diff changeset
  1499
addChangeRecordForRenameCategory:oldCategory to:newCategory
claus
parents: 77
diff changeset
  1500
    "add a category-rename record to the changes file"
claus
parents: 77
diff changeset
  1501
421
claus
parents: 415
diff changeset
  1502
    self writingChangeDo:[:aStream |
claus
parents: 415
diff changeset
  1503
	self addChangeRecordForRenameCategory:oldCategory to:newCategory to:aStream.
85
claus
parents: 77
diff changeset
  1504
    ]
claus
parents: 77
diff changeset
  1505
!
claus
parents: 77
diff changeset
  1506
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1507
addChangeRecordForClassFileOut:aClass
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1508
    "append a class-was-filedOut-record to the changes file"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1509
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1510
    self addInfoRecord:('fileOut ' , aClass name) 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1511
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1512
85
claus
parents: 77
diff changeset
  1513
addChangeRecordForChangeCategory
claus
parents: 77
diff changeset
  1514
    "add a category change record to the changes file"
claus
parents: 77
diff changeset
  1515
302
1f76060d58a4 *** empty log message ***
claus
parents: 295
diff changeset
  1516
    self writingChangePerform:#addChangeRecordForChangeCategory:to: with:category.
85
claus
parents: 77
diff changeset
  1517
!
claus
parents: 77
diff changeset
  1518
22
847106305963 *** empty log message ***
claus
parents: 10
diff changeset
  1519
addChangeRecordForSnapshot:aFileName
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1520
    "add a snapshot-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1521
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1522
    self addInfoRecord:('snapshot ' , aFileName) 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1523
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1524
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1525
!Class methodsFor:'compiling'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1526
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1527
compile:code
328
claus
parents: 326
diff changeset
  1528
    "compile code, aString for this class; 
claus
parents: 326
diff changeset
  1529
     if sucessful update the method dictionary."
claus
parents: 326
diff changeset
  1530
claus
parents: 326
diff changeset
  1531
    self compilerClass 
claus
parents: 326
diff changeset
  1532
	compile:code 
claus
parents: 326
diff changeset
  1533
	forClass:self
claus
parents: 326
diff changeset
  1534
!
claus
parents: 326
diff changeset
  1535
claus
parents: 326
diff changeset
  1536
compile:code classified:category
claus
parents: 326
diff changeset
  1537
    "compile code, aString for this class; 
claus
parents: 326
diff changeset
  1538
     if sucessful update the method dictionary. 
claus
parents: 326
diff changeset
  1539
     The method is classified under category."
claus
parents: 326
diff changeset
  1540
claus
parents: 326
diff changeset
  1541
    self compilerClass 
claus
parents: 326
diff changeset
  1542
	compile:code 
claus
parents: 326
diff changeset
  1543
	forClass:self 
claus
parents: 326
diff changeset
  1544
	inCategory:category
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1545
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1546
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1547
compile:code notifying:requestor
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1548
    "compile code, aString for this class; on any error, notify
328
claus
parents: 326
diff changeset
  1549
     requestor, anObject with the error reason."
claus
parents: 326
diff changeset
  1550
claus
parents: 326
diff changeset
  1551
    self compilerClass 
claus
parents: 326
diff changeset
  1552
	compile:code 
claus
parents: 326
diff changeset
  1553
	forClass:self 
claus
parents: 326
diff changeset
  1554
	notifying:requestor
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1555
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1556
2
claus
parents: 1
diff changeset
  1557
recompileMethodsAccessingAny:setOfNames
claus
parents: 1
diff changeset
  1558
    "recompile all methods accessing a variable from setOfNames"
claus
parents: 1
diff changeset
  1559
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1560
    self recompileMethodsAccessingAny:setOfNames orSuper:false 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1561
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1562
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1563
recompileMethodsAccessingAny:setOfNames orSuper:superBoolean
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1564
    "recompile all methods accessing a variable from setOfNames,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1565
     or super (if superBoolean is true)"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1566
2
claus
parents: 1
diff changeset
  1567
    |p|
claus
parents: 1
diff changeset
  1568
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1569
    selectorArray do:[:aSelector |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1570
	|m|
2
claus
parents: 1
diff changeset
  1571
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1572
	m := self compiledMethodAt:aSelector.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1573
	p := Parser parseMethod:(m source) in:self.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1574
	(p isNil 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1575
	 or:[(p usedVars notNil and:[p usedVars includesAny:setOfNames])
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1576
	 or:[superBoolean and:[p usesSuper]]]) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1577
	    self recompile:aSelector
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1578
	]
2
claus
parents: 1
diff changeset
  1579
    ]
claus
parents: 1
diff changeset
  1580
!
claus
parents: 1
diff changeset
  1581
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1582
recompile:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1583
    "recompile the method associated with the argument, aSelector;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1584
     used when a superclass changes instances and we have to recompile
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1585
     subclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1586
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1587
    |cat code|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1588
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1589
    Class withoutUpdatingChangesDo:[
362
claus
parents: 360
diff changeset
  1590
	Class methodRedefinitionSignal handle:[:ex |
claus
parents: 360
diff changeset
  1591
	    ex proceed
claus
parents: 360
diff changeset
  1592
	] do:[
claus
parents: 360
diff changeset
  1593
	    cat := (self compiledMethodAt:aSelector) category.
claus
parents: 360
diff changeset
  1594
	    code := self sourceCodeAt:aSelector.
claus
parents: 360
diff changeset
  1595
	    self compilerClass compile:code forClass:self inCategory:cat
claus
parents: 360
diff changeset
  1596
	]
2
claus
parents: 1
diff changeset
  1597
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1598
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1599
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1600
recompile
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1601
    "recompile all methods
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1602
     used when a class changes instances and therefore all methods
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1603
     have to be recompiled"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1604
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1605
    selectorArray do:[:aSelector |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1606
	self recompile:aSelector
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1607
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1608
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1609
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1610
recompileAll
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1611
    "recompile this class and all subclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1612
2
claus
parents: 1
diff changeset
  1613
    |classes|
claus
parents: 1
diff changeset
  1614
claus
parents: 1
diff changeset
  1615
    classes := self subclasses.
claus
parents: 1
diff changeset
  1616
    self recompile.
claus
parents: 1
diff changeset
  1617
    classes do:[:aClass |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1618
	aClass recompileAll
2
claus
parents: 1
diff changeset
  1619
    ]
claus
parents: 1
diff changeset
  1620
!
claus
parents: 1
diff changeset
  1621
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1622
recompileInvalidatedMethods:trap
2
claus
parents: 1
diff changeset
  1623
    "recompile all invalidated methods"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1624
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1625
    |trapCode trapByteCode|
2
claus
parents: 1
diff changeset
  1626
claus
parents: 1
diff changeset
  1627
    trapCode := trap code.
claus
parents: 1
diff changeset
  1628
    trapByteCode := trap byteCode.
claus
parents: 1
diff changeset
  1629
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1630
    selectorArray do:[:aSelector |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1631
	|m|
2
claus
parents: 1
diff changeset
  1632
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1633
	m := self compiledMethodAt:aSelector.
362
claus
parents: 360
diff changeset
  1634
	((m code = trapCode) and:[m byteCode == trapByteCode]) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1635
	    self recompile:aSelector
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1636
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1637
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1638
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1639
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1640
!Class methodsFor:'fileIn interface'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1641
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1642
methodsFor:aCategory
10
claus
parents: 5
diff changeset
  1643
    "return a ClassCategoryReader to read in and compile methods for me.
claus
parents: 5
diff changeset
  1644
     This one actually creates the ClassReader when code is filed-in."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1645
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1646
    ^ ClassCategoryReader class:self category:aCategory
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1647
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1648
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1649
publicMethodsFor:aCategory
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1650
    "this method allows fileIn of ENVY methods 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1651
     (although ST/X currently does NOT support method visibility).
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1652
     Returns a ClassCategoryReader to read in and compile methods for me."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1653
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1654
    ^ self methodsFor:aCategory
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1655
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1656
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1657
privateMethodsFor:aCategory
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1658
    "this method allows fileIn of ENVY methods 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1659
     (although ST/X currently does NOT really enforce method visibility yet).
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1660
     Returns a ClassCategoryReader to read in and compile methods for me."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1661
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1662
    ^ (self methodsFor:aCategory) privateProtocol
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1663
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1664
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1665
protectedMethodsFor:aCategory
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1666
    "this method allows fileIn of ENVY methods 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1667
     (although ST/X currently does NOT really enforce method visibility yet).
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1668
     Returns a ClassCategoryReader to read in and compile methods for me."
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1669
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1670
    ^ (self methodsFor:aCategory) protectedProtocol
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1671
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1672
295
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1673
methodsForUndefined:categoryString
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1674
    "ST-80 compatibility.
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1675
     I dont yet know what this does - it was encountered by some tester.
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1676
     For now, simply forward it."
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1677
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1678
    ^ self methodsFor:categoryString
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1679
!
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  1680
137
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1681
ignoredMethodsFor:aCategory
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1682
    "this is a speciality of ST/X - it allows quick commenting of methods
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1683
     from a source-file by replacing the 'methodsFor:' by 'ignoredMethodsFor'.
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1684
     Returns a ClassCategoryReader to read in and skip methods."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1685
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1686
    ^ ClassCategoryReader skippingChunks
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1687
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1688
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1689
methods
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1690
    "this method allows fileIn of ST/V methods -
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1691
     return a ClassCategoryReader to read in and compile methods for me."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1692
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1693
    ^ ClassCategoryReader class:self category:'ST/V methods'
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1694
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1695
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1696
primitiveDefinitions
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1697
    "this method allows fileIn of classes with primitive code
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1698
     outside of methods - it returns a CCReader which skips the next chunks"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1699
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1700
    ^ ClassCategoryReader class:self primitiveSpec:#primitiveDefinitions: 
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1701
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1702
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1703
primitiveVariables
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1704
    "this method allows fileIn of classes with primitive code
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1705
     outside of methods - it returns a CCReader which skips the next chunks"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1706
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1707
    ^ ClassCategoryReader class:self primitiveSpec:#primitiveVariables: 
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1708
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1709
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1710
primitiveFunctions
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1711
    "this method allows fileIn of classes with primitive code
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1712
     outside of methods - it returns a CCReader which skips the next chunks"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1713
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1714
    ^ ClassCategoryReader class:self primitiveSpec:#primitiveFunctions: 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1715
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1716
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1717
!Class methodsFor:'fileOut'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1718
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1719
fileOutDefinitionOn:aStream
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1720
    "append an expression on aStream, which defines myself."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1721
238
a4a50c67aeae *** empty log message ***
claus
parents: 216
diff changeset
  1722
    ^ self basicFileOutDefinitionOn:aStream
a4a50c67aeae *** empty log message ***
claus
parents: 216
diff changeset
  1723
!
a4a50c67aeae *** empty log message ***
claus
parents: 216
diff changeset
  1724
a4a50c67aeae *** empty log message ***
claus
parents: 216
diff changeset
  1725
basicFileOutDefinitionOn:aStream
a4a50c67aeae *** empty log message ***
claus
parents: 216
diff changeset
  1726
    "append an expression on aStream, which defines myself."
a4a50c67aeae *** empty log message ***
claus
parents: 216
diff changeset
  1727
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1728
    |isVar line s|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1729
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1730
    "take care of nil-superclass"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1731
    superclass isNil ifTrue:[
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1732
"/      previous versions of stc were not able to compile nil-subclasses;
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1733
"/      after 2.10, it can ...
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1734
"/        line := 'Object "nil"'.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1735
	line := 'nil'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1736
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1737
	line := (superclass name)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1738
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1739
    superclass isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1740
	isVar := self isVariable
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1741
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1742
	"I cant remember what this is for ?"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1743
	isVar := (self isVariable and:[superclass isVariable not])
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1744
    ].
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1745
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1746
    isVar ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1747
	self isBytes ifTrue:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1748
	    s := ' variableByteSubclass:#'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1749
	] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1750
	    self isWords ifTrue:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1751
		s := ' variableWordSubclass:#'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1752
	    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1753
		self isLongs ifTrue:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1754
		    s := ' variableLongSubclass:#'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1755
		] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1756
		    self isFloats ifTrue:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1757
			s := ' variableFloatSubclass:#'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1758
		    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1759
			self isDoubles ifTrue:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1760
			    s := ' variableDoubleSubclass:#'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1761
			] ifFalse:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1762
			    s := ' variableSubclass:#'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1763
			]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1764
		    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1765
		]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1766
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1767
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1768
    ] ifFalse:[
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1769
	s := ' subclass:#'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1770
    ].
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  1771
    line := line , s , name.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1772
    aStream nextPutAll:line.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1773
345
claus
parents: 333
diff changeset
  1774
    aStream crtab. 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1775
    aStream nextPutAll:' instanceVariableNames:'''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1776
    self printInstVarNamesOn:aStream indent:16.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1777
    aStream nextPutAll:''''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1778
345
claus
parents: 333
diff changeset
  1779
    aStream crtab.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1780
    aStream nextPutAll:' classVariableNames:'''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1781
    self printClassVarNamesOn:aStream indent:16.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1782
    aStream nextPutAll:''''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1783
345
claus
parents: 333
diff changeset
  1784
    aStream crtab.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1785
    aStream nextPutAll:' poolDictionaries:'''''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1786
345
claus
parents: 333
diff changeset
  1787
    aStream crtab.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1788
    aStream nextPutAll:' category:'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1789
    category isNil ifTrue:[
333
claus
parents: 328
diff changeset
  1790
	s := ''''''
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1791
    ] ifFalse:[
333
claus
parents: 328
diff changeset
  1792
	s := category asString storeString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1793
    ].
333
claus
parents: 328
diff changeset
  1794
    aStream nextPutAll:s.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1795
    aStream cr
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1796
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1797
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1798
fileOutMethod:aMethod on:aStream
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1799
    "file out the method, aMethod onto aStream"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1800
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1801
    |cat source privacy|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1802
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1803
    methodArray notNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1804
	aStream nextPutChunkSeparator.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1805
	self printClassNameOn:aStream.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1806
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1807
	(privacy := aMethod privacy) ~~ #public ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1808
	    aStream space; nextPutAll:privacy; nextPutAll:'MethodsFor:'''.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1809
	] ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1810
	    aStream nextPutAll:' methodsFor:'''.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1811
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1812
	cat := aMethod category.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1813
	cat notNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1814
	    aStream nextPutAll:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1815
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1816
	aStream nextPut:$'; nextPutChunkSeparator; cr; cr.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1817
	source := aMethod source.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1818
	source isNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1819
	    FileOutErrorSignal 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1820
		raiseRequestWith:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1821
		errorString:('no source for method: ' ,
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1822
			     self name , '>>' ,
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1823
			     (self selectorAtMethod:aMethod))
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1824
	] ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1825
	    aStream nextChunkPut:source.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1826
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1827
	aStream space.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1828
	aStream nextPutChunkSeparator.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1829
	aStream cr
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1830
    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1831
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1832
    "Modified: 27.8.1995 / 01:23:19 / claus"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1833
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1834
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1835
fileOutCategory:aCategory on:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1836
    "file out all methods belonging to aCategory, aString onto aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1837
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1838
    |nMethods count source sortedSelectors sortedMethods first 
415
claus
parents: 414
diff changeset
  1839
     privacy|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1840
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1841
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1842
	nMethods := 0.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1843
	methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1844
	    (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1845
		nMethods := nMethods + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1846
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1847
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1848
	(nMethods ~~ 0) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1849
	    count := 1.
412
claus
parents: 406
diff changeset
  1850
	    first := true.
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
  1851
	    privacy := nil.
362
claus
parents: 360
diff changeset
  1852
claus
parents: 360
diff changeset
  1853
	    "/
claus
parents: 360
diff changeset
  1854
	    "/ sort by selector
claus
parents: 360
diff changeset
  1855
	    "/
claus
parents: 360
diff changeset
  1856
	    sortedSelectors := selectorArray copy.
claus
parents: 360
diff changeset
  1857
	    sortedMethods := methodArray copy.
claus
parents: 360
diff changeset
  1858
	    sortedSelectors sortWith:sortedMethods.
claus
parents: 360
diff changeset
  1859
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1860
	    methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1861
		(aCategory = aMethod category) ifTrue:[
412
claus
parents: 406
diff changeset
  1862
claus
parents: 406
diff changeset
  1863
		    first ifFalse:[
415
claus
parents: 414
diff changeset
  1864
			privacy ~~ aMethod privacy ifTrue:[
412
claus
parents: 406
diff changeset
  1865
			    first := true.
claus
parents: 406
diff changeset
  1866
			    aStream space.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1867
			    aStream nextPutChunkSeparator.
412
claus
parents: 406
diff changeset
  1868
			].
claus
parents: 406
diff changeset
  1869
			aStream cr; cr
claus
parents: 406
diff changeset
  1870
		    ].
claus
parents: 406
diff changeset
  1871
415
claus
parents: 414
diff changeset
  1872
		    privacy := aMethod privacy.
412
claus
parents: 406
diff changeset
  1873
claus
parents: 406
diff changeset
  1874
		    first ifTrue:[
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1875
			aStream nextPutChunkSeparator.
412
claus
parents: 406
diff changeset
  1876
			self printClassNameOn:aStream.
415
claus
parents: 414
diff changeset
  1877
			privacy ~~ #public ifTrue:[
claus
parents: 414
diff changeset
  1878
			    aStream space; nextPutAll:privacy; nextPutAll:'MethodsFor:'''.
412
claus
parents: 406
diff changeset
  1879
			] ifFalse:[
415
claus
parents: 414
diff changeset
  1880
			    aStream nextPutAll:' methodsFor:'''.
412
claus
parents: 406
diff changeset
  1881
			].
claus
parents: 406
diff changeset
  1882
			aCategory notNil ifTrue:[
claus
parents: 406
diff changeset
  1883
			    aStream nextPutAll:aCategory
claus
parents: 406
diff changeset
  1884
			].
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1885
			aStream nextPut:$'; nextPutChunkSeparator; cr; cr.
412
claus
parents: 406
diff changeset
  1886
			first := false.
claus
parents: 406
diff changeset
  1887
		    ].
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1888
		    source := aMethod source.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1889
		    source isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1890
			FileOutErrorSignal raiseRequestWith:'no source for method'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1891
		    ] ifFalse:[
362
claus
parents: 360
diff changeset
  1892
			aStream nextChunkPut:source.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1893
		    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1894
		    count := count + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1895
		]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1896
	    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1897
	    aStream space.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1898
	    aStream nextPutChunkSeparator.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1899
	    aStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1900
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1901
    ]
412
claus
parents: 406
diff changeset
  1902
415
claus
parents: 414
diff changeset
  1903
    "Modified: 28.8.1995 / 14:30:41 / claus"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1904
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1905
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1906
fileOutPrimitiveDefinitionsOn:aStream
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1907
    "append primitive defs (if any) to aStream."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1908
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1909
    |s|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1910
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1911
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1912
     primitive definitions - if any
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1913
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1914
    (s := self primitiveDefinitionsString) notNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1915
	aStream nextPutChunkSeparator; 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1916
		nextPutAll:name; nextPutAll:' primitiveDefinitions';
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1917
		nextPutChunkSeparator;
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1918
		cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1919
	aStream nextPutAll:s.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1920
	aStream nextPutChunkSeparator; space; nextPutChunkSeparator; cr; cr
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1921
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1922
    (s := self primitiveVariablesString) notNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1923
	aStream nextPutChunkSeparator; 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1924
		nextPutAll:name; nextPutAll:' primitiveVariables';
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1925
		nextPutChunkSeparator;
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1926
		cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1927
	aStream nextPutAll:s.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1928
	aStream nextPutChunkSeparator; space; nextPutChunkSeparator; cr; cr
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  1929
    ].
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1930
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1931
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1932
fileOutCommentOn:aStream
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1933
    "append an expression on aStream, which defines my comment"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1934
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1935
    |comment s|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1936
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1937
    aStream nextPutAll:name; nextPutAll:' comment:'.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1938
    (comment := self comment) isNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1939
	s := ''''''
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1940
    ] ifFalse:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1941
	s := comment storeString
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1942
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1943
    aStream nextPutAll:s.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1944
    aStream cr
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1945
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1946
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1947
fileOutPrimitiveSpecsOn:aStream
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1948
    "append primitive defs (if any) to aStream."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1949
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1950
    |s|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1951
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1952
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1953
     primitive definitions - if any
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1954
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1955
    self fileOutPrimitiveDefinitionsOn:aStream.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1956
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1957
     primitive functions - if any
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1958
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1959
    (s := self primitiveFunctionsString) notNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1960
	aStream nextPutChunkSeparator; 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1961
		nextPutAll:name; nextPutAll:' primitiveFunctions';
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1962
		nextPutChunkSeparator;
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1963
		cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1964
	aStream nextPutAll:s.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1965
	aStream nextPutChunkSeparator; space; nextPutChunkSeparator; cr; cr
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  1966
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1967
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1968
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1969
fileOutOn:aStream
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1970
    "file out my definition and all methods onto aStream"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1971
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  1972
    |collectionOfCategories copyrightText comment cls|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1973
403
claus
parents: 399
diff changeset
  1974
    self isLoaded ifFalse:[
claus
parents: 399
diff changeset
  1975
	^ FileOutErrorSignal 
claus
parents: 399
diff changeset
  1976
	    raiseRequestWith:self
claus
parents: 399
diff changeset
  1977
		 errorString:'will not fileOut unloaded classes'
claus
parents: 399
diff changeset
  1978
    ].
claus
parents: 399
diff changeset
  1979
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1980
    "
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1981
     if there is a copyright method, add a copyright comment
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1982
     at the beginning, taking the string from the copyright method.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1983
     We cannot do this unconditionally - that would lead to my copyrights
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1984
     being put on your code ;-).
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1985
     On the other hand: I want every file created by myself to have the
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1986
     copyright string at the beginning be preserved .... even if the
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1987
     code was edited in the browser and filedOut.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1988
    "
356
claus
parents: 355
diff changeset
  1989
    ((cls := self class) selectorArray includes:#copyright) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1990
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1991
	 get the copyright methods source,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1992
	 and insert at beginning.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1993
	"
356
claus
parents: 355
diff changeset
  1994
	copyrightText := (cls  compiledMethodAt:#copyright) source.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1995
	copyrightText isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1996
	    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1997
	     no source available - trigger an error
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1998
	    "
399
claus
parents: 391
diff changeset
  1999
	    FileOutErrorSignal
claus
parents: 391
diff changeset
  2000
		raiseRequestWith:'no source for class ' , name , ' available. Cannot fileOut'.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2001
	    ^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2002
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2003
	copyrightText := copyrightText asCollectionOfLines.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2004
	copyrightText := copyrightText copyFrom:2 to:(copyrightText size).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2005
	copyrightText do:[:line | aStream nextPutAll:line. aStream cr.].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2006
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2007
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2008
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2009
     first, a timestamp
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2010
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2011
    aStream nextPutAll:(Smalltalk timeStamp).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  2012
    aStream nextPutChunkSeparator. 
333
claus
parents: 328
diff changeset
  2013
    aStream cr; cr.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2014
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2015
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2016
     then the definition
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2017
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2018
    self fileOutDefinitionOn:aStream.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  2019
    aStream nextPutChunkSeparator. 
333
claus
parents: 328
diff changeset
  2020
    aStream cr; cr.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2021
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2022
     optional classInstanceVariables
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2023
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2024
    self class instanceVariableString isBlank ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2025
	self fileOutClassInstVarDefinitionOn:aStream.
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  2026
	aStream nextPutChunkSeparator. 
333
claus
parents: 328
diff changeset
  2027
	aStream cr; cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2028
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2029
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2030
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2031
     a comment - if any
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2032
    "
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  2033
    (comment := self comment) notNil ifTrue:[
333
claus
parents: 328
diff changeset
  2034
	aStream nextPutAll:name; nextPutAll:' comment:'.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2035
	aStream nextPutAll:(comment storeString).
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  2036
	aStream nextPutChunkSeparator.
333
claus
parents: 328
diff changeset
  2037
	aStream cr; cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2038
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2039
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2040
    "
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2041
     primitive definitions - if any
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2042
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2043
    self fileOutPrimitiveSpecsOn:aStream.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2044
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2045
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2046
     methods from all categories in metaclass
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2047
    "
362
claus
parents: 360
diff changeset
  2048
    collectionOfCategories := self class categories asSortedCollection.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2049
    collectionOfCategories notNil ifTrue:[
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2050
	"
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2051
	 documentation first (if any)
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2052
	"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2053
	(collectionOfCategories includes:'documentation') ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2054
	    self class fileOutCategory:'documentation' on:aStream.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2055
	    aStream cr.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2056
	].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2057
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2058
	 initialization next (if any)
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2059
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2060
	(collectionOfCategories includes:'initialization') ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2061
	    self class fileOutCategory:'initialization' on:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2062
	    aStream cr.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2063
	].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2064
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2065
	 instance creation next (if any)
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2066
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2067
	(collectionOfCategories includes:'instance creation') ifTrue:[
213
3b56a17534fd *** empty log message ***
claus
parents: 205
diff changeset
  2068
	    self class fileOutCategory:'instance creation' on:aStream.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2069
	    aStream cr.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2070
	].
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2071
	collectionOfCategories do:[:aCategory |
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2072
	    ((aCategory ~= 'documentation')
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2073
	    and:[(aCategory ~= 'initialization')
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2074
	    and:[aCategory ~= 'instance creation']]) ifTrue:[
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2075
		self class fileOutCategory:aCategory on:aStream.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2076
		aStream cr
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  2077
	    ]
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2078
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2079
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2080
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2081
     methods from all categories in myself
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2082
    "
362
claus
parents: 360
diff changeset
  2083
    collectionOfCategories := self categories asSortedCollection.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2084
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2085
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2086
	    self fileOutCategory:aCategory on:aStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2087
	    aStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2088
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2089
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2090
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2091
     optionally an initialize message
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2092
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2093
    (self class implements:#initialize) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2094
	aStream nextPutAll:(name , ' initialize').
432
5815c61da8a2 *** empty log message ***
claus
parents: 423
diff changeset
  2095
	aStream nextPutChunkSeparator.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2096
	aStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2097
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2098
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2099
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2100
fileOut
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2101
    "create a file 'class.st' consisting of all methods in myself.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2102
     If the current project is not nil, create the file in the projects
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2103
     directory. Care is taken, to not clobber any existing file in
356
claus
parents: 355
diff changeset
  2104
     case of errors (for example: disk full). 
claus
parents: 355
diff changeset
  2105
     Also, since the classes methods need a valid sourcefile, the current 
claus
parents: 355
diff changeset
  2106
     sourceFile may not be rewritten."
claus
parents: 355
diff changeset
  2107
claus
parents: 355
diff changeset
  2108
    |aStream baseName dirName fileName newFileName needRename
claus
parents: 355
diff changeset
  2109
     mySourceFileName sameFile|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2110
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2111
    baseName := (Smalltalk fileNameForClass:self name).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2112
    fileName := baseName , '.st'.
356
claus
parents: 355
diff changeset
  2113
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  2114
    "
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  2115
     this test allows a smalltalk to be built without Projects/ChangeSets
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  2116
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2117
    Project notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2118
	dirName := Project currentProjectDirectory
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2119
    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2120
	dirName := ''
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2121
    ].
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2122
    fileName := dirName , fileName.
356
claus
parents: 355
diff changeset
  2123
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2124
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2125
     if file exists, copy the existing to a .sav-file,
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2126
     create the new file as XXX.new-file,
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2127
     and, if that worked rename afterwards ...
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2128
    "
357
claus
parents: 356
diff changeset
  2129
    (fileName asFilename exists 
claus
parents: 356
diff changeset
  2130
    and:[classFilename notNil]) ifTrue:[
356
claus
parents: 355
diff changeset
  2131
	"
claus
parents: 355
diff changeset
  2132
	 check for overwriting my current source file
claus
parents: 355
diff changeset
  2133
	 this is not allowed, since it would clobber my methods source
claus
parents: 355
diff changeset
  2134
	 file ... you have to save it to some other place.
claus
parents: 355
diff changeset
  2135
	 This happens if you ask for a fileOut into the source-directory
claus
parents: 355
diff changeset
  2136
	 (from which my methods get their source)
claus
parents: 355
diff changeset
  2137
	"
claus
parents: 355
diff changeset
  2138
	mySourceFileName := Smalltalk getSourceFileName:classFilename. 
claus
parents: 355
diff changeset
  2139
	sameFile := (fileName = mySourceFileName).
claus
parents: 355
diff changeset
  2140
	sameFile ifFalse:[
claus
parents: 355
diff changeset
  2141
	    sameFile := (fileName asFilename info at:#id) == (mySourceFileName asFilename info at:#id)
claus
parents: 355
diff changeset
  2142
	].
claus
parents: 355
diff changeset
  2143
	sameFile ifTrue:[
claus
parents: 355
diff changeset
  2144
	    ^ FileOutErrorSignal 
claus
parents: 355
diff changeset
  2145
		raiseRequestWith:fileName
claus
parents: 355
diff changeset
  2146
		errorString:('may not overwrite sourcefile:', fileName)
claus
parents: 355
diff changeset
  2147
	].
claus
parents: 355
diff changeset
  2148
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2149
	fileName asFilename copyTo:('/tmp/' , baseName , '.sav').
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2150
	newFileName := dirName , baseName , '.new'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2151
	needRename := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2152
    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2153
	newFileName := fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2154
	needRename := false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2155
    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2156
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2157
    aStream := FileStream newFileNamed:newFileName.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2158
    aStream isNil ifTrue:[
356
claus
parents: 355
diff changeset
  2159
	^ FileOutErrorSignal 
claus
parents: 355
diff changeset
  2160
		raiseRequestWith:newFileName
claus
parents: 355
diff changeset
  2161
		errorString:('cannot create file:', newFileName)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2162
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2163
    self fileOutOn:aStream.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2164
    aStream close.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2165
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2166
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2167
     finally, replace the old-file
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2168
     be careful, if the old one is a symbolic link; in this case,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2169
     we have to do a copy ...
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2170
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2171
    needRename ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2172
	newFileName asFilename copyTo:fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2173
	newFileName asFilename delete
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2174
    ].
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2175
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2176
    "
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2177
     add a change record; that way, administration is much easier,
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2178
     since we can see in that changeBrowser, which changes have 
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2179
     already found their way into a sourceFile and which must be
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2180
     applied again
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2181
    "
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2182
    self addChangeRecordForClassFileOut:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2183
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2184
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2185
fileOutClassInstVarDefinitionOn:aStream
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2186
    "append an expression to define my classInstanceVariables on aStream"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2187
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2188
    aStream nextPutAll:(name , ' class instanceVariableNames:''').
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2189
    self class printInstVarNamesOn:aStream indent:8.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2190
    aStream nextPutAll:''''.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2191
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2192
    "mhmh - good idea; saw this in SmallDraw sourcecode ..."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2193
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2194
    aStream cr; cr; nextPut:(Character doubleQuote); cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2195
    aStream space; 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2196
	    nextPutAll:'The following class instance variables are inherited by this class:';
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2197
	    cr; cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2198
    self allSuperclassesDo:[:aSuperClass |
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2199
	aStream tab; nextPutAll:aSuperClass name; nextPutAll:' - '.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2200
	aStream nextPutAll:(aSuperClass class instanceVariableString); cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2201
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2202
    aStream nextPut:(Character doubleQuote); cr.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2203
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2204
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2205
fileOutCategory:aCategory
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2206
    "create a file 'class-category.st' consisting of all methods in aCategory.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2207
     If the current project is not nil, create the file in the projects
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2208
     directory."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2209
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2210
    |aStream fileName|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2211
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2212
    fileName := name , '-' , aCategory , '.st'.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2213
    fileName replaceAll:(Character space) by:$_.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2214
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2215
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2216
     this test allows a smalltalk to be built without Projects/ChangeSets
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2217
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2218
    Project notNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2219
	fileName := Project currentProjectDirectory , fileName.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2220
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2221
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2222
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2223
     if file exists, save original in a .sav file
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2224
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2225
    fileName asFilename exists ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2226
	fileName asFilename copyTo:(fileName , '.sav')
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2227
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2228
    aStream := FileStream newFileNamed:fileName.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2229
    aStream isNil ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2230
	^ FileOutErrorSignal 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2231
		raiseRequestWith:fileName
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2232
		errorString:('cannot create file:', fileName)
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2233
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2234
    self fileOutCategory:aCategory on:aStream.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2235
    aStream close
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2236
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2237
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2238
fileOutMethod:aMethod
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2239
    "create a file 'class-method.st' consisting of the method, aMethod.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2240
     If the current project is not nil, create the file in the projects
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2241
     directory."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2242
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2243
    |aStream fileName selector|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2244
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2245
    selector := self selectorAtMethod:aMethod.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2246
    selector notNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2247
	fileName := name , '-' , selector, '.st'.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2248
	fileName replaceAll:$: by:$_.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2249
	"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2250
	 this test allows a smalltalk to be built without Projects/ChangeSets
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2251
	"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2252
	Project notNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2253
	    fileName := Project currentProjectDirectory , fileName.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2254
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2255
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2256
	"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2257
	 if file exists, save original in a .sav file
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2258
	"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2259
	fileName asFilename exists ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2260
	    fileName asFilename copyTo:(fileName , '.sav')
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2261
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2262
	aStream := FileStream newFileNamed:fileName.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2263
	aStream isNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2264
	    ^ FileOutErrorSignal 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2265
		raiseRequestWith:fileName
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2266
		errorString:('cannot create file:', fileName)
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2267
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2268
	self fileOutMethod:aMethod on:aStream.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2269
	aStream close
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2270
    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2271
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2272
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2273
fileOutIn:aFileDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2274
    "create a file 'class.st' consisting of all methods in self in
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  2275
     directory aFileDirectory (ignoring any directory setting in
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2276
     the current porject). 
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  2277
     This is not logged in that change file (should it be ?)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2278
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2279
    |aStream fileName|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2280
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2281
    fileName := (Smalltalk fileNameForClass:self name) , '.st'.
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  2282
    aStream := FileStream newFileNamed:fileName in:aFileDirectory.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2283
    aStream isNil ifTrue:[
356
claus
parents: 355
diff changeset
  2284
	^ FileOutErrorSignal 
claus
parents: 355
diff changeset
  2285
		raiseRequestWith:fileName
claus
parents: 355
diff changeset
  2286
		errorString:('cannot create file:', fileName)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2287
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2288
    self fileOutOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2289
    aStream close
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2290
! !
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2291
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2292
!Class methodsFor:'printOut'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2293
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2294
printClassNameOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2295
    "helper for fileOut - print my name if I am not a Metaclass;
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2296
     otherwise my name without -class followed by space-class"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2297
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2298
    self isMeta ifTrue:[
333
claus
parents: 328
diff changeset
  2299
	aStream nextPutAll:(name copyTo:(name size - 5)); nextPutAll:' class'
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2300
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2301
	name printOn:aStream
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2302
    ]
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2303
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2304
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2305
printNameArray:anArray on:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2306
    "print an array of strings separated by spaces; when the stream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2307
     defines a lineLength, break when this limit is reached; indent
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  2308
     every line; used to printOut instance variable names"
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2309
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2310
    |thisName nextName arraySize lenMax pos mustBreak line spaces|
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2311
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2312
    arraySize := anArray size.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2313
    arraySize ~~ 0 ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2314
	pos := indent.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2315
	lenMax := aStream lineLength.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2316
	thisName := anArray at:1.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2317
	line := ''.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2318
	1 to:arraySize do:[:index |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2319
	    line := line , thisName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2320
	    pos := pos + thisName size.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2321
	    (index == arraySize) ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2322
		nextName := anArray at:(index + 1).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2323
		mustBreak := false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2324
		(lenMax > 0) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2325
		    ((pos + nextName size) > lenMax) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2326
			mustBreak := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2327
		    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2328
		].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2329
		mustBreak ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2330
		    aStream nextPutAll:line.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2331
		    aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2332
		    spaces isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2333
			spaces := String new:indent
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2334
		    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2335
		    line := spaces.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2336
		    pos := indent
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2337
		] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2338
		    line := line , ' '.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2339
		    pos := pos + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2340
		].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2341
		thisName := nextName
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2342
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2343
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2344
	aStream nextPutAll:line
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2345
    ]
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2346
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2347
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2348
printClassVarNamesOn:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2349
    "print the class variable names indented and breaking at line end"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2350
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2351
    self printNameArray:(self classVarNames) on:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2352
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2353
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2354
printInstVarNamesOn:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2355
    "print the instance variable names indented and breaking at line end"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2356
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2357
    self printNameArray:(self instVarNames) on:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2358
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2359
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2360
printHierarchyOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2361
    "print my class hierarchy on aStream"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2362
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2363
    self printHierarchyAnswerIndentOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2364
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2365
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2366
printHierarchyAnswerIndentOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2367
    "print my class hierarchy on aStream - return indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2368
     recursively calls itself to print superclass and use returned indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2369
     for my description - used in the browser"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2370
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2371
    |indent|
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2372
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2373
    indent := 0.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2374
    (superclass notNil) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2375
	indent := (superclass printHierarchyAnswerIndentOn:aStream) + 2
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2376
    ].
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2377
    aStream spaces:indent.
333
claus
parents: 328
diff changeset
  2378
    aStream nextPutAll:name; nextPutAll:' ('.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2379
    self printInstVarNamesOn:aStream indent:(indent + name size + 2).
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2380
    aStream nextPutAll:')'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2381
    aStream cr.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2382
    ^ indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2383
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2384
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2385
printFullHierarchyOn:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2386
    "print myself and all subclasses on aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2387
     recursively calls itself to print subclasses. 
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2388
     Can be used to print hierarchy on the printer."
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2389
333
claus
parents: 328
diff changeset
  2390
    aStream spaces:indent; bold; nextPutAll:name; normal; nextPutAll:' ('.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2391
    self printInstVarNamesOn:aStream indent:(indent + name size + 2).
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2392
    aStream nextPutAll:')'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2393
    aStream cr.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2394
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2395
    (self subclasses sort:[:a :b | a name < b name]) do:[:aSubclass |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2396
	aSubclass printFullHierarchyOn:aStream indent:(indent + 2)
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2397
    ]
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2398
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2399
    "|printStream|
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2400
     printStream := Printer new.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2401
     Object printFullHierarchyOn:printStream indent:0.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2402
     printStream close"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2403
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2404
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2405
printOutDefinitionOn:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2406
    "print out my definition"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2407
333
claus
parents: 328
diff changeset
  2408
    |comment s|
claus
parents: 328
diff changeset
  2409
claus
parents: 328
diff changeset
  2410
    aPrintStream nextPutAll:'class                '; bold; nextPutAll:name; normal; cr. 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2411
    aPrintStream nextPutAll:'superclass           '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2412
    superclass isNil ifTrue:[
333
claus
parents: 328
diff changeset
  2413
	s := 'Object'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2414
    ] ifFalse:[
333
claus
parents: 328
diff changeset
  2415
	s := superclass name
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2416
    ].
333
claus
parents: 328
diff changeset
  2417
    aPrintStream nextPutAll:s.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2418
    aPrintStream cr. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2419
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2420
    aPrintStream nextPutAll:'instance Variables   '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2421
    self printInstVarNamesOn:aPrintStream indent:21.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2422
    aPrintStream cr. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2423
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2424
    aPrintStream nextPutAll:'class Variables      '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2425
    self printClassVarNamesOn:aPrintStream indent:21.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2426
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2427
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2428
    category notNil ifTrue:[
333
claus
parents: 328
diff changeset
  2429
	aPrintStream nextPutAll:'category             '; nextPutAll:(category printString).
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2430
	aPrintStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2431
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2432
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  2433
    (comment := self comment) notNil ifTrue:[
333
claus
parents: 328
diff changeset
  2434
	aPrintStream cr; nextPutAll:'comment:'; cr; italic; nextPutAll:comment; normal; cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2435
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2436
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2437
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2438
printOutSourceProtocol:aMethod on:aPrintStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2439
    "given the source in aString, print the methods message specification
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2440
     and any method comments - without source; used to generate documentation
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2441
     pages"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2442
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2443
    |text|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2444
247
9e3057039d60 asText eliminated
claus
parents: 238
diff changeset
  2445
    text := aMethod source asStringCollection.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2446
    (text size < 1) ifTrue:[^self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2447
    aPrintStream bold.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2448
    aPrintStream nextPutAll:(text at:1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2449
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2450
    (text size >= 2) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2451
	aPrintStream italic.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2452
	aPrintStream spaces:((text at:2) indexOfNonSeparatorStartingAt:1).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2453
	aPrintStream nextPutAll:aMethod comment.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2454
	aPrintStream cr.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2455
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2456
    aPrintStream normal
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2457
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2458
    "
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2459
      Float printOutProtocolOn:Stdout 
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2460
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2461
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2462
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2463
printOutSource:aString on:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2464
    "print out a source-string; the message-specification is printed bold,
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2465
     comments are printed italic"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2466
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2467
    |text textIndex textSize line lineIndex lineSize inComment aCharacter|
247
9e3057039d60 asText eliminated
claus
parents: 238
diff changeset
  2468
    text := aString asStringCollection.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2469
    aPrintStream bold.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2470
    aPrintStream nextPutAll:(text at:1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2471
    aPrintStream normal.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2472
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2473
    inComment := false.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2474
    textSize := text size.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2475
    textIndex := 2.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2476
    [textIndex <= textSize] whileTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2477
	line := text at:textIndex.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2478
	((line occurrencesOf:Character doubleQuote) == 0) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2479
	    aPrintStream nextPutAll:line
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2480
	] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2481
	    lineSize := line size.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2482
	    lineIndex := 1.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2483
	    [lineIndex <= lineSize] whileTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2484
		aCharacter := line at:lineIndex.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2485
		(aCharacter == Character doubleQuote) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2486
		    inComment ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2487
			aPrintStream normal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2488
			aPrintStream nextPut:aCharacter.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2489
			inComment := false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2490
		    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2491
			aPrintStream nextPut:aCharacter.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2492
			aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2493
			inComment := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2494
		    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2495
		] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2496
		    aPrintStream nextPut:aCharacter
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2497
		].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2498
		lineIndex := lineIndex + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2499
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2500
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2501
	aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2502
	textIndex := textIndex + 1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2503
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2504
!
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2505
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2506
printOutCategory:aCategory on:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2507
    "print out all methods in aCategory on aPrintStream should be a PrintStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2508
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2509
    |any|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2510
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2511
	any := false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2512
	methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2513
	    (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2514
		any := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2515
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2516
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2517
	any ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2518
	     aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2519
	     aPrintStream nextPutAll:aCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2520
	     aPrintStream normal.
333
claus
parents: 328
diff changeset
  2521
	     aPrintStream cr; cr.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2522
	     methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2523
		 (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2524
		     self printOutSource:(aMethod source) on:aPrintStream.
333
claus
parents: 328
diff changeset
  2525
		     aPrintStream cr; cr
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2526
		 ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2527
	     ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2528
	     aPrintStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2529
	 ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2530
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2531
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2532
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2533
printOutOn:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2534
    "print out all methods on aPrintStream which should be a printStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2535
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2536
    |collectionOfCategories|
333
claus
parents: 328
diff changeset
  2537
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2538
    self printOutDefinitionOn:aPrintStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2539
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2540
    collectionOfCategories := self class categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2541
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2542
	aPrintStream nextPutAll:'class protocol'.
333
claus
parents: 328
diff changeset
  2543
	aPrintStream cr; cr.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2544
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2545
	    self class printOutCategory:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2546
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2547
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2548
    collectionOfCategories := self categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2549
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2550
	aPrintStream nextPutAll:'instance protocol'.
333
claus
parents: 328
diff changeset
  2551
	aPrintStream cr; cr.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2552
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2553
	    self printOutCategory:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2554
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2555
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2556
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2557
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2558
printOutCategoryProtocol:aCategory on:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2559
    |any|
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2560
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2561
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2562
	any := false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2563
	methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2564
	    (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2565
		any := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2566
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2567
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2568
	any ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2569
	    aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2570
	    aPrintStream nextPutAll:aCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2571
	    aPrintStream normal.
333
claus
parents: 328
diff changeset
  2572
	    aPrintStream cr; cr.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2573
	    methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2574
		(aCategory = aMethod category) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2575
		    self printOutSourceProtocol:aMethod
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2576
					     on:aPrintStream.
333
claus
parents: 328
diff changeset
  2577
		    aPrintStream cr; cr
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2578
		]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2579
	    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2580
	    aPrintStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2581
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2582
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2583
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2584
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2585
printOutProtocolOn:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2586
    |collectionOfCategories|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2587
    self printOutDefinitionOn:aPrintStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2588
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2589
    collectionOfCategories := self class categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2590
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2591
	aPrintStream nextPutAll:'class protocol'.
333
claus
parents: 328
diff changeset
  2592
	aPrintStream cr; cr.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2593
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2594
	    self class printOutCategoryProtocol:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2595
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2596
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2597
    collectionOfCategories := self categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2598
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2599
	aPrintStream nextPutAll:'instance protocol'.
333
claus
parents: 328
diff changeset
  2600
	aPrintStream cr; cr.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2601
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2602
	    self printOutCategoryProtocol:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2603
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2604
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2605
! !
2
claus
parents: 1
diff changeset
  2606
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2607
!Class methodsFor:'private'!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2608
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2609
updateRevisionString
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2610
    "update my revision string, to reflect a change w.r.t.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2611
     the original source.
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2612
     The original revision string is kept as a reference i.e.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2613
       Header: /files/CVS/stx/libbasic/Class.st,v 1.63 1995/10/28 16:44:51 cg Exp $
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2614
     is changed into:
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2615
       Header: /files/CVS/stx/libbasic/Class.st,v 1.63mod 1995/10/28 16:44:51 cg Exp $
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2616
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2617
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2618
    |cls vs m idx leftPart rightPart vsnString|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2619
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2620
    cls := self.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2621
    self isMeta ifFalse:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2622
	cls := self class
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2623
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2624
    m := cls compiledMethodAt:#version.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2625
    m isNil ifTrue:[^ self].
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2626
    vs := self revisionString.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2627
    vs isNil ifTrue:[^ self].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2628
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2629
    "/ search for ,v
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2630
    idx := vs indexOfSubCollection:'.st,v'.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2631
    idx == 0 ifTrue:[^ self].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2632
    leftPart := vs copyTo:(idx - 1 + 5).
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2633
    rightPart := (vs copyFrom:(idx + 5)) withoutSpaces.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2634
    idx := rightPart indexOfSeparator.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2635
    idx == 0 ifTrue:[^ self].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2636
    vsnString := rightPart copyTo:idx - 1.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2637
    rightPart := rightPart copyFrom:idx + 1.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2638
    vsnString ~= self revision ifTrue:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2639
	"/ alread a modified class
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2640
"/        ('already modified: ' , vsnString) printNL.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2641
	^ self
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2642
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2643
    m source:'version
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2644
^ ''' , leftPart , ' ' , vsnString , 'mod' , ' ' , rightPart , ''''.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2645
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2646
"/ ('updated to :' , vsnString , 'mod') printNL.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2647
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2648
    "
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2649
     Class updateRevisionString
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2650
     Number updateRevisionString
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2651
     ProcessMonitor updateRevisionString
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2652
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2653
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2654
    "Created: 29.10.1995 / 19:25:15 / cg"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2655
    "Modified: 29.10.1995 / 19:39:38 / cg"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2656
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2657
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2658
revisionString
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2659
    "return my revision string; that one is extracted from the
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2660
     classes #version method. Either this is a method returning that string,
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2661
     or its a comment-only method and the comment defines the version.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2662
     If the source is not accessable or no such method exists,
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2663
     nil is returned."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2664
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2665
    |cls meta m src lines idx val|
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2666
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2667
    self isMeta ifTrue:[
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2668
	meta := self. cls := meta soleInstance
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2669
    ] ifFalse:[
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2670
	cls := self. meta := self class
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2671
    ].
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2672
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2673
    m := meta compiledMethodAt:#version.
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2674
    m isNil ifTrue:[^ nil].
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2675
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2676
    "/ if its a method returning the string,
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2677
    val := cls version.
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2678
    val isString ifTrue:[^ val].
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2679
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2680
    src := m source.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2681
    src isNil ifTrue:[^ nil].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2682
    lines := src asCollectionOfLines.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2683
    idx := lines findFirst:[:l |
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2684
	l withoutSpaces startsWith:'$Header'
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2685
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2686
    idx == 0 ifTrue:[^ nil].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2687
    ^ lines at:idx.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2688
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2689
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2690
     Smalltalk allClassesDo:[:cls |
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2691
	Transcript showCr:cls revisionString
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2692
     ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2693
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2694
     Number revisionString  
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2695
     FileDirectory revisionString  
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2696
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2697
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2698
    "Created: 29.10.1995 / 19:28:03 / cg"
527
7eedfdb0db62 try revisionString for revision-number as well
Claus Gittinger <cg@exept.de>
parents: 524
diff changeset
  2699
    "Modified: 11.11.1995 / 14:11:41 / cg"
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2700
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2701
544
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2702
revisionInfo
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2703
    "return a dictionary filled with revision info.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2704
     This extracts the reevant info from the revisionString."
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2705
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2706
    |vsnString words info nm|
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2707
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2708
    info := IdentityDictionary new.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2709
    vsnString := self revisionString.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2710
    vsnString notNil ifTrue:[
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2711
	words := vsnString asCollectionOfWords.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2712
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2713
	"/
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2714
	"/ supported formats:
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2715
	"/
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2716
	"/ $-Header: pathName rev date time user state $
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2717
	"/ $-Revision: rev $
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2718
	"/ $-Id: fileName rev date time user state $
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2719
	"/
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2720
	((words at:1) = '$Header:') ifTrue:[
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2721
	    nm := words at:2.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2722
	    info at:#repositoryPathName put:nm.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2723
	    (nm endsWith:',v') ifTrue:[
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2724
		nm := nm copyWithoutLast:2
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2725
	    ].
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2726
	    info at:#fileName put:nm asFilename baseName.
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2727
	    info at:#revision put:(words at:3).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2728
	    info at:#date put:(words at:4).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2729
	    info at:#time put:(words at:5).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2730
	    info at:#user put:(words at:6).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2731
	    info at:#state put:(words at:7).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2732
	    ^ info
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2733
	].
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2734
	((words at:1) = '$Revision:') ifTrue:[
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2735
	    info at:#revision put:(words at:2).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2736
	    ^ info
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2737
	].
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2738
	((words at:1) = '$Id:') ifTrue:[
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2739
	    info at:#fileName put:(words at:2).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2740
	    info at:#revision put:(words at:3).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2741
	    info at:#date put:(words at:4).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2742
	    info at:#time put:(words at:5).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2743
	    info at:#user put:(words at:6).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2744
	    info at:#state put:(words at:7).
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2745
	    ^ info
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2746
	].
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2747
    ].
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2748
    ^ nil
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2749
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2750
    "
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2751
     Object revisionString 
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2752
     Object revisionInfo 
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2753
    "
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2754
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2755
    "Created: 11.11.1995 / 14:27:20 / cg"
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2756
    "Modified: 14.11.1995 / 16:00:51 / cg"
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2757
!
d78012b20769 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 527
diff changeset
  2758
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2759
addAllClassVarNamesTo:aCollection
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2760
    "helper - add the name-strings of the class variables and of the class-vars
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2761
     of all superclasses to the argument, aCollection. Return aCollection"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2762
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2763
    (superclass notNil) ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2764
	superclass addAllClassVarNamesTo:aCollection
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2765
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2766
    classvars notNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2767
	aCollection addAll:(classvars asCollectionOfWords).
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2768
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2769
    ^ aCollection
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2770
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2771
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2772
getPrimitiveSpecsAt:index
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2773
    "return a primitiveSpecification component as string or nil"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2774
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2775
    |pos stream string|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2776
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2777
    primitiveSpec isNil ifTrue:[^ nil].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2778
    pos := primitiveSpec at:index.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2779
    pos isNil ifTrue:[^ nil].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2780
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2781
    "the primitiveSpec is either a string, or an integer specifying the
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2782
     position within the classes sourcefile ...
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2783
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2784
    pos isNumber ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2785
	classFilename notNil ifTrue:[
523
27e13690f124 sourceStream added (handles dynamic loaded code);
Claus Gittinger <cg@exept.de>
parents: 488
diff changeset
  2786
	    stream := self sourceStream. "/ Smalltalk sourceFileStreamFor:classFilename.
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2787
	    stream notNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2788
		stream position:pos+1.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2789
		string := stream nextChunk.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2790
		stream close.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2791
		^ string
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2792
	    ]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2793
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2794
	^ nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2795
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2796
    ^ pos
2
claus
parents: 1
diff changeset
  2797
!
claus
parents: 1
diff changeset
  2798
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2799
addCategoriesTo:aCollection
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2800
    "helper - add categories to the argument, aCollection"
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2801
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2802
    methodArray do:[:aMethod |
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2803
	|cat|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2804
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2805
	cat := aMethod category.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2806
	(aCollection includes:cat) ifFalse:[
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2807
	    aCollection add:cat
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2808
	]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2809
    ]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2810
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2811
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2812
addAllCategoriesTo:aCollection
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2813
    "helper - add categories and all superclasses categories
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2814
     to the argument, aCollection"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2815
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2816
    (superclass notNil) ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2817
	superclass addAllCategoriesTo:aCollection
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2818
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2819
    self addCategoriesTo:aCollection
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2820
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2821
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2822
setPrimitiveSpecsAt:index to:aString
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2823
    "set a primitiveSpecification component to aString"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2824
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2825
    primitiveSpec isNil ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2826
	primitiveSpec := Array new:3
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2827
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2828
    primitiveSpec at:index put:aString
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2829
! !
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2830
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2831
!Class methodsFor:'queries'!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2832
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2833
isClass
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2834
    "return true, if the receiver is some kind of class 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2835
     (a real class, not just behavior);
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2836
     true is returned here - the method is redefined from Object.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2837
     See also Behavior>>isBehavior."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2838
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2839
    ^ true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2840
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2841
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2842
     Point isClass  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2843
     1 isClass      
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2844
     Behavior new isBehavior  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2845
     Behavior new isClass       
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2846
     Class new isBehavior    
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2847
     Class new isClass
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2848
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2849
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2850
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2851
categories
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2852
    "Return a Collection of all method-category strings known in class.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2853
     The returned collection is not sorted by any order."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2854
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2855
    |newList cat|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2856
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2857
    newList := OrderedCollection new.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2858
    methodArray do:[:aMethod |
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2859
	cat := aMethod category.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2860
	newList indexOf:cat ifAbsent:[newList add:cat]
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2861
    ].
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2862
    ^ newList
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2863
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2864
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2865
     Point categories  
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  2866
    "
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2867
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2868
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2869
whichClassDefinesClassVar:aVariableName
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2870
    "return the class which defines the class variable
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2871
     named aVariableName. This method should not be used for
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2872
     repeated searches (i.e. in the compiler/parser), since it creates
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2873
     many throw away intermediate objects."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2874
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2875
    |cls|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2876
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2877
    cls := self.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2878
    [cls notNil] whileTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2879
	(cls classVarNames includes:aVariableName) ifTrue:[ ^ cls].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2880
	cls := cls superclass
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2881
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2882
    ^ nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2883
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2884
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2885
     StandardSystemView whichClassDefinesClassVar:'ErrorSignal'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2886
     StandardSystemView whichClassDefinesClassVar:'Foo'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2887
    "
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2888
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2889
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2890
wasAutoloaded
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2891
    "return true, if this class came into the system via an
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2892
     autoload; false otherwise.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2893
     This is not an attribute of the class, but instead remembered in
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2894
     Autoload. The interface here is for covenience."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2895
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2896
    ^ Autoload wasAutoloaded:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2897
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2898
457
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2899
allCategories
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2900
    "Return a Collection of all method-category strings known in class
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2901
     and all superclasses. The returned collection is not sorted by any order."
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2902
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2903
    |coll|
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2904
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2905
    coll := OrderedCollection new.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2906
    self addAllCategoriesTo:coll.
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2907
    ^ coll
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2908
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2909
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2910
     Point categories  
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2911
     Point allCategories 
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2912
    "
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2913
!
41c73cbee305 change classes versionString when class changes (prepare for sourceCode system)
Claus Gittinger <cg@exept.de>
parents: 453
diff changeset
  2914
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2915
whichClassDefinesInstVar:aVariableName
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2916
    "return the class which defines the instance variable
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2917
     named aVariableName. This method should not be used for
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2918
     repeated searches (i.e. in the compiler/parser), since it creates
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2919
     many throw away intermediate objects."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2920
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2921
    |cls|
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2922
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2923
    cls := self.
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2924
    [cls notNil] whileTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2925
	(cls instVarNames includes:aVariableName) ifTrue:[ ^ cls].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2926
	cls := cls superclass
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2927
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2928
    ^ nil
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  2929
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  2930
    "
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2931
     StandardSystemView whichClassDefinesInstVar:'label'  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2932
     StandardSystemView whichClassDefinesInstVar:'paint'  
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2933
     StandardSystemView whichClassDefinesInstVar:'foo'  
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  2934
    "
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2935
! !
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2936
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2937
!Class methodsFor:'subclass creation'!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2938
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2939
subclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2940
    "create a new class as a subclass of an existing class (the receiver).
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2941
     The subclass will have indexed variables if the receiving-class has."
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2942
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2943
    self isVariable ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2944
	^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2945
	    name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2946
	    inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2947
	    subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2948
	    instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2949
	    variable:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2950
	    words:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2951
	    pointers:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2952
	    classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2953
	    poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2954
	    category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2955
	    comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2956
	    changed:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2957
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2958
    self isBytes ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2959
	^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2960
	    variableByteSubclass:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2961
	    instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2962
	    classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2963
	    poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2964
	    category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2965
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2966
    self isLongs ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2967
	^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2968
	    variableLongSubclass:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2969
	    instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2970
	    classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2971
	    poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2972
	    category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2973
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2974
    self isFloats ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2975
	^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2976
	    variableFloatSubclass:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2977
	    instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2978
	    classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2979
	    poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2980
	    category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2981
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2982
    self isDoubles ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2983
	^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2984
	    variableDoubleSubclass:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2985
	    instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2986
	    classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2987
	    poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2988
	    category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2989
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2990
    self isWords ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2991
	^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2992
	    variableWordSubclass:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2993
	    instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2994
	    classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2995
	    poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2996
	    category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2997
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2998
    ^ self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  2999
	variableSubclass:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3000
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3001
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3002
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3003
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3004
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3005
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3006
variableSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3007
    "create a new class as a subclass of an existing class (the receiver) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3008
     in which the subclass has indexable pointer variables"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3009
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3010
    self isVariable ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3011
	self isPointers ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3012
	    ^ self error:
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3013
		'cannot make a variable pointer subclass of a variable non-pointer class'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3014
	]
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3015
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3016
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3017
    ^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3018
	name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3019
	inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3020
	subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3021
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3022
	variable:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3023
	words:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3024
	pointers:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3025
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3026
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3027
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3028
	comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3029
	changed:false
293
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  3030
!
31df3850e98c *** empty log message ***
claus
parents: 289
diff changeset
  3031
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3032
variableByteSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3033
    "create a new class as a subclass of an existing class (the receiver) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3034
     in which the subclass has indexable byte-sized nonpointer variables"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3035
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3036
    self isVariable ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3037
	self isBytes ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3038
	    ^ self error:
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3039
		'cannot make a variable byte subclass of a variable non-byte class'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3040
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3041
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3042
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3043
    ^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3044
	name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3045
	inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3046
	subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3047
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3048
	variable:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3049
	words:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3050
	pointers:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3051
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3052
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3053
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3054
	comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3055
	changed:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3056
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3057
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3058
variableWordSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3059
    "create a new class as a subclass of an existing class (the receiver) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3060
     in which the subclass has indexable word-sized nonpointer variables"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3061
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3062
    self isVariable ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3063
	self isWords ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3064
	    ^ self error:
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3065
		'cannot make a variable word subclass of a variable non-word class'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3066
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3067
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3068
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3069
    ^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3070
	name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3071
	inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3072
	subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3073
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3074
	variable:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3075
	words:true
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3076
	pointers:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3077
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3078
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3079
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3080
	comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3081
	changed:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3082
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3083
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3084
variableLongSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3085
    "create a new class as a subclass of an existing class (the receiver) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3086
     in which the subclass has indexable long-sized nonpointer variables"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3087
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3088
    self isVariable ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3089
	self isLongs ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3090
	    ^ self error:
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3091
		'cannot make a variable long subclass of a variable non-long class'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3092
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3093
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3094
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3095
    ^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3096
	name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3097
	inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3098
	subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3099
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3100
	variable:#long 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3101
	words:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3102
	pointers:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3103
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3104
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3105
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3106
	comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3107
	changed:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3108
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3109
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3110
variableFloatSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3111
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3112
    "create a new class as a subclass of an existing class (the receiver) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3113
     in which the subclass has indexable float-sized nonpointer variables"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3114
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3115
    self isVariable ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3116
	self isFloats ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3117
	    ^ self error:
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3118
		'cannot make a variable float subclass of a variable non-float class'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3119
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3120
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3121
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3122
    ^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3123
	name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3124
	inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3125
	subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3126
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3127
	variable:#float 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3128
	words:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3129
	pointers:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3130
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3131
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3132
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3133
	comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3134
	changed:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3135
!
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3136
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3137
variableDoubleSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3138
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3139
    "create a new class as a subclass of an existing class (the receiver) 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3140
     in which the subclass has indexable double-sized nonpointer variables"
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3141
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3142
    self isVariable ifTrue:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3143
	self isDoubles ifFalse:[
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3144
	    ^ self error:
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3145
		'cannot make a variable double subclass of a variable non-double class'
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3146
	].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3147
    ].
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3148
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3149
    ^ self class
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3150
	name:t
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3151
	inEnvironment:Smalltalk
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3152
	subclassOf:self
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3153
	instanceVariableNames:f
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3154
	variable:#double 
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3155
	words:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3156
	pointers:false
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3157
	classVariableNames:d
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3158
	poolDictionaries:s
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3159
	category:cat
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3160
	comment:nil
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3161
	changed:false
2
claus
parents: 1
diff changeset
  3162
! !
453
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3163
57381f377c3f fix logged-arg (was nil)
Claus Gittinger <cg@exept.de>
parents: 435
diff changeset
  3164
Class initialize!