SourceCodeManagerUtilitiesForWorkspaceBasedManagers.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Thu, 27 Sep 2012 20:37:25 +0100
branchjv
changeset 3088 e1f7c7f799f8
parent 3067 580931ccfea6
child 3121 19723298dd2c
child 3125 08d6603c4fe9
permissions -rw-r--r--
Merged with /trunk
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3065
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     1
"
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     2
 COPYRIGHT (c) 2012 eXept Software AG
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     3
              All Rights Reserved
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     4
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    10
 hereby transferred.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    11
"
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    12
"{ Package: 'stx:libbasic3' }"
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    13
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    14
SourceCodeManagerUtilities subclass:#SourceCodeManagerUtilitiesForWorkspaceBasedManagers
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    15
	instanceVariableNames:''
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    16
	classVariableNames:''
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    17
	poolDictionaries:''
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    18
	category:'System-SourceCodeManagement'
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    19
!
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    20
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    21
!SourceCodeManagerUtilitiesForWorkspaceBasedManagers class methodsFor:'documentation'!
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    22
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    23
copyright
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    24
"
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    25
 COPYRIGHT (c) 2012 eXept Software AG
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    26
              All Rights Reserved
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    27
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    28
 This software is furnished under a license and may be used
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    29
 only in accordance with the terms of that license and with the
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    31
 be provided or otherwise made available to, or used by, any
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    32
 other person.  No title to or ownership of the software is
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    33
 hereby transferred.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    34
"
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    35
! !
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    36
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    37
!SourceCodeManagerUtilitiesForWorkspaceBasedManagers methodsFor:'utilities-cvs'!
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    38
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    39
checkinPackage:packageToCheckIn classes:doClasses extensions:doExtensions buildSupport:doBuild askForMethodsInOtherPackages:askForMethodsInOtherPackages
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    40
    |mgr classesToCheckIn methodsToCheckIn
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    41
     methodsInOtherPackages looseMethods otherPackages
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    42
     msg classesInChangeSet checkinInfo repos pkgDir extensionsSource defClass
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    43
     path fileIsNew|
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    44
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    45
    mgr := self sourceCodeManagerFor: packageToCheckIn.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    46
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    47
    repos := (mgr repositoryNameForPackage:packageToCheckIn) ifNil:[mgr repositoryName].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    48
3088
e1f7c7f799f8 Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3067
diff changeset
    49
    pkgDir := packageToCheckIn asPackageId pathRelativeToTopDirectory:(mgr workDirectory). 
3065
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    50
    pkgDir recursiveMakeDirectory.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    51
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    52
    "/ containerFileName := self nameOfExtensionsContainer.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    53
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    54
    methodsToCheckIn := IdentitySet new.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    55
    methodsInOtherPackages := IdentitySet new.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    56
    looseMethods := IdentitySet new.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    57
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    58
    classesToCheckIn := Smalltalk allClassesInPackage: packageToCheckIn.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    59
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    60
    "/ cg: O(n^2) algorithm
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    61
    "/  classesInChangeSet := classesToCheckIn select:[:cls | cls hasUnsavedChanges].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    62
    "/ replaced by: O(n) algorithm
3088
e1f7c7f799f8 Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3067
diff changeset
    63
    classesInChangeSet := ChangeSet current selectClassesForWhichIncludesChangeForClassOrMetaclassOrPrivateClassFrom:classesToCheckIn. 
3065
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    64
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    65
    "/ individual methods ...
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    66
    Smalltalk allClassesDo:[:aClass |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    67
        aClass isMeta ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    68
            methodsToCheckIn addAll:(aClass extensionsFrom:packageToCheckIn).
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    69
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    70
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    71
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    72
    self assert:doExtensions.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    73
    self assert:doClasses.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    74
    self assert:doBuild.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    75
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    76
    msg := '%1 classes (%4 changed) '.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    77
    methodsToCheckIn notEmpty ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    78
        msg := msg , 'and %2 extensions '.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    79
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    80
    msg := msg , 'of project "%3"'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    81
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    82
    checkinInfo := self
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    83
                getCheckinInfoFor:(msg
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    84
                                        bindWith:classesToCheckIn size
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    85
                                        with:methodsToCheckIn size
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    86
                                        with:packageToCheckIn allBold
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    87
                                        with:classesInChangeSet size)
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    88
                initialAnswer:nil
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    89
                withQuickOption:false.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    90
    checkinInfo isNil ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    91
        ^ self.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    92
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    93
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    94
    "/ check if any of the classes contains methods for other packages ...
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    95
    classesToCheckIn do:[:eachClass |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    96
        eachClass instAndClassMethodsDo:[:eachMethod |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    97
            |mPgk|
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    98
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    99
            mPgk := eachMethod package.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   100
            (mPgk = packageToCheckIn) ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   101
                mPgk == PackageId noProjectID ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   102
                    looseMethods add:eachMethod
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   103
                ] ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   104
                    methodsInOtherPackages add:eachMethod
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   105
                ]
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   106
            ]
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   107
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   108
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   109
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   110
    askForMethodsInOtherPackages ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   111
        methodsInOtherPackages notEmpty ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   112
            otherPackages := Set new.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   113
            methodsInOtherPackages do:[:eachMethod | otherPackages add:eachMethod package].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   114
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   115
            methodsInOtherPackages size == 1 ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   116
                msg := 'The ''%4'' method in ''%5'' is contained in the ''%2'' package.'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   117
                msg := msg , '\\This method will remain in its package.'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   118
            ] ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   119
                otherPackages size == 1 ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   120
                    msg := 'The %1 methods from the %2 package will remain in its package.'
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   121
                ] ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   122
                    msg := 'The %1 methods from %3 other packages will remain in their packages.'
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   123
                ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   124
                msg := msg , '\\Hint: if these are meant to belong to this package,'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   125
                msg := msg , '\move them first, then repeat the checkin operation.'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   126
            ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   127
            msg := msg withCRs.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   128
            msg := msg bindWith:methodsInOtherPackages size
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   129
                           with:otherPackages first allBold
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   130
                           with:otherPackages size
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   131
                           with:methodsInOtherPackages first selector allBold
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   132
                           with:methodsInOtherPackages first mclass name allBold.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   133
            (Dialog confirm:msg noLabel:(resources string:'Cancel')) ifFalse:[^ self].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   134
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   135
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   136
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   137
    classesToCheckIn notEmpty ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   138
        looseMethods notEmpty ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   139
            looseMethods size == 1 ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   140
                msg := 'The ''%2'' method in ''%3'' is unassigned (loose).'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   141
                msg := msg , '\\If you proceed, this method will be moved to the ''%4'' package'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   142
                msg := msg , '\\Hint: if this is meant to be an extension of another package,'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   143
                msg := msg , '\cancel and move it to the appropriate package first.'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   144
            ] ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   145
                msg := 'There are %1 unassigned (loose) methods in classes from this project.'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   146
                msg := msg , '\\If you proceed, those will be moved to the ''%4'' package ?'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   147
                msg := msg , '\\Hint: if these are meant to be extensions of another package,'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   148
                msg := msg , '\cancel and move them to the appropriate package first.'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   149
            ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   150
            msg := msg withCRs.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   151
            msg := msg bindWith:looseMethods size
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   152
                           with:(looseMethods isEmpty ifTrue:[''] ifFalse:[looseMethods first selector allBold])
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   153
                           with:(looseMethods isEmpty ifTrue:[''] ifFalse:[looseMethods first mclass name allBold])
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   154
                           with:packageToCheckIn allBold.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   155
            (Dialog confirm:msg noLabel:(resources string:'Cancel')) ifFalse:[^ self].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   156
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   157
            looseMethods do:[:mthd |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   158
                mthd package:packageToCheckIn
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   159
            ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   160
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   161
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   162
        classesToCheckIn do:[:eachClass |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   163
            |classFileName|
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   164
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   165
            classFileName := (Smalltalk fileNameForClass:eachClass) , '.st'.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   166
            mgr
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   167
                withClass:eachClass 
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   168
                classFileName:classFileName 
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   169
                filedOutToTemporaryFileDo:[:tempFile |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   170
                    path := pkgDir construct:classFileName.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   171
                    fileIsNew := path exists not.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   172
                    tempFile moveTo:path.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   173
                    fileIsNew ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   174
                        mgr addFile:path baseName inDirectory:path directory.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   175
                    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   176
                ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   177
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   178
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   179
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   180
    path := pkgDir construct:self nameOfExtensionsContainer.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   181
    methodsToCheckIn notEmpty ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   182
        extensionsSource := self sourceCodeForExtensions:methodsToCheckIn package:packageToCheckIn forManager:mgr.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   183
        fileIsNew := path exists not.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   184
        path contents:extensionsSource.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   185
        fileIsNew ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   186
            mgr addFile:path baseName inDirectory:path directory.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   187
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   188
   ] ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   189
        "/ there may have been extension-methods previously - if so, remove them
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   190
        path remove
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   191
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   192
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   193
    defClass := ProjectDefinition definitionClassForPackage: packageToCheckIn.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   194
    defClass forEachFileNameAndGeneratedContentsDo:[:fileName :fileContents |
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   195
        path := pkgDir construct:fileName.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   196
        fileIsNew := path exists not.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   197
        path directory exists ifFalse:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   198
            path directory recursiveMakeDirectory. "/ for autopackage
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   199
            mgr addFile:path directory baseName inDirectory:path directory directory.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   200
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   201
        path contents:fileContents.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   202
        fileIsNew ifTrue:[
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   203
            mgr addFile:fileName inDirectory:path directory.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   204
        ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   205
    ].
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   206
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   207
    mgr commitRepository:repos logMessage:checkinInfo logMessage.
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   208
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   209
    "Created: / 13-10-2011 / 11:15:22 / Jan Vrany <jan.vrany@fit.cvut.cz>"
3088
e1f7c7f799f8 Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3067
diff changeset
   210
    "Modified: / 24-09-2012 / 11:13:04 / cg"
3065
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   211
! !
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   212
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   213
!SourceCodeManagerUtilitiesForWorkspaceBasedManagers class methodsFor:'documentation'!
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   214
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   215
version
3088
e1f7c7f799f8 Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3067
diff changeset
   216
    ^ '$Header: /cvs/stx/stx/libbasic3/SourceCodeManagerUtilitiesForWorkspaceBasedManagers.st,v 1.3 2012/09/26 16:17:41 cg Exp $'
3065
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   217
!
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   218
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   219
version_CVS
3088
e1f7c7f799f8 Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3067
diff changeset
   220
    ^ '§Header: /cvs/stx/stx/libbasic3/SourceCodeManagerUtilitiesForWorkspaceBasedManagers.st,v 1.3 2012/09/26 16:17:41 cg Exp §'
3067
580931ccfea6 fixed bug in changeset reading (info changes were lost)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   221
!
580931ccfea6 fixed bug in changeset reading (info changes were lost)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   222
580931ccfea6 fixed bug in changeset reading (info changes were lost)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   223
version_SVN
3088
e1f7c7f799f8 Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3067
diff changeset
   224
    ^ '$Id:: SourceCodeManagerUtilitiesForWorkspaceBasedManagers.st 1971 2012-09-27 19:37:25Z vranyj1                               $'
3067
580931ccfea6 fixed bug in changeset reading (info changes were lost)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   225
! !