All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.refactoringminer.util.AstUtils Maven / Gradle / Ivy

Go to download

RefactoringMiner is a library/API written in Java that can detect refactorings applied in the history of a Java project.

There is a newer version: 3.0.9
Show newest version
package org.refactoringminer.util;

import java.util.Iterator;
import java.util.List;

import org.eclipse.jdt.core.dom.ASTNode;
import org.eclipse.jdt.core.dom.ASTVisitor;
import org.eclipse.jdt.core.dom.Block;
import org.eclipse.jdt.core.dom.IMethodBinding;
import org.eclipse.jdt.core.dom.ITypeBinding;
import org.eclipse.jdt.core.dom.IVariableBinding;
import org.eclipse.jdt.core.dom.Javadoc;
import org.eclipse.jdt.core.dom.MethodDeclaration;
import org.eclipse.jdt.core.dom.SingleVariableDeclaration;
import org.eclipse.jdt.core.dom.Statement;
import org.eclipse.jdt.core.dom.TagElement;
import org.eclipse.jdt.core.dom.Type;

public class AstUtils {

	private AstUtils() {
		//
	}
	
	public static String getKeyFromTypeBinding(ITypeBinding binding) {
	    return binding.getErasure().getQualifiedName();
	}
	
	public static String getKeyFromMethodBinding(IMethodBinding binding) {
		StringBuilder sb = new StringBuilder();
		String className = binding.getDeclaringClass().getErasure().getQualifiedName();
		sb.append(className);
		sb.append('#');
		String methodName = binding.isConstructor() ? "" : binding.getName();
		sb.append(methodName);
		//if (methodName.equals("allObjectsSorted")) {
		//	System.out.println();
		//}
		sb.append('(');
		ITypeBinding[] parameters = binding.getParameterTypes();
		for (int i = 0; i < parameters.length; i++) {
			if (i > 0) {
				sb.append(", ");
			}
			ITypeBinding type = parameters[i];
			sb.append(type.getErasure().getName());
		}
		sb.append(')');
		return sb.toString();
	}

	public static String getKeyFromFieldBinding(IVariableBinding binding) {
	    StringBuilder sb = new StringBuilder();
	    String className = binding.getDeclaringClass().getErasure().getQualifiedName();
	    sb.append(className);
	    sb.append('#');
	    sb.append(binding.getName());
	    return sb.toString();
	}
	
	public static String getSignatureFromMethodDeclaration(MethodDeclaration methodDeclaration) {
		String methodName = methodDeclaration.isConstructor() ? "" : methodDeclaration.getName().getIdentifier();
//		if (methodName.equals("allObjectsSorted")) {
//			System.out.println();
//		}
		StringBuilder sb = new StringBuilder();
		sb.append(methodName);
		sb.append('(');
		Iterator parameters = methodDeclaration.parameters().iterator();
		while (parameters.hasNext()) {
			SingleVariableDeclaration parameter = parameters.next();
			Type parameterType = parameter.getType();
			String typeName = normalizeTypeName(parameterType, parameter.getExtraDimensions(), parameter.isVarargs());
			sb.append(typeName);
			if (parameters.hasNext()) {
				sb.append(", ");
			}
		}
		sb.append(')');
		String methodSignature = sb.toString();
		return methodSignature;
	}
	
	public static String normalizeTypeName(Type type, int extraDimensions, boolean varargs) {
	    StringBuilder sb = new StringBuilder();
//	    String rawTypeName = stripQualifiedTypeName(stripTypeParamsFromTypeName(type.toString()));
	    String rawTypeName = stripTypeParamsFromTypeName(type.toString());
        sb.append(rawTypeName);
        for (int i = extraDimensions; i > 0; i--) {
            sb.append("[]");
        }
        if (varargs) {
            sb.append("[]");
        }
        return sb.toString();
	}
	
	public static String stripTypeParamsFromTypeName(String typeNameWithGenerics) {
		String rawTypeName = typeNameWithGenerics;
		int startOfTypeParams = typeNameWithGenerics.indexOf('<');
		if (startOfTypeParams >= 0) {
			rawTypeName = typeNameWithGenerics.substring(0, startOfTypeParams);
			int endOfTypeParams = typeNameWithGenerics.lastIndexOf('>');
			if (endOfTypeParams > startOfTypeParams && endOfTypeParams < typeNameWithGenerics.length() - 1) {
				rawTypeName = rawTypeName + typeNameWithGenerics.substring(endOfTypeParams + 1);
			}
		}
		return rawTypeName;
	}
	
	public static String stripTypeArguments(String entity) {
        StringBuilder sb = new StringBuilder();
        int openGenerics = 0;
        for (int i = 0; i < entity.length(); i++) {
            char c = entity.charAt(i);
            if (c == '<') {
                openGenerics++;
            }
            if (openGenerics == 0) {
                sb.append(c);
            }
            if (c == '>') {
                openGenerics--;
            }
        }
        return sb.toString();
    }
	
	public static String stripQualifiedTypeName(String qualifiedTypeName) {
		int dotPos = qualifiedTypeName.lastIndexOf('.');
		if (dotPos >= 0) {
			return qualifiedTypeName.substring(dotPos + 1);
		}
		return qualifiedTypeName;
	}

    public static String normalizeMethodSignature(String methodSignature) {
        StringBuilder sb = new StringBuilder();
        int start = 0;
        int openPar = methodSignature.indexOf('(');
        int closePar = methodSignature.lastIndexOf(')');
        if (openPar == -1 || closePar == -1) {
            throw new IllegalArgumentException("Invalid method signature: " + methodSignature);
        }
        int lastSpace = methodSignature.lastIndexOf(' ', openPar);
        if (lastSpace != -1) {
            start = lastSpace + 1;
        }
        sb.append(methodSignature, start, openPar);
        sb.append('(');
        
        String[] parameters;
        String parametersStr = stripTypeArguments(methodSignature.substring(openPar + 1, closePar));
        if (parametersStr.length() > 0) {
            parameters = parametersStr.split(" *, *");
        } else {
            parameters = new String[0];
        }
        for (int i = 0; i < parameters.length; i++) {
            String parameter = parameters[i];
            int space = parameter.lastIndexOf(' ');
            if (space == -1) {
                sb.append(parameter);
            } else {
                sb.append(parameter.substring(space + 1));
            }
            if (i < parameters.length - 1) {
                sb.append(',');
            }
        }
        sb.append(')');
        return sb.toString();
    }
    
    public static String normalizeAttribute(String attributeDescription) {
        int idx = attributeDescription.indexOf(':');
        if (idx == -1) {
            return attributeDescription.trim();
        } else {
            int start = attributeDescription.indexOf(' ');
            if (start == -1) {
                return attributeDescription.substring(0, idx).trim();
            } else {
                return attributeDescription.substring(start, idx).trim();
            }
        }
    }

	public static boolean containsDeprecatedTag(Javadoc javadoc) {
		if (javadoc == null) {
			return false;
		}
		List javadocTags = (List) javadoc.tags();
		for (TagElement tag : javadocTags) {
			if ("@deprecated".equals(tag.getTagName())) {
				return true;
			}
		}
		return false;
	}

	public static int countNumberOfStatements(MethodDeclaration decl) {
		return new StatementCounter().countStatements(decl);
	}
	
	private static class StatementCounter extends ASTVisitor {
		private int counter;
		public int countStatements(MethodDeclaration methodDeclaration) {
			counter = 0;
			methodDeclaration.accept(this);
			return counter;
		}
		@Override
		public void preVisit(ASTNode node) {
			if (node instanceof Statement && !(node instanceof Block)) {
				counter++;
			}
		}
	}
	
	public static Statement getEnclosingStatement(ASTNode node) {
	    do {
	        if (node instanceof Statement) {
	            return (Statement) node;
	        } else {
	            node = node.getParent();
	        }
	    } while (node != null);
	    return null;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy