com.cflint.plugins.core.CreateObjectChecker Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of CFLint Show documentation
Show all versions of CFLint Show documentation
A static code analysis tool for ColdFusion (in the spirit of FindBugs and Lint). With CFLint, you are able to analyze your ColdFusion code base for code violations.
package com.cflint.plugins.core;
import com.cflint.BugInfo;
import com.cflint.BugList;
import com.cflint.plugins.CFLintScannerAdapter;
import com.cflint.plugins.Context;
import cfml.parsing.cfscript.script.CFExpressionStatement;
import cfml.parsing.cfscript.script.CFScriptStatement;
import ro.fortsoft.pf4j.Extension;
@Extension
public class CreateObjectChecker extends CFLintScannerAdapter {
final String severity = "INFO";
@Override
public void expression(final CFScriptStatement expression, final Context context, final BugList bugs) {
if (expression instanceof CFExpressionStatement) {
final String code = ((CFExpressionStatement) expression).getExpression().Decompile(0);
final int lineNo = ((CFExpressionStatement) expression).getLine() + context.startLine() - 1;
if (code.toLowerCase().contains("createobject('component'")) {
noNeedtoUseCreateObject(lineNo, context, bugs);
}
}
}
protected void noNeedtoUseCreateObject(final int lineNo, final Context context, final BugList bugs) {
bugs.add(new BugInfo.BugInfoBuilder().setLine(lineNo).setMessageCode("AVOID_USING_CREATEOBJECT")
.setSeverity(severity).setFilename(context.getFilename()).setMessage("CreateObject statement at line "
+ lineNo + ". Use createObject(path_to_component) or even better new path_to_component().")
.build());
}
}