Project.st
author Claus Gittinger <cg@exept.de>
Thu, 14 Dec 1995 16:56:13 +0100
changeset 750 f4ed622893ce
parent 725 02759b2003a8
child 848 76a83f34c26a
permissions -rw-r--r--
added schedulerInterrupt - for soon to come semaSignal primitive function
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     1
"
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
     3
	      All Rights Reserved
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     4
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     5
 This software is furnished under a license and may be used
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     6
 only in accordance with the terms of that license and with the
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     8
 be provided or otherwise made available to, or used by, any
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
     9
 other person.  No title to or ownership of the software is
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    10
 hereby transferred.
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    11
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object subclass:#Project
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
    14
	 instanceVariableNames:'name changeSet views directoryName properties packageName
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    15
                repositoryDirectory repositoryModule'
315
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
    16
	 classVariableNames:'CurrentProject SystemProject NextSequential'
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
    17
	 poolDictionaries:''
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
    18
	 category:'System-Support'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    21
!Project class methodsFor:'documentation'!
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    22
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    23
copyright
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    24
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    25
 COPYRIGHT (c) 1993 by Claus Gittinger
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
    26
	      All Rights Reserved
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    27
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    28
 This software is furnished under a license and may be used
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    29
 only in accordance with the terms of that license and with the
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    31
 be provided or otherwise made available to, or used by, any
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    32
 other person.  No title to or ownership of the software is
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    33
 hereby transferred.
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    34
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    35
!
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    36
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    37
documentation
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    38
"
338
claus
parents: 336
diff changeset
    39
    this class is still under construction (especially the build features are unfinished).
235
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
    40
    Currently, all it does is keep track of per-project views 
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
    41
    (to hide or show them), define the directory when filing-out,
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    42
    and define packageNames for new classes and methods.
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    43
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    44
    instance variables:
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    45
        name            <String>        the name of this project, as shown
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    46
                                        in a ProjectView
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    47
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    48
        changeSet       <ChangeSet>     changes done, while this was the active project
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    49
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    50
        views           <Collection>    views opened while this was the active project
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    51
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    52
        directoryName   <String>        directory name, where fileOuts are done
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    53
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    54
        properties 
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    55
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    56
        packageName     <String>        given to classes/methods which are created while
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    57
                                        this is the active project
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    58
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    59
        repositoryDirectory             (default) name of the repository, when a new source containers are
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    60
                                        created.
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    61
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    62
        repositoryModule                (default) name of the module, when new source containers are
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    63
                                        created.
235
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
    64
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
    65
    Future: 
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    66
        - keep track of per-project changes
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    67
        - allow speficiation of the type of the project (application, library, etc)
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    68
        - allow building of whatever the target (as defined by the type) is
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    69
          (this will allow build of class libs and apps by clicking a button)
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
    70
        - allow removal of project specific classes, methods etc.
89
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    71
"
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    72
! !
7be0b86ef80f *** empty log message ***
claus
parents: 87
diff changeset
    73
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    74
!Project class methodsFor:'initialization'!
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    75
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    76
initialize
338
claus
parents: 336
diff changeset
    77
    SystemProject isNil ifTrue:[
315
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
    78
	NextSequential := 1.
338
claus
parents: 336
diff changeset
    79
	SystemProject := self new name:'default'.
claus
parents: 336
diff changeset
    80
	SystemProject packageName:'private'.
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    81
	"
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    82
	 the SystemProject does not keep a record if changes,
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    83
	 but instead depends on the changes file - recording anything there.
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    84
	"
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    85
	SystemProject changeSet:nil.
338
claus
parents: 336
diff changeset
    86
    ].
claus
parents: 336
diff changeset
    87
claus
parents: 336
diff changeset
    88
    CurrentProject := SystemProject.
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    89
315
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
    90
    "
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
    91
     Project initialize
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
    92
    "
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    93
! !
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    94
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    95
!Project class methodsFor:'instance creation'!
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    96
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    97
new
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    98
    ^ self basicNew initialize
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
    99
! !
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   100
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
!Project class methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
current
10
claus
parents: 2
diff changeset
   104
    "return the currently active project"
claus
parents: 2
diff changeset
   105
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
    ^ CurrentProject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
362
claus
parents: 356
diff changeset
   108
    "
claus
parents: 356
diff changeset
   109
     Project current
claus
parents: 356
diff changeset
   110
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
current:aProject
10
claus
parents: 2
diff changeset
   114
    "set the currently active project"
claus
parents: 2
diff changeset
   115
315
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   116
    CurrentProject := aProject.
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   117
    self changed:#currentProject
334
claus
parents: 330
diff changeset
   118
!
claus
parents: 330
diff changeset
   119
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   120
currentPackageName
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   121
    CurrentProject notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   122
	^ CurrentProject packageName
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   123
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   124
    ^ 'no package' 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   125
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   126
    "
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   127
     Project currentPackageName
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   128
    "
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   129
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   130
336
claus
parents: 334
diff changeset
   131
defaultProject
claus
parents: 334
diff changeset
   132
    "return the SystemDefault project"
claus
parents: 334
diff changeset
   133
claus
parents: 334
diff changeset
   134
    ^ SystemProject.
claus
parents: 334
diff changeset
   135
!
claus
parents: 334
diff changeset
   136
334
claus
parents: 330
diff changeset
   137
setDefaultProject
claus
parents: 330
diff changeset
   138
    "set the currently active project to be the SystemDEfault project"
claus
parents: 330
diff changeset
   139
claus
parents: 330
diff changeset
   140
    self current:SystemProject.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   143
!Project class methodsFor:'changes management'!
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   144
664
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   145
addClassDefinitionChangeFor:aClass
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   146
    |p c|
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   147
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   148
    p := CurrentProject.
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   149
    (p notNil 
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   150
    and:[(c := p changeSet) notNil]) ifTrue:[
666
6d4175de8c55 fixed primitiveDefinitions changes
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
   151
	c addClassDefinitionChangeFor:aClass 
664
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   152
    ]
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   153
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   154
    "Created: 3.12.1995 / 13:44:58 / cg"
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   155
    "Modified: 3.12.1995 / 13:58:04 / cg"
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   156
!
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   157
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   158
addMethodCategoryChange:aMethod category:newCategory in:aClass
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   159
    |p c|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   160
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   161
    p := CurrentProject.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   162
    (p notNil 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   163
    and:[(c := p changeSet) notNil]) ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   164
	c addMethodCategoryChange:aMethod category:newCategory in:aClass 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   165
    ]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   166
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   167
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   168
addMethodChange:aMethod in:aClass
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   169
    "add a change for a method to the current project"
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   170
235
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
   171
    |p c|
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   172
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   173
    p := CurrentProject.
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   174
    (p notNil 
235
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
   175
    and:[(c := p changeSet) notNil]) ifTrue:[
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
   176
	c addMethodChange:aMethod in:aClass 
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   177
    ]
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   178
!
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   179
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   180
addMethodPrivacyChange:aMethod in:aClass
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   181
    |p c|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   182
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   183
    p := CurrentProject.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   184
    (p notNil 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   185
    and:[(c := p changeSet) notNil]) ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   186
	c addMethodPrivacyChange:aMethod in:aClass 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   187
    ]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   188
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   189
    "Modified: 27.8.1995 / 22:48:17 / claus"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   190
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   191
705
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   192
addPrimitiveDefinitionsChangeFor:aClass
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   193
    |p c|
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   194
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   195
    p := CurrentProject.
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   196
    (p notNil 
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   197
    and:[(c := p changeSet) notNil]) ifTrue:[
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   198
	c addPrimitiveDefinitionsChangeFor:aClass 
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   199
    ]
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   200
!
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   201
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   202
addPrimitiveFunctionsChangeFor:aClass
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   203
    |p c|
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   204
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   205
    p := CurrentProject.
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   206
    (p notNil 
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   207
    and:[(c := p changeSet) notNil]) ifTrue:[
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   208
	c addPrimitiveFunctionsChangeFor:aClass 
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   209
    ]
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   210
!
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   211
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   212
addPrimitiveVariablesChangeFor:aClass
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   213
    |p c|
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   214
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   215
    p := CurrentProject.
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   216
    (p notNil 
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   217
    and:[(c := p changeSet) notNil]) ifTrue:[
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   218
	c addPrimitiveVariablesChangeFor:aClass 
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   219
    ]
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   220
!
2126aba57d34 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 666
diff changeset
   221
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   222
currentProjectDirectory
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   223
    "return the name of the directory to use for fileOut.
235
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
   224
     The returned name already includes a file-separator at the end, 
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
   225
     so the filename can be concatenated to it."
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   226
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   227
    |p dirName|
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   228
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   229
    p := CurrentProject.
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   230
    p notNil ifTrue:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   231
	dirName := p directory  
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   232
    ] ifFalse:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   233
	dirName := '.'
149
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   234
    ].
a3b1bf2938c6 changeSet interface changed
claus
parents: 97
diff changeset
   235
    ^ dirName , Filename separator asString
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   236
! !
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   237
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
!Project methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
changeSet
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
    ^ changeSet
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   244
changeSet:aChangeSet
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   245
    changeSet := aChangeSet
73
a6640cc96199 *** empty log message ***
claus
parents: 13
diff changeset
   246
!
a6640cc96199 *** empty log message ***
claus
parents: 13
diff changeset
   247
315
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   248
directory
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   249
    directoryName isNil ifTrue:[^ '.'].
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   250
    ^ directoryName
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   251
!
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   252
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   253
directory:aDirectoryName
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   254
    directoryName := aDirectoryName.
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   255
    self == CurrentProject ifTrue:[
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   256
	Project changed:#directory 
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   257
    ]
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   258
!
356
claus
parents: 338
diff changeset
   259
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   260
name
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   261
    ^ name
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   262
!
356
claus
parents: 338
diff changeset
   263
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   264
name:aString
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   265
    name := aString.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   266
    self == CurrentProject ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   267
	Project changed:#name
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   268
    ]
356
claus
parents: 338
diff changeset
   269
!
claus
parents: 338
diff changeset
   270
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   271
packageName
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   272
    ^ packageName
10
claus
parents: 2
diff changeset
   273
!
claus
parents: 2
diff changeset
   274
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   275
packageName:aStringOrSymbol
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   276
    packageName := aStringOrSymbol asSymbol.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   277
    self == CurrentProject ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   278
	Project changed:#package
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   279
    ]
10
claus
parents: 2
diff changeset
   280
!
claus
parents: 2
diff changeset
   281
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   282
repositoryDirectory
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   283
    ^ repositoryDirectory
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   284
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   285
    "Created: 25.11.1995 / 18:04:51 / cg"
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   286
    "Modified: 9.12.1995 / 16:58:05 / cg"
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   287
!
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   288
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   289
repositoryDirectory:aRelativePathName
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   290
    repositoryDirectory := aRelativePathName
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   291
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   292
    "Created: 25.11.1995 / 18:05:06 / cg"
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   293
    "Modified: 9.12.1995 / 16:58:11 / cg"
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   294
!
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   295
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   296
repositoryModule
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   297
    ^ repositoryModule
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   298
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   299
    "Created: 25.11.1995 / 18:04:51 / cg"
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   300
    "Modified: 9.12.1995 / 16:58:18 / cg"
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   301
!
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   302
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   303
repositoryModule:aString
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   304
    repositoryModule := aString
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   305
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   306
    "Created: 25.11.1995 / 18:05:06 / cg"
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   307
    "Modified: 9.12.1995 / 16:58:35 / cg"
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   308
!
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   309
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   310
views
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   311
    ^ views asArray
338
claus
parents: 336
diff changeset
   312
!
claus
parents: 336
diff changeset
   313
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   314
views:aSetOfViews
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   315
    views := WeakIdentitySet withAll:aSetOfViews
10
claus
parents: 2
diff changeset
   316
! !
claus
parents: 2
diff changeset
   317
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   318
!Project methodsFor:'initialization'!
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   319
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   320
initialize
338
claus
parents: 336
diff changeset
   321
    |numString|
claus
parents: 336
diff changeset
   322
330
claus
parents: 318
diff changeset
   323
    views := WeakIdentitySet new.
338
claus
parents: 336
diff changeset
   324
    numString := NextSequential printString.
315
7683685383d6 *** empty log message ***
claus
parents: 236
diff changeset
   325
    NextSequential := NextSequential + 1.
338
claus
parents: 336
diff changeset
   326
claus
parents: 336
diff changeset
   327
    name := 'new Project-' , numString.
claus
parents: 336
diff changeset
   328
    packageName := 'private-' , numString.
664
42ea897fbebe project changeSet fixes
Claus Gittinger <cg@exept.de>
parents: 654
diff changeset
   329
     changeSet := ChangeSet new.
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   330
    self directory:'.'.
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   331
    self repositoryModule:(OperatingSystem getLoginName).
654
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   332
    self repositoryDirectory:'private'
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   333
1e039f69fdee added repository
Claus Gittinger <cg@exept.de>
parents: 630
diff changeset
   334
    "Created: 25.11.1995 / 18:05:44 / cg"
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   335
    "Modified: 9.12.1995 / 17:14:30 / cg"
236
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   336
! !
fa6d1f330010 *** empty log message ***
claus
parents: 235
diff changeset
   337
2
claus
parents: 1
diff changeset
   338
!Project methodsFor:'maintenance'!
claus
parents: 1
diff changeset
   339
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   340
buildProject
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   341
    OperatingSystem executeCommand:('cd ' , self directory , ' ; make')
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   342
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   343
2
claus
parents: 1
diff changeset
   344
createMakefile
claus
parents: 1
diff changeset
   345
    "creates an initial makefile, which will recreate a correct
claus
parents: 1
diff changeset
   346
     Makefile, then compile all"
claus
parents: 1
diff changeset
   347
362
claus
parents: 356
diff changeset
   348
    |d f out in topName|
2
claus
parents: 1
diff changeset
   349
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   350
    Transcript showCr:'creating Makefile'.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   351
356
claus
parents: 338
diff changeset
   352
    d := directoryName asFilename.
2
claus
parents: 1
diff changeset
   353
    f := d construct:'Makefile'.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   354
    f exists ifTrue:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   355
	f renameTo:(d construct:'Makefile.bak')
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   356
    ].
2
claus
parents: 1
diff changeset
   357
    out := f writeStream.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   358
    out isNil ifTrue:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   359
	self warn:'cannot create Makefile'.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   360
	^ self
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   361
    ].
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   362
    in := Smalltalk systemFileStreamFor:'rules/stdHeader'.
2
claus
parents: 1
diff changeset
   363
    out nextPutAll:in contents asString.
claus
parents: 1
diff changeset
   364
    in close.
362
claus
parents: 356
diff changeset
   365
claus
parents: 356
diff changeset
   366
    topName := self findTopFrom:directoryName.
claus
parents: 356
diff changeset
   367
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   368
    out nextPutAll:'#TOP=/usr/local/lib/smalltalk'; cr.
362
claus
parents: 356
diff changeset
   369
    out nextPutAll:'TOP=' , topName; cr.
2
claus
parents: 1
diff changeset
   370
    out nextPutAll:'target:'; cr.
claus
parents: 1
diff changeset
   371
    out tab; nextPutAll:'touch Make.proto'; cr.
claus
parents: 1
diff changeset
   372
    out tab; nextPutAll:'$(MAKE) Makefile'; cr.
claus
parents: 1
diff changeset
   373
    out tab; nextPutAll:'make'; cr; cr.
claus
parents: 1
diff changeset
   374
362
claus
parents: 356
diff changeset
   375
    in := Smalltalk systemFileStreamFor:'configurations/COMMON/defines'.
claus
parents: 356
diff changeset
   376
    out nextPutAll:in contents asString.
claus
parents: 356
diff changeset
   377
    in close.
claus
parents: 356
diff changeset
   378
claus
parents: 356
diff changeset
   379
    in := Smalltalk systemFileStreamFor:'configurations/vendorConf'.
claus
parents: 356
diff changeset
   380
    out nextPutAll:in contents asString.
claus
parents: 356
diff changeset
   381
    in close.
claus
parents: 356
diff changeset
   382
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   383
    in := Smalltalk systemFileStreamFor:'configurations/myConf'.
2
claus
parents: 1
diff changeset
   384
    out nextPutAll:in contents asString.
claus
parents: 1
diff changeset
   385
    in close.
362
claus
parents: 356
diff changeset
   386
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   387
    in := Smalltalk systemFileStreamFor:'rules/stdRules'.
2
claus
parents: 1
diff changeset
   388
    out nextPutAll:in contents asString.
claus
parents: 1
diff changeset
   389
    in close.
claus
parents: 1
diff changeset
   390
    out close
claus
parents: 1
diff changeset
   391
!
claus
parents: 1
diff changeset
   392
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   393
createProjectFiles
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   394
    "actually, creates all files to do a make in the project directory"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   395
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   396
    directoryName asFilename exists ifFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   397
	(self confirm:'create new projectDirectory: ' , directoryName) 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   398
	    ifFalse:[^ self].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   399
	OperatingSystem recursiveCreateDirectory:directoryName.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   400
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   401
    self createMakefile.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   402
    self createSourcefiles.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   403
    self createProtoMakefile.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   404
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   405
2
claus
parents: 1
diff changeset
   406
createProtoMakefile
claus
parents: 1
diff changeset
   407
    "creates a Make.proto file"
claus
parents: 1
diff changeset
   408
362
claus
parents: 356
diff changeset
   409
    |d f s type appName libName startUpClass startUpSelector
claus
parents: 356
diff changeset
   410
     topName classes|
2
claus
parents: 1
diff changeset
   411
362
claus
parents: 356
diff changeset
   412
    topName := self findTopFrom:directoryName.
2
claus
parents: 1
diff changeset
   413
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   414
    Transcript showCr:'creating Make.proto'.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   415
356
claus
parents: 338
diff changeset
   416
    d := directoryName asFilename.
2
claus
parents: 1
diff changeset
   417
    f := d construct:'Make.proto'.
claus
parents: 1
diff changeset
   418
    f exists ifTrue:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   419
	f renameTo:(d construct:'Make.proto.bak')
2
claus
parents: 1
diff changeset
   420
    ].
claus
parents: 1
diff changeset
   421
    s := f writeStream.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   422
    s isNil ifTrue:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   423
	self warn:'cannot create prototype Makefile'.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   424
	^ self
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   425
    ].
2
claus
parents: 1
diff changeset
   426
    s nextPutAll:'#
362
claus
parents: 356
diff changeset
   427
# ' , Smalltalk timeStamp , '
claus
parents: 356
diff changeset
   428
#
235
d8e62525bfdf *** empty log message ***
claus
parents: 203
diff changeset
   429
# created by Smalltalks Project support
2
claus
parents: 1
diff changeset
   430
#
362
claus
parents: 356
diff changeset
   431
claus
parents: 356
diff changeset
   432
claus
parents: 356
diff changeset
   433
# the next line defines the path to the TOP directory,
claus
parents: 356
diff changeset
   434
# (where the directories "configurations" and "include" are found)
claus
parents: 356
diff changeset
   435
#
claus
parents: 356
diff changeset
   436
#TOP=/usr/local/lib/smalltalk
claus
parents: 356
diff changeset
   437
TOP=' , topName ,'
claus
parents: 356
diff changeset
   438
claus
parents: 356
diff changeset
   439
#
claus
parents: 356
diff changeset
   440
# add any subdirectories that have to be visited by make
claus
parents: 356
diff changeset
   441
#
claus
parents: 356
diff changeset
   442
SUBDIRS=
claus
parents: 356
diff changeset
   443
claus
parents: 356
diff changeset
   444
#
claus
parents: 356
diff changeset
   445
# do not change
claus
parents: 356
diff changeset
   446
#
2
claus
parents: 1
diff changeset
   447
SHELL=/bin/sh
claus
parents: 1
diff changeset
   448
362
claus
parents: 356
diff changeset
   449
'.
claus
parents: 356
diff changeset
   450
claus
parents: 356
diff changeset
   451
    s nextPutAll:'#
claus
parents: 356
diff changeset
   452
# set the stc options
claus
parents: 356
diff changeset
   453
#
claus
parents: 356
diff changeset
   454
STCOPT=$(DEFAULT_STCOPT)
claus
parents: 356
diff changeset
   455
# STCOPT=+optspace2
claus
parents: 356
diff changeset
   456
# STCOPT=+optspace2 -warnNonStandard
claus
parents: 356
diff changeset
   457
claus
parents: 356
diff changeset
   458
#
claus
parents: 356
diff changeset
   459
# and packageName option
claus
parents: 356
diff changeset
   460
#
claus
parents: 356
diff changeset
   461
STCLOCALOPT=''-Pprivate-classes-(libapp)''
2
claus
parents: 1
diff changeset
   462
claus
parents: 1
diff changeset
   463
'.
claus
parents: 1
diff changeset
   464
356
claus
parents: 338
diff changeset
   465
    type := #library.
claus
parents: 338
diff changeset
   466
    appName := 'app'.
claus
parents: 338
diff changeset
   467
    libName := 'lib'.
claus
parents: 338
diff changeset
   468
    startUpClass := 'Smalltalk'.
claus
parents: 338
diff changeset
   469
    startUpSelector := 'start'.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   470
356
claus
parents: 338
diff changeset
   471
    properties notNil ifTrue:[
claus
parents: 338
diff changeset
   472
	type := properties at:#projectType ifAbsent:type.
claus
parents: 338
diff changeset
   473
	appName := properties at:#applicationName ifAbsent:appName.
claus
parents: 338
diff changeset
   474
	startUpClass := properties at:#startupClass ifAbsent:startUpClass.
claus
parents: 338
diff changeset
   475
	startUpSelector := properties at:#startupSelector ifAbsent:startUpSelector.
claus
parents: 338
diff changeset
   476
    ].
claus
parents: 338
diff changeset
   477
362
claus
parents: 356
diff changeset
   478
    s nextPutAll:'#
claus
parents: 356
diff changeset
   479
# define the name of the library to create
claus
parents: 356
diff changeset
   480
#
claus
parents: 356
diff changeset
   481
'.
claus
parents: 356
diff changeset
   482
    s nextPutAll:'LIBNAME=lib' , appName; cr; cr.
claus
parents: 356
diff changeset
   483
claus
parents: 356
diff changeset
   484
    s nextPutAll:'#
claus
parents: 356
diff changeset
   485
# the target rule:
claus
parents: 356
diff changeset
   486
#
claus
parents: 356
diff changeset
   487
all::   abbrev.stc objs genClassList $(OBJTARGET)
claus
parents: 356
diff changeset
   488
claus
parents: 356
diff changeset
   489
'.
2
claus
parents: 1
diff changeset
   490
claus
parents: 1
diff changeset
   491
    type == #executable ifTrue:[
362
claus
parents: 356
diff changeset
   492
	s nextPutAll:'PROGS = ' , appName; cr.
claus
parents: 356
diff changeset
   493
	s nextPutAll:('STARTUP_CLASS=' , startUpClass); cr.
claus
parents: 356
diff changeset
   494
	s nextPutAll:'STARTUP_SELECTOR="' , startUpSelector; nextPutAll:'"'; cr.
2
claus
parents: 1
diff changeset
   495
    ].
claus
parents: 1
diff changeset
   496
362
claus
parents: 356
diff changeset
   497
    s nextPutAll:'#
claus
parents: 356
diff changeset
   498
# define the object files that are to be created
claus
parents: 356
diff changeset
   499
#
claus
parents: 356
diff changeset
   500
'.
2
claus
parents: 1
diff changeset
   501
    s nextPutAll:'OBJS='.
claus
parents: 1
diff changeset
   502
362
claus
parents: 356
diff changeset
   503
    (classes := self classes) notNil ifTrue:[
claus
parents: 356
diff changeset
   504
	classes do:[:aClass |
claus
parents: 356
diff changeset
   505
	    |abbrev|
claus
parents: 356
diff changeset
   506
claus
parents: 356
diff changeset
   507
	    s nextPutAll:' \'. s cr.
claus
parents: 356
diff changeset
   508
	    abbrev := Smalltalk fileNameForClass:aClass name.
claus
parents: 356
diff changeset
   509
	    s nextPutAll:'  '; nextPutAll:abbrev; nextPutAll:'.o'.
claus
parents: 356
diff changeset
   510
	].
2
claus
parents: 1
diff changeset
   511
    ].
claus
parents: 1
diff changeset
   512
    s cr; cr.
claus
parents: 1
diff changeset
   513
362
claus
parents: 356
diff changeset
   514
    s nextPutAll:'#
claus
parents: 356
diff changeset
   515
# dependencies:
claus
parents: 356
diff changeset
   516
#
claus
parents: 356
diff changeset
   517
I=$(TOP)/include
claus
parents: 356
diff changeset
   518
RT_STUFF=$(I)/Object.H $(I)/stc.h $(I)/stcIntern.h
claus
parents: 356
diff changeset
   519
claus
parents: 356
diff changeset
   520
'.
claus
parents: 356
diff changeset
   521
    classes notNil ifTrue:[
claus
parents: 356
diff changeset
   522
	classes do:[:aClass |
claus
parents: 356
diff changeset
   523
	    |abbrev|
claus
parents: 356
diff changeset
   524
claus
parents: 356
diff changeset
   525
	    abbrev := Smalltalk fileNameForClass:aClass name.
claus
parents: 356
diff changeset
   526
	    s nextPutAll:abbrev; nextPutAll:'.o: '.
claus
parents: 356
diff changeset
   527
	    s nextPutAll:abbrev; nextPutAll:'.st '.
claus
parents: 356
diff changeset
   528
	    aClass allSuperclassesDo:[:superClass|
claus
parents: 356
diff changeset
   529
		s nextPutAll:'$(I)/'.
claus
parents: 356
diff changeset
   530
		s nextPutAll:(Smalltalk fileNameForClass:superClass name) , '.H '.
claus
parents: 356
diff changeset
   531
	    ].
claus
parents: 356
diff changeset
   532
	    s nextPutAll:'$(RT_STUFF)';  cr.
claus
parents: 356
diff changeset
   533
	].
claus
parents: 356
diff changeset
   534
    ].
claus
parents: 356
diff changeset
   535
    s cr; cr.
2
claus
parents: 1
diff changeset
   536
claus
parents: 1
diff changeset
   537
    type == #executable ifTrue:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   538
	s nextPutAll:'all:: $(PROGS)'; cr.
2
claus
parents: 1
diff changeset
   539
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   540
	s nextPutAll:appName.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   541
	s nextPutAll:':: main.o classList.o $(OBJS)'; cr.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   542
	s tab;      nextPutAll:'$(LD) $(ST_LDFLAG) $(LDFLAGS) -o ';
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   543
		    nextPutAll:appName;
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   544
		    nextPutAll:' \'; cr.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   545
	s tab; tab; nextPutAll:'$(CRT0) main.$(O) classList.$(O) $(OBJS) $(EXTRA_OBJ) $(LIBOBJS) \'; cr.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   546
	s tab; tab; nextPutAll:'$(LIBRUNDIR)/hidata.o $(LIBRUN) \'; cr.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   547
	s tab; tab; nextPutAll:'$(MATHLIB) $(EXTRALIBS) -lXext $(SYSLIBS) $(OTHERLIBS) $(CRTN)'; cr.
2
claus
parents: 1
diff changeset
   548
    ].
claus
parents: 1
diff changeset
   549
claus
parents: 1
diff changeset
   550
    s close
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   551
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   552
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   553
createSourcefiles
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   554
    "creates all Smalltalk-source files in the project directory"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   555
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   556
    |classes methods methodClasses dir stream|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   557
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   558
    dir := FileDirectory directoryNamed:self directory.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   559
    Transcript showCr:'creating sources in ' , dir pathName , ' ...'; endEntry.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   560
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   561
    classes := self classes.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   562
    classes isNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   563
	self warn:'no classes in current project'
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   564
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   565
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   566
    classes notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   567
	classes do:[:aClass |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   568
	    aClass isLoaded ifFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   569
		aClass autoload.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   570
	    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   571
	].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   572
	classes := classes topologicalSort:[:a :b | a isSubclassOf:b].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   573
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   574
	classes do:[:aClass |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   575
	    Transcript show:' ... '; showCr:aClass name, '.st'; endEntry.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   576
	    aClass fileOutIn:dir
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   577
	]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   578
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   579
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   580
    methods := self individualMethods.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   581
    methods notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   582
	methods := methods asIdentitySet.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   583
	"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   584
	 get classes ...
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   585
	"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   586
	methodClasses := IdentitySet new.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   587
	methods do:[:m | 
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   588
			|mCls|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   589
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   590
			mCls := m who at:1.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   591
			mCls isMeta ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   592
			    mCls := mCls soleInstance.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   593
			].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   594
			methodClasses add:mCls].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   595
	"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   596
	 fileOut by class
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   597
	"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   598
	methodClasses do:[:cls |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   599
	    stream := (self directory asFilename construct:(cls name , '.chg')) writeStream.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   600
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   601
	    Transcript show:' ... '; showCr:cls name, '.chg'; endEntry.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   602
	    methods do:[:m |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   603
		|mCls|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   604
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   605
		mCls := m who at:1.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   606
		(mCls == cls or:[mCls == cls class]) ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   607
		    mCls fileOutMethod:m on:stream.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   608
		].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   609
		stream cr.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   610
	    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   611
	    stream close.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   612
	].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   613
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   614
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   615
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   616
findTopFrom:directoryName
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   617
    "returns the relative path from directoryName to the TOP
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   618
     directory."
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   619
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   620
    |topName relParent foundTop|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   621
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   622
    "/ find TOP
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   623
    relParent := '..'.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   624
    foundTop := false.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   625
    [foundTop] whileFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   626
	topName := directoryName , '/' , relParent.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   627
	topName asFilename pathName = '/' ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   628
	    self warn:'could not find TOP; assume absoulte path to TOP'.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   629
	    topName := '/usr/local/lib/smalltalk'.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   630
	    foundTop := true.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   631
	] ifFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   632
	    (topName , '/configurations') asFilename exists ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   633
		(topName , '/include') asFilename exists ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   634
		    foundTop := true.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   635
		    topName := relParent.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   636
		]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   637
	    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   638
	    foundTop ifFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   639
		relParent := relParent , '/..'.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   640
	    ]        
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   641
	]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   642
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   643
    ^ topName
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   644
! !
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   645
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   646
!Project methodsFor:'properties'!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   647
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   648
properties
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   649
    ^ properties
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   650
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   651
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   652
properties:p
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   653
    properties := p
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   654
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   655
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   656
type
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   657
    "return the type of project"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   658
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   659
    ^ properties at:#type ifAbsent:[#application]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   660
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   661
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   662
type:aSymbol
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   663
    "set the projects type"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   664
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   665
    (#(application library smalltalk) includes:aSymbol) ifFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   666
	self warn:'invalid project type'.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   667
	^ self
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   668
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   669
    properties at:#type put:aSymbol
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   670
! !
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   671
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   672
!Project methodsFor:'queries'!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   673
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   674
classes
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   675
    "return a collection of classes belonging to that project"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   676
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   677
    |classes|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   678
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   679
    properties notNil ifTrue:[classes := properties at:#classes ifAbsent:nil].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   680
    classes isNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   681
	classes := OrderedCollection new.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   682
	Smalltalk allClassesDo:[:aClass | aClass package = packageName ifTrue:[classes add:aClass]].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   683
	classes isEmpty ifTrue:[^ nil].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   684
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   685
    ^ classes
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   686
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   687
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   688
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   689
individualMethods
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   690
    "return a collection of individual methods belonging to that project,
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   691
     only methods are returned which are not contained in the
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   692
     projects class set."
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   693
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   694
    |classes methods|
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   695
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   696
    classes := self classes.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   697
    classes notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   698
	classes := classes asIdentitySet.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   699
    ] ifFalse:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   700
	classes := #()
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   701
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   702
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   703
    methods := IdentitySet new.
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   704
    Smalltalk allBehaviorsDo:[:cls |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   705
	(classes isNil or:[(classes includes:cls) not]) ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   706
	    cls methodArray do:[:m |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   707
		m package = packageName ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   708
		    methods add:m
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   709
		]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   710
	    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   711
	    cls class methodArray do:[:m |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   712
		m package = packageName ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   713
		    methods add:m
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   714
		]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   715
	    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   716
	]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   717
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   718
    ^ methods asArray
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   719
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   720
    "
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   721
     Project current classes
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   722
     Project current individualMethods
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   723
    "
2
claus
parents: 1
diff changeset
   724
! !
claus
parents: 1
diff changeset
   725
claus
parents: 1
diff changeset
   726
!Project methodsFor:'specifications'!
claus
parents: 1
diff changeset
   727
claus
parents: 1
diff changeset
   728
readSpec
claus
parents: 1
diff changeset
   729
    |s chunk fileName|
claus
parents: 1
diff changeset
   730
claus
parents: 1
diff changeset
   731
    fileName := (properties at:#directoryName) asFilename construct:'.project'.
claus
parents: 1
diff changeset
   732
    s := fileName readStream.
claus
parents: 1
diff changeset
   733
    s isNil ifTrue:[^ self].
claus
parents: 1
diff changeset
   734
    [s atEnd] whileFalse:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   735
	chunk := s nextChunk.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   736
	Compiler evaluate:chunk receiver:properties notifying:nil
2
claus
parents: 1
diff changeset
   737
    ].
claus
parents: 1
diff changeset
   738
    s close.
claus
parents: 1
diff changeset
   739
claus
parents: 1
diff changeset
   740
    "(Project new directory:'../projects/Clock') readSpec"
claus
parents: 1
diff changeset
   741
!
claus
parents: 1
diff changeset
   742
claus
parents: 1
diff changeset
   743
saveSpec
claus
parents: 1
diff changeset
   744
    |f d s|
claus
parents: 1
diff changeset
   745
claus
parents: 1
diff changeset
   746
    d := (properties at:#directoryName) asFilename.
claus
parents: 1
diff changeset
   747
    d exists ifFalse:[
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   748
	self error:'directory does not exist'.
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   749
	^ self
2
claus
parents: 1
diff changeset
   750
    ].
claus
parents: 1
diff changeset
   751
    f := d construct:'.project'.
claus
parents: 1
diff changeset
   752
    s := f writeStream.
claus
parents: 1
diff changeset
   753
    s isNil ifTrue:[^ self].
claus
parents: 1
diff changeset
   754
    properties associationsDo:[:aProp |
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   755
	(aProp == #directoryName) ifFalse:[
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   756
	    s nextChunkPut:('self at:' , aProp key storeString, 
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   757
			       ' put:' , aProp value storeString).
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   758
	    s cr
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   759
	]
2
claus
parents: 1
diff changeset
   760
    ].
claus
parents: 1
diff changeset
   761
    s close
claus
parents: 1
diff changeset
   762
claus
parents: 1
diff changeset
   763
    "((Project new directory:'../projects/Clock') readSpec
203
3d88fa870de0 *** empty log message ***
claus
parents: 150
diff changeset
   764
	 directory:'../projects/xxx') saveSpec"
2
claus
parents: 1
diff changeset
   765
! !
claus
parents: 1
diff changeset
   766
617
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   767
!Project methodsFor:'views'!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   768
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   769
addView:aView
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   770
    views notNil ifTrue:[views add:aView]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   771
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   772
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   773
destroyViews
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   774
    "destroy all views of this project"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   775
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   776
    views notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   777
	views do:[:aView |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   778
	    aView notNil ifTrue:[aView destroy]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   779
	]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   780
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   781
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   782
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   783
hideViews
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   784
    "hide all views of this project"
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   785
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   786
    views notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   787
	views do:[:aView |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   788
	    aView notNil ifTrue:[aView unrealize]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   789
	]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   790
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   791
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   792
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   793
removeView:aView
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   794
    views notNil ifTrue:[views remove:aView ifAbsent:[]]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   795
!
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   796
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   797
showViews
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   798
    views notNil ifTrue:[
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   799
	views do:[:aView |
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   800
	    aView notNil ifTrue:[aView rerealize]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   801
	]
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   802
    ].
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   803
! !
427245e28240 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   804
630
b785d23d7c5b version at the end
Claus Gittinger <cg@exept.de>
parents: 617
diff changeset
   805
!Project class methodsFor:'documentation'!
b785d23d7c5b version at the end
Claus Gittinger <cg@exept.de>
parents: 617
diff changeset
   806
b785d23d7c5b version at the end
Claus Gittinger <cg@exept.de>
parents: 617
diff changeset
   807
version
725
02759b2003a8 keep module & directory separately (as defaults when creating a container)
Claus Gittinger <cg@exept.de>
parents: 705
diff changeset
   808
^ '$Header: /cvs/stx/stx/libbasic/Project.st,v 1.35 1995-12-09 17:39:20 cg Exp $'! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   809
Project initialize!