All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.liferay.source.formatter.checks.JavaStaticBlockCheck Maven / Gradle / Ivy
/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*/
package com.liferay.source.formatter.checks;
import com.liferay.petra.string.StringPool;
import com.liferay.portal.kernel.util.StringUtil;
import com.liferay.source.formatter.parser.JavaClass;
import com.liferay.source.formatter.parser.JavaTerm;
import com.liferay.source.formatter.parser.JavaVariable;
import java.util.List;
/**
* @author Hugo Huijser
*/
public class JavaStaticBlockCheck extends BaseJavaTermCheck {
@Override
protected String doProcess(
String fileName, String absolutePath, JavaTerm javaTerm,
String fileContent) {
JavaClass javaClass = (JavaClass)javaTerm;
String classContent = javaClass.getContent();
List childJavaTerms = javaClass.getChildJavaTerms();
if (!isExcludedPath(JAVATERM_SORT_EXCLUDES, absolutePath)) {
classContent = _sortStaticBlocks(classContent, childJavaTerms);
}
return _combineStaticBlocks(classContent, childJavaTerms);
}
@Override
protected String[] getCheckableJavaTermNames() {
return new String[] {JAVA_CLASS};
}
private String _combineStaticBlocks(
String classContent, List childJavaTerms) {
if (childJavaTerms.size() <= 1) {
return classContent;
}
JavaTerm previousJavaTerm = null;
for (JavaTerm javaTerm : childJavaTerms) {
if (previousJavaTerm == null) {
previousJavaTerm = javaTerm;
continue;
}
if (previousJavaTerm.isJavaStaticBlock() &&
javaTerm.isJavaStaticBlock()) {
classContent = StringUtil.replaceFirst(
classContent, javaTerm.getContent(), StringPool.BLANK);
return StringUtil.replaceFirst(
classContent, previousJavaTerm.getContent(),
_getCombinedStaticBlocks(
previousJavaTerm.getContent(), javaTerm.getContent()));
}
previousJavaTerm = javaTerm;
}
return classContent;
}
private String _getCombinedStaticBlocks(
String staticBlockContent1, String staticBlockContent2) {
int x = staticBlockContent1.lastIndexOf(StringPool.CLOSE_CURLY_BRACE);
x = staticBlockContent1.lastIndexOf(StringPool.NEW_LINE, x - 1);
int y = staticBlockContent2.indexOf(StringPool.OPEN_CURLY_BRACE) + 1;
return staticBlockContent1.substring(0, x + 1) +
staticBlockContent2.substring(y);
}
private JavaTerm _getLastJavaTerm(
Class> clazz, String accessModifier, boolean isStatic,
List childJavaTerms) {
for (int i = childJavaTerms.size() - 1; i >= 0; i--) {
JavaTerm javaTerm = childJavaTerms.get(i);
String javaTermAccessModifier = javaTerm.getAccessModifier();
if ((javaTerm.getClass() == clazz) &&
javaTermAccessModifier.equals(accessModifier) &&
(javaTerm.isStatic() == isStatic)) {
return javaTerm;
}
}
return null;
}
private JavaTerm _getLastReferencedJavaTerm(
String staticBlockContent, List childJavaTerms) {
boolean containsMethodCall = false;
for (JavaTerm javaTerm : childJavaTerms) {
if (javaTerm.isStatic() && javaTerm.isJavaMethod() &&
staticBlockContent.matches(
"[\\s\\S]*\\s" + javaTerm.getName() + "\\([\\s\\S]*")) {
containsMethodCall = true;
break;
}
}
for (int i = childJavaTerms.size() - 1; i >= 0; i--) {
JavaTerm javaTerm = childJavaTerms.get(i);
if (!javaTerm.isStatic() ||
!staticBlockContent.matches(
"[\\s\\S]*\\W" + javaTerm.getName() + "\\W[\\s\\S]*")) {
continue;
}
if (javaTerm.isJavaClass() ||
(javaTerm.isJavaVariable() && !containsMethodCall)) {
return javaTerm;
}
}
return null;
}
private String _sortStaticBlocks(
String classContent, List childJavaTerms) {
for (JavaTerm childJavaTerm : childJavaTerms) {
if (!childJavaTerm.isJavaStaticBlock()) {
continue;
}
String staticBlockContent = childJavaTerm.getContent();
JavaTerm lastReferencedJavaTerm = _getLastReferencedJavaTerm(
staticBlockContent, childJavaTerms);
JavaTerm lastJavaTerm = null;
if (lastReferencedJavaTerm == null) {
lastJavaTerm = _getLastJavaTerm(
JavaVariable.class, JavaTerm.ACCESS_MODIFIER_PRIVATE, true,
childJavaTerms);
}
else {
lastJavaTerm = _getLastJavaTerm(
lastReferencedJavaTerm.getClass(),
lastReferencedJavaTerm.getAccessModifier(),
lastReferencedJavaTerm.isStatic(), childJavaTerms);
}
if (lastJavaTerm == null) {
return classContent;
}
String lastJavaTermContent = lastJavaTerm.getContent();
if (classContent.contains(
lastJavaTermContent + "\n" + staticBlockContent)) {
continue;
}
classContent = StringUtil.removeSubstring(
classContent, staticBlockContent + "\n");
classContent = StringUtil.replace(
classContent, lastJavaTermContent,
lastJavaTermContent + "\n" + staticBlockContent);
break;
}
return classContent;
}
}