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

com.scudata.expression.mfn.dw.Attach Maven / Gradle / Ivy

Go to download

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

There is a newer version: 20241126
Show newest version
package com.scudata.expression.mfn.dw;

import java.io.IOException;

import com.scudata.common.MessageManager;
import com.scudata.common.RQException;
import com.scudata.dm.Context;
import com.scudata.dw.ColPhyTable;
import com.scudata.dw.IPhyTable;
import com.scudata.expression.IParam;
import com.scudata.expression.PhyTableFunction;
import com.scudata.resources.EngineMessage;

/**
 * ȡ???????????Ϊ??????Ӹ???
 * T.attach(T??,C??)
 * @author RunQian
 *
 */
public class Attach extends PhyTableFunction {
	public Object calculate(Context ctx) {
		if (param == null) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("attach" + mm.getMessage("function.missingParam"));
		} else if (param.isLeaf()) {
			String tableName = param.getLeafExpression().getIdentifierName();
			IPhyTable table = this.table;
			table = table.getAnnexTable(tableName);
			if (table == null) {
				MessageManager mm = EngineMessage.get();
				throw new RQException(tableName + mm.getMessage("dw.tableNotExist"));
			}

			return table;
		}
		
		IParam sub0 = param.getSub(0);
		if (sub0 == null) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("attach" + mm.getMessage("function.invalidParam"));
		}
		
		//??ʱ???ʱ???ܽ???????
		if (table instanceof ColPhyTable && ((ColPhyTable)table).getGroupTable().hasTimeKey()) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("attach" + mm.getMessage("function.invalidParam"));
		}
		
		String tableName = sub0.getLeafExpression().getIdentifierName();
		int size = param.getSubSize();
		String []fields = new String[size - 1];
		int []serialBytesLen = new int[size - 1];
		
		for (int i = 1; i < size; ++i) {
			IParam sub = param.getSub(i);
			if (sub == null) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("attach" + mm.getMessage("function.invalidParam"));
			} else if (sub.isLeaf()) {
				fields[i - 1] = sub.getLeafExpression().getIdentifierName();
			} else {
				IParam p0 = sub.getSub(0);
				IParam p1 = sub.getSub(1);
				if (p0 == null || p1 == null) {
					MessageManager mm = EngineMessage.get();
					throw new RQException("attach" + mm.getMessage("function.invalidParam"));
				}
				
				fields[i - 1] = p0.getLeafExpression().getIdentifierName();
				Object obj = p1.getLeafExpression().calculate(ctx);
				if (!(obj instanceof Number)) {
					MessageManager mm = EngineMessage.get();
					throw new RQException("attach" + mm.getMessage("function.paramTypeError"));
				}
				
				serialBytesLen[i - 1] = ((Number)obj).intValue();
			}
		}
		
		try {
			return table.createAnnexTable(fields, serialBytesLen, tableName);
		} catch (IOException e) {
			throw new RQException(e.getMessage(), e);
		}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy