1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 package org.apache.maven.scm.provider.hg.command;
20
21 import java.util.ArrayList;
22 import java.util.HashMap;
23 import java.util.Iterator;
24 import java.util.List;
25 import java.util.Map;
26
27 import org.apache.maven.scm.ScmFileStatus;
28 import org.apache.maven.scm.util.AbstractConsumer;
29
30
31
32
33
34
35
36
37
38 public class HgConsumer extends AbstractConsumer {
39
40
41
42
43 private static final Map<String, ScmFileStatus> IDENTIFIERS = new HashMap<>();
44
45
46
47
48 private static final Map<String, String> MESSAGES = new HashMap<>();
49
50
51
52
53
54
55 private static final int MAX_STDERR_SIZE = 10;
56
57
58
59
60 private final List<String> stderr = new ArrayList<>();
61
62 static {
63
64
65 IDENTIFIERS.put("adding", ScmFileStatus.ADDED);
66 IDENTIFIERS.put("unknown", ScmFileStatus.UNKNOWN);
67 IDENTIFIERS.put("modified", ScmFileStatus.MODIFIED);
68 IDENTIFIERS.put("removed", ScmFileStatus.DELETED);
69 IDENTIFIERS.put("renamed", ScmFileStatus.MODIFIED);
70
71
72
73 IDENTIFIERS.put("A", ScmFileStatus.ADDED);
74 IDENTIFIERS.put("?", ScmFileStatus.UNKNOWN);
75 IDENTIFIERS.put("M", ScmFileStatus.MODIFIED);
76 IDENTIFIERS.put("R", ScmFileStatus.DELETED);
77 IDENTIFIERS.put("C", ScmFileStatus.CHECKED_IN);
78 IDENTIFIERS.put("!", ScmFileStatus.MISSING);
79 IDENTIFIERS.put("I", ScmFileStatus.UNKNOWN);
80
81 MESSAGES.put("hg: WARNING:", "WARNING");
82 MESSAGES.put("hg: ERROR:", "ERROR");
83 MESSAGES.put("'hg' ", "ERROR");
84 }
85
86 public void doConsume(ScmFileStatus status, String trimmedLine) {
87
88 }
89
90
91
92
93 public void consumeLine(String line) {
94 if (logger.isDebugEnabled()) {
95 logger.debug(line);
96 }
97 String trimmedLine = line.trim();
98
99 String statusStr = processInputForKnownIdentifiers(trimmedLine);
100
101
102 if (statusStr == null) {
103 boolean isMessage = processInputForKnownMessages(trimmedLine);
104
105 if (isMessage) {
106 return;
107 }
108 } else {
109
110 trimmedLine = trimmedLine.substring(statusStr.length());
111 trimmedLine = trimmedLine.trim();
112 }
113
114 ScmFileStatus status = statusStr != null ? (IDENTIFIERS.get(statusStr.intern())) : null;
115 doConsume(status, trimmedLine);
116 }
117
118
119
120
121
122
123
124 public String getStdErr() {
125 StringBuilder str = new StringBuilder();
126 for (Iterator<String> it = stderr.iterator(); it.hasNext(); ) {
127 str.append(it.next());
128 }
129 return str.toString();
130 }
131
132 private static String processInputForKnownIdentifiers(String line) {
133 for (Iterator<String> it = IDENTIFIERS.keySet().iterator(); it.hasNext(); ) {
134 String id = it.next();
135 if (line.startsWith(id)) {
136 return id;
137 }
138 }
139 return null;
140 }
141
142 private boolean processInputForKnownMessages(String line) {
143 for (Iterator<String> it = MESSAGES.keySet().iterator(); it.hasNext(); ) {
144 String prefix = it.next();
145 if (line.startsWith(prefix)) {
146 stderr.add(line);
147 if (stderr.size() > MAX_STDERR_SIZE) {
148 stderr.remove(0);
149 }
150 String message = line.substring(prefix.length());
151 if (MESSAGES.get(prefix).equals("WARNING")) {
152 if (logger.isWarnEnabled()) {
153 logger.warn(message);
154 }
155 } else {
156 if (logger.isErrorEnabled()) {
157 logger.error(message);
158 }
159 }
160 return true;
161 }
162 }
163 return false;
164 }
165 }