Conform to our own Checkstyle rules in checkstyle-logging utility
[yangtools.git] / common / checkstyle-logging / src / main / java / org / opendaylight / yangtools / checkstyle / LogMessageConcatenationCheck.java
1 /*
2  * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.yangtools.checkstyle;
10
11 import com.puppycrawl.tools.checkstyle.api.Check;
12 import com.puppycrawl.tools.checkstyle.api.DetailAST;
13 import com.puppycrawl.tools.checkstyle.api.TokenTypes;
14
15 public class LogMessageConcatenationCheck extends Check {
16
17     private static final String LOG_MESSAGE = "Log message contains string concatenation.";
18
19     @Override
20     public int[] getDefaultTokens() {
21         return new int[]{TokenTypes.METHOD_CALL};
22     }
23
24     @Override
25     public void visitToken(DetailAST ast) {
26         final String methodName = CheckLoggingUtil.getMethodName(ast);
27         if (CheckLoggingUtil.isLogMethod(methodName)) {
28             DetailAST plus = ast.findFirstToken(TokenTypes.ELIST).getFirstChild().findFirstToken(TokenTypes.PLUS);
29             if (plus != null) {
30                 while (plus.getChildCount(TokenTypes.PLUS) != 0) {
31                     plus = plus.findFirstToken(TokenTypes.PLUS);
32                 }
33                 if (plus.getChildCount(TokenTypes.STRING_LITERAL) != 2) {
34                     log(ast.getLineNo(), LOG_MESSAGE);
35                 }
36             }
37         }
38     }
39 }