/** * Implements the CFML Function querysetcell */ package railo.runtime.functions.query; import railo.runtime.PageContext; import railo.runtime.exp.FunctionException; import railo.runtime.exp.PageException; import railo.runtime.functions.BIF; import railo.runtime.op.Caster; import railo.runtime.type.Collection; import railo.runtime.type.Query; import railo.runtime.type.QueryImpl; import railo.runtime.type.Struct; import railo.runtime.type.StructImpl; import railo.runtime.type.util.KeyConstants; public final class QueryConvertForGrid extends BIF { private static final long serialVersionUID = 871091293736619034L; public static Struct call(PageContext pc , Query src, double dpage,double dpageSize) throws PageException { int page=(int) dpage; int pageSize=(int) dpageSize; if(page<1) { throw new FunctionException(pc,"QueryConvertForGrid",2,"page","page must be a positive number now ("+page+")"); } int start = ((page-1)*pageSize)+1; int end = start+pageSize; Collection.Key[] srcColumns = src.getColumnNames(); int srcRows = src.getRowCount(); int trgRows = srcRows-start+1; if (trgRows > pageSize) trgRows = pageSize; if(trgRows<0)trgRows=0; Query trg=new QueryImpl(srcColumns,trgRows,src.getName()); int trgRow=0; for (int srcRow = start; (srcRow <= end) && (srcRow <= srcRows); srcRow++) { trgRow++; for (int col = 0; col < srcColumns.length; col++){ trg.setAtEL( srcColumns[col], trgRow, src.getAt(srcColumns[col],srcRow, null)); } } Struct sct = new StructImpl(); sct.setEL(KeyConstants._QUERY, trg); sct.setEL("TOTALROWCOUNT", new Integer(srcRows)); return sct; } @Override public Object invoke(PageContext pc, Object[] args) throws PageException { return call(pc,Caster.toQuery(args[0]),Caster.toDoubleValue(args[1]),Caster.toDoubleValue(args[2])); } }