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

com.scudata.expression.fn.parallel.SyncFile 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.fn.parallel;

import com.scudata.common.*;
import com.scudata.dm.*;
import com.scudata.expression.*;
import com.scudata.parallel.PartitionUtil;
import com.scudata.resources.EngineMessage;

/**
 * syncfile(hs,p)	ͬ????ǰ????p·???µ??ļ????ֻ?????hs??p·?????ý??µ??滻?Ͼɵģ???ɾ??????
 * ·??p????Ϊ???·???? ???·??ʱ?? ?????·????p????ʡ??
 * @author Joancy
 *
 */
public class SyncFile extends Function {
	public Node optimize(Context ctx) {
		param.optimize(ctx);
		return this;
	}

	/**
	 * ??????ʽ????Ч?ԣ???Ч???׳??쳣
	 */
	public void checkValidity() {
		if (param == null) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("sync" + mm.getMessage("function.missingParam"));
		}
	}

	public Object calculate(Context ctx) {
		Machines mcHS = new Machines();
		String path = null;
		
		if (param.isLeaf()) {
			Object obj = param.getLeafExpression().calculate(ctx);
			mcHS.set(obj);
		} else if (param.getSubSize() == 2) {
			IParam hParam = param.getSub(0);
			if (hParam == null) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("sync" + mm.getMessage("function.invalidParam"));
			} else {
				Object obj = hParam.getLeafExpression().calculate(ctx);
				mcHS.set(obj);
			}
			
			IParam sub1 = param.getSub(1);
			if (sub1 != null) {
				Object op = sub1.getLeafExpression().calculate(ctx);
				if(op instanceof String){
					path = (String)op;
				} else {
					MessageManager mm = EngineMessage.get();
					throw new RQException("sync" + mm.getMessage("function.paramTypeError"));
				}
			}
		} else {
			MessageManager mm = EngineMessage.get();
			throw new RQException("sync" + mm.getMessage("function.invalidParam"));
		}
		
		PartitionUtil.syncTo(mcHS, path);
		return Boolean.TRUE;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy