/* xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */ /* vim: set ts=2: */ package com.sheetjs; import java.lang.Integer; import java.lang.StringBuilder; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; import org.mozilla.javascript.Context; import org.mozilla.javascript.NativeArray; import org.mozilla.javascript.NativeObject; import org.mozilla.javascript.Scriptable; public class JSHelper { static String read_file(String file) throws IOException { byte[] b = Files.readAllBytes(Paths.get(file)); System.out.println(b.length); StringBuilder sb = new StringBuilder(); for(int i = 0; i < b.length; ++i) sb.append(Character.toString((char)(b[i] < 0 ? b[i] + 256 : b[i]))); return sb.toString(); } static Object get_object(String path, Object base) throws ObjectNotFoundException { int idx = path.indexOf("."); Scriptable b = (Scriptable)base; if(idx == -1) return b.get(path, b); Object o = b.get(path.substring(0,idx), b); if(o == Scriptable.NOT_FOUND) throw new ObjectNotFoundException("not found: |" + path.substring(0,idx) + "|" + Integer.toString(idx)); return get_object(path.substring(idx+1), (NativeObject)o); } static Object[] get_array(String path, Object base) throws ObjectNotFoundException { NativeArray arr = (NativeArray)get_object(path, base); Object[] out = new Object[(int)arr.getLength()]; int idx; for(Object o : arr.getIds()) out[idx = (Integer)o] = arr.get(idx, arr); return out; } static String[] get_string_array(String path, Object base) throws ObjectNotFoundException { NativeArray arr = (NativeArray)get_object(path, base); String[] out = new String[(int)arr.getLength()]; int idx; for(Object o : arr.getIds()) out[idx = (Integer)o] = arr.get(idx, arr).toString(); return out; } public static void close() { Context.exit(); } }