package org.geogebra.common.kernel.statistics; import org.geogebra.common.kernel.Kernel; import org.geogebra.common.kernel.arithmetic.Command; import org.geogebra.common.kernel.arithmetic.ExpressionNode; import org.geogebra.common.kernel.arithmetic.Variable; import org.geogebra.common.kernel.commands.CommandProcessor; import org.geogebra.common.kernel.geos.GeoElement; import org.geogebra.common.kernel.geos.GeoElementSpreadsheet; import org.geogebra.common.main.MyError; import org.geogebra.common.plugin.Operation; /** * CellRange[ <start cell>, <end cell> ], e.g. CellRange[A1, B2] */ public class CmdCellRange extends CommandProcessor { /** * Create new command processor * * @param kernel * kernel */ public CmdCellRange(Kernel kernel) { super(kernel); } @Override public GeoElement[] process(Command c) throws MyError { int n = c.getArgumentNumber(); switch (n) { case 2: ExpressionNode[] args = c.getArguments(); // check if we really have two leafs String start = spreadsheetLabel(args[0], c); String end = spreadsheetLabel(args[1], c); // both start and end need to have valid spreadsheet coordinates AlgoCellRange algo = app.getSpreadsheetTableModel() .getCellRangeManager() .getAlgoCellRange(cons, c.getLabel(), start, end); GeoElement[] ret = { algo.getList() }; return ret; default: throw argNumErr(app, c, n); } } private String spreadsheetLabel(ExpressionNode expressionNode, Command c) { if (expressionNode.getOperation() != Operation.NO_OPERATION || !expressionNode.getLeft().isVariable()) { throw argErr(app, c, expressionNode); } String cell = ((Variable) expressionNode.getLeft()).getName(); if (GeoElementSpreadsheet.isSpreadsheetLabel(cell)) { return cell; } throw argErr(app, c, expressionNode); } }