1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44 package org.eclipse.jgit.pgm;
45
46 import java.util.ArrayList;
47 import java.util.List;
48
49 import org.eclipse.jgit.api.Git;
50 import org.eclipse.jgit.api.ResetCommand;
51 import org.eclipse.jgit.api.ResetCommand.ResetType;
52 import org.eclipse.jgit.api.errors.GitAPIException;
53 import org.eclipse.jgit.pgm.internal.CLIText;
54 import org.kohsuke.args4j.Argument;
55 import org.kohsuke.args4j.Option;
56 import org.kohsuke.args4j.spi.RestOfArgumentsHandler;
57
58 @Command(common = true, usage = "usage_reset")
59 class Reset extends TextBuiltin {
60
61 @Option(name = "--soft", usage = "usage_resetSoft")
62 private boolean soft = false;
63
64 @Option(name = "--mixed", usage = "usage_resetMixed")
65 private boolean mixed = false;
66
67 @Option(name = "--hard", usage = "usage_resetHard")
68 private boolean hard = false;
69
70 @Argument(required = false, index = 0, metaVar = "metaVar_commitish", usage = "usage_resetReference")
71 private String commit;
72
73 @Argument(required = false, index = 1, metaVar = "metaVar_paths")
74 @Option(name = "--", metaVar = "metaVar_paths", handler = RestOfArgumentsHandler.class)
75 private List<String> paths = new ArrayList<>();
76
77
78 @Override
79 protected void run() {
80 try (Gitit.html#Git">Git git = new Git(db)) {
81 ResetCommand command = git.reset();
82 command.setRef(commit);
83 if (paths.size() > 0) {
84 for (String path : paths) {
85 command.addPath(path);
86 }
87 } else {
88 ResetType mode = null;
89 if (soft) {
90 mode = selectMode(mode, ResetType.SOFT);
91 }
92 if (mixed) {
93 mode = selectMode(mode, ResetType.MIXED);
94 }
95 if (hard) {
96 mode = selectMode(mode, ResetType.HARD);
97 }
98 if (mode == null) {
99 throw die(CLIText.get().resetNoMode);
100 }
101 command.setMode(mode);
102 }
103 command.call();
104 } catch (GitAPIException e) {
105 throw die(e.getMessage(), e);
106 }
107 }
108
109 private static ResetType selectMode(ResetType mode, ResetType want) {
110 if (mode != null)
111 throw die("reset modes are mutually exclusive, select one");
112 return want;
113 }
114 }