package mobvista.dmp.function import java.util import com.googlecode.aviator.runtime.`type`.{AviatorJavaType, AviatorObject} import com.googlecode.aviator.runtime.function.FunctionUtils import mobvista.dmp.util.BytesRefUtil import org.apache.hadoop.hive.serde2.columnar.BytesRefArrayWritable import scala.collection.mutable.ArrayBuffer class SplitRCFileInputData extends CommonFunction { override def getName = "split_rcfile_input_data" override def call(env: util.Map[String, AnyRef], arg1: AviatorObject, arg2 : AviatorObject) = { val line = FunctionUtils.getJavaObject(arg1, env).asInstanceOf[BytesRefArrayWritable] val indices = FunctionUtils.getStringValue(arg2, env) val buffer = new ArrayBuffer[String] splitFun(indices, ",") .foreach(index => { buffer += BytesRefUtil.BytesRefWritableToString(line.get(index.toInt)) }) env.put("array", buffer.toArray) new AviatorJavaType("array") } }