1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 package com.puppycrawl.tools.checkstyle;
21
22 import java.util.Locale;
23
24 import com.puppycrawl.tools.checkstyle.api.AuditEvent;
25 import com.puppycrawl.tools.checkstyle.api.SeverityLevel;
26
27
28
29
30
31
32
33
34 public class AuditEventDefaultFormatter implements AuditEventFormatter {
35
36
37 private static final int LENGTH_OF_ALL_SEPARATORS = 10;
38
39
40 private static final String SUFFIX = "Check";
41
42 @Override
43 public String format(AuditEvent event) {
44 final String fileName = event.getFileName();
45 final String message = event.getMessage();
46
47 final SeverityLevel severityLevel = event.getSeverityLevel();
48 final String severityLevelName;
49 if (severityLevel == SeverityLevel.WARNING) {
50
51
52 severityLevelName = "WARN";
53 }
54 else {
55 severityLevelName = severityLevel.getName().toUpperCase(Locale.US);
56 }
57
58
59 final int bufLen = calculateBufferLength(event, severityLevelName.length());
60 final StringBuilder sb = new StringBuilder(bufLen);
61
62 sb.append('[').append(severityLevelName).append("] ")
63 .append(fileName).append(':').append(event.getLine());
64 if (event.getColumn() > 0) {
65 sb.append(':').append(event.getColumn());
66 }
67 sb.append(": ").append(message).append(" [");
68 if (event.getModuleId() == null) {
69 final String checkShortName = getCheckShortName(event);
70 sb.append(checkShortName);
71 }
72 else {
73 sb.append(event.getModuleId());
74 }
75 sb.append(']');
76
77 return sb.toString();
78 }
79
80
81
82
83
84
85
86
87
88 private static int calculateBufferLength(AuditEvent event, int severityLevelNameLength) {
89 return LENGTH_OF_ALL_SEPARATORS + event.getFileName().length()
90 + event.getMessage().length() + severityLevelNameLength
91 + getCheckShortName(event).length();
92 }
93
94
95
96
97
98
99 private static String getCheckShortName(AuditEvent event) {
100 final String checkFullName = event.getSourceName();
101 final String checkShortName;
102 final int lastDotIndex = checkFullName.lastIndexOf('.');
103 if (lastDotIndex == -1) {
104 if (checkFullName.endsWith(SUFFIX)) {
105 checkShortName = checkFullName.substring(0, checkFullName.lastIndexOf(SUFFIX));
106 }
107 else {
108 checkShortName = checkFullName;
109 }
110 }
111 else {
112 if (checkFullName.endsWith(SUFFIX)) {
113 checkShortName = checkFullName.substring(lastDotIndex + 1,
114 checkFullName.lastIndexOf(SUFFIX));
115 }
116 else {
117 checkShortName = checkFullName.substring(lastDotIndex + 1);
118 }
119 }
120 return checkShortName;
121 }
122
123 }