annotate mercurial-server/src/jetbrains/buildServer/buildTriggers/vcs/mercurial/MercurialVcsSupport.java @ 97:3ac056b1932e

TW-10928
author Pavel.Sher
date Mon, 08 Feb 2010 14:03:50 +0300
parents 6c1cff1f61cc
children 95c28c14b26e
rev   line source
25
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
1 /*
95
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
2 * Copyright 2000-2010 JetBrains s.r.o.
25
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
3 *
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
4 * Licensed under the Apache License, Version 2.0 (the "License");
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
5 * you may not use this file except in compliance with the License.
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
6 * You may obtain a copy of the License at
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
7 *
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
8 * http://www.apache.org/licenses/LICENSE-2.0
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
9 *
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
10 * Unless required by applicable law or agreed to in writing, software
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
11 * distributed under the License is distributed on an "AS IS" BASIS,
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
13 * See the License for the specific language governing permissions and
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
14 * limitations under the License.
7047f643747f license added, preamble added to source code
Pavel.Sher
parents: 23
diff changeset
15 */
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
16 package jetbrains.buildServer.buildTriggers.vcs.mercurial;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
17
48
8665bfa3e03a enable agent side checkout
Pavel.Sher
parents: 47
diff changeset
18 import jetbrains.buildServer.AgentSideCheckoutAbility;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
19 import jetbrains.buildServer.CollectChangesByIncludeRule;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
20 import jetbrains.buildServer.Used;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
21 import jetbrains.buildServer.buildTriggers.vcs.AbstractVcsPropertiesProcessor;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
22 import jetbrains.buildServer.buildTriggers.vcs.mercurial.command.*;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
23 import jetbrains.buildServer.log.Loggers;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
24 import jetbrains.buildServer.serverSide.InvalidProperty;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
25 import jetbrains.buildServer.serverSide.PropertiesProcessor;
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
26 import jetbrains.buildServer.serverSide.SBuildServer;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
27 import jetbrains.buildServer.serverSide.ServerPaths;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
28 import jetbrains.buildServer.util.FileUtil;
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
29 import jetbrains.buildServer.util.StringUtil;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
30 import jetbrains.buildServer.vcs.*;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
31 import jetbrains.buildServer.vcs.patches.PatchBuilder;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
32 import org.jetbrains.annotations.NotNull;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
33 import org.jetbrains.annotations.Nullable;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
34
1
56e7f34ca887 added TeamCity libs, fix tests
Pavel.Sher
parents: 0
diff changeset
35 import java.io.File;
56e7f34ca887 added TeamCity libs, fix tests
Pavel.Sher
parents: 0
diff changeset
36 import java.io.FileFilter;
56e7f34ca887 added TeamCity libs, fix tests
Pavel.Sher
parents: 0
diff changeset
37 import java.io.FileInputStream;
56e7f34ca887 added TeamCity libs, fix tests
Pavel.Sher
parents: 0
diff changeset
38 import java.io.IOException;
56e7f34ca887 added TeamCity libs, fix tests
Pavel.Sher
parents: 0
diff changeset
39 import java.util.*;
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
40 import java.util.concurrent.ConcurrentHashMap;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
41 import java.util.concurrent.ConcurrentMap;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
42 import java.util.concurrent.TimeUnit;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
43 import java.util.concurrent.locks.Lock;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
44 import java.util.concurrent.locks.ReentrantLock;
1
56e7f34ca887 added TeamCity libs, fix tests
Pavel.Sher
parents: 0
diff changeset
45
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
46 /**
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
47 * Mercurial VCS plugin for TeamCity works as follows:
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
48 * <ul>
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
49 * <li>clones repository to internal storage
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
50 * <li>before any operation with working copy of repository pulls changes from the original repository
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
51 * <li>executes corresponding hg command
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
52 * </ul>
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
53 *
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
54 * <p>Working copy of repository is created in the $TEAMCITY_DATA_PATH/system/caches/hg_&lt;hash code> folder.
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
55 * <p>Personal builds (remote runs) are not yet supported, they require corresponding functionality from the IDE.
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
56 */
48
8665bfa3e03a enable agent side checkout
Pavel.Sher
parents: 47
diff changeset
57 public class MercurialVcsSupport extends VcsSupport implements CollectChangesByIncludeRule, LabelingSupport, AgentSideCheckoutAbility {
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
58 private ConcurrentMap<String, Lock> myWorkDirLocks= new ConcurrentHashMap<String, Lock>();
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
59 private static final int OLD_WORK_DIRS_CLEANUP_PERIOD = 600;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
60 private VcsManager myVcsManager;
27
7944e8985ebd prepare modules structure for agent side checkout
Pavel.Sher
parents: 25
diff changeset
61 private File myDefaultWorkFolderParent;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
62
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
63 public MercurialVcsSupport(@NotNull final VcsManager vcsManager,
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
64 @NotNull ServerPaths paths,
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
65 @NotNull SBuildServer server) {
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
66 vcsManager.registerVcsSupport(this);
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
67 myVcsManager = vcsManager;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
68 server.getExecutor().scheduleAtFixedRate(new Runnable() {
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
69 public void run() {
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
70 removeOldWorkFolders();
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
71 }
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
72 }, 0, OLD_WORK_DIRS_CLEANUP_PERIOD, TimeUnit.SECONDS);
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
73 myDefaultWorkFolderParent = new File(paths.getCachesDir(), "mercurial");
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
74 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
75
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
76 public List<ModificationData> collectBuildChanges(final VcsRoot root,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
77 @NotNull final String fromVersion,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
78 @NotNull final String currentVersion,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
79 final CheckoutRules checkoutRules) throws VcsException {
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
80 syncClonedRepository(root);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
81 return VcsSupportUtil.collectBuildChanges(root, fromVersion, currentVersion, checkoutRules, this);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
82 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
83
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
84 public List<ModificationData> collectBuildChanges(final VcsRoot root,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
85 final String fromVersion,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
86 final String currentVersion,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
87 final IncludeRule includeRule) throws VcsException {
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
88 // first obtain changes between specified versions
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
89 List<ModificationData> result = new ArrayList<ModificationData>();
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
90 Settings settings = createSettings(root);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
91 LogCommand lc = new LogCommand(settings);
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
92 String fromId = new ChangeSetRevision(fromVersion).getId();
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
93 lc.setFromRevId(fromId);
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
94 lc.setToRevId(new ChangeSetRevision(currentVersion).getId());
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
95 List<ChangeSet> changeSets = lc.execute();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
96 if (changeSets.isEmpty()) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
97 return result;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
98 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
99
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
100 // invoke status command for each changeset and determine what files were modified in these changesets
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
101 StatusCommand st = new StatusCommand(settings);
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
102 ChangeSet prev = new ChangeSet(fromVersion);
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
103 for (ChangeSet cur : changeSets) {
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
104 if (cur.getId().equals(fromId)) continue; // skip already reported changeset
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
105
90
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
106 String prevId = prev.getId();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
107 List<ChangeSetRevision> curParents = cur.getParents();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
108 boolean merge = curParents != null && curParents.size() > 1;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
109 if (curParents != null && !merge) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
110 prevId = curParents.get(0).getId();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
111 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
112
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
113 List<ModifiedFile> modifiedFiles = new ArrayList<ModifiedFile>();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
114 if (merge) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
115 modifiedFiles.addAll(computeModifiedFilesForMergeCommit(settings, cur));
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
116 } else {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
117 st.setFromRevId(prevId);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
118 st.setToRevId(cur.getId());
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
119 modifiedFiles = st.execute();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
120 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
121
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
122 // changeset full version will be set into VcsChange structure and
20
90f5e574fb73 comments
Pavel.Sher
parents: 19
diff changeset
123 // stored in database (note that getContent method will be invoked with this version)
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
124 List<VcsChange> files = toVcsChanges(modifiedFiles, prev.getFullVersion(), cur.getFullVersion(), includeRule);
90
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
125 if (files.isEmpty() && !merge) continue;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
126 ModificationData md = new ModificationData(cur.getTimestamp(), files, cur.getDescription(), cur.getUser(), root, cur.getFullVersion(), cur.getId());
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
127 if (merge) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
128 md.setCanBeIgnored(false);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
129 }
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
130 result.add(md);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
131 prev = cur;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
132 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
133
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
134 return result;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
135 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
136
90
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
137 private Collection<ModifiedFile> computeModifiedFilesForMergeCommit(final Settings settings, final ChangeSet cur) throws VcsException {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
138 if (!cur.containsFiles()) return Collections.emptyList();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
139
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
140 ChangedFilesCommand cfc = new ChangedFilesCommand(settings);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
141 cfc.setRevId(cur.getId());
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
142 return cfc.execute();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
143 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents: 86
diff changeset
144
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
145 private List<VcsChange> toVcsChanges(final List<ModifiedFile> modifiedFiles, String prevVer, String curVer, final IncludeRule includeRule) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
146 List<VcsChange> files = new ArrayList<VcsChange>();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
147 for (ModifiedFile mf: modifiedFiles) {
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
148 String normalizedPath = PathUtil.normalizeSeparator(mf.getPath());
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
149 if (!normalizedPath.startsWith(includeRule.getFrom())) continue; // skip files which do not match include rule
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
150
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
151 VcsChangeInfo.Type changeType = getChangeType(mf.getStatus());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
152 if (changeType == null) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
153 Loggers.VCS.warn("Unable to convert status: " + mf.getStatus() + " to VCS change type");
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
154 changeType = VcsChangeInfo.Type.NOT_CHANGED;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
155 }
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
156 files.add(new VcsChange(changeType, mf.getStatus().getName(), normalizedPath, normalizedPath, prevVer, curVer));
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
157 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
158 return files;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
159 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
160
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
161 private VcsChangeInfo.Type getChangeType(final ModifiedFile.Status status) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
162 switch (status) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
163 case ADDED:return VcsChangeInfo.Type.ADDED;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
164 case MODIFIED:return VcsChangeInfo.Type.CHANGED;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
165 case REMOVED:return VcsChangeInfo.Type.REMOVED;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
166 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
167 return null;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
168 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
169
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
170 @NotNull
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
171 public byte[] getContent(@NotNull final VcsModification vcsModification,
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
172 @NotNull final VcsChangeInfo change,
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
173 @NotNull final VcsChangeInfo.ContentType contentType,
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
174 @NotNull final VcsRoot vcsRoot) throws VcsException {
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
175 syncClonedRepository(vcsRoot);
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
176 String version = contentType == VcsChangeInfo.ContentType.AFTER_CHANGE ? change.getAfterChangeRevisionNumber() : change.getBeforeChangeRevisionNumber();
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
177 return getContent(change.getRelativeFileName(), vcsRoot, version);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
178 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
179
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
180 @NotNull
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
181 public byte[] getContent(@NotNull final String filePath, @NotNull final VcsRoot vcsRoot, @NotNull final String version) throws VcsException {
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
182 syncClonedRepository(vcsRoot);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
183 Settings settings = createSettings(vcsRoot);
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
184 CatCommand cc = new CatCommand(settings);
59
30cc10fe9479 accept version in two formats: with rev number and without
Pavel.Sher
parents: 58
diff changeset
185 cc.setRevId(new ChangeSet(version).getId());
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
186 File parentDir = cc.execute(Collections.singletonList(filePath));
30
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
187 try {
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
188 File file = new File(parentDir, filePath);
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
189 if (file.isFile()) {
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
190 try {
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
191 return FileUtil.loadFileBytes(file);
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
192 } catch (IOException e) {
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
193 throw new VcsException("Failed to load content of file: " + file.getAbsolutePath(), e);
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
194 }
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
195 } else {
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
196 Loggers.VCS.warn("Unable to obtain content of the file: " + filePath);
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
197 }
30
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
198 } finally {
007c63ae45b0 delete temp dir after getContent call
Pavel.Sher
parents: 29
diff changeset
199 FileUtil.delete(parentDir);
12
6989ac0f8cac getContent supported
Pavel.Sher
parents: 11
diff changeset
200 }
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
201 return new byte[0];
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
202 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
203
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
204 @NotNull
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
205 public String getName() {
28
a7cab5083ada libraries moved on top level, dummy implementation of agent side checkout interface
Pavel.Sher
parents: 27
diff changeset
206 return Constants.VCS_NAME;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
207 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
208
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
209 @NotNull
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
210 @Used("jsp")
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
211 public String getDisplayName() {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
212 return "Mercurial";
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
213 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
214
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
215 @Nullable
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
216 public PropertiesProcessor getVcsPropertiesProcessor() {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
217 return new AbstractVcsPropertiesProcessor() {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
218 public Collection<InvalidProperty> process(final Map<String, String> properties) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
219 List<InvalidProperty> result = new ArrayList<InvalidProperty>();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
220 if (isEmpty(properties.get(Constants.HG_COMMAND_PATH_PROP))) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
221 result.add(new InvalidProperty(Constants.HG_COMMAND_PATH_PROP, "Path to 'hg' command must be specified"));
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
222 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
223 if (isEmpty(properties.get(Constants.REPOSITORY_PROP))) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
224 result.add(new InvalidProperty(Constants.REPOSITORY_PROP, "Repository must be specified"));
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
225 }
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
226 if (isEmpty(properties.get(Constants.SERVER_CLONE_PATH_PROP))) {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
227 properties.put(Constants.SERVER_CLONE_PATH_PROP, myDefaultWorkFolderParent.getAbsolutePath());
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
228 }
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
229 return result;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
230 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
231 };
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
232 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
233
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
234 @NotNull
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
235 public String getVcsSettingsJspFilePath() {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
236 return "mercurialSettings.jsp";
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
237 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
238
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
239 @NotNull
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
240 public String getCurrentVersion(@NotNull final VcsRoot root) throws VcsException {
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
241 // we will return full version of the most recent change as current version
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
242 syncClonedRepository(root);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
243 Settings settings = createSettings(root);
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
244 BranchesCommand branches = new BranchesCommand(settings);
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
245 Map<String, ChangeSet> result = branches.execute();
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
246 if (!result.containsKey(settings.getBranchName())) {
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
247 throw new VcsException("Unable to find current version for the branch: " + settings.getBranchName());
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
248 }
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
249
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
250 return result.get(settings.getBranchName()).getFullVersion();
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
251 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
252
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
253 @NotNull
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
254 public String describeVcsRoot(final VcsRoot vcsRoot) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
255 return "mercurial: " + vcsRoot.getProperty(Constants.REPOSITORY_PROP);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
256 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
257
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
258 public boolean isTestConnectionSupported() {
16
7aa397165fa0 identify command added, test connection now uses identify command
Pavel.Sher
parents: 13
diff changeset
259 return true;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
260 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
261
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
262 @Nullable
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
263 public String testConnection(@NotNull final VcsRoot vcsRoot) throws VcsException {
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
264 Settings settings = createSettings(vcsRoot);
16
7aa397165fa0 identify command added, test connection now uses identify command
Pavel.Sher
parents: 13
diff changeset
265 IdentifyCommand id = new IdentifyCommand(settings);
7aa397165fa0 identify command added, test connection now uses identify command
Pavel.Sher
parents: 13
diff changeset
266 StringBuilder res = new StringBuilder();
17
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
267 res.append(quoteIfNeeded(settings.getHgCommandPath()));
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
268 res.append(" identify ");
71
4c15e7de1f9d do not show password in test connection popup
Pavel.Sher
parents: 67
diff changeset
269 final String obfuscatedUrl = CommandUtil.removePrivateData(settings.getRepositoryUrl(), Collections.singleton(settings.getPassword()));
4c15e7de1f9d do not show password in test connection popup
Pavel.Sher
parents: 67
diff changeset
270 res.append(quoteIfNeeded(obfuscatedUrl));
16
7aa397165fa0 identify command added, test connection now uses identify command
Pavel.Sher
parents: 13
diff changeset
271 res.append('\n').append(id.execute());
7aa397165fa0 identify command added, test connection now uses identify command
Pavel.Sher
parents: 13
diff changeset
272 return res.toString();
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
273 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
274
17
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
275 private String quoteIfNeeded(@NotNull String str) {
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
276 if (str.indexOf(' ') != -1) {
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
277 return "\"" + str + "\"";
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
278 }
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
279
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
280 return str;
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
281 }
21b5b1c5dd74 test connection minor fix
Pavel.Sher
parents: 16
diff changeset
282
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
283 @Nullable
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
284 public Map<String, String> getDefaultVcsProperties() {
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
285 Map<String, String> defaults = new HashMap<String, String>();
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
286 defaults.put(Constants.HG_COMMAND_PATH_PROP, "hg");
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
287 defaults.put(Constants.SERVER_CLONE_PATH_PROP, myDefaultWorkFolderParent.getAbsolutePath());
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
288 return defaults;
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
289 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
290
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
291 public String getVersionDisplayName(@NotNull final String version, @NotNull final VcsRoot root) throws VcsException {
59
30cc10fe9479 accept version in two formats: with rev number and without
Pavel.Sher
parents: 58
diff changeset
292 return new ChangeSet(version).getId();
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
293 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
294
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
295 @NotNull
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
296 public Comparator<String> getVersionComparator() {
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
297 // comparator is called when TeamCity needs to sort modifications in the order of their appearance,
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
298 // currently we sort changes by revision number, not sure however that this is a good idea,
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
299 // probably it would be better to sort them by timestamp (and to add timestamp into the version).
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
300 return new Comparator<String>() {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
301 public int compare(final String o1, final String o2) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
302 try {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
303 return new ChangeSet(o1).getRevNumber() - new ChangeSet(o2).getRevNumber();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
304 } catch (Exception e) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
305 return 1;
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
306 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
307 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
308 };
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
309 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
310
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
311 public void buildPatch(@NotNull final VcsRoot root,
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
312 @Nullable final String fromVersion,
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
313 @NotNull final String toVersion,
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
314 @NotNull final PatchBuilder builder,
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
315 @NotNull final CheckoutRules checkoutRules) throws IOException, VcsException {
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
316 syncClonedRepository(root);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
317 Settings settings = createSettings(root);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
318 if (fromVersion == null) {
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
319 buildFullPatch(settings, new ChangeSet(toVersion), builder, checkoutRules);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
320 } else {
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
321 buildIncrementalPatch(settings, new ChangeSet(fromVersion), new ChangeSet(toVersion), builder, checkoutRules);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
322 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
323 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
324
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
325 // builds patch from version to version
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
326 private void buildIncrementalPatch(final Settings settings, @NotNull final ChangeSet fromVer, @NotNull final ChangeSet toVer, final PatchBuilder builder, final CheckoutRules checkoutRules)
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
327 throws VcsException, IOException {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
328 StatusCommand st = new StatusCommand(settings);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
329 st.setFromRevId(fromVer.getId());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
330 st.setToRevId(toVer.getId());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
331 List<ModifiedFile> modifiedFiles = st.execute();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
332 List<String> notDeletedFiles = new ArrayList<String>();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
333 for (ModifiedFile f: modifiedFiles) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
334 if (f.getStatus() != ModifiedFile.Status.REMOVED) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
335 notDeletedFiles.add(f.getPath());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
336 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
337 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
338
47
c785bc4c5f39 minor fix: do not call cat command if there are no files to export
Pavel.Sher
parents: 46
diff changeset
339 if (notDeletedFiles.isEmpty()) return;
c785bc4c5f39 minor fix: do not call cat command if there are no files to export
Pavel.Sher
parents: 46
diff changeset
340
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
341 CatCommand cc = new CatCommand(settings);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
342 cc.setRevId(toVer.getId());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
343 File parentDir = cc.execute(notDeletedFiles);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
344
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
345 try {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
346 for (ModifiedFile f: modifiedFiles) {
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
347 String mappedPath = checkoutRules.map(f.getPath());
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
348 if (mappedPath == null) continue; // skip
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
349 final File virtualFile = new File(mappedPath);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
350 if (f.getStatus() == ModifiedFile.Status.REMOVED) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
351 builder.deleteFile(virtualFile, true);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
352 } else {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
353 File realFile = new File(parentDir, f.getPath());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
354 FileInputStream is = new FileInputStream(realFile);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
355 try {
11
568707240741 fix patch
Pavel.Sher
parents: 9
diff changeset
356 builder.changeOrCreateBinaryFile(virtualFile, null, is, realFile.length());
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
357 } finally {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
358 is.close();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
359 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
360 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
361 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
362 } finally {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
363 FileUtil.delete(parentDir);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
364 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
365 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
366
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
367 // builds patch by exporting files using specified version
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
368 private void buildFullPatch(final Settings settings, @NotNull final ChangeSet toVer, final PatchBuilder builder, final CheckoutRules checkoutRules)
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
369 throws IOException, VcsException {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
370 CloneCommand cl = new CloneCommand(settings);
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
371 // clone from the local repository
67
e6971dc6b17c always use url with credentials if username/password are specified
Pavel.Sher
parents: 62
diff changeset
372 cl.setRepository(settings.getLocalRepositoryDir().getAbsolutePath());
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
373 cl.setToId(toVer.getId());
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
374 cl.setUpdateWorkingDir(false);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
375 File tempDir = FileUtil.createTempDirectory("mercurial", toVer.getId());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
376 try {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
377 final File repRoot = new File(tempDir, "rep");
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
378 cl.setDestDir(repRoot.getAbsolutePath());
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
379 cl.execute();
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
380
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
381 UpdateCommand up = new UpdateCommand(settings);
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
382 up.setWorkDirectory(repRoot.getAbsolutePath());
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
383 up.setToId(toVer.getId());
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
384 up.execute();
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
385
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
386 buildPatchFromDirectory(builder, repRoot, new FileFilter() {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
387 public boolean accept(final File file) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
388 return !(file.isDirectory() && ".hg".equals(file.getName()));
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
389 }
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
390 }, checkoutRules);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
391 } finally {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
392 FileUtil.delete(tempDir);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
393 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
394 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
395
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
396 private void buildPatchFromDirectory(final PatchBuilder builder, final File repRoot, final FileFilter filter, final CheckoutRules checkoutRules) throws IOException {
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
397 buildPatchFromDirectory(repRoot, builder, repRoot, filter, checkoutRules);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
398 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
399
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
400 private void buildPatchFromDirectory(File curDir, final PatchBuilder builder, final File repRoot, final FileFilter filter, final CheckoutRules checkoutRules) throws IOException {
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
401 File[] files = curDir.listFiles(filter);
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
402 if (files != null) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
403 for (File realFile: files) {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
404 String relPath = realFile.getAbsolutePath().substring(repRoot.getAbsolutePath().length());
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
405 String mappedPath = checkoutRules.map(relPath);
97
3ac056b1932e TW-10928
Pavel.Sher
parents: 95
diff changeset
406 if (mappedPath != null && mappedPath.length() > 0) {
79
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
407 final File virtualFile = new File(mappedPath);
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
408 if (realFile.isDirectory()) {
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
409 builder.createDirectory(virtualFile);
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
410 buildPatchFromDirectory(realFile, builder, repRoot, filter, checkoutRules);
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
411 } else {
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
412 final FileInputStream is = new FileInputStream(realFile);
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
413 try {
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
414 builder.createBinaryFile(virtualFile, null, is, realFile.length());
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
415 } finally {
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
416 is.close();
2e57d4e3f7b7 support checkout rules for server side patch
Pavel.Sher
parents: 71
diff changeset
417 }
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
418 }
97
3ac056b1932e TW-10928
Pavel.Sher
parents: 95
diff changeset
419 } else {
3ac056b1932e TW-10928
Pavel.Sher
parents: 95
diff changeset
420 if (realFile.isDirectory()) {
3ac056b1932e TW-10928
Pavel.Sher
parents: 95
diff changeset
421 buildPatchFromDirectory(realFile, builder, repRoot, filter, checkoutRules);
3ac056b1932e TW-10928
Pavel.Sher
parents: 95
diff changeset
422 }
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
423 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
424 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
425 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
426 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
427
19
40b2cf04cd4b some comments added
Pavel.Sher
parents: 18
diff changeset
428 // updates current working copy of repository by pulling changes from the repository specified in VCS root
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
429 private void syncClonedRepository(final VcsRoot root) throws VcsException {
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
430 Settings settings = createSettings(root);
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
431 File workDir = settings.getLocalRepositoryDir();
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
432 lockWorkDir(workDir);
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
433 try {
29
798e750e4f26 first version of agent side checkout
Pavel.Sher
parents: 28
diff changeset
434 if (settings.hasCopyOfRepository()) {
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
435 // update
8
2cb2df5a0dcd fix working directory update (use pull command)
Pavel.Sher
parents: 1
diff changeset
436 PullCommand pull = new PullCommand(settings);
2cb2df5a0dcd fix working directory update (use pull command)
Pavel.Sher
parents: 1
diff changeset
437 pull.execute();
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
438 } else {
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
439 // clone
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
440 CloneCommand cl = new CloneCommand(settings);
22
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
441 cl.setDestDir(workDir.getAbsolutePath());
18
d787c696225c do not update local working directory
Pavel.Sher
parents: 17
diff changeset
442 cl.setUpdateWorkingDir(false);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
443 cl.execute();
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
444 }
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
445 } finally {
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
446 unlockWorkDir(workDir);
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
447 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
448 }
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
449
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
450 @Override
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
451 public LabelingSupport getLabelingSupport() {
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
452 return this;
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
453 }
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
454
22
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
455 private void lockWorkDir(@NotNull File workDir) {
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
456 getWorkDirLock(workDir).lock();
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
457 }
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
458
22
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
459 private void unlockWorkDir(@NotNull File workDir) {
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
460 getWorkDirLock(workDir).unlock();
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
461 }
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
462
31
1c11478f515b disable cache
Pavel.Sher
parents: 30
diff changeset
463 @Override
86
948a35b430e1 report parent changesets
Pavel.Sher
parents: 79
diff changeset
464 public boolean ignoreServerCachesFor(@NotNull final VcsRoot root) {
31
1c11478f515b disable cache
Pavel.Sher
parents: 30
diff changeset
465 // since a copy of repository for each VCS root is already stored on disk
1c11478f515b disable cache
Pavel.Sher
parents: 30
diff changeset
466 // we do not need separate cache for our patches
1c11478f515b disable cache
Pavel.Sher
parents: 30
diff changeset
467 return true;
1c11478f515b disable cache
Pavel.Sher
parents: 30
diff changeset
468 }
1c11478f515b disable cache
Pavel.Sher
parents: 30
diff changeset
469
22
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
470 private Lock getWorkDirLock(final File workDir) {
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
471 String path = workDir.getAbsolutePath();
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
472 Lock lock = myWorkDirLocks.get(path);
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
473 if (lock == null) {
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
474 lock = new ReentrantLock();
22
0d6f27953b30 synchronization fixes
Pavel.Sher
parents: 21
diff changeset
475 Lock curLock = myWorkDirLocks.putIfAbsent(path, lock);
21
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
476 if (curLock != null) {
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
477 lock = curLock;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
478 }
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
479 }
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
480 return lock;
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
481 }
c76d6a2b27f6 proper synchronization for working directories
Pavel.Sher
parents: 20
diff changeset
482
23
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
483 private void removeOldWorkFolders() {
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
484 File workFoldersParent = myDefaultWorkFolderParent;
23
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
485 if (!workFoldersParent.isDirectory()) return;
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
486
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
487 Set<File> workDirs = new HashSet<File>();
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
488 File[] files = workFoldersParent.listFiles(new FileFilter() {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
489 public boolean accept(final File file) {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
490 return file.isDirectory() && file.getName().startsWith(Settings.DEFAULT_WORK_DIR_PREFIX);
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
491 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
492 });
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
493 if (files != null) {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
494 for (File f: files) {
46
13d5f0f56e70 compatibility with TeamCity 3.x
Pavel.Sher
parents: 44
diff changeset
495 workDirs.add(PathUtil.getCanonicalFile(f));
23
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
496 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
497 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
498
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
499 for (VcsRoot vcsRoot: myVcsManager.getAllRegisteredVcsRoots()) {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
500 if (getName().equals(vcsRoot.getVcsName())) {
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
501 try {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
502 Settings s = createSettings(vcsRoot);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
503 workDirs.remove(PathUtil.getCanonicalFile(s.getLocalRepositoryDir()));
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
504 } catch (VcsException e) {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
505 Loggers.VCS.error(e);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
506 }
23
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
507 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
508 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
509
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
510 for (File f: workDirs) {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
511 lockWorkDir(f);
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
512 try {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
513 FileUtil.delete(f);
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
514 } finally {
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
515 unlockWorkDir(f);
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
516 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
517 }
3ddf410c2fd6 minor change
Pavel.Sher
parents: 22
diff changeset
518 }
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
519
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
520 public String label(@NotNull String label, @NotNull String version, @NotNull VcsRoot root, @NotNull CheckoutRules checkoutRules) throws VcsException {
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
521 syncClonedRepository(root);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
522
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
523 Settings settings = createSettings(root);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
524
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
525 // I do not know why but hg tag does not work correctly if
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
526 // update command was not invoked for the current repo
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
527 // in such case if there were no tags before Mercurial attempts to
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
528 // create new head when tag is pushed to the parent repository
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
529 UpdateCommand uc = new UpdateCommand(settings);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
530 uc.execute();
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
531
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
532 String fixedTagname = fixTagName(label);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
533 TagCommand tc = new TagCommand(settings);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
534 tc.setRevId(new ChangeSet(version).getId());
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
535 tc.setTag(fixedTagname);
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
536 tc.execute();
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
537
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
538 PushCommand pc = new PushCommand(settings);
57
99e757f2527b branches support
Pavel.Sher
parents: 56
diff changeset
539 pc.setForce(true);
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
540 pc.execute();
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
541 return fixedTagname;
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
542 }
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
543
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
544 private String fixTagName(final String label) {
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
545 // according to Mercurial documentation http://hgbook.red-bean.com/hgbookch8.html#x12-1570008
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
546 // tag name must not contain:
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
547 // Colon (ASCII 58, “:”)
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
548 // Carriage return (ASCII 13, “\r”)
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
549 // Newline (ASCII 10, “\n”)
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
550 // all these characters will be replaced with _ (underscore)
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
551 return label.replace(':', '_').replace('\r', '_').replace('\n', '_');
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
552 }
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
553
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
554 private Settings createSettings(final VcsRoot root) throws VcsException {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
555 Settings settings = new Settings(myDefaultWorkFolderParent, root);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
556 String customClonePath = root.getProperty(Constants.SERVER_CLONE_PATH_PROP);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
557 if (!StringUtil.isEmptyOrSpaces(customClonePath) && !myDefaultWorkFolderParent.equals(new File(customClonePath).getAbsoluteFile())) {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
558 File parentDir = new File(customClonePath);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
559 createClonedRepositoryParentDir(parentDir);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
560
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
561 // take last part of repository path
67
e6971dc6b17c always use url with credentials if username/password are specified
Pavel.Sher
parents: 62
diff changeset
562 String repPath = settings.getRepositoryUrl();
62
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
563 String[] splitted = repPath.split("[/\\\\]");
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
564 if (splitted.length > 0) {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
565 repPath = splitted[splitted.length-1];
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
566 }
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
567
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
568 File customWorkingDir = new File(parentDir, repPath);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
569 settings.setWorkingDir(customWorkingDir);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
570 } else {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
571 createClonedRepositoryParentDir(myDefaultWorkFolderParent);
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
572 }
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
573 return settings;
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
574 }
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
575
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
576 private void createClonedRepositoryParentDir(final File parentDir) throws VcsException {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
577 if (!parentDir.exists() && !parentDir.mkdirs()) {
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
578 throw new VcsException("Failed to create parent directory for cloned repository: " + parentDir.getAbsolutePath());
b328c6b6526d TW-5636: Mercurial plugin can easilly hit Windows MAX_PATH limitations
Pavel.Sher
parents: 59
diff changeset
579 }
44
1490e2981799 labeling/tagging support
Pavel.Sher
parents: 31
diff changeset
580 }
48
8665bfa3e03a enable agent side checkout
Pavel.Sher
parents: 47
diff changeset
581
8665bfa3e03a enable agent side checkout
Pavel.Sher
parents: 47
diff changeset
582 public boolean isAgentSideCheckoutAvailable() {
8665bfa3e03a enable agent side checkout
Pavel.Sher
parents: 47
diff changeset
583 return true;
8665bfa3e03a enable agent side checkout
Pavel.Sher
parents: 47
diff changeset
584 }
0
a530ea876f55 mercurial support sources added
Pavel.Sher
parents:
diff changeset
585 }