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

com.scudata.expression.fn.convert.ToAsc 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.convert;

import com.scudata.array.ConstArray;
import com.scudata.array.IArray;
import com.scudata.array.IntArray;
import com.scudata.array.StringArray;
import com.scudata.common.MessageManager;
import com.scudata.common.ObjectCache;
import com.scudata.common.RQException;
import com.scudata.dm.Context;
import com.scudata.expression.Function;
import com.scudata.expression.IParam;
import com.scudata.resources.EngineMessage;

/**
 * ȡ?ַ?????ָ??λ???ַ???unicodeֵ??
 * asc( string{, nPos} ) ȡ?ַ???stringָ??λ??nPos???ַ?unicodeֵ???????ascii?ַ??򷵻?ascii?롣
 * @author runqian
 *
 */
public class ToAsc extends Function {
	/**
	 * ??????ʽ????Ч?ԣ???Ч???׳??쳣
	 */
	public void checkValidity() {
		if (param == null) {
			MessageManager mm = EngineMessage.get();
			throw new RQException("asc" + mm.getMessage("function.missingParam"));
		}
	}

	public Object calculate(Context ctx) {
		String str;
		int pos = 0;
		if (param.isLeaf()) {
			Object result1 = param.getLeafExpression().calculate(ctx);
			if (!(result1 instanceof String)) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("asc" + mm.getMessage("function.paramTypeError"));
			}
			
			str = (String)result1;
		} else {
			if (param.getSubSize() != 2) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("asc" + mm.getMessage("function.invalidParam"));
			}
			
			IParam sub1 = param.getSub(0);
			if (sub1 == null) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("asc" + mm.getMessage("function.invalidParam"));
			}
			
			Object result1 = sub1.getLeafExpression().calculate(ctx);
			if (!(result1 instanceof String)) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("asc" + mm.getMessage("function.paramTypeError"));
			}
			
			str = (String)result1;
			IParam sub2 = param.getSub(1);
			if (sub2 != null) {
				Object result2 = sub2.getLeafExpression().calculate(ctx);
				if (!(result2 instanceof Number)) {
					MessageManager mm = EngineMessage.get();
					throw new RQException("acs" + mm.getMessage("function.paramTypeError"));
				}
				
				pos = ((Number)result2).intValue() - 1;
			}
		}
		
		if (str.length() > pos && pos >= 0) {
			return ObjectCache.getInteger(str.charAt(pos));
		} else {
			return null;
		}
	}
	
	/**
	 * ??????????еĽ??
	 * @param ctx ??????????
	 * @return IArray
	 */
	public IArray calculateAll(Context ctx) {
		int pos = 0;
		IArray array;
		
		if (param.isLeaf()) {
			array = param.getLeafExpression().calculateAll(ctx);
		} else {
			if (param.getSubSize() != 2) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("asc" + mm.getMessage("function.invalidParam"));
			}
			
			IParam sub1 = param.getSub(0);
			IParam sub2 = param.getSub(1);
			if (sub1 == null || sub2 == null) {
				MessageManager mm = EngineMessage.get();
				throw new RQException("asc" + mm.getMessage("function.invalidParam"));
			}
			
			array = sub1.getLeafExpression().calculateAll(ctx);
			IArray posArray = sub2.getLeafExpression().calculateAll(ctx);
			if (posArray instanceof ConstArray) {
				Object obj = posArray.get(1);
				if (!(obj instanceof Number)) {
					MessageManager mm = EngineMessage.get();
					throw new RQException("acs" + mm.getMessage("function.paramTypeError"));
				}
				
				pos = ((Number)obj).intValue() - 1;
				if (pos < 0) {
					MessageManager mm = EngineMessage.get();
					throw new RQException("asc" + mm.getMessage("function.invalidParam"));
				}
			} else if (posArray.isNumberArray()) {
				return asc(array, posArray);
			} else {
				MessageManager mm = EngineMessage.get();
				throw new RQException("acs" + mm.getMessage("function.paramTypeError"));
			}
		}
		
		int len = array.size();
		IntArray result = new IntArray(len);
		
		if (array instanceof StringArray) {
			StringArray strArray = (StringArray)array;
			for (int i = 1; i <= len; ++i) {
				String str = strArray.getString(i);
				if (str != null && str.length() > pos) {
					result.pushInt(str.charAt(pos));
				} else {
					result.pushNull();
				}
			}
		} else {
			for (int i = 1; i <= len; ++i) {
				Object obj = array.get(i);
				if (obj instanceof String) {
					String str = (String)obj;
					if (str.length() > pos) {
						result.pushInt(str.charAt(pos));
					} else {
						
					}
				} else if (obj == null) {
					result.pushNull();
				} else {
					MessageManager mm = EngineMessage.get();
					throw new RQException("acs" + mm.getMessage("function.paramTypeError"));
				}
			}
		}
		
		result.setTemporary(true);
		return result;
	}
	
	private static IArray asc(IArray array, IArray posArray) {
		int len = array.size();
		IntArray result = new IntArray(len);
		
		if (array instanceof StringArray) {
			StringArray strArray = (StringArray)array;
			for (int i = 1; i <= len; ++i) {
				String str = strArray.getString(i);
				int pos = posArray.getInt(i);
				if (pos < 0) {
					MessageManager mm = EngineMessage.get();
					throw new RQException("asc" + mm.getMessage("function.invalidParam"));
				}
				
				if (str != null && str.length() > pos) {
					result.pushInt(str.charAt(pos));
				} else {
					result.pushNull();
				}
			}
		} else {
			for (int i = 1; i <= len; ++i) {
				Object obj = array.get(i);
				if (obj instanceof String) {
					String str = (String)obj;
					int pos = posArray.getInt(i);
					if (pos < 0) {
						MessageManager mm = EngineMessage.get();
						throw new RQException("asc" + mm.getMessage("function.invalidParam"));
					}

					if (str.length() > pos) {
						result.pushInt(str.charAt(pos));
					} else {
						
					}
				} else if (obj == null) {
					result.pushNull();
				} else {
					MessageManager mm = EngineMessage.get();
					throw new RQException("acs" + mm.getMessage("function.paramTypeError"));
				}
			}
		}
		
		result.setTemporary(true);
		return result;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy