PerforceSourceCodeManager.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Tue, 05 Jun 2012 14:52:00 +0100
branchjv
changeset 3054 d4f41c83c03b
parent 3023 ed74806df5bc
child 3063 5334204e354f
permissions -rw-r--r--
Merged with /trunk
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     1
"
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     2
 COPYRIGHT (c) 2006 by eXept Software AG
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     3
              All Rights Reserved
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     4
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     5
 This software is furnished under a license and may be used
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     6
 only in accordance with the terms of that license and with the
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     8
 be provided or otherwise made available to, or used by, any
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     9
 other person.  No title to or ownership of the software is
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    10
 hereby transferred.
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    11
"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
AbstractSourceCodeManager subclass:#PerforceSourceCodeManager
2359
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    13
	instanceVariableNames:''
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    14
	classVariableNames:'PerforceExecutable PerforceModuleRoots PerforceClient
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    15
		PerforcePort PerforceUser PerforcePassword PerforceTempDir
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    16
		Verbose PerforceCommandSemaphore PerforceEnabled
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    17
		ShownInBrowserMenus PerforceWorkspaces'
2359
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    18
	poolDictionaries:''
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    19
	category:'System-SourceCodeManagement'
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
Object subclass:#CheckInDefinition
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    23
	instanceVariableNames:'class packageDir classFileName sourceFileName logMessage
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    24
		moduleName manager tempDirectory definitionClass workSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    25
		temporaryWorkSpace package reposRevisionInfoBeforeAction
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    26
		reposRevisionInfoAfterAction revisionStringBeforeAction
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    27
		fileContents'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    28
	classVariableNames:''
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    29
	poolDictionaries:''
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    30
	privateIn:PerforceSourceCodeManager
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    31
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    32
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    33
ProceedableError subclass:#PerforceError
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    34
	instanceVariableNames:''
2359
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    35
	classVariableNames:''
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    36
	poolDictionaries:''
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    37
	privateIn:PerforceSourceCodeManager
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
    40
VersionInfo subclass:#PerforceVersionInfo
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    41
	instanceVariableNames:'repositoryPathName revisionNumber'
2359
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    42
	classVariableNames:''
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    43
	poolDictionaries:''
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
    44
	privateIn:PerforceSourceCodeManager
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
    45
!
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
    46
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    47
!PerforceSourceCodeManager class methodsFor:'documentation'!
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    48
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    49
copyright
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    50
"
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    51
 COPYRIGHT (c) 2006 by eXept Software AG
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    52
              All Rights Reserved
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    53
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    54
 This software is furnished under a license and may be used
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    55
 only in accordance with the terms of that license and with the
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    56
 inclusion of the above copyright notice.   This software may not
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    57
 be provided or otherwise made available to, or used by, any
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    58
 other person.  No title to or ownership of the software is
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    59
 hereby transferred.
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    60
"
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    61
! !
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
!PerforceSourceCodeManager class methodsFor:'accessing'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    65
flushPerforceWorkspaces
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    67
    PerforceWorkspaces := nil.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
perforceClient
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
    |envVar|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
    73
    PerforceClient notEmptyOrNil ifTrue:[ ^ PerforceClient].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    envVar := OperatingSystem getEnvironment:'P4CLIENT'.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    envVar notEmptyOrNil ifTrue:[ ^ envVar].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    ^ 'workspace'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
perforceClient:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
    PerforceClient := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
perforceEnabled
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
    PerforceEnabled notNil ifTrue:[ ^ false].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
    ^ PerforceEnabled
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
perforceEnabled:enable
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    PerforceEnabled := enable.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
perforceExecutable
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
    ^ PerforceExecutable ? 'p4'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
perforceExecutable:aString
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
    "set the name of the cvs executable."
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    aString isEmptyOrNil ifTrue:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   102
        PerforceExecutable := nil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
    ] ifFalse:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   104
        PerforceExecutable := aString.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
    "Created: / 21-09-2006 / 15:31:59 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
    "Modified: / 21-09-2006 / 16:41:33 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
perforcePassword
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
    |envVar|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    PerforcePassword notNil ifTrue:[ ^ PerforcePassword].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
    envVar := OperatingSystem getEnvironment:'P4PASSWD'.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
    envVar notEmptyOrNil ifTrue:[ ^ envVar].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   117
    ^ nil
2341
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   118
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   119
    "Modified: / 19-04-2011 / 10:46:56 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
perforcePassword:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    PerforcePassword := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
perforcePort
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
    |envVar|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    PerforcePort notNil ifTrue:[ ^ PerforcePort].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    envVar := OperatingSystem getEnvironment:'P4PORT'.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    envVar notEmptyOrNil ifTrue:[ ^ envVar].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    ^ 'localhost:1666'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
perforcePort:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    PerforcePort := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
perforceUser
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
    |envVar|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    PerforceUser notNil ifTrue:[ ^ PerforceUser].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
    envVar := OperatingSystem getEnvironment:'P4USER'.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    envVar notEmptyOrNil ifTrue:[ ^ envVar].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
    ^ OperatingSystem getLoginName ? 'user'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
perforceUser:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
    PerforceUser := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   152
perforceWorkspaces
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   153
    "Superclass AbstractSourceCodeManager class says that I am responsible to implement this method"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   154
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   155
    PerforceWorkspaces isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   156
        PerforceWorkspaces := Dictionary new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   157
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   158
    ^ PerforceWorkspaces 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   159
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   160
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
repositoryInfoPerModule
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
    "Superclass AbstractSourceCodeManager class says that I am responsible to implement this method"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
    ^ PerforceModuleRoots ? Dictionary new
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
repositoryInfoPerModule:aDictionary
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
    "set the dictionary, which associates CVSRoots to module names.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
     If no entry is contained in this dictionary for some module,
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
     the default cvsRoot (CVSRoot) will be used."
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   172
    self flushPerforceWorkspaces.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
    PerforceModuleRoots := aDictionary
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
repositoryName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
    "return the name of the repository.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
     Since this is an abstract class, return nil (i.e. none)"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
    ^ (self perforceClient ,':',
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
       self perforceUser, ':',
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
       (self perforcePassword ? 'pass'), '@',
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
       self perforcePort)
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
    "Modified: 12.9.1996 / 02:20:45 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
    "Created: 14.9.1996 / 13:21:37 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
repositoryName:settingsString
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
    "return the name of the repository.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
     Since this is an abstract class, return nil (i.e. none)"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
    |settings|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
    settings := self getPerforceSettingsFromString:settingsString.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    self perforceClient:(settings at:#client ifAbsent:nil).
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
    self perforceUser:(settings at:#user ifAbsent:nil).
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
    self perforcePassword:(settings at:#password ifAbsent:nil).
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
    self perforcePort:(settings at:#port ifAbsent:nil).
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    "Modified: 12.9.1996 / 02:20:45 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
    "Created: 14.9.1996 / 13:21:37 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
repositoryNameForModule:aModuleName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
    |settings|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   207
    settings := self getPerforceSettingsForPackage:aModuleName.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
    settings isNil ifTrue:[ ^ ''].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   209
    ^ settings
2341
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   210
!
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   211
2595
ad4056ade722 added: #repositoryNameForPackage:
vrany
parents: 2567
diff changeset
   212
repositoryNameForPackage:packageId 
2669
e3dad043debf refactoring
Claus Gittinger <cg@exept.de>
parents: 2652
diff changeset
   213
    ^ self repositoryNameForModule:(packageId upTo:$: )
e3dad043debf refactoring
Claus Gittinger <cg@exept.de>
parents: 2652
diff changeset
   214
e3dad043debf refactoring
Claus Gittinger <cg@exept.de>
parents: 2652
diff changeset
   215
    "Modified: / 10-10-2011 / 19:48:10 / Jan Vrany <jan.vrany@fit.cvut.cz>"
e3dad043debf refactoring
Claus Gittinger <cg@exept.de>
parents: 2652
diff changeset
   216
    "Modified (format): / 21-12-2011 / 23:03:41 / cg"
2567
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
   217
!
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
   218
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   219
setDefaultPerforceSettingsFromString:aString 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   220
    |settings defaultSettingsString workSpace|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   221
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   222
    defaultSettingsString := self getPerforceDefaultSettingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   223
    defaultSettingsString ~= aString ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   224
        settings := PerforceSourceCodeManager 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   225
                    getPerforceSettingsFromString:aString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   226
        PerforceSourceCodeManager 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   227
            perforceClient:(settings at:#client ifAbsent:nil).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   228
        PerforceSourceCodeManager perforceUser:(settings at:#user ifAbsent:nil).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   229
        PerforceSourceCodeManager perforcePort:(settings at:#port ifAbsent:nil).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   230
        PerforceSourceCodeManager 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   231
            perforcePassword:(settings at:#password ifAbsent:nil).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   232
        self removeWorkSpaceForSettings:defaultSettingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   233
        self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   234
            self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   235
            ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   236
        ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   237
            workSpace := self workSpaceClass newWorkSpaceFor:aString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   238
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   239
        workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   240
            ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   241
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   242
        self perforceWorkspaces at:aString put:workSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   243
        defaultSettingsString := aString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   244
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   245
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   246
    "Modified: / 01-06-2012 / 11:06:24 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   247
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   248
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   249
shownInBrowserMenus
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   250
    ^ ShownInBrowserMenus ? true
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   251
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   252
    "Created: / 08-01-2012 / 19:53:20 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   253
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   254
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   255
shownInBrowserMenus:aBoolean
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   256
    ShownInBrowserMenus := aBoolean
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   257
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   258
    "Created: / 08-01-2012 / 19:53:34 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   259
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   260
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   261
utilities
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   262
    "Returns 'utilities' object that can be used by tools. 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   263
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   264
     By default, it returns an instance of
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   265
     SourceCodeManagerUtilities with receiver as its
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   266
     manager, but individual managers may override this
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   267
     method and supply its own, customized utilities."
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   268
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   269
    ^ PerforceSourceCodeManagerUtilities forManager: self
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   270
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   271
    "Created: / 10-10-2011 / 15:10:05 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   272
    "Modified (format): / 21-12-2011 / 20:05:31 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   273
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   274
2341
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   275
verboseSourceCodeAccess
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   276
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   277
    ^ Verbose
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   278
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   279
    "Created: / 19-04-2011 / 10:52:29 / cg"
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   280
!
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   281
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   282
verboseSourceCodeAccess:aBoolean
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   283
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   284
    Verbose := aBoolean
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   285
Claus Gittinger <cg@exept.de>
parents: 2340
diff changeset
   286
    "Created: / 19-04-2011 / 10:52:43 / cg"
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   287
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   288
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   289
workSpaceClass
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   290
    ^ PerforceSourceCodeManagerUtilities workSpaceClass
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   291
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   292
    "Modified: / 01-06-2012 / 11:14:15 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   295
!PerforceSourceCodeManager class methodsFor:'actions'!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   296
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   297
checkinClass:aClass fileName:classFileName directory:packageDir module:moduleDir logMessage:logMessage force:force
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   298
    "checkin of a class into the source repository.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   299
     Return true if ok, false if not."
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   300
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   301
    ^self checkinClass:aClass fileName:classFileName directory:packageDir module:moduleDir logMessage:logMessage force:force submit:false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   302
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   303
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   304
checkinClass:aClass fileName:classFileName directory:packageDir module:moduleDir logMessage:logMessage force:force submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   305
    "checkin of a class into the source repository.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   306
     Return true if ok, false if not."
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   307
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   308
    |className answer allLabel allValue 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   309
     nameOfVersionMethodInClasses requestMessage locDoSubmit|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   310
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   311
    locDoSubmit := doSubmit.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   312
    className := aClass name.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   313
    nameOfVersionMethodInClasses := self nameOfVersionMethodInClasses.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   314
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   315
    aClass revision isNil ifTrue:[ 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   316
        force ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   317
            ('PerforceSourceCodeManager [warning]: class ' , className, ' has no revision string') errorPrintCR.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   318
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   319
            AbortAllOperationWantedQuery query ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   320
                allLabel := #('Cancel All').
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   321
                allValue := #(cancelAll).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   322
            ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   323
                allLabel := #().
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   324
                allValue := #().
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   325
            ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   326
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   327
            ((aClass theMetaclass includesSelector:#version)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   328
               or:[aClass theMetaclass includesSelector: nameOfVersionMethodInClasses]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   329
                requestMessage := ('Class %1 has no (usable) revision string.\\Check in as newest ?' bindWith:className allBold) withCRs.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   330
            ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   331
                requestMessage := ('Class %1 has no revision string.\\Check in as newest ?' bindWith:className allBold) withCRs.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   332
            ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   333
            answer := OptionBox 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   334
                        request: requestMessage
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   335
                        label:'Confirm'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   336
                        buttonLabels:(allLabel , #('Cancel' 'CheckIn' 'CheckIn & Submit')) 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   337
                        values:(allValue , #(false #checkIn #checkInAndSubmit ))
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   338
                        default:#checkIn.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   339
            answer == false ifTrue:[ AbortSignal raise. ^ false ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   340
            answer == #cancelAll ifTrue:[ AbortAllSignal raise. ^ false ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   341
            answer == #checkInAndSubmit ifTrue:[ locDoSubmit := true ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   342
        ]
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   343
    ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   345
    "Ensure that the method #version_XXX is present before checking in XXX. 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   346
     It will be missing when checking in classes with only the old method #version"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   347
"/ this is wrong - it would add the SVN-id as CVS id...
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   348
"/    (aClass theMetaclass includesSelector: nameOfVersionMethodInClasses) ifFalse: [
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   349
"/        versionAsKnownBefore := aClass revisionString.   "/ looks in the old version (non-repository based)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   350
"/
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   351
"/        self 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   352
"/            compileVersionMethod:nameOfVersionMethodInClasses 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   353
"/            of:aClass 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   354
"/            for:(versionAsKnownBefore ? ('$' , 'Header' , '$')).  "/ concatenated to avoid RCS expansion
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   355
"/    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   356
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   357
    ^ self basicCheckinClass:aClass fileName:classFileName directory:packageDir module:moduleDir logMessage:logMessage force:force submit:locDoSubmit.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   358
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   359
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   360
     SourceCodeManager checkinClass:Array
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   361
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   362
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   363
    "Created: / 11-09-1996 / 16:15:17 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   364
    "Modified: / 25-09-1997 / 12:16:00 / stefan"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   365
    "Modified: / 21-12-2011 / 19:30:38 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   366
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   367
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   368
checkinClass:aClass logMessage:logMessage submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   369
    "checkin of a class into the source repository.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   370
     Return true if ok, false if not."
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   372
    |sourceInfo packageDir moduleDir classFileName|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   373
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   374
    sourceInfo := self sourceInfoOfClass:aClass.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   375
    sourceInfo isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   376
        self reportError:('no sourceInfo for class: ' , aClass name).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   377
        ^ false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   378
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   379
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   380
    packageDir := self directoryFromSourceInfo:sourceInfo.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   381
    moduleDir := self moduleFromSourceInfo:sourceInfo.  "/ use the modules name as CVS module
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   382
    classFileName := self containerFromSourceInfo:sourceInfo.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   383
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   384
    ^ self 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   385
        checkinClass:aClass 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   386
        fileName:classFileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   387
        directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   388
        module:moduleDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   389
        logMessage:logMessage
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   390
        force:false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   391
        submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   392
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   393
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   394
     SourceCodeManager checkinClass:Array logMessage:'foo'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   395
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   396
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   397
    "Created: / 06-11-1995 / 18:56:00 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   398
    "Modified: / 29-08-2006 / 12:46:28 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
createTempDirectory:packageDir forModule:moduleDir
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
    "create a temp directory for checking out"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
    |tempdir dir|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
    "/ if CVSTempDir isNil, use current.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
    OperatingSystem errorSignal handle:[:ex |
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   408
        self reportError:('cannot create temporary directory').
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   409
        ^ nil.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
    ] do:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   411
        tempdir := Filename newTemporaryDirectoryIn:(self perforceTmpDirectory).
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
    moduleDir notNil ifTrue:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   415
        dir := tempdir construct:moduleDir.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   416
        dir makeDirectory.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   418
        packageDir notNil ifTrue:[
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   419
            dir := dir construct:packageDir.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   420
            dir recursiveMakeDirectory.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   421
        ].
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   422
        dir exists ifFalse:[
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   423
            (tempdir construct:moduleDir) recursiveRemove.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   424
            tempdir recursiveRemove.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   425
            self reportError:('cannot create temporary directory').
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   426
            ^ nil.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   427
        ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
    ^ tempdir
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
    "self createTempDirectory:'fooPackage' forModule:'fooModule'"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
    "Created: / 09-12-1995 / 19:14:35 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   434
    "Modified: / 19-12-1995 / 16:13:02 / stefan"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
    "Modified: / 29-08-2006 / 13:16:23 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   436
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   437
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   438
ensureDollarsInVersionMethod:aString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   439
    "given the source code of my version method, ensure that it contains dollars for
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   440
     proper keyword expansion
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   441
     do nothing here because we dont need this - make our own version
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   442
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   443
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   444
    ^aString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   445
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   446
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   447
removeContainer:fileName inModule:moduleName directory:packageDir
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   448
    "remove a container"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   449
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   450
    ^self removeContainer:fileName inModule:moduleName directory:packageDir submit:false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   451
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   452
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   453
removeContainer:fileName inModule:moduleName directory:packageDir submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   454
    "remove a container"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   455
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   456
    |cls checkInDefinition classFileName workSpace clsName|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   457
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   458
    clsName := fileName asFilename withoutSuffix baseName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   459
    cls := Smalltalk at:clsName asSymbol ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   460
    cls isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   461
        self reportError:'Error removing class - ', clsName, ' not exists'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   462
        ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   463
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   464
    classFileName := fileName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   465
    cls isPrivate ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   466
        self reportError:'refuse to check in private classes.'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   467
        ^ false.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   468
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   469
    checkInDefinition := CheckInDefinition new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   470
    checkInDefinition manager:self.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   471
    checkInDefinition setDefinitionClass:cls.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   472
    checkInDefinition classFileName:classFileName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   473
    checkInDefinition package:moduleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   474
    checkInDefinition packageDir:packageDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   475
    checkInDefinition setLogMessage:'Remove from Smalltalk Browser'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   476
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   477
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   478
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   479
        ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   480
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   481
        workSpace := self getWorkSpaceForPackage:(checkInDefinition packageString).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   482
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   483
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   484
        ^ false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   485
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   486
    checkInDefinition workSpace:workSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   487
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   488
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   489
        ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   490
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   491
        ^ workSpace delete:checkInDefinition submit:doSubmit.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   492
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   493
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   494
    ^true
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   495
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   496
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   497
    self removeContainer:'ActionNQualifier.st' inModule:'applistx' directory:'util/libDataType'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   498
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   499
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   500
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   501
savePreferencesOn:aStream
2364
90ed7ea7d1e2 changed: #savePreferencesOn:
Stefan Vogel <sv@exept.de>
parents: 2359
diff changeset
   502
    aStream nextPutLine:'PerforceSourceCodeManager notNil ifTrue:['.
90ed7ea7d1e2 changed: #savePreferencesOn:
Stefan Vogel <sv@exept.de>
parents: 2359
diff changeset
   503
    self repositoryInfoPerModule notEmptyOrNil ifTrue:[
90ed7ea7d1e2 changed: #savePreferencesOn:
Stefan Vogel <sv@exept.de>
parents: 2359
diff changeset
   504
        aStream nextPutLine:'    PerforceSourceCodeManager repositoryInfoPerModule:' , self repositoryInfoPerModule storeString , '.'.
90ed7ea7d1e2 changed: #savePreferencesOn:
Stefan Vogel <sv@exept.de>
parents: 2359
diff changeset
   505
    ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   506
    PerforceExecutable notNil ifTrue:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   507
        aStream nextPutLine:'    PerforceSourceCodeManager perforceExecutable:' , PerforceExecutable storeString , '.'.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   508
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   509
    (Smalltalk at:#SourceCodeManager) == self ifTrue:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   510
        aStream nextPutLine:'    Smalltalk at:#SourceCodeManager put: PerforceSourceCodeManager.'.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   511
        aStream nextPutLine:'    PerforceSourceCodeManager initializeForRepository:' , self repositoryName storeString , '.'.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   512
    ].
2364
90ed7ea7d1e2 changed: #savePreferencesOn:
Stefan Vogel <sv@exept.de>
parents: 2359
diff changeset
   513
    aStream nextPutLine:'].'.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   514
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   515
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   516
submit
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   517
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   518
    self perforceWorkspaces do:[:aWorkSpace | 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   519
        self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   520
            self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   521
            ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   522
        ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   523
            aWorkSpace submit.
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
   524
        ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   525
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   526
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   527
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   528
!PerforceSourceCodeManager class methodsFor:'basic administration'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   529
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   530
basicCheckinClass:cls fileName:classFileName directory:packageDir module:moduleName logMessage:logMessage force:forceArg submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   531
    "enter a classes source code
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   532
     into the source repository. If the force argument is true, no merge is done;
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   533
     instead, the code is checked in as given (Dangerous).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   534
     Return true if ok, false if not."
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   535
    ^self basicCheckinClass:cls 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   536
    fileName:classFileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   537
    directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   538
    module:moduleName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   539
    logMessage:logMessage 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   540
    force:forceArg 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   541
    submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   542
    fileContents:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   543
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   544
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   545
basicCheckinClass:cls 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   546
    fileName:classFileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   547
    directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   548
    module:moduleName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   549
    logMessage:logMessage 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   550
    force:forceArg 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   551
    submit:doSubmit
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   552
    fileContents:fileContents
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   553
    "enter a classes source code
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   554
     into the source repository. If the force argument is true, no merge is done;
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   555
     instead, the code is checked in as given (Dangerous).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   556
     Return true if ok, false if not."
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   557
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   558
    |binRevision checkInDefinition workSpace initialResult revisionBeforeCheckin 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   559
   revisionInfoBeforeCheckin revisions revisionInfo locRevision revisionState result|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   560
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   561
    (cls notNil and:[cls isPrivate]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   562
        self reportError:'refuse to check in private classes.'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   563
        ^ false.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   564
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   565
    checkInDefinition := CheckInDefinition new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   566
    checkInDefinition manager:self.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   567
    checkInDefinition setDefinitionClass:cls.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   568
    checkInDefinition classFileName:classFileName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   569
    checkInDefinition sourceFileName:classFileName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   570
    checkInDefinition package:moduleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   571
    checkInDefinition packageDir:packageDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   572
    checkInDefinition fileContents:fileContents.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   573
    (checkInDefinition setLogMessage:logMessage) ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   574
        self reportError:'Perforce cannot handle unicode in logMessage'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   575
        ^ false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   576
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   577
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   578
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   579
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   580
        ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   581
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   582
        workSpace := self getWorkSpaceForPackage:(checkInDefinition packageString).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   583
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   584
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   585
        ^ false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   586
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   587
    checkInDefinition workSpace:workSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   588
    checkInDefinition isClassCheckin ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   589
        binRevision := checkInDefinition getBinaryRevisionNumber.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   590
        locRevision := checkInDefinition getLocalRevisionNumber.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   591
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   592
    revisionInfoBeforeCheckin := checkInDefinition getReposRevisionInfoBeforeCheckin.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   593
    revisions := revisionInfoBeforeCheckin at:#revisions ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   594
    revisions notEmptyOrNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   595
        revisionInfo := revisions first.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   596
        revisionBeforeCheckin := (revisionInfo at:#revision) asNumber.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   597
        revisionState := revisionInfo at:#state ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   598
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   599
    checkInDefinition isClassCheckin ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   600
        (revisionBeforeCheckin ~= binRevision and:[self verboseSourceCodeAccess]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   601
            ('PerforceSourceCodeManager [info]: class ' , checkInDefinition definitionObjectString , ' is based upon ' , binRevision printString, ' but has revision ' , (revisionBeforeCheckin printString)) infoPrintCR
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   602
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   603
     ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   604
    (revisionBeforeCheckin isNil or:[revisionState = 'delete']) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   605
        " add file to p4 "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   606
        self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   607
            self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   608
            ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   609
        ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   610
            initialResult := workSpace addCheckIn:checkInDefinition submit:doSubmit.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   611
            initialResult ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   612
                ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   613
            ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   614
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   615
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   616
        " change file in p4 "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   617
        self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   618
            self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   619
            ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   620
        ] do:[                   
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   621
            result := workSpace checkIn:checkInDefinition submit:doSubmit.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   622
            result ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   623
                ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   624
            ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   625
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   626
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   627
    checkInDefinition isClassCheckin ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   628
        result := self postCheckInClass:cls checkInDefinition:checkInDefinition.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   629
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   630
    ^ true
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   631
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   632
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   633
     SourceCodeManager checkinClass:PerforceSourceCodeManager logMessage:'testing only'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   634
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   635
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   636
    "Created: / 11-09-1996 / 16:16:11 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   637
    "Modified: / 26-02-1998 / 17:34:16 / stefan"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   638
    "Modified: / 25-10-2006 / 17:41:46 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   639
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   640
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   641
checkForExistingContainer:fileName inModule:moduleDir directory:packageDir
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   642
    "check for a container to exist"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   643
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   644
    |checkInDefinition workSpace result|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   645
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   646
    checkInDefinition := CheckInDefinition new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   647
    checkInDefinition manager:self.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   648
    checkInDefinition package:moduleDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   649
    checkInDefinition packageDir:packageDir.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   650
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   651
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   652
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   653
        ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   654
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   655
        workSpace := self getWorkSpaceForPackage:(checkInDefinition package).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   656
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   657
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   658
        ^ false
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   659
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   660
    checkInDefinition workSpace:workSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   661
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   662
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   663
        ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   664
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   665
        result := workSpace checkForExistingContainer:checkInDefinition.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   666
        ^result
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   667
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   668
    ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   669
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   670
    self checkForExistingContainer:'baseline.rbspec' inModule:'applistx' directory:'application/rtdbInspector/builder'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   671
    self checkForExistingContainer:'baseline.rbspec' inModule:'applistx' directory:'application/rtdbInspector'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   672
    self checkForExistingContainer:'baseline.rbspec' inModule:'applistx' directory:'util/*'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   673
"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   674
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   675
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   676
checkForExistingModule:moduleName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   677
    "check for a module directory to be present"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   678
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   679
    |workSpaceDefinition|
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   680
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   681
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   682
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   683
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   684
        workSpaceDefinition := self getWorkSpaceForPackage:moduleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   685
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   686
    workSpaceDefinition isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   687
        ('PerforceSourceCodeManager [error]: no workspace for ', moduleName) errorPrintCR.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   688
        ^ false.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   689
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   690
    ^ true.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   691
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   692
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   693
"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   694
self checkForExistingModule:'applistx'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   695
self checkForExistingModule:'balla'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   696
"
2344
8a715906b999 comment/format in: #checkForExistingModule:
Claus Gittinger <cg@exept.de>
parents: 2341
diff changeset
   697
8a715906b999 comment/format in: #checkForExistingModule:
Claus Gittinger <cg@exept.de>
parents: 2341
diff changeset
   698
    "Modified: / 19-04-2011 / 11:30:41 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   699
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   700
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   701
checkForExistingModule:moduleName directory:packageDir
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   702
    "check for a package directory to be present
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   703
     in perforce directory will be created with checkin
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   704
     so we need only to check if we have a matching workspace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   705
    "
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   706
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   707
    |modulePath inDirectory workSpace|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   708
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   709
    modulePath :=  moduleName , '/' , packageDir.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   710
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   711
    inDirectory := (Filename currentDirectory asAbsoluteFilename) pathName.
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   712
    workSpace := self getWorkSpaceForPackage:moduleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   713
    ^workSpace notNil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   714
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   715
"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   716
    self checkForExistingModule:'testModule' directory:'libTestPerforce'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   717
"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   718
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   719
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   720
checkin:containerFilename text:someText directory:packageDir module:moduleName logMessage:logMessage force:force
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   721
    "enter some (source) code (which is someText)
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   722
     into the source repository. If the force argument is true, no merge is done;
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   723
     instead, the code is checked in as given (Dangerous).
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   724
     Return true if ok, false if not."
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   725
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   726
    ^self basicCheckinClass:nil 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   727
        fileName:containerFilename 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   728
        directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   729
        module:moduleName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   730
        logMessage:logMessage 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   731
        force:force 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   732
        submit:false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   733
        fileContents:someText
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   734
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   735
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   736
checkinClass:cls fileName:classFileName directory:packageDir module:moduleName source:sourceFileName logMessage:logMessage force:forceArg
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   737
    "enter a classes source code (which has been already filed out into sourceFileName)
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   738
     here we have to create our own source file
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   739
     into the source repository. If the force argument is true, no merge is done;
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   740
     instead, the code is checked in as given (Dangerous).
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   741
     Return true if ok, false if not."
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   742
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   743
    ^ self checkinClass:cls fileName:classFileName directory:packageDir module:moduleName logMessage:logMessage force:forceArg
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   744
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   745
    "
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   746
     SourceCodeManager checkinClass:Array logMessage:'testing only'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   747
    "
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   748
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   749
    "Created: / 11-09-1996 / 16:16:11 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   750
    "Modified: / 26-02-1998 / 17:34:16 / stefan"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   751
    "Modified: / 25-10-2006 / 17:41:46 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   752
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   753
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   754
createContainerFor:cls inModule:moduleName package:packageDir container:classFileName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   755
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   756
    ^ self checkinClass:cls fileName:classFileName directory:packageDir module:moduleName logMessage:'Initial check in' force:false.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   757
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   758
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   759
createContainerFor:cls inModule:moduleName package:packageDir container:classFileName logMessage:logMessage
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   760
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   761
    ^ self checkinClass:cls fileName:classFileName directory:packageDir module:moduleName logMessage:logMessage force:false.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   762
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   763
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   764
createContainerForText:someText inModule:moduleDir package:packageDir container:fileName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   765
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   766
    ^self basicCheckinClass:nil 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   767
        fileName:fileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   768
        directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   769
        module:moduleDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   770
        logMessage:'initial checkin'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   771
        force:false 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   772
        submit:false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   773
        fileContents:someText
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   774
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   775
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   776
createModule:moduleName
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   777
    "we dont need to create directories in perforce before checkin"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   778
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   779
    ^self checkForExistingModule:moduleName
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   780
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   781
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   782
createModule:module directory:directory
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   783
    "nothing to do with PerforceSourceCodeManager
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   784
     subdirectory in repository will created with adding the file "
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   785
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   786
    ^self checkForExistingModule:module
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   787
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   788
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   789
initialRevisionStringFor:aClass inModule:moduleDir directory:packageDir container:fileName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   790
    "return a string usable as initial revision string"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   791
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   792
    |checkInDefinition workSpace|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   793
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   794
    aClass isPrivate ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   795
        self reportError:'refuse to get revision for private classes.'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   796
        ^ false.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   797
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   798
    checkInDefinition := CheckInDefinition new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   799
    checkInDefinition setDefinitionClass:aClass.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   800
    checkInDefinition classFileName:fileName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   801
    checkInDefinition package:moduleDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   802
    checkInDefinition packageDir:packageDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   803
    checkInDefinition manager:self.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   804
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   805
    "/
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   806
    "/ first, create a temporary work tree
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   807
    "/
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   808
"/    tempdir := checkInDefinition tempDirectory.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   809
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   810
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   811
    workSpace := self getWorkSpaceForPackage:(checkInDefinition packageString).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   812
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   813
        ('PerforceSourceCodeManager [error]: failed to create workspace for', checkInDefinition fileName)  errorPrintCR.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   814
        ^ false
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   815
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   816
    checkInDefinition workSpace:workSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   817
    ^workSpace initialRevisionStringFor:checkInDefinition
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   818
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   819
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   820
self initialRevisionStringFor:RTDBInspectorStartup inModule:'applistx' directory:'util/rtdb' container:'RTDBInterfaceInspector.st'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   821
"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   822
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   823
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   824
revisionInfoFromString:aString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   825
    "{ Pragma: +optSpace }"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   826
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   827
    ^ PerforceVersionInfo fromRCSString:aString.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   828
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   829
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   830
|stream|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   831
stream := WriteStream on:''.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   832
SourceCodeManagerUtilities repositoryLogOf:ExtIF onto:stream.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   833
^ stream contents.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   834
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   835
self revisionInfoFromString:((RTDBInterfaceInspector findVersionMethodOfManager:PerforceSourceCodeManager) valueWithReceiver:(self theNonMetaclass) arguments:#())
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   836
self revisionInfoFromString:'Path: //depot/applistx/util/libDataType/ActionDQualifier.st#1 User: penk Date: 30-03-2012 Time: 15-50-39.992'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   837
"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   838
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   839
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   840
revisionLogOf:clsOrNil 
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   841
fromRevision:firstRev 
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   842
toRevision:lastRef 
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   843
numberOfRevisions:numRevisions 
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   844
fileName:classFileName 
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   845
directory:packageDir 
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   846
module:aPackage
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   847
    "return info about the repository container and
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   848
     (part of) the revisionlog as a collection of revision entries.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   849
     Return nil on failure.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   850
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   851
     If numRevisions is notNil, it limits the number of revision records returned -
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   852
     only numRevions of the newest revision infos will be collected.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   853
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   854
     The returned information is a structure (IdentityDictionary)
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   855
     filled with:
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   856
            #newestRevision     -> the revisionString of the newest revision
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   857
            #numberOfRevisions  -> the number of revisions in the container (nil for all)
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   858
            #revisions          -> collection of per-revision info (see below)
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   859
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   860
            firstRev / lastRef specify from which revisions a logEntry is wanted:
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   861
             -If firstRev is nil, the first revision is the initial revision
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   862
              otherwise, the log starts with that revision.
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   863
             -If lastRef is nil, the last revision is the newest revision
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   864
              otherwise, the log ends with that revision.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   865
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   866
             -If both are nil, all logEntries are extracted.
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   867
             -If both are 0 (not nil), no logEntries are extracted (i.e. only the header).
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   868
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   869
            per revision info consists of one record per revision:
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   870
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   871
              #revision              -> the revision string
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   872
              #author                -> who checked that revision into the repository
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   873
              #date                  -> when was it checked in
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   874
              #state                 -> the RCS state
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   875
              #numberOfChangedLines  -> the number of changed line w.r.t the previous
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   876
              #logMessage            -> the checkIn log message
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   877
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   878
            revisions are ordered newest first
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   879
            (i.e. the last entry is for the initial revision; the first for the most recent one)
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   880
            Attention: if state = 'dead' that revision is no longer valid.
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
   881
        "
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   882
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   883
    |workSpace rslt|
2354
Claus Gittinger <cg@exept.de>
parents: 2353
diff changeset
   884
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   885
    workSpace := self getWorkSpaceForPackage:aPackage.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   886
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   887
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   888
        ('PerforceSourceCodeManager [warning]: cant get workspace definition for module ', aPackage) errorPrintCR.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   889
        ^ nil.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   890
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   891
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   892
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   893
        ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   894
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   895
        rslt := workSpace revisionLogOf:clsOrNil 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   896
            fromRevision:firstRev 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   897
            toRevision:lastRef 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   898
            numberOfRevisions:numRevisions 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   899
            fileName:classFileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   900
            directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   901
            module:aPackage.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   902
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   903
    ^rslt
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   904
    "
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   905
     AbstractSourceCodeManager revisionLogOf:ExtIF
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   906
     SourceCodeManager revisionLogOf:Array fromRevision:'1.40' toRevision:'1.43'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   907
     SourceCodeManager revisionLogOf:Array fromRevision:'1.40' toRevision:nil
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   908
     SourceCodeManager revisionLogOf:Array fromRevision:nil toRevision:'1.3'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   909
     SourceCodeManager revisionLogOf:Array fromRevision:nil toRevision:nil
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   910
     SourceCodeManager revisionLogOf:Array fromRevision:0 toRevision:0
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   911
    "
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   912
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   913
    "Created: / 16-11-1995 / 13:25:30 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   914
    "Modified: / 29-01-1997 / 16:51:30 / stefan"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   915
    "Modified: / 29-08-2006 / 14:57:26 / cg"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   916
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   917
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   918
setSymbolicName:symbolicName revision:rev overWrite:overWriteBool classes:aCollectionOfClasses
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   919
    "set a symbolicName for revision rev.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   920
     If rev is nil, set it for the head (most recent) revision.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   921
     If rev is 0, delete the symbolic name.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   922
     If overWriteBool is true, the symbolicName will be changed, even if it has already been set.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   923
     If overWriteBool is false, an error will be raised if symbolicName has already been set.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   924
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   925
     If filename is nil, the symbolicName for a whole package is set"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   926
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   927
    |pathes workSpace|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   928
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   929
    pathes := aCollectionOfClasses 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   930
                collect:[:cls | (self sourceInfoOfClass:cls) at:#pathInRepository].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   931
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   932
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   933
    workSpace := nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   934
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   935
        self information:'Implementation of setting Labels not finished yet'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   936
        ^self.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   937
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   938
    workSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   939
        setSymbolicName:symbolicName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   940
        revision:rev 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   941
        overWrite:overWriteBool 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   942
        pathes:pathes
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   943
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   944
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   945
     self setSymbolicName:'foo' revision:nil overWrite:false classes:(Array with:True with:False)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   946
     self setSymbolicName:'foo' revision:nil overWrite:true classes:(Array with:True with:False)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   947
     self setSymbolicName:'foo' revision:nil overWrite:true classes:(Array with:True with:False)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   948
     self setSymbolicName:'foo' revision:'1.1' overWrite:true classes:(Array with:True with:False)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   949
     self setSymbolicName:'foo' revision:0 overWrite:true classes:(Array with:True with:False)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   950
    "
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   951
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   952
    "Created: / 12-09-2006 / 12:58:23 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   953
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   954
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   955
streamForClass:cls fileName:fileName revision:revision directory:packageDir module:moduleDir cache:doCache
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   956
    "extract a classes source code and return an open readStream on it.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   957
     A revision of nil selects the current (in image) revision.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   958
     The classes source code is extracted using the revision and the sourceCodeInfo,
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   959
     which itself is extracted from the classes packageString."
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   960
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   961
    |checkInDefinition workSpace|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   962
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   963
    checkInDefinition := CheckInDefinition new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   964
    checkInDefinition setDefinitionClass:cls.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   965
    checkInDefinition classFileName:fileName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   966
    checkInDefinition package:moduleDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   967
    checkInDefinition packageDir:packageDir.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   968
    checkInDefinition manager:self.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   969
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   970
    workSpace := self getWorkSpaceForPackage:(checkInDefinition packageString).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   971
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   972
        ('PerforceSourceCodeManager [error]: failed to create workspace for', checkInDefinition fileName)  errorPrintCR.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   973
        ^ nil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   974
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   975
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   976
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   977
        ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   978
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   979
        ^workSpace streamFor:checkInDefinition revision:revision cache:doCache.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   980
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   981
    ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   982
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   983
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   984
writeRevisionLogMessagesFrom:log withHeader:header to:aStream
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   985
    "helper; send the revisionlog to aStream"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   986
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   987
    |tags|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   988
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   989
    header ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   990
"/        (log at:#renamed ifAbsent:false) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   991
"/            aStream nextPutAll:'  Class was probably renamed; revision info is from original class.'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   992
"/            aStream cr; nextPutAll:'  You may have to create a new container for it.'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   993
"/            aStream cr; cr.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   994
"/        ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   995
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   996
        aStream nextPutAll:'  Total revisions: '; nextPutLine:(log at:#numberOfRevisions) printString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   997
        aStream nextPutAll:'  Newest revision: '; nextPutLine:(log at:#newestRevision) printString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   998
        tags := log at:#symbolicNames ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
   999
        tags notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1000
            aStream nextPutAll:'  Stable revision: '; nextPutAll:(tags at:'stable' ifAbsent:'none'); cr.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1001
            aStream nextPutAll:'  Symbolic names: '; cr.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1002
            "sort tags by tag name"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1003
            tags := tags associations sort:[:a :b| a key < b key].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1004
            tags do:[:eachAssociation|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1005
                aStream tab; nextPutAll:eachAssociation key; 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1006
                             nextPutAll:': '; 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1007
                             nextPutAll:eachAssociation value; cr.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1008
            ]
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
  1009
        ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1010
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1011
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1012
    (log at:#revisions) do:[:entry |
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1013
        |logMsg|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1014
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1015
        aStream cr.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1016
        aStream nextPutAll:'  revision '; 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1017
            show:(entry at:#revision); tab.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1018
        aStream nextPutAll:' date: '; 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1019
            show:((entry at:#date ifAbsent:nil) ? '?'); space;
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1020
            show:((entry at:#time ifAbsent:nil) ? '?'); tab.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1021
        aStream nextPutAll:' author: '; 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1022
            show:(entry at:#author ifAbsent:nil) ? '?'; tab.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1023
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1024
        logMsg := entry at:#logMessage ifAbsent:''.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1025
        (logMsg isBlank or:[logMsg withoutSeparators = '.']) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1026
            logMsg := '*** empty log message ***'
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
  1027
        ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1028
        aStream tab; nextPutLine:logMsg.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1029
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1030
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1031
    "Created: / 16-11-1995 / 13:25:30 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1032
    "Modified: / 27-11-1996 / 18:26:30 / stefan"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1033
    "Modified: / 21-12-2011 / 23:33:53 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1034
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1035
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1036
!PerforceSourceCodeManager class methodsFor:'private'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1037
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1038
getCheckInDefinitionForClass:aClass
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1039
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1040
    |checkInDefinition|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1041
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1042
    checkInDefinition := CheckInDefinition new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1043
    checkInDefinition manager:self.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1044
    checkInDefinition setDefinitionClass:aClass.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1045
    ^checkInDefinition
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1046
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1047
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1048
postCheckInClass:class checkInDefinition:checkInDefinition
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1049
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1050
    self postCheckInClass:class.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1051
    ^ true                                                            
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1052
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1053
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1054
reportError:msg
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1055
    |fullMsg|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1056
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1057
    fullMsg := self nameWithoutNameSpacePrefix,' [error]: ',msg.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1058
    fullMsg errorPrintCR.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1059
    SourceCodeManagerError isHandled ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1060
        SourceCodeManagerError raiseErrorString:fullMsg.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1061
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1062
        self warn:fullMsg.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1063
    ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1064
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1065
    "Created: / 29-08-2006 / 12:44:19 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1066
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1067
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1068
submitInfoDialogClass
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1069
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1070
    ^ PerforceSourceCodeManagerUtilities  submitInfoDialogClass
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1071
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1072
    "Modified: / 01-06-2012 / 11:10:12 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1073
!
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1074
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1075
updateVersionMethodOf:aClass for:newRevisionString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1076
    " redefinition because I like to handle my version updates by myself "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1077
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1078
self halt.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1079
    super updateVersionMethodOf:aClass for:newRevisionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1080
    ^ self
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1081
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1082
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1083
updatedRevisionStringOf:aClass forRevision:newRevision with:originalVersionString
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1084
    "update a revision string"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1085
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1086
    |versionInfo module workSpace|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1087
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1088
    originalVersionString isEmptyOrNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1089
        workSpace := self getWorkSpaceForPackage:module.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1090
        workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1091
            self reportError:('no workSpace for class: ' , aClass name).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1092
            ^ nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1093
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1094
        versionInfo := workSpace updatedRevisionStringOf:aClass forRevision:newRevision with:originalVersionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1095
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1096
        versionInfo := PerforceVersionInfo fromRCSString:originalVersionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1097
        versionInfo isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1098
            ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1099
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1100
    ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1101
    versionInfo revision:newRevision printString.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1102
    ^ versionInfo getVersionString.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1103
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1104
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1105
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1106
"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1107
    self updatedRevisionStringOf:nil
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1108
            forRevision:'6'
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1109
            with:'$','Header','$'
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1110
"
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1111
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1112
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1113
versionInfoClass
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1114
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1115
    ^PerforceVersionInfo
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1116
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1117
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1118
!PerforceSourceCodeManager class methodsFor:'queries'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1119
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1120
checkInInfoDialogClass
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1121
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1122
    ^P4CheckinInfoDialog
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1123
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1124
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1125
checkPerforceSettings:aSettingsString forPackage:aPackage 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1126
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1127
        create an temporary workspace for handle checkin"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1128
    
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1129
    |workSpace perforceSettings|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1130
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1131
    perforceSettings := self getPerforceSettingsFromString:aSettingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1132
    aPackage notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1133
        (self hasPackage:aPackage) ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1134
            self perforceError raiseErrorString:('Package <', aPackage, '> not exists.').
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1135
        ]
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1136
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1137
    workSpace := self getWorkSpaceForSettings:aSettingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1138
    aSettingsString isEmptyOrNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1139
        self perforceError raiseErrorString:('No valid settings <', aSettingsString, '>.').
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1140
    ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1141
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1142
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1143
        self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1144
            self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1145
            ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1146
        ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1147
            workSpace := self workSpaceClass newWorkSpaceFor:aSettingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1148
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1149
        workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1150
            ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1151
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1152
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1153
    (workSpace hasViewForPackage:aPackage) ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1154
        self perforceError raiseErrorString:('No View for Settings <', aSettingsString, '>  and Package <', aPackage, '>. Please check Workspace settings with Perforce Tools.').
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1155
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1156
    ^ true
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1157
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1158
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1159
     self checkPerforceSettings:'penk_DEL00089:penk:@localhost:1666' forPackage:'stx/libbasic3' 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1160
     self checkPerforceSettings:'penk_DEL00089:penk:@localhost:1666' forPackage:'balla'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1161
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1162
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1163
        ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1164
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1165
         self checkPerforceSettings:'penk_DEL0ss0089:penk:@localhost:1666' forPackage:'balla'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1166
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1167
        
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1168
    "
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1169
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1170
    "Modified: / 01-06-2012 / 11:06:36 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1171
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1172
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1173
getTrailungPathNameFrom:path1 with:path2
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1174
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1175
" path1 have to start with path2 not the other way around "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1176
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1177
    |componentsPath1 componentsPath2 locPath1 locPath2|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1178
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1179
    ((path1 first = $/) and:[path1 second = $/]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1180
        locPath1 := path1 copyFrom:2.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1181
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1182
        locPath1 := path1.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1183
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1184
    ((path2 first = $/) and:[path2 second = $/]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1185
        locPath2 := path2 copyFrom:2.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1186
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1187
        locPath2 := path2.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1188
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1189
    componentsPath1 := locPath1 asFilename components.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1190
    componentsPath2 := locPath2 asFilename components.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1191
    componentsPath1 size <= componentsPath2 size ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1192
        ^path1
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1193
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1194
    ^ (Filename fromComponents:(componentsPath1 copyFrom:(componentsPath2 size + 1))) pathName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1195
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1196
self getTrailungPathNameFrom:'foo/bar' with:'foo'     
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1197
self getTrailungPathNameFrom:'foo' with:'foo/bar'     
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1198
self getTrailungPathNameFrom:'//depot/' with:'//depot/applistx/util/libDataType/ActionLQualifier.st'     
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1199
self getTrailungPathNameFrom:'//depot/applistx/util/libDataType/ActionLQualifier.st' with:'//depot/'     
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1200
"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1201
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1202
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1203
getWorkSpaceForPackage:aPackage  
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1204
    "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1205
        get the workspace definition from perforce client command output"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1206
    
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1207
    |workSpace settingsString|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1208
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1209
    aPackage isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1210
        ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1211
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1212
    aPackage notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1213
        settingsString := self getPerforceSettingsForPackage:aPackage.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1214
        settingsString isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1215
            self perforceError raiseErrorString:('No Perforce Settings for Package <', aPackage, '>. Please define in Settings Dialog.').
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1216
            ^ nil
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1217
        ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1218
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1219
    self perforceWorkspaces do:[:aWorkSpace | 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1220
        aWorkSpace perforceSettingsString = settingsString ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1221
            (aWorkSpace hasViewForPackage:aPackage) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1222
                ^aWorkSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1223
            ].
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1224
        ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1225
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1226
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1227
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1228
        ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1229
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1230
        workSpace := self workSpaceClass newWorkSpaceFor:settingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1231
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1232
    workSpace isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1233
        ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1234
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1235
    (workSpace hasViewForPackage:aPackage) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1236
        self perforceWorkspaces at:settingsString put:workSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1237
        ^workSpace
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1238
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1239
    ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1240
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1241
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1242
    | workSpace |
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1243
    self getPerforceSettingsForPackage:'applistxaa'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1244
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1245
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1246
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1247
        workSpace := self getWorkSpaceForPackage:'applistxaa'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1248
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1249
    workSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1250
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1251
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1252
    "Modified: / 01-06-2012 / 11:06:33 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1253
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1254
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1255
getWorkSpaceForSettings:aSettingsString  
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1256
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1257
    self perforceWorkspaces do:[:aWorkSpace | 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1258
        aWorkSpace perforceSettingsString = aSettingsString ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1259
            ^aWorkSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1260
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1261
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1262
    ^nil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1263
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1264
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1265
    | workSpace |
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1266
    self getPerforceSettingsForPackage:'applistxaa'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1267
    self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1268
        self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1269
    ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1270
        workSpace := self getWorkSpaceForPackage:'applistxaa'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1271
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1272
    workSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1273
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1274
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1275
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1276
hasPackage:aPackage
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1277
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1278
    Smalltalk allProjectIDs do:[:aId|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1279
        (aId startsWith:aPackage) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1280
            ^true
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1281
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1282
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1283
    ^false
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1284
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1285
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1286
isPerforce
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1287
    "Superclass AbstractSourceCodeManager class says that I am responsible to implement this method"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1288
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1289
    ^ true
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1290
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1291
2567
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
  1292
isResponsibleForPackage:aStringOrSymbol
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
  1293
    "superclass AbstractSourceCodeManager class says that I am responsible to implement this method"
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
  1294
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1295
    ^true
2567
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
  1296
!
c9004cd0d0f6 Lost methods
vrany
parents: 2551
diff changeset
  1297
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1298
managerTypeName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1299
    "Superclass AbstractSourceCodeManager class says that I am responsible to implement this method"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1300
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1301
    ^ 'Perforce'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1302
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1303
2551
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1304
managerTypeNameShort
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1305
    "Answers short version manager name suitable for UI,
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1306
     i,e., CVS, SVN, P4. Used in cases where sorter strings
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1307
     are preferred. Defaults to #managerTypeName"
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1308
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1309
    ^'P4'
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1310
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1311
    "Created: / 03-10-2011 / 13:28:50 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2639
11a1cea10275 changed: #managerTypeNameShort
Claus Gittinger <cg@exept.de>
parents: 2599
diff changeset
  1312
    "Modified (format): / 04-12-2011 / 10:15:31 / cg"
2551
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1313
!
baaf89f420fa - more subclassReponsibilities to AbstractSourceCodeManager
vrany
parents: 2542
diff changeset
  1314
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1315
nameOfVersionMethodForExtensions
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1316
    ^ #'extensionsVersion_P4'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1317
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1318
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1319
nameOfVersionMethodInClasses
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1320
    ^ #'version_P4'
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1321
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1322
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1323
path:path1 hasSamePrefixLikePath:path2
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1324
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1325
" path1 have to start with path2 not the other way around "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1326
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1327
    |locPath1 locPath2 componentsPath1 componentsPath2|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1328
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1329
    ((path1 first = $/) and:[path1 second = $/]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1330
        locPath1 := path1 copyFrom:2.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1331
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1332
        locPath1 := path1.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1333
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1334
    ((path2 first = $/) and:[path2 second = $/]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1335
        locPath2 := path2 copyFrom:2.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1336
    ] ifFalse:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1337
        locPath2 := path2.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1338
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1339
    componentsPath1 := locPath1 asFilename components.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1340
    componentsPath2 := locPath2 asFilename components.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1341
    componentsPath2 size > componentsPath1 size ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1342
        ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1343
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1344
    componentsPath2 doWithIndex:[:component :index|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1345
        ((componentsPath1 at:index) ~= component) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1346
            ^false
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1347
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1348
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1349
    ^true
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1350
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1351
self path:'foo/bar' hasSamePrefixLikePath:'foo'   
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1352
self path:'foo' hasSamePrefixLikePath:'foo/bar'  
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1353
self path:'//depot/applistx/util/libDataType/ActionLQualifier.st' hasSamePrefixLikePath:'//depot/'  
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1354
self path:'//depot/' hasSamePrefixLikePath:'//depot/applistx/util/libDataType/ActionLQualifier.st'  
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1355
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1356
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1357
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1358
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1359
perforceError
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1360
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1361
    ^PerforceError
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1362
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1363
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1364
perforceTmpDirectory
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1365
    "return the name of the tmp repository.
2720
a8ee3209589e refactored
Claus Gittinger <cg@exept.de>
parents: 2698
diff changeset
  1366
     That's the directory, where temporary files are created for checkin/checkout.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1367
     If nil, the systems default tempDirectory is used."
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1368
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1369
    ^ (PerforceTempDir ? Filename tempDirectory pathName)
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1370
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1371
    "
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1372
     PerforceTempDir := nil
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1373
    "
2720
a8ee3209589e refactored
Claus Gittinger <cg@exept.de>
parents: 2698
diff changeset
  1374
a8ee3209589e refactored
Claus Gittinger <cg@exept.de>
parents: 2698
diff changeset
  1375
    "Modified (comment): / 14-01-2012 / 20:54:29 / cg"
2345
2dde5bda539c added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2344
diff changeset
  1376
!
2dde5bda539c added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2344
diff changeset
  1377
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1378
removeWorkSpaceForSettings:settingsString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1379
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1380
    |workSpace|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1381
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1382
    workSpace := self perforceWorkspaces at:settingsString ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1383
    workSpace notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1384
        self perforceError handle:[:ex|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1385
            self reportError:ex description.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1386
            ex proceed.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1387
        ] do:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1388
            workSpace releaseWorkSpace.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1389
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1390
        self perforceWorkspaces removeKey:settingsString ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1391
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1392
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1393
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1394
self perforceWorkspaces remove:(self perforceWorkspaces first)
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1395
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1396
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1397
2345
2dde5bda539c added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2344
diff changeset
  1398
settingsApplicationClass
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1399
    "link to my settings application (needed for the settings dialog"
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1400
2359
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
  1401
    ^ PerforceSourceCodeManagementSettingsAppl
2345
2dde5bda539c added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2344
diff changeset
  1402
2dde5bda539c added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2344
diff changeset
  1403
    "Created: / 19-04-2011 / 12:45:13 / cg"
2359
62c8ea518b59 changed: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2355
diff changeset
  1404
    "Modified: / 20-04-2011 / 12:49:41 / cg"
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1405
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1406
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1407
!PerforceSourceCodeManager class methodsFor:'queries - settings'!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1408
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1409
getPerforceDefaultSettingsString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1410
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1411
    ^(PerforceSourceCodeManager perforceClient ,':',
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1412
       PerforceSourceCodeManager perforceUser, ':',
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1413
       (PerforceSourceCodeManager perforcePassword ? ''), '@',
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1414
       PerforceSourceCodeManager perforcePort).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1415
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1416
    "Modified: / 19-04-2011 / 10:46:37 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1417
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1418
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1419
getPerforcePasswordForModule:aModuleName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1420
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1421
    | settings settingsString|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1422
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1423
    aModuleName isNil ifTrue:[^ nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1424
    settingsString := self getPerforceSettingsForPackage:aModuleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1425
    settingsString isNil ifTrue:[^ PerforcePassword].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1426
    settings := self getPerforceSettingsFromString:settingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1427
    ^ settings at:#password ifAbsent:PerforcePassword.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1428
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1429
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1430
getPerforcePortForModule:aModuleName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1431
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1432
    | settings settingsString|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1433
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1434
    aModuleName isNil ifTrue:[^ nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1435
    settingsString := self getPerforceSettingsForPackage:aModuleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1436
    settingsString isNil ifTrue:[^ PerforcePort].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1437
    settings := self getPerforceSettingsFromString:settingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1438
    ^ settings at:#port ifAbsent:PerforcePort.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1439
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1440
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1441
getPerforceSettingsForPackage:aPackage
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1442
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1443
    |samePath|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1444
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1445
    aPackage isNil ifTrue:[^ nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1446
    self repositoryInfoPerModule keysAndValuesDo:[:package :settings|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1447
        samePath := self path:aPackage asPackageId pathRelativeToTopDirectory hasSamePrefixLikePath:package asPackageId pathRelativeToTopDirectory.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1448
        samePath ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1449
            ^settings
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1450
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1451
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1452
    (((self managerForPackage:aPackage) == self) or:[(Smalltalk at:#SourceCodeManager) == self]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1453
        ^ self getPerforceDefaultSettingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1454
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1455
    ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1456
    
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1457
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1458
self getPerforceSettingsForPackage:'applistx'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1459
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1460
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1461
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1462
getPerforceSettingsFromString:aString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1463
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1464
    |clientAndPort noOfClientAndPortElements userAndClientAndPassword noOfUserAndClient settings |
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1465
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1466
    settings := Dictionary new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1467
    clientAndPort := aString asCollectionOfSubstringsSeparatedBy:$@.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1468
    noOfClientAndPortElements := clientAndPort size.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1469
    noOfClientAndPortElements > 0 ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1470
        userAndClientAndPassword := clientAndPort first asCollectionOfSubstringsSeparatedBy:$:.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1471
        noOfUserAndClient := userAndClientAndPassword size.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1472
        noOfUserAndClient > 0 ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1473
            settings at:#client put:userAndClientAndPassword first.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1474
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1475
        noOfUserAndClient > 1 ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1476
            settings at:#user put:userAndClientAndPassword second.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1477
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1478
        (noOfUserAndClient > 2 and:[userAndClientAndPassword third notEmpty]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1479
            settings at:#password put:userAndClientAndPassword third.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1480
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1481
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1482
    noOfClientAndPortElements > 1 ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1483
        settings at:#port put:clientAndPort second.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1484
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1485
    ^ settings
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1486
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1487
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1488
self getPerforceSettingsFromString:'alspa:penk:@perlin:1666'
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1489
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1490
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1491
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1492
getPerforceUserForModule:aModuleName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1493
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1494
    | settings settingsString|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1495
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1496
    aModuleName isNil ifTrue:[^ nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1497
    settingsString := self getPerforceSettingsForPackage:aModuleName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1498
    settingsString isNil ifTrue:[^ PerforcePassword].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1499
    settings := self getPerforceSettingsFromString:settingsString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1500
    ^ settings at:#password ifAbsent:PerforcePassword.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1501
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1502
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1503
getStringFromPerforceSettings:perforceSettings
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1504
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1505
    |settingsStream client user password port|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1506
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1507
    settingsStream := WriteStream on:''.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1508
    client := perforceSettings at:#client ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1509
    client notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1510
        settingsStream nextPutAll:client.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1511
        settingsStream nextPut:$:.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1512
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1513
    user := perforceSettings at:#user ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1514
    user notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1515
        settingsStream nextPutAll:user.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1516
        settingsStream nextPut:$:.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1517
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1518
    password := perforceSettings at:#password ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1519
    password notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1520
        settingsStream nextPutAll:password.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1521
        settingsStream nextPut:$:.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1522
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1523
    settingsStream nextPut:$@.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1524
    port := perforceSettings at:#port ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1525
    port notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1526
        settingsStream nextPutAll:port.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1527
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1528
    ^ settingsStream contents.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1529
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1530
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1531
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1532
self getStringFromPerforceSettings:(self getPerforceSettingsFromString:'alspa:penk:@perlin:1666')
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1533
"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1534
! !
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1535
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1536
!PerforceSourceCodeManager class methodsFor:'subclass responsibility'!
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1537
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1538
getExistingContainersInModule:aModule directory:aPackage
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1539
    "{ Pragma: +optSpace }"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1540
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1541
    " can be easy done with dirs command "
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1542
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1543
    self shouldImplement
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1544
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1545
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1546
getExistingDirectoriesInModule:aModule
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1547
    "{ Pragma: +optSpace }"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1548
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1549
    self shouldImplement
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1550
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1551
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1552
getExistingModules
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1553
    "{ Pragma: +optSpace }"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1554
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1555
    self shouldImplement
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1556
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1557
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1558
reportHistoryLogSince:timeGoal filterSTSources:filter filterUser:userFilter filterRepository:repositoryFilter filterModules:moduleFilter inTo:aBlock
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1559
    "Superclass AbstractSourceCodeManager class says that I am responsible to implement this method"
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1560
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1561
    self shouldImplement
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1562
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1563
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1564
!PerforceSourceCodeManager::CheckInDefinition methodsFor:'accessing'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1565
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1566
classFileName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1567
    ^ classFileName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1568
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1569
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1570
classFileName:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1571
    classFileName := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1572
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1573
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1574
definitionClass
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1575
    ^ definitionClass
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1576
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1577
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1578
fileContents
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1579
    ^ fileContents
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1580
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1581
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1582
fileContents:something
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1583
    fileContents := something.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1584
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1585
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1586
logMessage
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1587
    ^ logMessage
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1588
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1589
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1590
logMessage:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1591
    logMessage := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1592
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1593
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1594
manager
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1595
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1596
    ^ manager
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1597
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1598
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1599
manager:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1600
    manager := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1601
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1602
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1603
package
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1604
    ^ package
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1605
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1606
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1607
package:something
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1608
    package := something.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1609
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1610
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1611
packageDir
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1612
    ^ packageDir
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1613
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1614
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1615
packageDir:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1616
    packageDir := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1617
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1618
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1619
revisionStringBeforeAction
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1620
    ^ revisionStringBeforeAction
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1621
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1622
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1623
revisionStringBeforeAction:something
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1624
    revisionStringBeforeAction := something.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1625
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1626
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1627
setDefinitionClass:something
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1628
    definitionClass := something.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1629
    self  revisionStringBeforeAction:self getLocalRevisionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1630
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1631
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1632
setLogMessage:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1633
    something isNil ifTrue:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1634
        logMessage := ''.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1635
    ] ifFalse:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1636
        logMessage := something asSingleByteStringIfPossible.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1637
        logMessage bitsPerCharacter ~~ 8 ifTrue:[
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1638
            ^ false.
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1639
        ].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1640
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1641
    ^ true
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1642
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1643
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1644
sourceFileName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1645
    ^ sourceFileName
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1646
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1647
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1648
sourceFileName:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1649
    sourceFileName := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1650
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1651
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1652
tempDirectory:something
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1653
    tempDirectory := something.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1654
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1655
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1656
workSpace
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1657
    ^ workSpace
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1658
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1659
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1660
workSpace:something
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1661
    workSpace := something.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1662
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1663
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1664
!PerforceSourceCodeManager::CheckInDefinition methodsFor:'actions'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1665
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1666
getBinaryRevision
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1667
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1668
    |locRevision |
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1669
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1670
    definitionClass isNil ifTrue:[ ^nil].
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1671
    locRevision := definitionClass binaryRevision.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1672
    ^ locRevision
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1673
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1674
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1675
getBinaryRevisionNumber
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1676
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1677
    |locRevision |
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1678
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1679
    locRevision := self getBinaryRevision.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1680
    locRevision notNil ifTrue:[
2353
8841e465eb49 added: #settingsApplicationClass
Claus Gittinger <cg@exept.de>
parents: 2349
diff changeset
  1681
        locRevision := locRevision asNumber.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1682
    ].
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1683
    ^ locRevision
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1684
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1685
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1686
getLocalRevision
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1687
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1688
    |locRevisionString versionInfo|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1689
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1690
    locRevisionString := self getLocalRevisionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1691
    locRevisionString notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1692
        versionInfo := PerforceSourceCodeManager versionInfoClass fromRCSString:locRevisionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1693
        versionInfo isNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1694
        ^versionInfo revision
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1695
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1696
    ^ nil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1697
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1698
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1699
getLocalRevisionNumber
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1700
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1701
    |locRevision locRevisionNumber|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1702
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1703
    locRevision := self getLocalRevision.
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1704
    locRevision notNil ifTrue:[
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1705
        locRevisionNumber := Number readFrom:locRevision onError:nil.
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1706
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1707
    ^ locRevisionNumber
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1708
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1709
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1710
getLocalRevisionString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1711
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1712
    |locRevisionString |
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1713
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1714
    definitionClass isNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1715
    locRevisionString := definitionClass revisionStringOfManager:self manager.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1716
    ^ locRevisionString
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1717
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1718
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1719
getReposRevisionAfterCheckin
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1720
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1721
    |log|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1722
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1723
    log := self getReposRevisionInfoAfterCheckin.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1724
    log isNil ifTrue:[^ nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1725
    ^ log at:#newestRevision ifAbsent:nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1726
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1727
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1728
getReposRevisionBeforeCheckin
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1729
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1730
    |log|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1731
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1732
    log := self getReposRevisionInfoBeforeCheckin.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1733
    log isNil ifTrue:[^ nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1734
    ^ log at:#newestRevision ifAbsent:nil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1735
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1736
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1737
getReposRevisionInfoAfterCheckin
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1738
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1739
    reposRevisionInfoAfterAction isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1740
        reposRevisionInfoAfterAction := self manager revisionLogOf:nil 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1741
            fromRevision:0 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1742
            toRevision:0 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1743
            fileName:self fileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1744
            directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1745
            module:package.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1746
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1747
    ^ reposRevisionInfoAfterAction
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1748
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1749
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1750
getReposRevisionInfoBeforeCheckin
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1751
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1752
    reposRevisionInfoBeforeAction isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1753
        reposRevisionInfoBeforeAction := self manager revisionLogOf:nil 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1754
            fromRevision:0 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1755
            toRevision:0 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1756
            fileName:self fileName 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1757
            directory:packageDir 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1758
            module:package.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1759
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1760
    ^ reposRevisionInfoBeforeAction
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1761
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1762
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1763
getReposRevisionNumberAfterCheckin
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1764
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1765
    | newestRevisionInfo newestRevisionString|
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1766
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1767
    newestRevisionInfo := self getReposRevisionInfoAfterCheckin.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1768
    newestRevisionInfo isNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1769
    newestRevisionString := newestRevisionInfo at:#newestRevision ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1770
    newestRevisionString isEmptyOrNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1771
    ^ Number readFrom:(ReadStream on:newestRevisionString) onError:nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1772
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1773
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1774
getReposRevisionNumberBeforeCheckin
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1775
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1776
    | newestRevisionInfo newestRevisionString|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1777
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1778
    newestRevisionInfo := self getReposRevisionInfoBeforeCheckin.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1779
    newestRevisionInfo isNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1780
    newestRevisionString := newestRevisionInfo at:#newestRevision ifAbsent:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1781
    newestRevisionString isEmptyOrNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1782
    ^ Number readFrom:(ReadStream on:newestRevisionString) onError:nil
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1783
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1784
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1785
!PerforceSourceCodeManager::CheckInDefinition methodsFor:'queries'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1786
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1787
definitionObjectString
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1788
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1789
    definitionClass notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1790
        ^definitionClass name
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1791
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1792
    sourceFileName notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1793
        ^sourceFileName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1794
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1795
    ^'?'
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1796
!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1797
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1798
fileName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1799
    ^classFileName ? sourceFileName
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1800
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1801
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1802
isClassCheckin
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1803
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1804
    ^definitionClass notNil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1805
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1806
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1807
packageString
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1808
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1809
    ^ (PackageId module:package directory:packageDir) asString. 
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1810
! !
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1811
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1812
!PerforceSourceCodeManager::PerforceVersionInfo class methodsFor:'documentation'!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1813
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1814
documentation
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1815
"
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1816
    Class used to return a Dictionary when asked for versionInfo.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1817
    This has been replaced by instances of VersionInfo and subclasses.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1818
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1819
    Notice, that CVSVersionInfo adds some CVS specific data.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1820
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1821
    [author:]
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1822
        cg (cg@AQUA-DUO)
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1823
"
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1824
! !
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1825
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1826
!PerforceSourceCodeManager::PerforceVersionInfo class methodsFor:'instance creation'!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1827
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1828
fromRCSString:aString
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1829
    "{ Pragma: +optSpace }"
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1830
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1831
    "I know how to parse RCS/CVS version id strings.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1832
     Return an instance filled with revision info which is
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1833
     extracted from aString. This must be in RCS/CVS format."
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1834
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1835
    |words firstWord info s depotName revNumber rest hashIndex revNumberIndex|
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1836
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1837
    s := aString readStream.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1838
    s skipSeparators.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1839
    firstWord := s upToSeparator.
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1840
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1841
    info := self new.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1842
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1843
    "/
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1844
    "/ supported formats:
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1845
    "/
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1846
    "/ $-Header:   pathName rev date time user state $
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1847
    "/ $-Revision: rev $
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1848
    "/ $-Id:       fileName rev date time user state $
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1849
    "/
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1850
    (firstWord = ('$','Header:')        "/ WARNING: need to split the strings to prevent CVS from expanding them
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1851
    or:[firstWord = ('','Header:') 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1852
    or:[firstWord = ('$','Id:') 
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1853
    or:[firstWord = ('','Id:')]]]) ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1854
        s skipSeparators.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1855
        rest := s upToEnd.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1856
        hashIndex := rest indexOf:$#.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1857
        hashIndex = 0 ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1858
            " not a perforce RCS version string"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1859
            ^nil
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1860
        ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1861
        depotName := rest copyTo:(hashIndex - 1).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1862
        info repositoryPathName:depotName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1863
        info fileName:(depotName asFilename baseName).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1864
        revNumberIndex := rest indexOfSeparatorStartingAt:hashIndex.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1865
        revNumber := (rest copyFrom:(hashIndex + 1) to:(revNumberIndex -1 )).
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1866
        info revision:revNumber.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1867
        words := s upToEnd asCollectionOfWords readStream.
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1868
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1869
        ^ info
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1870
    ].
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1871
    ^ nil
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1872
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1873
    "
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1874
     | versionInfo s|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1875
     versionInfo := PerforceVersionInfo fromRepositoryPathName:'//depot/applistx/util/rtdb/RTDBInterfaceInspector.st'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1876
     versionInfo revision:26.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1877
     versionInfo user:'penk'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1878
     s := CharacterWriteStream on:(String basicNew:40).    
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1879
     Date today printOn:s format:'%d-%m-%y' language:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1880
     versionInfo date:s contents.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1881
     s := CharacterWriteStream on:(String basicNew:40).    
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1882
     Timestamp now printOn:s format:'%h-%m-%s.%i'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1883
     versionInfo time:s contents.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1884
     PerforceVersionInfo fromRCSString:versionInfo getVersionString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1885
     PerforceVersionInfo fromRCSString:'$Header: /cvs/stx/stx/libbasic3/PerforceSourceCodeManager.st,v 1.26 2012/06/01 11:33:16 cg Exp $'
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1886
    "
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1887
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1888
    "Modified: / 01-06-2012 / 13:32:40 / cg"
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1889
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1890
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1891
fromRepositoryPathName:something
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1892
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1893
    |inst|
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1894
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1895
    inst := self new.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1896
    inst repositoryPathName:something.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1897
    ^inst
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1898
! !
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1899
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1900
!PerforceSourceCodeManager::PerforceVersionInfo methodsFor:'accessing'!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1901
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1902
repositoryPathName
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1903
    ^ repositoryPathName
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1904
!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1905
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1906
repositoryPathName:something
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1907
    repositoryPathName := something.
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1908
    self fileName:repositoryPathName asFilename baseName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1909
!
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1910
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1911
revisionNumber
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1912
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1913
    revision isNil ifTrue:[ ^nil].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1914
    revisionNumber isNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1915
        revisionNumber := Number readFrom:(ReadStream on:revision) onError:nil.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1916
    ].
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1917
    ^ revisionNumber
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1918
!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1919
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1920
state
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1921
    ^ ''
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1922
!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1923
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1924
timeZone
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1925
    ^ ''
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1926
!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1927
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1928
timezone
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1929
    ^ ''
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1930
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1931
    "Created: / 22-10-2008 / 20:50:39 / cg"
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1932
! !
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1933
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1934
!PerforceSourceCodeManager::PerforceVersionInfo methodsFor:'queries'!
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1935
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1936
getVersionString
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1937
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1938
    |stream|
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1939
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1940
    stream := WriteStream on:''.
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1941
    stream nextPutAll:'$Header: '.
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1942
    stream nextPutAll:repositoryPathName.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1943
    stream nextPut:$#.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1944
    stream nextPutAll:revision printString.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1945
    stream space.
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1946
    stream nextPut:$$.
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1947
        
2355
6c21470136d2 PerforceVersion as private class
Claus Gittinger <cg@exept.de>
parents: 2354
diff changeset
  1948
    ^ stream contents
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
  1949
!
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
  1950
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1951
getVersionString_ownVersion
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
  1952
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1953
    |stream|
2349
Claus Gittinger <cg@exept.de>
parents: 2345
diff changeset
  1954
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1955
    stream := WriteStream on:''.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1956
    stream nextPutAll:'Path:'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1957
    stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1958
    stream nextPutAll:repositoryPathName.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1959
    stream nextPut:$#.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1960
    stream nextPutAll:revision printString.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1961
    self user notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1962
        stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1963
        stream nextPutAll:'User:'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1964
        stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1965
        stream nextPutAll:self user printString.
2354
Claus Gittinger <cg@exept.de>
parents: 2353
diff changeset
  1966
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1967
    self date notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1968
        stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1969
        stream nextPutAll:'Date:'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1970
        stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1971
        stream nextPutAll:self date printString.
2354
Claus Gittinger <cg@exept.de>
parents: 2353
diff changeset
  1972
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1973
    self time notNil ifTrue:[
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1974
        stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1975
        stream nextPutAll:'Time:'.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1976
        stream space.
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1977
        stream nextPutAll:self time printString.
2354
Claus Gittinger <cg@exept.de>
parents: 2353
diff changeset
  1978
    ].
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1979
        
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1980
    ^ stream contents
2354
Claus Gittinger <cg@exept.de>
parents: 2353
diff changeset
  1981
! !
Claus Gittinger <cg@exept.de>
parents: 2353
diff changeset
  1982
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1983
!PerforceSourceCodeManager class methodsFor:'documentation'!
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1984
2652
f1faa96b62ac comment/format in: #initialRevisionStringFor:inModule:directory:container:
Claus Gittinger <cg@exept.de>
parents: 2646
diff changeset
  1985
version
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1986
    ^ '$Header: /cvs/stx/stx/libbasic3/PerforceSourceCodeManager.st,v 1.26 2012/06/01 11:33:16 cg Exp $'
2652
f1faa96b62ac comment/format in: #initialRevisionStringFor:inModule:directory:container:
Claus Gittinger <cg@exept.de>
parents: 2646
diff changeset
  1987
!
f1faa96b62ac comment/format in: #initialRevisionStringFor:inModule:directory:container:
Claus Gittinger <cg@exept.de>
parents: 2646
diff changeset
  1988
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1989
version_CVS
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1990
    ^ 'Header: /cvs/stx/stx/libbasic3/PerforceSourceCodeManager.st,v 1.26 2012/06/01 11:33:16 cg Exp '
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
  1991
!
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
  1992
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
  1993
version_SVN
3054
d4f41c83c03b Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3023
diff changeset
  1994
    ^ '$Id: PerforceSourceCodeManager.st 1925 2012-06-05 13:52:00Z vranyj1 $'
2330
96c6e13dded5 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1995
! !