Centralized mapping between operation names and their reconstructors.
Implemented comparison operators. git-svn-id: http://google-refine.googlecode.com/svn/trunk@117 7d457c2a-affb-35e4-300a-418c747d4874
This commit is contained in:
parent
934c0f81c3
commit
1227c9dff4
@ -33,12 +33,12 @@ import com.metaweb.gridworks.commands.info.GetOperationsCommand;
|
|||||||
import com.metaweb.gridworks.commands.info.GetProcessesCommand;
|
import com.metaweb.gridworks.commands.info.GetProcessesCommand;
|
||||||
import com.metaweb.gridworks.commands.info.GetProjectMetadataCommand;
|
import com.metaweb.gridworks.commands.info.GetProjectMetadataCommand;
|
||||||
import com.metaweb.gridworks.commands.info.GetRowsCommand;
|
import com.metaweb.gridworks.commands.info.GetRowsCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.ApproveNewReconcileCommand;
|
import com.metaweb.gridworks.commands.recon.ReconMarkNewTopicsCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.ApproveReconcileCommand;
|
import com.metaweb.gridworks.commands.recon.ReconMatchBestCandidatesCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.DiscardReconcileCommand;
|
import com.metaweb.gridworks.commands.recon.ReconDiscardJudgmentsCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.JudgeOneCellCommand;
|
import com.metaweb.gridworks.commands.recon.ReconJudgeOneCellCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.JudgeSimilarCellsCommand;
|
import com.metaweb.gridworks.commands.recon.ReconJudgeSimilarCellsCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.MatchSpecificTopicCommand;
|
import com.metaweb.gridworks.commands.recon.ReconMatchSpecificTopicCommand;
|
||||||
import com.metaweb.gridworks.commands.recon.ReconcileCommand;
|
import com.metaweb.gridworks.commands.recon.ReconcileCommand;
|
||||||
import com.metaweb.gridworks.commands.util.GetExpressionLanguageInfoCommand;
|
import com.metaweb.gridworks.commands.util.GetExpressionLanguageInfoCommand;
|
||||||
import com.metaweb.gridworks.commands.util.GuessTypesOfColumnCommand;
|
import com.metaweb.gridworks.commands.util.GuessTypesOfColumnCommand;
|
||||||
@ -75,12 +75,12 @@ public class GridworksServlet extends HttpServlet {
|
|||||||
_commands.put("split-multi-value-cells", new SplitMultiValueCellsCommand());
|
_commands.put("split-multi-value-cells", new SplitMultiValueCellsCommand());
|
||||||
|
|
||||||
_commands.put("reconcile", new ReconcileCommand());
|
_commands.put("reconcile", new ReconcileCommand());
|
||||||
_commands.put("recon-match-best-candidates", new ApproveReconcileCommand());
|
_commands.put("recon-match-best-candidates", new ReconMatchBestCandidatesCommand());
|
||||||
_commands.put("recon-mark-new-topics", new ApproveNewReconcileCommand());
|
_commands.put("recon-mark-new-topics", new ReconMarkNewTopicsCommand());
|
||||||
_commands.put("recon-discard-judgments", new DiscardReconcileCommand());
|
_commands.put("recon-discard-judgments", new ReconDiscardJudgmentsCommand());
|
||||||
_commands.put("recon-match-specific-topic-to-cells", new MatchSpecificTopicCommand());
|
_commands.put("recon-match-specific-topic-to-cells", new ReconMatchSpecificTopicCommand());
|
||||||
_commands.put("recon-judge-one-cell", new JudgeOneCellCommand());
|
_commands.put("recon-judge-one-cell", new ReconJudgeOneCellCommand());
|
||||||
_commands.put("recon-judge-similar-cells", new JudgeSimilarCellsCommand());
|
_commands.put("recon-judge-similar-cells", new ReconJudgeSimilarCellsCommand());
|
||||||
|
|
||||||
_commands.put("save-protograph", new SaveProtographCommand());
|
_commands.put("save-protograph", new SaveProtographCommand());
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package com.metaweb.gridworks.commands.edit;
|
package com.metaweb.gridworks.commands.edit;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
@ -14,18 +15,8 @@ import org.json.JSONObject;
|
|||||||
import com.metaweb.gridworks.commands.Command;
|
import com.metaweb.gridworks.commands.Command;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
import com.metaweb.gridworks.model.operations.ApproveNewReconOperation;
|
import com.metaweb.gridworks.model.operations.OperationRegistry;
|
||||||
import com.metaweb.gridworks.model.operations.ApproveReconOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.ColumnAdditionOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.ColumnRemovalOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.DiscardReconOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.MultiValueCellJoinOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.MultiValueCellSplitOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.ReconOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.SaveProtographOperation;
|
|
||||||
import com.metaweb.gridworks.model.operations.TextTransformOperation;
|
|
||||||
import com.metaweb.gridworks.process.Process;
|
import com.metaweb.gridworks.process.Process;
|
||||||
import com.metaweb.gridworks.protograph.Protograph;
|
|
||||||
|
|
||||||
public class ApplyOperationsCommand extends Command {
|
public class ApplyOperationsCommand extends Command {
|
||||||
|
|
||||||
@ -53,66 +44,23 @@ public class ApplyOperationsCommand extends Command {
|
|||||||
protected void reconstructOperation(Project project, JSONObject obj) {
|
protected void reconstructOperation(Project project, JSONObject obj) {
|
||||||
try {
|
try {
|
||||||
String op = obj.getString("op");
|
String op = obj.getString("op");
|
||||||
AbstractOperation operation = null;
|
|
||||||
|
|
||||||
JSONObject engineConfig = obj.has("engineConfig") ? obj.getJSONObject("engineConfig") : null;
|
Class<? extends AbstractOperation> klass = OperationRegistry.s_opNameToClass.get(op);
|
||||||
String columnName = obj.has("columnName") ? obj.getString("columnName") : null;
|
if (klass == null) {
|
||||||
|
return;
|
||||||
if ("approve-new-recon".equals(op)) {
|
|
||||||
operation = new ApproveNewReconOperation(engineConfig, columnName);
|
|
||||||
} else if ("approve-recon".equals(op)) {
|
|
||||||
operation = new ApproveReconOperation(engineConfig, columnName);
|
|
||||||
} else if ("add-column".equals(op)) {
|
|
||||||
operation = new ColumnAdditionOperation(
|
|
||||||
engineConfig,
|
|
||||||
obj.getString("baseColumnName"),
|
|
||||||
obj.getString("expression"),
|
|
||||||
obj.getString("headerLabel"),
|
|
||||||
obj.getInt("columnInsertIndex")
|
|
||||||
);
|
|
||||||
} else if ("remove-column".equals(op)) {
|
|
||||||
operation = new ColumnRemovalOperation(columnName);
|
|
||||||
} else if ("discard-recon".equals(op)) {
|
|
||||||
operation = new DiscardReconOperation(engineConfig, columnName);
|
|
||||||
} else if ("join-multivalued-cells".equals(op)) {
|
|
||||||
operation = new MultiValueCellJoinOperation(
|
|
||||||
columnName,
|
|
||||||
obj.getString("keyColumnName"),
|
|
||||||
obj.getString("separator")
|
|
||||||
);
|
|
||||||
} else if ("split-multivalued-cells".equals(op)) {
|
|
||||||
operation = new MultiValueCellSplitOperation(
|
|
||||||
columnName,
|
|
||||||
obj.getString("keyColumnName"),
|
|
||||||
obj.getString("separator"),
|
|
||||||
obj.getString("mode")
|
|
||||||
);
|
|
||||||
} else if ("recon".equals(op)) {
|
|
||||||
operation = new ReconOperation(
|
|
||||||
engineConfig,
|
|
||||||
columnName,
|
|
||||||
obj.getString("typeID"),
|
|
||||||
obj.getString("typeName"),
|
|
||||||
obj.getBoolean("autoMatch"),
|
|
||||||
obj.getDouble("minScore")
|
|
||||||
);
|
|
||||||
} else if ("save-protograph".equals(op)) {
|
|
||||||
operation = new SaveProtographOperation(
|
|
||||||
Protograph.reconstruct(obj.getJSONObject("protograph"))
|
|
||||||
);
|
|
||||||
} else if ("text-transform".equals(op)) {
|
|
||||||
operation = new TextTransformOperation(
|
|
||||||
engineConfig,
|
|
||||||
columnName,
|
|
||||||
obj.getString("expression")
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (operation != null) {
|
Method reconstruct = klass.getMethod("reconstruct", Project.class, JSONObject.class);
|
||||||
Process process = operation.createProcess(project, new Properties());
|
if (reconstruct == null) {
|
||||||
|
return;
|
||||||
project.processManager.queueProcess(process);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AbstractOperation operation = (AbstractOperation) reconstruct.invoke(null, project, obj);
|
||||||
|
if (operation != null) {
|
||||||
|
Process process = operation.createProcess(project, new Properties());
|
||||||
|
|
||||||
|
project.processManager.queueProcess(process);
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ import javax.servlet.http.HttpServletResponse;
|
|||||||
import com.metaweb.gridworks.commands.Command;
|
import com.metaweb.gridworks.commands.Command;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
import com.metaweb.gridworks.model.operations.MultiValueCellJoinOperation;
|
import com.metaweb.gridworks.model.operations.MultiValuedCellJoinOperation;
|
||||||
import com.metaweb.gridworks.process.Process;
|
import com.metaweb.gridworks.process.Process;
|
||||||
|
|
||||||
public class JoinMultiValueCellsCommand extends Command {
|
public class JoinMultiValueCellsCommand extends Command {
|
||||||
@ -25,7 +25,7 @@ public class JoinMultiValueCellsCommand extends Command {
|
|||||||
String keyColumnName = request.getParameter("keyColumnName");
|
String keyColumnName = request.getParameter("keyColumnName");
|
||||||
String separator = request.getParameter("separator");
|
String separator = request.getParameter("separator");
|
||||||
|
|
||||||
AbstractOperation op = new MultiValueCellJoinOperation(columnName, keyColumnName, separator);
|
AbstractOperation op = new MultiValuedCellJoinOperation(columnName, keyColumnName, separator);
|
||||||
Process process = op.createProcess(project, new Properties());
|
Process process = op.createProcess(project, new Properties());
|
||||||
|
|
||||||
boolean done = project.processManager.queueProcess(process);
|
boolean done = project.processManager.queueProcess(process);
|
||||||
|
@ -10,7 +10,7 @@ import javax.servlet.http.HttpServletResponse;
|
|||||||
import com.metaweb.gridworks.commands.Command;
|
import com.metaweb.gridworks.commands.Command;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
import com.metaweb.gridworks.model.operations.MultiValueCellSplitOperation;
|
import com.metaweb.gridworks.model.operations.MultiValuedCellSplitOperation;
|
||||||
import com.metaweb.gridworks.process.Process;
|
import com.metaweb.gridworks.process.Process;
|
||||||
|
|
||||||
public class SplitMultiValueCellsCommand extends Command {
|
public class SplitMultiValueCellsCommand extends Command {
|
||||||
@ -26,7 +26,7 @@ public class SplitMultiValueCellsCommand extends Command {
|
|||||||
String separator = request.getParameter("separator");
|
String separator = request.getParameter("separator");
|
||||||
String mode = request.getParameter("mode");
|
String mode = request.getParameter("mode");
|
||||||
|
|
||||||
AbstractOperation op = new MultiValueCellSplitOperation(columnName, keyColumnName, separator, mode);
|
AbstractOperation op = new MultiValuedCellSplitOperation(columnName, keyColumnName, separator, mode);
|
||||||
Process process = op.createProcess(project, new Properties());
|
Process process = op.createProcess(project, new Properties());
|
||||||
|
|
||||||
boolean done = project.processManager.queueProcess(process);
|
boolean done = project.processManager.queueProcess(process);
|
||||||
|
@ -6,16 +6,15 @@ import org.json.JSONObject;
|
|||||||
|
|
||||||
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.operations.ApproveReconOperation;
|
import com.metaweb.gridworks.model.operations.ReconDiscardJudgmentsOperation;
|
||||||
|
|
||||||
public class ApproveReconcileCommand extends EngineDependentCommand {
|
|
||||||
|
|
||||||
|
public class ReconDiscardJudgmentsCommand extends EngineDependentCommand {
|
||||||
@Override
|
@Override
|
||||||
protected AbstractOperation createOperation(HttpServletRequest request,
|
protected AbstractOperation createOperation(HttpServletRequest request,
|
||||||
JSONObject engineConfig) throws Exception {
|
JSONObject engineConfig) throws Exception {
|
||||||
|
|
||||||
String columnName = request.getParameter("columnName");
|
String columnName = request.getParameter("columnName");
|
||||||
|
|
||||||
return new ApproveReconOperation(engineConfig, columnName);
|
return new ReconDiscardJudgmentsOperation(engineConfig, columnName);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -21,7 +21,7 @@ import com.metaweb.gridworks.model.ReconCandidate;
|
|||||||
import com.metaweb.gridworks.model.changes.CellChange;
|
import com.metaweb.gridworks.model.changes.CellChange;
|
||||||
import com.metaweb.gridworks.process.QuickHistoryEntryProcess;
|
import com.metaweb.gridworks.process.QuickHistoryEntryProcess;
|
||||||
|
|
||||||
public class JudgeOneCellCommand extends Command {
|
public class ReconJudgeOneCellCommand extends Command {
|
||||||
@Override
|
@Override
|
||||||
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
||||||
throws ServletException, IOException {
|
throws ServletException, IOException {
|
@ -26,7 +26,7 @@ import com.metaweb.gridworks.model.changes.CellChange;
|
|||||||
import com.metaweb.gridworks.model.changes.MassCellChange;
|
import com.metaweb.gridworks.model.changes.MassCellChange;
|
||||||
import com.metaweb.gridworks.process.QuickHistoryEntryProcess;
|
import com.metaweb.gridworks.process.QuickHistoryEntryProcess;
|
||||||
|
|
||||||
public class JudgeSimilarCellsCommand extends Command {
|
public class ReconJudgeSimilarCellsCommand extends Command {
|
||||||
@Override
|
@Override
|
||||||
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
public void doPost(HttpServletRequest request, HttpServletResponse response)
|
||||||
throws ServletException, IOException {
|
throws ServletException, IOException {
|
@ -6,9 +6,9 @@ import org.json.JSONObject;
|
|||||||
|
|
||||||
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.operations.ApproveNewReconOperation;
|
import com.metaweb.gridworks.model.operations.ReconMarkNewTopicsOperation;
|
||||||
|
|
||||||
public class ApproveNewReconcileCommand extends EngineDependentCommand {
|
public class ReconMarkNewTopicsCommand extends EngineDependentCommand {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected AbstractOperation createOperation(HttpServletRequest request,
|
protected AbstractOperation createOperation(HttpServletRequest request,
|
||||||
@ -16,6 +16,6 @@ public class ApproveNewReconcileCommand extends EngineDependentCommand {
|
|||||||
|
|
||||||
String columnName = request.getParameter("columnName");
|
String columnName = request.getParameter("columnName");
|
||||||
|
|
||||||
return new ApproveNewReconOperation(engineConfig, columnName);
|
return new ReconMarkNewTopicsOperation(engineConfig, columnName);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -6,15 +6,16 @@ import org.json.JSONObject;
|
|||||||
|
|
||||||
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.operations.DiscardReconOperation;
|
import com.metaweb.gridworks.model.operations.ReconMatchBestCandidatesOperation;
|
||||||
|
|
||||||
|
public class ReconMatchBestCandidatesCommand extends EngineDependentCommand {
|
||||||
|
|
||||||
public class DiscardReconcileCommand extends EngineDependentCommand {
|
|
||||||
@Override
|
@Override
|
||||||
protected AbstractOperation createOperation(HttpServletRequest request,
|
protected AbstractOperation createOperation(HttpServletRequest request,
|
||||||
JSONObject engineConfig) throws Exception {
|
JSONObject engineConfig) throws Exception {
|
||||||
|
|
||||||
String columnName = request.getParameter("columnName");
|
String columnName = request.getParameter("columnName");
|
||||||
|
|
||||||
return new DiscardReconOperation(engineConfig, columnName);
|
return new ReconMatchBestCandidatesOperation(engineConfig, columnName);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -7,9 +7,9 @@ import org.json.JSONObject;
|
|||||||
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
import com.metaweb.gridworks.commands.EngineDependentCommand;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.ReconCandidate;
|
import com.metaweb.gridworks.model.ReconCandidate;
|
||||||
import com.metaweb.gridworks.model.operations.MatchSpecificTopicReconOperation;
|
import com.metaweb.gridworks.model.operations.ReconMatchSpecificTopicOperation;
|
||||||
|
|
||||||
public class MatchSpecificTopicCommand extends EngineDependentCommand {
|
public class ReconMatchSpecificTopicCommand extends EngineDependentCommand {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected AbstractOperation createOperation(HttpServletRequest request,
|
protected AbstractOperation createOperation(HttpServletRequest request,
|
||||||
@ -24,6 +24,6 @@ public class MatchSpecificTopicCommand extends EngineDependentCommand {
|
|||||||
100
|
100
|
||||||
);
|
);
|
||||||
|
|
||||||
return new MatchSpecificTopicReconOperation(engineConfig, columnName, match);
|
return new ReconMatchSpecificTopicOperation(engineConfig, columnName, match);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -43,6 +43,46 @@ public class OperatorCallExpr implements Evaluable {
|
|||||||
return ((Number) args[0]).doubleValue() / ((Number) args[1]).doubleValue();
|
return ((Number) args[0]).doubleValue() / ((Number) args[1]).doubleValue();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (">".equals(_op)) {
|
||||||
|
if (args.length == 2) {
|
||||||
|
if (args[0] instanceof Number && args[1] instanceof Number) {
|
||||||
|
return ((Number) args[0]).doubleValue() > ((Number) args[1]).doubleValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (">=".equals(_op)) {
|
||||||
|
if (args.length == 2) {
|
||||||
|
if (args[0] instanceof Number && args[1] instanceof Number) {
|
||||||
|
return ((Number) args[0]).doubleValue() >= ((Number) args[1]).doubleValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if ("<".equals(_op)) {
|
||||||
|
if (args.length == 2) {
|
||||||
|
if (args[0] instanceof Number && args[1] instanceof Number) {
|
||||||
|
return ((Number) args[0]).doubleValue() < ((Number) args[1]).doubleValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if ("<=".equals(_op)) {
|
||||||
|
if (args.length == 2) {
|
||||||
|
if (args[0] instanceof Number && args[1] instanceof Number) {
|
||||||
|
return ((Number) args[0]).doubleValue() <= ((Number) args[1]).doubleValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if ("==".equals(_op)) {
|
||||||
|
if (args.length == 2) {
|
||||||
|
if (args[0] != null) {
|
||||||
|
return args[0].equals(args[1]);
|
||||||
|
} else {
|
||||||
|
return args[1] == null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if ("!=".equals(_op)) {
|
||||||
|
if (args.length == 2) {
|
||||||
|
if (args[0] != null) {
|
||||||
|
return !args[0].equals(args[1]);
|
||||||
|
} else {
|
||||||
|
return args[1] != null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@ import com.metaweb.gridworks.expr.ExpressionUtils;
|
|||||||
import com.metaweb.gridworks.expr.Parser;
|
import com.metaweb.gridworks.expr.Parser;
|
||||||
import com.metaweb.gridworks.history.Change;
|
import com.metaweb.gridworks.history.Change;
|
||||||
import com.metaweb.gridworks.history.HistoryEntry;
|
import com.metaweb.gridworks.history.HistoryEntry;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
@ -32,6 +33,18 @@ public class ColumnAdditionOperation extends EngineDependentOperation {
|
|||||||
final protected String _headerLabel;
|
final protected String _headerLabel;
|
||||||
final protected int _columnInsertIndex;
|
final protected int _columnInsertIndex;
|
||||||
|
|
||||||
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
|
||||||
|
return new ColumnAdditionOperation(
|
||||||
|
engineConfig,
|
||||||
|
obj.getString("baseColumnName"),
|
||||||
|
obj.getString("expression"),
|
||||||
|
obj.getString("headerLabel"),
|
||||||
|
obj.getInt("columnInsertIndex")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public ColumnAdditionOperation(
|
public ColumnAdditionOperation(
|
||||||
JSONObject engineConfig,
|
JSONObject engineConfig,
|
||||||
String baseColumnName,
|
String baseColumnName,
|
||||||
@ -48,38 +61,12 @@ public class ColumnAdditionOperation extends EngineDependentOperation {
|
|||||||
_columnInsertIndex = columnInsertIndex;
|
_columnInsertIndex = columnInsertIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected HistoryEntry createHistoryEntry(Project project) throws Exception {
|
|
||||||
Engine engine = createEngine(project);
|
|
||||||
|
|
||||||
Column column = project.columnModel.getColumnByName(_baseColumnName);
|
|
||||||
if (column == null) {
|
|
||||||
throw new Exception("No column named " + _baseColumnName);
|
|
||||||
}
|
|
||||||
|
|
||||||
List<CellAtRow> cellsAtRows = new ArrayList<CellAtRow>(project.rows.size());
|
|
||||||
|
|
||||||
FilteredRows filteredRows = engine.getAllFilteredRows(false);
|
|
||||||
filteredRows.accept(project, createRowVisitor(project, cellsAtRows));
|
|
||||||
|
|
||||||
String description = createDescription(column, cellsAtRows);
|
|
||||||
|
|
||||||
Change change = new ColumnAdditionChange(_headerLabel, _columnInsertIndex, cellsAtRows);
|
|
||||||
|
|
||||||
return new HistoryEntry(
|
|
||||||
project, description, this, change);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void write(JSONWriter writer, Properties options)
|
public void write(JSONWriter writer, Properties options)
|
||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("add-column");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value(
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
"Create column " + _headerLabel +
|
|
||||||
" at index " + _columnInsertIndex +
|
|
||||||
" based on column " + _baseColumnName +
|
|
||||||
" using expression " + _expression);
|
|
||||||
|
|
||||||
writer.key("engineConfig"); writer.value(getEngineConfig());
|
writer.key("engineConfig"); writer.value(getEngineConfig());
|
||||||
writer.key("headerLabel"); writer.value(_headerLabel);
|
writer.key("headerLabel"); writer.value(_headerLabel);
|
||||||
writer.key("columnInsertIndex"); writer.value(_columnInsertIndex);
|
writer.key("columnInsertIndex"); writer.value(_columnInsertIndex);
|
||||||
@ -89,7 +76,10 @@ public class ColumnAdditionOperation extends EngineDependentOperation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Add in column " + _headerLabel + " based on column " + _baseColumnName;
|
return "Create column " + _headerLabel +
|
||||||
|
" at index " + _columnInsertIndex +
|
||||||
|
" based on column " + _baseColumnName +
|
||||||
|
" using expression " + _expression;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String createDescription(Column column, List<CellAtRow> cellsAtRows) {
|
protected String createDescription(Column column, List<CellAtRow> cellsAtRows) {
|
||||||
@ -99,6 +89,27 @@ public class ColumnAdditionOperation extends EngineDependentOperation {
|
|||||||
" rows with " + _expression;
|
" rows with " + _expression;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected HistoryEntry createHistoryEntry(Project project) throws Exception {
|
||||||
|
Engine engine = createEngine(project);
|
||||||
|
|
||||||
|
Column column = project.columnModel.getColumnByName(_baseColumnName);
|
||||||
|
if (column == null) {
|
||||||
|
throw new Exception("No column named " + _baseColumnName);
|
||||||
|
}
|
||||||
|
|
||||||
|
List<CellAtRow> cellsAtRows = new ArrayList<CellAtRow>(project.rows.size());
|
||||||
|
|
||||||
|
FilteredRows filteredRows = engine.getAllFilteredRows(false);
|
||||||
|
filteredRows.accept(project, createRowVisitor(project, cellsAtRows));
|
||||||
|
|
||||||
|
String description = createDescription(column, cellsAtRows);
|
||||||
|
|
||||||
|
Change change = new ColumnAdditionChange(_headerLabel, _columnInsertIndex, cellsAtRows);
|
||||||
|
|
||||||
|
return new HistoryEntry(
|
||||||
|
project, description, this, change);
|
||||||
|
}
|
||||||
|
|
||||||
protected RowVisitor createRowVisitor(Project project, List<CellAtRow> cellsAtRows) throws Exception {
|
protected RowVisitor createRowVisitor(Project project, List<CellAtRow> cellsAtRows) throws Exception {
|
||||||
Column column = project.columnModel.getColumnByName(_baseColumnName);
|
Column column = project.columnModel.getColumnByName(_baseColumnName);
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ package com.metaweb.gridworks.model.operations;
|
|||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.history.Change;
|
import com.metaweb.gridworks.history.Change;
|
||||||
@ -17,12 +18,29 @@ public class ColumnRemovalOperation extends AbstractOperation {
|
|||||||
|
|
||||||
final protected String _columnName;
|
final protected String _columnName;
|
||||||
|
|
||||||
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
return new ColumnRemovalOperation(
|
||||||
|
obj.getString("columnName")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public ColumnRemovalOperation(
|
public ColumnRemovalOperation(
|
||||||
String columnName
|
String columnName
|
||||||
) {
|
) {
|
||||||
_columnName = columnName;
|
_columnName = columnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void write(JSONWriter writer, Properties options)
|
||||||
|
throws JSONException {
|
||||||
|
|
||||||
|
writer.object();
|
||||||
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
|
writer.key("description"); writer.value("Remove column " + _columnName);
|
||||||
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
|
writer.endObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Remove column " + _columnName;
|
return "Remove column " + _columnName;
|
||||||
}
|
}
|
||||||
@ -39,14 +57,4 @@ public class ColumnRemovalOperation extends AbstractOperation {
|
|||||||
|
|
||||||
return new HistoryEntry(project, description, ColumnRemovalOperation.this, change);
|
return new HistoryEntry(project, description, ColumnRemovalOperation.this, change);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void write(JSONWriter writer, Properties options)
|
|
||||||
throws JSONException {
|
|
||||||
|
|
||||||
writer.object();
|
|
||||||
writer.key("op"); writer.value("remove-column");
|
|
||||||
writer.key("description"); writer.value("Remove column " + _columnName);
|
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
|
||||||
writer.endObject();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -5,10 +5,10 @@ import java.util.List;
|
|||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.expr.ExpressionUtils;
|
import com.metaweb.gridworks.expr.ExpressionUtils;
|
||||||
import com.metaweb.gridworks.history.Change;
|
|
||||||
import com.metaweb.gridworks.history.HistoryEntry;
|
import com.metaweb.gridworks.history.HistoryEntry;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
@ -17,14 +17,22 @@ import com.metaweb.gridworks.model.Project;
|
|||||||
import com.metaweb.gridworks.model.Row;
|
import com.metaweb.gridworks.model.Row;
|
||||||
import com.metaweb.gridworks.model.changes.MassRowChange;
|
import com.metaweb.gridworks.model.changes.MassRowChange;
|
||||||
|
|
||||||
public class MultiValueCellJoinOperation extends AbstractOperation {
|
public class MultiValuedCellJoinOperation extends AbstractOperation {
|
||||||
private static final long serialVersionUID = 3134524625206033285L;
|
private static final long serialVersionUID = 3134524625206033285L;
|
||||||
|
|
||||||
final protected String _columnName;
|
final protected String _columnName;
|
||||||
final protected String _keyColumnName;
|
final protected String _keyColumnName;
|
||||||
final protected String _separator;
|
final protected String _separator;
|
||||||
|
|
||||||
public MultiValueCellJoinOperation(
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
return new MultiValuedCellJoinOperation(
|
||||||
|
obj.getString("columnName"),
|
||||||
|
obj.getString("keyColumnName"),
|
||||||
|
obj.getString("separator")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public MultiValuedCellJoinOperation(
|
||||||
String columnName,
|
String columnName,
|
||||||
String keyColumnName,
|
String keyColumnName,
|
||||||
String separator
|
String separator
|
||||||
@ -34,6 +42,18 @@ public class MultiValueCellJoinOperation extends AbstractOperation {
|
|||||||
_separator = separator;
|
_separator = separator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void write(JSONWriter writer, Properties options)
|
||||||
|
throws JSONException {
|
||||||
|
|
||||||
|
writer.object();
|
||||||
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
|
writer.key("keyColumnName"); writer.value(_keyColumnName);
|
||||||
|
writer.key("separator"); writer.value(_separator);
|
||||||
|
writer.endObject();
|
||||||
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Join multi-valued cells in column " + _columnName;
|
return "Join multi-valued cells in column " + _columnName;
|
||||||
}
|
}
|
||||||
@ -99,22 +119,12 @@ public class MultiValueCellJoinOperation extends AbstractOperation {
|
|||||||
r = r2 - 1; // r will be incremented by the for loop anyway
|
r = r2 - 1; // r will be incremented by the for loop anyway
|
||||||
}
|
}
|
||||||
|
|
||||||
String description = "Join multi-valued cells in column " + column.getHeaderLabel();
|
return new HistoryEntry(
|
||||||
|
project,
|
||||||
Change change = new MassRowChange(newRows);
|
getBriefDescription(),
|
||||||
|
this,
|
||||||
return new HistoryEntry(project, description, this, change);
|
new MassRowChange(newRows)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void write(JSONWriter writer, Properties options)
|
|
||||||
throws JSONException {
|
|
||||||
|
|
||||||
writer.object();
|
|
||||||
writer.key("op"); writer.value("join-multivalued-cells");
|
|
||||||
writer.key("description"); writer.value("Join multi-valued cells in column " + _columnName);
|
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
|
||||||
writer.key("keyColumnName"); writer.value(_keyColumnName);
|
|
||||||
writer.key("separator"); writer.value(_separator);
|
|
||||||
writer.endObject();
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -6,9 +6,9 @@ import java.util.Properties;
|
|||||||
|
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.history.Change;
|
|
||||||
import com.metaweb.gridworks.history.HistoryEntry;
|
import com.metaweb.gridworks.history.HistoryEntry;
|
||||||
import com.metaweb.gridworks.model.AbstractOperation;
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
@ -17,7 +17,7 @@ import com.metaweb.gridworks.model.Project;
|
|||||||
import com.metaweb.gridworks.model.Row;
|
import com.metaweb.gridworks.model.Row;
|
||||||
import com.metaweb.gridworks.model.changes.MassRowChange;
|
import com.metaweb.gridworks.model.changes.MassRowChange;
|
||||||
|
|
||||||
public class MultiValueCellSplitOperation extends AbstractOperation {
|
public class MultiValuedCellSplitOperation extends AbstractOperation {
|
||||||
private static final long serialVersionUID = 8217930220439070322L;
|
private static final long serialVersionUID = 8217930220439070322L;
|
||||||
|
|
||||||
final protected String _columnName;
|
final protected String _columnName;
|
||||||
@ -25,7 +25,16 @@ public class MultiValueCellSplitOperation extends AbstractOperation {
|
|||||||
final protected String _separator;
|
final protected String _separator;
|
||||||
final protected String _mode;
|
final protected String _mode;
|
||||||
|
|
||||||
public MultiValueCellSplitOperation(
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
return new MultiValuedCellSplitOperation(
|
||||||
|
obj.getString("columnName"),
|
||||||
|
obj.getString("keyColumnName"),
|
||||||
|
obj.getString("separator"),
|
||||||
|
obj.getString("mode")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public MultiValuedCellSplitOperation(
|
||||||
String columnName,
|
String columnName,
|
||||||
String keyColumnName,
|
String keyColumnName,
|
||||||
String separator,
|
String separator,
|
||||||
@ -37,6 +46,19 @@ public class MultiValueCellSplitOperation extends AbstractOperation {
|
|||||||
_mode = mode;
|
_mode = mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void write(JSONWriter writer, Properties options)
|
||||||
|
throws JSONException {
|
||||||
|
|
||||||
|
writer.object();
|
||||||
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
|
writer.key("description"); writer.value("Split multi-valued cells in column " + _columnName);
|
||||||
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
|
writer.key("keyColumnName"); writer.value(_keyColumnName);
|
||||||
|
writer.key("separator"); writer.value(_separator);
|
||||||
|
writer.key("mode"); writer.value(_mode);
|
||||||
|
writer.endObject();
|
||||||
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Split multi-valued cells in column " + _columnName;
|
return "Split multi-valued cells in column " + _columnName;
|
||||||
}
|
}
|
||||||
@ -115,23 +137,11 @@ public class MultiValueCellSplitOperation extends AbstractOperation {
|
|||||||
r = r2 - 1; // r will be incremented by the for loop anyway
|
r = r2 - 1; // r will be incremented by the for loop anyway
|
||||||
}
|
}
|
||||||
|
|
||||||
String description = "Split multi-valued cells in column " + column.getHeaderLabel();
|
return new HistoryEntry(
|
||||||
|
project,
|
||||||
Change change = new MassRowChange(newRows);
|
getBriefDescription(),
|
||||||
|
this,
|
||||||
return new HistoryEntry(project, description, this, change);
|
new MassRowChange(newRows)
|
||||||
}
|
);
|
||||||
|
|
||||||
public void write(JSONWriter writer, Properties options)
|
|
||||||
throws JSONException {
|
|
||||||
|
|
||||||
writer.object();
|
|
||||||
writer.key("op"); writer.value("split-multivalued-cells");
|
|
||||||
writer.key("description"); writer.value("Split multi-valued cells in column " + _columnName);
|
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
|
||||||
writer.key("keyColumnName"); writer.value(_keyColumnName);
|
|
||||||
writer.key("separator"); writer.value(_separator);
|
|
||||||
writer.key("mode"); writer.value(_mode);
|
|
||||||
writer.endObject();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package com.metaweb.gridworks.model.operations;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
|
|
||||||
|
public abstract class OperationRegistry {
|
||||||
|
static public Map<String, Class<? extends AbstractOperation>> s_opNameToClass;
|
||||||
|
static public Map<Class<? extends AbstractOperation>, String> s_opClassToName;
|
||||||
|
|
||||||
|
static protected void register(String name, Class<? extends AbstractOperation> klass) {
|
||||||
|
s_opNameToClass.put(name, klass);
|
||||||
|
s_opClassToName.put(klass, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
static {
|
||||||
|
s_opNameToClass = new HashMap<String, Class<? extends AbstractOperation>>();
|
||||||
|
s_opClassToName = new HashMap<Class<? extends AbstractOperation>, String>();
|
||||||
|
|
||||||
|
register("recon", ReconOperation.class);
|
||||||
|
register("recon-mark-new-topics", ReconMarkNewTopicsOperation.class);
|
||||||
|
register("recon-match-best-candidates", ReconMatchBestCandidatesOperation.class);
|
||||||
|
register("recon-discard-judgments", ReconDiscardJudgmentsOperation.class);
|
||||||
|
register("recon-match-specific-topic-to-cells", ReconMatchSpecificTopicOperation.class);
|
||||||
|
|
||||||
|
register("multivalued-cell-join", MultiValuedCellJoinOperation.class);
|
||||||
|
register("multivalued-cell-split", MultiValuedCellSplitOperation.class);
|
||||||
|
|
||||||
|
register("column-addition", ColumnAdditionOperation.class);
|
||||||
|
register("column-removal", ColumnRemovalOperation.class);
|
||||||
|
|
||||||
|
register("save-protograph", SaveProtographOperation.class);
|
||||||
|
register("text-transform", TextTransformOperation.class);
|
||||||
|
}
|
||||||
|
}
|
@ -8,16 +8,29 @@ import org.json.JSONObject;
|
|||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.browsing.RowVisitor;
|
import com.metaweb.gridworks.browsing.RowVisitor;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
|
import com.metaweb.gridworks.model.Recon;
|
||||||
import com.metaweb.gridworks.model.Row;
|
import com.metaweb.gridworks.model.Row;
|
||||||
|
import com.metaweb.gridworks.model.Recon.Judgment;
|
||||||
import com.metaweb.gridworks.model.changes.CellChange;
|
import com.metaweb.gridworks.model.changes.CellChange;
|
||||||
|
|
||||||
public class DiscardReconOperation extends EngineDependentMassCellOperation {
|
public class ReconDiscardJudgmentsOperation extends EngineDependentMassCellOperation {
|
||||||
private static final long serialVersionUID = 6799029731665369179L;
|
private static final long serialVersionUID = 6799029731665369179L;
|
||||||
|
|
||||||
public DiscardReconOperation(JSONObject engineConfig, String columnName) {
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
String columnName = obj.getString("columnName");
|
||||||
|
|
||||||
|
return new ReconDiscardJudgmentsOperation(
|
||||||
|
engineConfig,
|
||||||
|
columnName
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ReconDiscardJudgmentsOperation(JSONObject engineConfig, String columnName) {
|
||||||
super(engineConfig, columnName, false);
|
super(engineConfig, columnName, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -25,21 +38,21 @@ public class DiscardReconOperation extends EngineDependentMassCellOperation {
|
|||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("discard-recon");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value("Discard recon matches in column " + _columnName);
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
writer.key("engineConfig"); writer.value(getEngineConfig());
|
writer.key("engineConfig"); writer.value(getEngineConfig());
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
writer.endObject();
|
writer.endObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Discard recon results for cells in column " + _columnName;
|
return "Discard recon judgments for cells in column " + _columnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String createDescription(Column column,
|
protected String createDescription(Column column,
|
||||||
List<CellChange> cellChanges) {
|
List<CellChange> cellChanges) {
|
||||||
|
|
||||||
return "Discard recon results for " + cellChanges.size() +
|
return "Discard recon judgments for " + cellChanges.size() +
|
||||||
" cells in column " + column.getHeaderLabel();
|
" cells in column " + column.getHeaderLabel();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,11 +72,15 @@ public class DiscardReconOperation extends EngineDependentMassCellOperation {
|
|||||||
public boolean visit(Project project, int rowIndex, Row row, boolean contextual) {
|
public boolean visit(Project project, int rowIndex, Row row, boolean contextual) {
|
||||||
if (cellIndex < row.cells.size()) {
|
if (cellIndex < row.cells.size()) {
|
||||||
Cell cell = row.cells.get(cellIndex);
|
Cell cell = row.cells.get(cellIndex);
|
||||||
|
if (cell.recon != null) {
|
||||||
|
Recon recon = cell.recon.dup();
|
||||||
|
recon.judgment = Judgment.None;
|
||||||
|
|
||||||
Cell newCell = new Cell(cell.value, null);
|
Cell newCell = new Cell(cell.value, recon);
|
||||||
|
|
||||||
CellChange cellChange = new CellChange(rowIndex, cellIndex, cell, newCell);
|
CellChange cellChange = new CellChange(rowIndex, cellIndex, cell, newCell);
|
||||||
cellChanges.add(cellChange);
|
cellChanges.add(cellChange);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
@ -8,6 +8,7 @@ import org.json.JSONObject;
|
|||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.browsing.RowVisitor;
|
import com.metaweb.gridworks.browsing.RowVisitor;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
@ -16,10 +17,20 @@ import com.metaweb.gridworks.model.Row;
|
|||||||
import com.metaweb.gridworks.model.Recon.Judgment;
|
import com.metaweb.gridworks.model.Recon.Judgment;
|
||||||
import com.metaweb.gridworks.model.changes.CellChange;
|
import com.metaweb.gridworks.model.changes.CellChange;
|
||||||
|
|
||||||
public class ApproveNewReconOperation extends EngineDependentMassCellOperation {
|
public class ReconMarkNewTopicsOperation extends EngineDependentMassCellOperation {
|
||||||
private static final long serialVersionUID = -5205694623711144436L;
|
private static final long serialVersionUID = -5205694623711144436L;
|
||||||
|
|
||||||
public ApproveNewReconOperation(JSONObject engineConfig, String columnName) {
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
String columnName = obj.getString("columnName");
|
||||||
|
|
||||||
|
return new ReconMarkNewTopicsOperation(
|
||||||
|
engineConfig,
|
||||||
|
columnName
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ReconMarkNewTopicsOperation(JSONObject engineConfig, String columnName) {
|
||||||
super(engineConfig, columnName, false);
|
super(engineConfig, columnName, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -27,21 +38,21 @@ public class ApproveNewReconOperation extends EngineDependentMassCellOperation {
|
|||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("approve-new-recon");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value("Approve new topics in column " + _columnName);
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
writer.key("engineConfig"); writer.value(getEngineConfig());
|
writer.key("engineConfig"); writer.value(getEngineConfig());
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
writer.endObject();
|
writer.endObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Approve new topics for cells in column " + _columnName;
|
return "Mark to create new topics for cells in column " + _columnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String createDescription(Column column,
|
protected String createDescription(Column column,
|
||||||
List<CellChange> cellChanges) {
|
List<CellChange> cellChanges) {
|
||||||
|
|
||||||
return "Approve new topics for " + cellChanges.size() +
|
return "Mark to create new topics for " + cellChanges.size() +
|
||||||
" cells in column " + column.getHeaderLabel();
|
" cells in column " + column.getHeaderLabel();
|
||||||
}
|
}
|
||||||
|
|
@ -8,6 +8,7 @@ import org.json.JSONObject;
|
|||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.browsing.RowVisitor;
|
import com.metaweb.gridworks.browsing.RowVisitor;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
@ -15,10 +16,20 @@ import com.metaweb.gridworks.model.Row;
|
|||||||
import com.metaweb.gridworks.model.Recon.Judgment;
|
import com.metaweb.gridworks.model.Recon.Judgment;
|
||||||
import com.metaweb.gridworks.model.changes.CellChange;
|
import com.metaweb.gridworks.model.changes.CellChange;
|
||||||
|
|
||||||
public class ApproveReconOperation extends EngineDependentMassCellOperation {
|
public class ReconMatchBestCandidatesOperation extends EngineDependentMassCellOperation {
|
||||||
private static final long serialVersionUID = 5393888241057341155L;
|
private static final long serialVersionUID = 5393888241057341155L;
|
||||||
|
|
||||||
public ApproveReconOperation(JSONObject engineConfig, String columnName) {
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
String columnName = obj.getString("columnName");
|
||||||
|
|
||||||
|
return new ReconMatchBestCandidatesOperation(
|
||||||
|
engineConfig,
|
||||||
|
columnName
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ReconMatchBestCandidatesOperation(JSONObject engineConfig, String columnName) {
|
||||||
super(engineConfig, columnName, false);
|
super(engineConfig, columnName, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,22 +37,22 @@ public class ApproveReconOperation extends EngineDependentMassCellOperation {
|
|||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("approve-recon");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value("Approve best recon matches in column " + _columnName);
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
writer.key("engineConfig"); writer.value(getEngineConfig());
|
writer.key("engineConfig"); writer.value(getEngineConfig());
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
writer.endObject();
|
writer.endObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Approve best recon candidates for cells in column " + _columnName;
|
return "Match each cell to its best recon candidate in column " + _columnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String createDescription(Column column,
|
protected String createDescription(Column column,
|
||||||
List<CellChange> cellChanges) {
|
List<CellChange> cellChanges) {
|
||||||
|
|
||||||
return "Approve best candidates for " + cellChanges.size() +
|
return "Match each of " + cellChanges.size() +
|
||||||
" cells in column " + column.getHeaderLabel();
|
" cells to its best candidate in column " + column.getHeaderLabel();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected RowVisitor createRowVisitor(Project project, List<CellChange> cellChanges) throws Exception {
|
protected RowVisitor createRowVisitor(Project project, List<CellChange> cellChanges) throws Exception {
|
@ -3,11 +3,13 @@ package com.metaweb.gridworks.model.operations;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import org.json.JSONArray;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.browsing.RowVisitor;
|
import com.metaweb.gridworks.browsing.RowVisitor;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
@ -17,12 +19,36 @@ import com.metaweb.gridworks.model.Row;
|
|||||||
import com.metaweb.gridworks.model.Recon.Judgment;
|
import com.metaweb.gridworks.model.Recon.Judgment;
|
||||||
import com.metaweb.gridworks.model.changes.CellChange;
|
import com.metaweb.gridworks.model.changes.CellChange;
|
||||||
|
|
||||||
public class MatchSpecificTopicReconOperation extends EngineDependentMassCellOperation {
|
public class ReconMatchSpecificTopicOperation extends EngineDependentMassCellOperation {
|
||||||
private static final long serialVersionUID = -5205694623711144436L;
|
private static final long serialVersionUID = -5205694623711144436L;
|
||||||
|
|
||||||
final protected ReconCandidate match;
|
final protected ReconCandidate match;
|
||||||
|
|
||||||
public MatchSpecificTopicReconOperation(JSONObject engineConfig, String columnName, ReconCandidate match) {
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
|
||||||
|
JSONObject match = obj.getJSONObject("match");
|
||||||
|
|
||||||
|
JSONArray types = obj.getJSONArray("types");
|
||||||
|
String[] typeIDs = new String[types.length()];
|
||||||
|
for (int i = 0; i < typeIDs.length; i++) {
|
||||||
|
typeIDs[i] = types.getString(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ReconMatchSpecificTopicOperation(
|
||||||
|
engineConfig,
|
||||||
|
obj.getString("columnName"),
|
||||||
|
new ReconCandidate(
|
||||||
|
match.getString("id"),
|
||||||
|
match.getString("guid"),
|
||||||
|
match.getString("name"),
|
||||||
|
typeIDs,
|
||||||
|
100
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ReconMatchSpecificTopicOperation(JSONObject engineConfig, String columnName, ReconCandidate match) {
|
||||||
super(engineConfig, columnName, false);
|
super(engineConfig, columnName, false);
|
||||||
this.match = match;
|
this.match = match;
|
||||||
}
|
}
|
||||||
@ -31,13 +57,22 @@ public class MatchSpecificTopicReconOperation extends EngineDependentMassCellOpe
|
|||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("recon-match-specific-topic-to-cells");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value(
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
"Match specific topic " +
|
|
||||||
match.topicName + " (" +
|
|
||||||
match.topicID + ") to cells in column " + _columnName);
|
|
||||||
writer.key("engineConfig"); writer.value(getEngineConfig());
|
writer.key("engineConfig"); writer.value(getEngineConfig());
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
|
writer.key("match");
|
||||||
|
writer.object();
|
||||||
|
writer.key("id"); writer.value(match.topicID);
|
||||||
|
writer.key("guid"); writer.value(match.topicGUID);
|
||||||
|
writer.key("name"); writer.value(match.topicName);
|
||||||
|
writer.key("types");
|
||||||
|
writer.array();
|
||||||
|
for (String typeID : match.typeIDs) {
|
||||||
|
writer.value(typeID);
|
||||||
|
}
|
||||||
|
writer.endArray();
|
||||||
|
writer.endObject();
|
||||||
writer.endObject();
|
writer.endObject();
|
||||||
}
|
}
|
||||||
|
|
@ -25,6 +25,7 @@ import com.metaweb.gridworks.browsing.RowVisitor;
|
|||||||
import com.metaweb.gridworks.expr.ExpressionUtils;
|
import com.metaweb.gridworks.expr.ExpressionUtils;
|
||||||
import com.metaweb.gridworks.history.Change;
|
import com.metaweb.gridworks.history.Change;
|
||||||
import com.metaweb.gridworks.history.HistoryEntry;
|
import com.metaweb.gridworks.history.HistoryEntry;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
@ -48,6 +49,19 @@ public class ReconOperation extends EngineDependentOperation {
|
|||||||
final protected boolean _autoMatch;
|
final protected boolean _autoMatch;
|
||||||
final protected double _minScore;
|
final protected double _minScore;
|
||||||
|
|
||||||
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
|
||||||
|
return new ReconOperation(
|
||||||
|
engineConfig,
|
||||||
|
obj.getString("columnName"),
|
||||||
|
obj.getString("typeID"),
|
||||||
|
obj.getString("typeName"),
|
||||||
|
obj.getBoolean("autoMatch"),
|
||||||
|
obj.getDouble("minScore")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public ReconOperation(
|
public ReconOperation(
|
||||||
JSONObject engineConfig,
|
JSONObject engineConfig,
|
||||||
String columnName,
|
String columnName,
|
||||||
@ -65,27 +79,23 @@ public class ReconOperation extends EngineDependentOperation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Process createProcess(Project project, Properties options) throws Exception {
|
public Process createProcess(Project project, Properties options) throws Exception {
|
||||||
Column column = project.columnModel.getColumnByName(_columnName);
|
|
||||||
if (column == null) {
|
|
||||||
throw new Exception("No column named " + _columnName);
|
|
||||||
}
|
|
||||||
|
|
||||||
String description =
|
|
||||||
"Reconcile cells in column " + column.getHeaderLabel() + " to type " + _typeID;
|
|
||||||
|
|
||||||
return new ReconProcess(
|
return new ReconProcess(
|
||||||
project,
|
project,
|
||||||
getEngineConfig(),
|
getEngineConfig(),
|
||||||
description
|
getBriefDescription()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected String getBriefDescription() {
|
||||||
|
return "Reconcile cells in column " + _columnName + " to type " + _typeID;
|
||||||
|
}
|
||||||
|
|
||||||
public void write(JSONWriter writer, Properties options)
|
public void write(JSONWriter writer, Properties options)
|
||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("recon");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value("Reconcile cells in column " + _columnName + " to type " + _typeID);
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
writer.key("typeID"); writer.value(_typeID);
|
writer.key("typeID"); writer.value(_typeID);
|
||||||
writer.key("typeName"); writer.value(_typeName);
|
writer.key("typeName"); writer.value(_typeName);
|
||||||
|
@ -3,6 +3,7 @@ package com.metaweb.gridworks.model.operations;
|
|||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
|
import org.json.JSONObject;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.metaweb.gridworks.history.Change;
|
import com.metaweb.gridworks.history.Change;
|
||||||
@ -16,12 +17,28 @@ public class SaveProtographOperation extends AbstractOperation {
|
|||||||
|
|
||||||
final protected Protograph _protograph;
|
final protected Protograph _protograph;
|
||||||
|
|
||||||
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
return new SaveProtographOperation(
|
||||||
|
Protograph.reconstruct(obj.getJSONObject("protograph"))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public SaveProtographOperation(
|
public SaveProtographOperation(
|
||||||
Protograph protograph
|
Protograph protograph
|
||||||
) {
|
) {
|
||||||
_protograph = protograph;
|
_protograph = protograph;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void write(JSONWriter writer, Properties options)
|
||||||
|
throws JSONException {
|
||||||
|
|
||||||
|
writer.object();
|
||||||
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
|
writer.key("description"); writer.value("Save protograph");
|
||||||
|
writer.key("protograph"); _protograph.write(writer, options);
|
||||||
|
writer.endObject();
|
||||||
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Save schema skeleton";
|
return "Save schema skeleton";
|
||||||
}
|
}
|
||||||
@ -35,17 +52,6 @@ public class SaveProtographOperation extends AbstractOperation {
|
|||||||
return new HistoryEntry(project, description, SaveProtographOperation.this, change);
|
return new HistoryEntry(project, description, SaveProtographOperation.this, change);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void write(JSONWriter writer, Properties options)
|
|
||||||
throws JSONException {
|
|
||||||
|
|
||||||
writer.object();
|
|
||||||
writer.key("op"); writer.value("save-protograph");
|
|
||||||
writer.key("description"); writer.value("Save protograph");
|
|
||||||
writer.key("protograph"); _protograph.write(writer, options);
|
|
||||||
writer.endObject();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static public class ProtographChange implements Change {
|
static public class ProtographChange implements Change {
|
||||||
private static final long serialVersionUID = -564820111174473901L;
|
private static final long serialVersionUID = -564820111174473901L;
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@ import com.metaweb.gridworks.browsing.RowVisitor;
|
|||||||
import com.metaweb.gridworks.expr.Evaluable;
|
import com.metaweb.gridworks.expr.Evaluable;
|
||||||
import com.metaweb.gridworks.expr.ExpressionUtils;
|
import com.metaweb.gridworks.expr.ExpressionUtils;
|
||||||
import com.metaweb.gridworks.expr.Parser;
|
import com.metaweb.gridworks.expr.Parser;
|
||||||
|
import com.metaweb.gridworks.model.AbstractOperation;
|
||||||
import com.metaweb.gridworks.model.Cell;
|
import com.metaweb.gridworks.model.Cell;
|
||||||
import com.metaweb.gridworks.model.Column;
|
import com.metaweb.gridworks.model.Column;
|
||||||
import com.metaweb.gridworks.model.Project;
|
import com.metaweb.gridworks.model.Project;
|
||||||
@ -22,6 +23,16 @@ public class TextTransformOperation extends EngineDependentMassCellOperation {
|
|||||||
|
|
||||||
final protected String _expression;
|
final protected String _expression;
|
||||||
|
|
||||||
|
static public AbstractOperation reconstruct(Project project, JSONObject obj) throws Exception {
|
||||||
|
JSONObject engineConfig = obj.getJSONObject("engineConfig");
|
||||||
|
|
||||||
|
return new TextTransformOperation(
|
||||||
|
engineConfig,
|
||||||
|
obj.getString("columnName"),
|
||||||
|
obj.getString("expression")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public TextTransformOperation(JSONObject engineConfig, String columnName, String expression) {
|
public TextTransformOperation(JSONObject engineConfig, String columnName, String expression) {
|
||||||
super(engineConfig, columnName, true);
|
super(engineConfig, columnName, true);
|
||||||
_expression = expression;
|
_expression = expression;
|
||||||
@ -31,8 +42,8 @@ public class TextTransformOperation extends EngineDependentMassCellOperation {
|
|||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("op"); writer.value("text-transform");
|
writer.key("op"); writer.value(OperationRegistry.s_opClassToName.get(this.getClass()));
|
||||||
writer.key("description"); writer.value("Text transform on cells in column " + _columnName + " with expression " + _expression);
|
writer.key("description"); writer.value(getBriefDescription());
|
||||||
writer.key("engineConfig"); writer.value(getEngineConfig());
|
writer.key("engineConfig"); writer.value(getEngineConfig());
|
||||||
writer.key("columnName"); writer.value(_columnName);
|
writer.key("columnName"); writer.value(_columnName);
|
||||||
writer.key("expression"); writer.value(_expression);
|
writer.key("expression"); writer.value(_expression);
|
||||||
@ -40,7 +51,7 @@ public class TextTransformOperation extends EngineDependentMassCellOperation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected String getBriefDescription() {
|
protected String getBriefDescription() {
|
||||||
return "Text transform on cells in column " + _columnName + " using " + _expression;
|
return "Text transform on cells in column " + _columnName + " using expression " + _expression;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String createDescription(Column column,
|
protected String createDescription(Column column,
|
||||||
|
Loading…
Reference in New Issue
Block a user