Browse Source

合法性检查

9.0
richie 5 years ago
parent
commit
018d1c7fed
  1. 11
      src/main/java/com/fr/solution/plugin/design/formula/ui/type/BaseFormulaPane.java
  2. 16
      src/main/java/com/fr/solution/plugin/design/formula/ui/type/impl/BasicFormulaPane.java
  3. 41
      src/main/java/com/fr/solution/plugin/design/formula/ui/type/impl/ScriptFormulaPane.java

11
src/main/java/com/fr/solution/plugin/design/formula/ui/type/BaseFormulaPane.java

@ -308,20 +308,15 @@ public abstract class BaseFormulaPane<T extends BaseFormula> extends FurtherBasi
// Execute Formula default cell element. // Execute Formula default cell element.
String formulaText = formulaTextArea.getText().trim(); String formulaText = formulaTextArea.getText().trim();
if (StringUtils.isNotEmpty(formulaText)) { if (StringUtils.isNotEmpty(formulaText)) {
Calculator calculator = Calculator.createCalculator();
Expression expression = null;
try {
expression = calculator.parse(formulaText);
} catch (ANTLRException e) {
FRLogger.getLogger().error(e.getMessage(), e);
}
JOptionPane.showMessageDialog( JOptionPane.showMessageDialog(
BaseFormulaPane.this, BaseFormulaPane.this,
(expression != null ? Inter.getLocText("Plugin-Design_Basic_FormulaD_Valid_Formula") : Inter.getLocText("Plugin-Design_Basic_FormulaD_Invalid_Formula")) + ".", ProductConstants.PRODUCT_NAME, (isValidFormula(formulaText) ? Inter.getLocText("Plugin-Design_Basic_FormulaD_Valid_Formula") : Inter.getLocText("Plugin-Design_Basic_FormulaD_Invalid_Formula")) + ".", ProductConstants.PRODUCT_NAME,
JOptionPane.INFORMATION_MESSAGE); JOptionPane.INFORMATION_MESSAGE);
} }
} }
protected abstract boolean isValidFormula(String formulaText);
public void onSearch() { public void onSearch() {
formulaTextArea.requestFocusInWindow(); formulaTextArea.requestFocusInWindow();
} }

16
src/main/java/com/fr/solution/plugin/design/formula/ui/type/impl/BasicFormulaPane.java

@ -4,9 +4,12 @@ import com.fr.base.Formula;
import com.fr.base.Parameter; import com.fr.base.Parameter;
import com.fr.design.gui.syntax.ui.rsyntaxtextarea.RSyntaxTextArea; import com.fr.design.gui.syntax.ui.rsyntaxtextarea.RSyntaxTextArea;
import com.fr.design.gui.syntax.ui.rsyntaxtextarea.SyntaxConstants; import com.fr.design.gui.syntax.ui.rsyntaxtextarea.SyntaxConstants;
import com.fr.general.FRLogger;
import com.fr.script.Calculator; import com.fr.script.Calculator;
import com.fr.solution.plugin.design.formula.ui.type.BaseFormulaPane; import com.fr.solution.plugin.design.formula.ui.type.BaseFormulaPane;
import com.fr.stable.StringUtils; import com.fr.stable.StringUtils;
import com.fr.stable.script.Expression;
import com.fr.third.antlr.ANTLRException;
import java.util.Set; import java.util.Set;
@ -41,6 +44,7 @@ public class BasicFormulaPane extends BaseFormulaPane<Formula> {
return formula; return formula;
} }
@Override @Override
protected RSyntaxTextArea createContentEditor() { protected RSyntaxTextArea createContentEditor() {
RSyntaxTextArea formulaTextArea = new RSyntaxTextArea(); RSyntaxTextArea formulaTextArea = new RSyntaxTextArea();
@ -62,6 +66,18 @@ public class BasicFormulaPane extends BaseFormulaPane<Formula> {
formulaTextArea.setLineWrap(true); formulaTextArea.setLineWrap(true);
} }
@Override
protected boolean isValidFormula(String formulaText) {
Formula formula = createFormula(formulaText);
Expression expression = null;
try {
expression = formula.parse(Calculator.createCalculator());
} catch (ANTLRException e) {
FRLogger.getLogger().error(e.getMessage(), e);
}
return expression != null;
}
@Override @Override
public Parameter[] analyze4Parameters(Calculator calculator) { public Parameter[] analyze4Parameters(Calculator calculator) {
Formula formula = updateBean(); Formula formula = updateBean();

41
src/main/java/com/fr/solution/plugin/design/formula/ui/type/impl/ScriptFormulaPane.java

@ -3,15 +3,27 @@ package com.fr.solution.plugin.design.formula.ui.type.impl;
import com.fr.base.Parameter; import com.fr.base.Parameter;
import com.fr.base.ParameterHelper; import com.fr.base.ParameterHelper;
import com.fr.base.ScriptFormula; import com.fr.base.ScriptFormula;
import com.fr.base.TemplateUtils;
import com.fr.design.gui.syntax.ui.rsyntaxtextarea.RSyntaxTextArea; import com.fr.design.gui.syntax.ui.rsyntaxtextarea.RSyntaxTextArea;
import com.fr.design.gui.syntax.ui.rsyntaxtextarea.SyntaxConstants; import com.fr.design.gui.syntax.ui.rsyntaxtextarea.SyntaxConstants;
import com.fr.general.FRLogger;
import com.fr.general.Inter; import com.fr.general.Inter;
import com.fr.script.Calculator; import com.fr.script.Calculator;
import com.fr.script.ScriptFactory;
import com.fr.solution.plugin.design.formula.ui.type.BaseFormulaPane; import com.fr.solution.plugin.design.formula.ui.type.BaseFormulaPane;
import com.fr.stable.StringUtils; import com.fr.stable.StringUtils;
import javax.script.ScriptException;
import java.util.HashMap;
import java.util.Map;
public class ScriptFormulaPane extends BaseFormulaPane<ScriptFormula> { public class ScriptFormulaPane extends BaseFormulaPane<ScriptFormula> {
private static final String FUN_TPL = "(function() {\n" +
" var array = function(str) {return str ? str.split(\",\") : [];},int = function(str) {return parseInt(str);},number = function(str) {return parseFloat(str);};\n" +
" %s\n" +
"})();";
@Override @Override
protected RSyntaxTextArea createContentEditor() { protected RSyntaxTextArea createContentEditor() {
RSyntaxTextArea formulaTextArea = new RSyntaxTextArea(); RSyntaxTextArea formulaTextArea = new RSyntaxTextArea();
@ -67,6 +79,35 @@ public class ScriptFormulaPane extends BaseFormulaPane<ScriptFormula> {
return "'${" + text + "}'"; return "'${" + text + "}'";
} }
@Override
protected boolean isValidFormula(String formulaText) {
Calculator calculator = Calculator.createCalculator();
ScriptFormula formula = createFormula(formulaText);
Parameter[] parameters = analyze4Parameters(calculator);
Map<String, Object> map = new HashMap<String, Object>();
for (Parameter parameter : parameters) {
String name = parameter.getName();
Object value = parameter.getValue();
if (value instanceof Boolean) {
map.put(name, true);
} else if (value instanceof Number) {
map.put(name, 1);
} else {
map.put(name, "1");
}
}
try {
String content = TemplateUtils.renderParameter4Tpl(formula.getPureContent(), map);
ScriptFactory.newSingletonScriptEngine().eval(String.format(FUN_TPL, content));
} catch (Exception e) {
FRLogger.getLogger().error(e.getMessage(), e);
return false;
}
return true;
}
@Override @Override
public Parameter[] analyze4Parameters(Calculator calculator) { public Parameter[] analyze4Parameters(Calculator calculator) {
ScriptFormula scriptFormula = updateBean(); ScriptFormula scriptFormula = updateBean();

Loading…
Cancel
Save