annotate mercurial-common/src/jetbrains/buildServer/buildTriggers/vcs/mercurial/command/ChangedFilesCommand.java @ 160:5198b02fc5e9

Update copyrights
author Dmitry Neverov <dmitry.neverov@jetbrains.com>
date Fri, 21 Jan 2011 09:54:10 +0300
parents 6c1cff1f61cc
children d314f06e6ee3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
95
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
1 /*
160
5198b02fc5e9 Update copyrights
Dmitry Neverov <dmitry.neverov@jetbrains.com>
parents: 95
diff changeset
2 * Copyright 2000-2011 JetBrains s.r.o.
95
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
3 *
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
4 * Licensed under the Apache License, Version 2.0 (the "License");
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
5 * you may not use this file except in compliance with the License.
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
6 * You may obtain a copy of the License at
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
7 *
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
8 * http://www.apache.org/licenses/LICENSE-2.0
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
9 *
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
10 * Unless required by applicable law or agreed to in writing, software
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
11 * distributed under the License is distributed on an "AS IS" BASIS,
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
13 * See the License for the specific language governing permissions and
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
14 * limitations under the License.
6c1cff1f61cc copyright =>2010
Pavel.Sher
parents: 90
diff changeset
15 */
90
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
16 package jetbrains.buildServer.buildTriggers.vcs.mercurial.command;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
17
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
18 import com.intellij.execution.configurations.GeneralCommandLine;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
19 import jetbrains.buildServer.ExecResult;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
20 import jetbrains.buildServer.util.FileUtil;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
21 import jetbrains.buildServer.vcs.VcsException;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
22 import org.jetbrains.annotations.NotNull;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
23
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
24 import java.io.File;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
25 import java.io.IOException;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
26 import java.util.List;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
27
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
28 /**
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
29 * @author Pavel.Sher
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
30 */
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
31 public class ChangedFilesCommand extends BaseCommand {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
32 private String myRevId;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
33
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
34 public ChangedFilesCommand(@NotNull final Settings settings) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
35 super(settings);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
36 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
37
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
38 public void setRevId(@NotNull final String revId) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
39 myRevId = revId;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
40 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
41
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
42 public List<ModifiedFile> execute() throws VcsException {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
43 File styleFile;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
44 try {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
45 styleFile = getStyleFile();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
46 } catch (IOException e) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
47 throw new VcsException("Unable to create style file: " + e.toString(), e);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
48 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
49 try {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
50 GeneralCommandLine cli = createCommandLine();
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
51 cli.addParameter("log");
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
52 cli.addParameter("-r");
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
53 cli.addParameter(myRevId + ":" + myRevId);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
54 cli.addParameter("--style=" + styleFile.getAbsolutePath());
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
55
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
56 ExecResult res = runCommand(cli);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
57 return parseFiles(res.getStdout());
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
58 } finally {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
59 FileUtil.delete(styleFile);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
60 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
61 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
62
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
63 private File getStyleFile() throws IOException {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
64 File styleFile = FileUtil.createTempFile("hg", "style");
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
65 FileUtil.writeFile(styleFile,
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
66 "changeset = \"{file_mods}{file_adds}{file_dels}\"\n" +
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
67 "file_add = \"A {file_add}\\n\"\n" +
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
68 "file_del = \"R {file_del}\\n\"\n" +
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
69 "file_mod = \"M {file_mod}\\n\"");
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
70 return styleFile;
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
71 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
72
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
73 private List<ModifiedFile> parseFiles(final String stdout) {
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
74 return StatusCommand.parseFiles(stdout);
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
75 }
5d9c34cb543a improving merge commits reporting
Pavel.Sher
parents:
diff changeset
76 }