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.diff;
45
46 import java.text.MessageFormat;
47
48 import org.eclipse.jgit.internal.JGitText;
49 import org.eclipse.jgit.lib.Config;
50 import org.eclipse.jgit.lib.Config.SectionParser;
51 import org.eclipse.jgit.lib.ConfigConstants;
52 import org.eclipse.jgit.util.StringUtils;
53
54
55 public class DiffConfig {
56
57 public static final Config.SectionParser<DiffConfig> KEY = DiffConfig::new;
58
59
60 public static enum RenameDetectionType {
61
62 FALSE,
63
64
65 TRUE,
66
67
68 COPY
69 }
70
71 private final boolean noPrefix;
72
73 private final RenameDetectionType renameDetectionType;
74
75 private final int renameLimit;
76
77 private DiffConfig(final Config rc) {
78 noPrefix = rc.getBoolean(ConfigConstants.CONFIG_DIFF_SECTION,
79 ConfigConstants.CONFIG_KEY_NOPREFIX, false);
80 renameDetectionType = parseRenameDetectionType(rc.getString(
81 ConfigConstants.CONFIG_DIFF_SECTION, null, ConfigConstants.CONFIG_KEY_RENAMES));
82 renameLimit = rc.getInt(ConfigConstants.CONFIG_DIFF_SECTION,
83 ConfigConstants.CONFIG_KEY_RENAMELIMIT, 200);
84 }
85
86
87 public boolean isNoPrefix() {
88 return noPrefix;
89 }
90
91
92 public boolean isRenameDetectionEnabled() {
93 return renameDetectionType != RenameDetectionType.FALSE;
94 }
95
96
97 public RenameDetectionType getRenameDetectionType() {
98 return renameDetectionType;
99 }
100
101
102 public int getRenameLimit() {
103 return renameLimit;
104 }
105
106 private static RenameDetectionType parseRenameDetectionType(
107 final String renameString) {
108 if (renameString == null)
109 return RenameDetectionType.FALSE;
110 else if (StringUtils.equalsIgnoreCase(
111 ConfigConstants.CONFIG_RENAMELIMIT_COPY, renameString)
112 || StringUtils
113 .equalsIgnoreCase(
114 ConfigConstants.CONFIG_RENAMELIMIT_COPIES,
115 renameString))
116 return RenameDetectionType.COPY;
117 else {
118 final Boolean renameBoolean = StringUtils
119 .toBooleanOrNull(renameString);
120 if (renameBoolean == null)
121 throw new IllegalArgumentException(MessageFormat.format(
122 JGitText.get().enumValueNotSupported2,
123 ConfigConstants.CONFIG_DIFF_SECTION,
124 ConfigConstants.CONFIG_KEY_RENAMES, renameString));
125 else if (renameBoolean.booleanValue())
126 return RenameDetectionType.TRUE;
127 else
128 return RenameDetectionType.FALSE;
129 }
130 }
131 }