All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.scudata.expression.mfn.op.AttachGroupn Maven / Gradle / Ivy

Go to download

SPL(Structured Process Language) A programming language specially for structured data computing.

There is a newer version: 20240823
Show newest version
package com.scudata.expression.mfn.op;

import com.scudata.common.MessageManager;
import com.scudata.common.RQException;
import com.scudata.dm.Context;
import com.scudata.dm.Sequence;
import com.scudata.dm.op.Groupn;
import com.scudata.expression.Expression;
import com.scudata.expression.IParam;
import com.scudata.expression.OperableFunction;
import com.scudata.resources.EngineMessage;

/**
 * ???α??ܵ????Ӱ???ŷ??????㣬???鰴???д????Ӧ?????????
 * op.groupn(x;F) op.groupn(x;C) op???α??ܵ???F???ļ????У?C?ǹܵ?????
 * @author RunQian
 *
 */
public class AttachGroupn extends OperableFunction {
	public Object calculate(Context ctx) {
		if (param == null) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("groupn" + mm.getMessage("function.missingParam"));
		}
		
		if (param.getSubSize() != 2) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("groupn" + mm.getMessage("function.invalidParam"));
		}
		
		IParam sub0 = param.getSub(0);
		IParam sub1 = param.getSub(1);
		if (sub0 == null || !sub0.isLeaf() || sub1 == null || !sub1.isLeaf()) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("groupn" + mm.getMessage("function.invalidParam"));
		}
		
		Expression exp = sub0.getLeafExpression();
		Object val = sub1.getLeafExpression().calculate(ctx);
		Sequence out = null;
		if (val instanceof Sequence) {
			out = (Sequence)val;
		} else if (val != null) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("groupn" + mm.getMessage("function.paramTypeError"));
		}

		Groupn groupn = new Groupn(this, exp, out);
		if (cs != null) {
			groupn.setCurrentCell(cs.getCurrent());
		}
		
		return operable.addOperation(groupn, ctx);
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy