gr.uom.java.xmi.decomposition.CompositeStatementObject Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of refactoring-miner Show documentation
Show all versions of refactoring-miner Show documentation
RefactoringMiner is a library/API written in Java that can detect refactorings applied in the history of a Java project.
package gr.uom.java.xmi.decomposition;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jdt.core.dom.Statement;
import gr.uom.java.xmi.LocationInfo;
import gr.uom.java.xmi.LocationInfo.CodeElementType;
import gr.uom.java.xmi.diff.CodeRange;
public class CompositeStatementObject extends AbstractStatement {
private List statementList;
private List expressionList;
private List variableDeclarations;
private LocationInfo locationInfo;
public CompositeStatementObject(CompilationUnit cu, String filePath, Statement statement, int depth, CodeElementType codeElementType) {
super();
this.setDepth(depth);
this.locationInfo = new LocationInfo(cu, filePath, statement, codeElementType);
this.statementList = new ArrayList();
this.expressionList = new ArrayList();
this.variableDeclarations = new ArrayList();
}
public void addStatement(AbstractStatement statement) {
statement.setIndex(statementList.size());
statementList.add(statement);
statement.setParent(this);
}
public List getStatements() {
return statementList;
}
public void addExpression(AbstractExpression expression) {
//an expression has the same index and depth as the composite statement it belong to
expression.setDepth(this.getDepth());
expression.setIndex(this.getIndex());
expressionList.add(expression);
expression.setOwner(this);
}
public List getExpressions() {
return expressionList;
}
public void addVariableDeclaration(VariableDeclaration declaration) {
this.variableDeclarations.add(declaration);
}
@Override
public List getLeaves() {
List leaves = new ArrayList();
for(AbstractStatement statement : statementList) {
leaves.addAll(statement.getLeaves());
}
return leaves;
}
public List getInnerNodes() {
List innerNodes = new ArrayList();
for(AbstractStatement statement : statementList) {
if(statement instanceof CompositeStatementObject) {
CompositeStatementObject composite = (CompositeStatementObject)statement;
innerNodes.addAll(composite.getInnerNodes());
}
}
innerNodes.add(this);
return innerNodes;
}
public boolean contains(AbstractCodeFragment fragment) {
if(fragment instanceof StatementObject) {
return getLeaves().contains(fragment);
}
else if(fragment instanceof CompositeStatementObject) {
return getInnerNodes().contains(fragment);
}
else if(fragment instanceof AbstractExpression) {
return getExpressions().contains(fragment);
}
return false;
}
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append(locationInfo.getCodeElementType().getName());
if(expressionList.size() > 0) {
sb.append("(");
for(int i=0; i getVariables() {
List variables = new ArrayList();
for(AbstractExpression expression : expressionList) {
variables.addAll(expression.getVariables());
}
return variables;
}
@Override
public List getTypes() {
List types = new ArrayList();
for(AbstractExpression expression : expressionList) {
types.addAll(expression.getTypes());
}
return types;
}
@Override
public List getVariableDeclarations() {
List variableDeclarations = new ArrayList();
//special handling for enhanced-for formal parameter
variableDeclarations.addAll(this.variableDeclarations);
for(AbstractExpression expression : expressionList) {
variableDeclarations.addAll(expression.getVariableDeclarations());
}
return variableDeclarations;
}
@Override
public Map> getMethodInvocationMap() {
Map> map = new LinkedHashMap>();
for(AbstractExpression expression : expressionList) {
Map> expressionMap = expression.getMethodInvocationMap();
for(String key : expressionMap.keySet()) {
if(map.containsKey(key)) {
map.get(key).addAll(expressionMap.get(key));
}
else {
List list = new ArrayList();
list.addAll(expressionMap.get(key));
map.put(key, list);
}
}
}
return map;
}
@Override
public List getAnonymousClassDeclarations() {
List anonymousClassDeclarations = new ArrayList();
for(AbstractExpression expression : expressionList) {
anonymousClassDeclarations.addAll(expression.getAnonymousClassDeclarations());
}
return anonymousClassDeclarations;
}
@Override
public List getStringLiterals() {
List stringLiterals = new ArrayList();
for(AbstractExpression expression : expressionList) {
stringLiterals.addAll(expression.getStringLiterals());
}
return stringLiterals;
}
@Override
public List getNumberLiterals() {
List numberLiterals = new ArrayList();
for(AbstractExpression expression : expressionList) {
numberLiterals.addAll(expression.getNumberLiterals());
}
return numberLiterals;
}
@Override
public List getNullLiterals() {
List nullLiterals = new ArrayList();
for(AbstractExpression expression : expressionList) {
nullLiterals.addAll(expression.getNullLiterals());
}
return nullLiterals;
}
@Override
public List getBooleanLiterals() {
List booleanLiterals = new ArrayList();
for(AbstractExpression expression : expressionList) {
booleanLiterals.addAll(expression.getBooleanLiterals());
}
return booleanLiterals;
}
@Override
public List getTypeLiterals() {
List typeLiterals = new ArrayList();
for(AbstractExpression expression : expressionList) {
typeLiterals.addAll(expression.getTypeLiterals());
}
return typeLiterals;
}
@Override
public List getInfixOperators() {
List infixOperators = new ArrayList();
for(AbstractExpression expression : expressionList) {
infixOperators.addAll(expression.getInfixOperators());
}
return infixOperators;
}
@Override
public List getArrayAccesses() {
List arrayAccesses = new ArrayList();
for(AbstractExpression expression : expressionList) {
arrayAccesses.addAll(expression.getArrayAccesses());
}
return arrayAccesses;
}
@Override
public List getPrefixExpressions() {
List prefixExpressions = new ArrayList();
for(AbstractExpression expression : expressionList) {
prefixExpressions.addAll(expression.getPrefixExpressions());
}
return prefixExpressions;
}
@Override
public List getPostfixExpressions() {
List postfixExpressions = new ArrayList();
for(AbstractExpression expression : expressionList) {
postfixExpressions.addAll(expression.getPostfixExpressions());
}
return postfixExpressions;
}
@Override
public List getArguments() {
List arguments = new ArrayList();
for(AbstractExpression expression : expressionList) {
arguments.addAll(expression.getArguments());
}
return arguments;
}
@Override
public List getTernaryOperatorExpressions() {
List ternaryOperatorExpressions = new ArrayList();
for(AbstractExpression expression : expressionList) {
ternaryOperatorExpressions.addAll(expression.getTernaryOperatorExpressions());
}
return ternaryOperatorExpressions;
}
@Override
public List getLambdas() {
List lambdas = new ArrayList();
for(AbstractExpression expression : expressionList) {
lambdas.addAll(expression.getLambdas());
}
return lambdas;
}
@Override
public Map> getCreationMap() {
Map> map = new LinkedHashMap>();
for(AbstractExpression expression : expressionList) {
Map> expressionMap = expression.getCreationMap();
for(String key : expressionMap.keySet()) {
if(map.containsKey(key)) {
map.get(key).addAll(expressionMap.get(key));
}
else {
List list = new ArrayList();
list.addAll(expressionMap.get(key));
map.put(key, list);
}
}
}
return map;
}
public Map> getAllMethodInvocations() {
Map> map = new LinkedHashMap>();
map.putAll(getMethodInvocationMap());
for(AbstractStatement statement : statementList) {
if(statement instanceof CompositeStatementObject) {
CompositeStatementObject composite = (CompositeStatementObject)statement;
Map> compositeMap = composite.getAllMethodInvocations();
for(String key : compositeMap.keySet()) {
if(map.containsKey(key)) {
map.get(key).addAll(compositeMap.get(key));
}
else {
List list = new ArrayList();
list.addAll(compositeMap.get(key));
map.put(key, list);
}
}
}
else if(statement instanceof StatementObject) {
StatementObject statementObject = (StatementObject)statement;
Map> statementMap = statementObject.getMethodInvocationMap();
for(String key : statementMap.keySet()) {
if(map.containsKey(key)) {
map.get(key).addAll(statementMap.get(key));
}
else {
List list = new ArrayList();
list.addAll(statementMap.get(key));
map.put(key, list);
}
}
for(LambdaExpressionObject lambda : statementObject.getLambdas()) {
if(lambda.getBody() != null) {
Map> lambdaMap = lambda.getBody().getCompositeStatement().getAllMethodInvocations();
for(String key : lambdaMap.keySet()) {
if(map.containsKey(key)) {
map.get(key).addAll(lambdaMap.get(key));
}
else {
List list = new ArrayList();
list.addAll(lambdaMap.get(key));
map.put(key, list);
}
}
}
}
}
}
return map;
}
public List getAllAnonymousClassDeclarations() {
List anonymousClassDeclarations = new ArrayList();
anonymousClassDeclarations.addAll(getAnonymousClassDeclarations());
for(AbstractStatement statement : statementList) {
if(statement instanceof CompositeStatementObject) {
CompositeStatementObject composite = (CompositeStatementObject)statement;
anonymousClassDeclarations.addAll(composite.getAllAnonymousClassDeclarations());
}
else if(statement instanceof StatementObject) {
StatementObject statementObject = (StatementObject)statement;
anonymousClassDeclarations.addAll(statementObject.getAnonymousClassDeclarations());
}
}
return anonymousClassDeclarations;
}
public List getAllLambdas() {
List lambdas = new ArrayList();
lambdas.addAll(getLambdas());
for(AbstractStatement statement : statementList) {
if(statement instanceof CompositeStatementObject) {
CompositeStatementObject composite = (CompositeStatementObject)statement;
lambdas.addAll(composite.getAllLambdas());
}
else if(statement instanceof StatementObject) {
StatementObject statementObject = (StatementObject)statement;
lambdas.addAll(statementObject.getLambdas());
}
}
return lambdas;
}
public List getAllVariables() {
List variables = new ArrayList();
variables.addAll(getVariables());
for(AbstractStatement statement : statementList) {
if(statement instanceof CompositeStatementObject) {
CompositeStatementObject composite = (CompositeStatementObject)statement;
variables.addAll(composite.getAllVariables());
}
else if(statement instanceof StatementObject) {
StatementObject statementObject = (StatementObject)statement;
variables.addAll(statementObject.getVariables());
}
}
return variables;
}
public List getAllVariableDeclarations() {
List variableDeclarations = new ArrayList();
variableDeclarations.addAll(getVariableDeclarations());
for(AbstractStatement statement : statementList) {
if(statement instanceof CompositeStatementObject) {
CompositeStatementObject composite = (CompositeStatementObject)statement;
variableDeclarations.addAll(composite.getAllVariableDeclarations());
}
else if(statement instanceof StatementObject) {
StatementObject statementObject = (StatementObject)statement;
variableDeclarations.addAll(statementObject.getVariableDeclarations());
for(LambdaExpressionObject lambda : statementObject.getLambdas()) {
if(lambda.getBody() != null) {
variableDeclarations.addAll(lambda.getBody().getAllVariableDeclarations());
}
}
}
}
return variableDeclarations;
}
public List getVariableDeclarationsInScope(LocationInfo location) {
List variableDeclarations = new ArrayList();
for(VariableDeclaration variableDeclaration : getAllVariableDeclarations()) {
if(variableDeclaration.getScope().subsumes(location)) {
variableDeclarations.add(variableDeclaration);
}
}
return variableDeclarations;
}
@Override
public int statementCount() {
int count = 0;
if(!this.getString().equals("{"))
count++;
for(AbstractStatement statement : statementList) {
count += statement.statementCount();
}
return count;
}
public LocationInfo getLocationInfo() {
return locationInfo;
}
public VariableDeclaration getVariableDeclaration(String variableName) {
List variableDeclarations = getAllVariableDeclarations();
for(VariableDeclaration declaration : variableDeclarations) {
if(declaration.getVariableName().equals(variableName)) {
return declaration;
}
}
return null;
}
public Map> aliasedAttributes() {
Map> map = new LinkedHashMap>();
for(StatementObject statement : getLeaves()) {
String s = statement.getString();
if(s.startsWith("this.") && s.endsWith(";\n")) {
String firstLine = s.substring(0, s.indexOf("\n"));
if(firstLine.contains("=")) {
String attribute = s.substring(5, s.indexOf("="));
String value = s.substring(s.indexOf("=")+1, s.indexOf(";\n"));
if(map.containsKey(value)) {
map.get(value).add(attribute);
}
else {
Set set = new LinkedHashSet();
set.add(attribute);
map.put(value, set);
}
}
}
}
Set keysToBeRemoved = new LinkedHashSet();
for(String key : map.keySet()) {
if(map.get(key).size() <= 1) {
keysToBeRemoved.add(key);
}
}
for(String key : keysToBeRemoved) {
map.remove(key);
}
return map;
}
public CodeRange codeRange() {
return locationInfo.codeRange();
}
public boolean isLoop() {
return this.locationInfo.getCodeElementType().equals(CodeElementType.ENHANCED_FOR_STATEMENT) ||
this.locationInfo.getCodeElementType().equals(CodeElementType.FOR_STATEMENT) ||
this.locationInfo.getCodeElementType().equals(CodeElementType.WHILE_STATEMENT) ||
this.locationInfo.getCodeElementType().equals(CodeElementType.DO_STATEMENT);
}
public CompositeStatementObject loopWithVariables(String currentElementName, String collectionName) {
for(CompositeStatementObject innerNode : getInnerNodes()) {
if(innerNode.getLocationInfo().getCodeElementType().equals(CodeElementType.ENHANCED_FOR_STATEMENT)) {
boolean currentElementNameMatched = false;
for(VariableDeclaration declaration : innerNode.getVariableDeclarations()) {
if(declaration.getVariableName().equals(currentElementName)) {
currentElementNameMatched = true;
break;
}
}
boolean collectionNameMatched = false;
for(AbstractExpression expression : innerNode.getExpressions()) {
if(expression.getVariables().contains(collectionName)) {
collectionNameMatched = true;
break;
}
}
if(currentElementNameMatched && collectionNameMatched) {
return innerNode;
}
}
else if(innerNode.getLocationInfo().getCodeElementType().equals(CodeElementType.FOR_STATEMENT) ||
innerNode.getLocationInfo().getCodeElementType().equals(CodeElementType.WHILE_STATEMENT)) {
boolean collectionNameMatched = false;
for(AbstractExpression expression : innerNode.getExpressions()) {
if(expression.getVariables().contains(collectionName)) {
collectionNameMatched = true;
break;
}
}
boolean currentElementNameMatched = false;
for(StatementObject statement : innerNode.getLeaves()) {
VariableDeclaration variableDeclaration = statement.getVariableDeclaration(currentElementName);
if(variableDeclaration != null && statement.getVariables().contains(collectionName)) {
currentElementNameMatched = true;
break;
}
}
if(currentElementNameMatched && collectionNameMatched) {
return innerNode;
}
}
}
return null;
}
}