Conform to our own Checkstyle rules in checkstyle-logging utility
[yangtools.git] / common / checkstyle-logging / src / main / java / org / opendaylight / yangtools / checkstyle / LoggerVariableModifiersCheck.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 LoggerVariableModifiersCheck extends Check {
16
17     private static final String LOG_MESSAGE = "Logger must be declared as private static final.";
18
19     @Override
20     public int[] getDefaultTokens() {
21         return new int[]{TokenTypes.VARIABLE_DEF};
22     }
23
24     @Override
25     public void visitToken(DetailAST ast) {
26         if (CheckLoggingUtil.isAFieldVariable(ast) && CheckLoggingUtil.isLoggerType(ast)
27                 && !hasPrivatStaticFinalModifier(ast)) {
28             log(ast.getLineNo(), LOG_MESSAGE);
29         }
30     }
31
32     private boolean hasPrivatStaticFinalModifier(DetailAST ast) {
33         DetailAST modifiers = ast.findFirstToken(TokenTypes.MODIFIERS);
34         if (modifiers != null && modifiers.branchContains(TokenTypes.LITERAL_PRIVATE)
35                 && modifiers.branchContains(TokenTypes.LITERAL_STATIC) && modifiers.branchContains(TokenTypes.FINAL)) {
36             return true;
37         }
38         return false;
39     }
40
41 }