2003/12/29 03:25:45
[org.ibex.core.git] / src / org / xwt / translators / Freetype.java
index ed52857..3bff602 100644 (file)
@@ -6,70 +6,40 @@ import java.util.zip.*;
 import java.util.*;
 import org.bouncycastle.util.encoders.Base64;
 
+import org.xwt.mips.Runtime;
+
 // FEATURE: use streams, not memoryfont's
 // FEATURE: kerning pairs
 public class Freetype {
 
     public Freetype() { }
 
-    private static byte[] image = null;
-    private static final int FONT_RESERVED = 256*1024;
-
-    private org.xwt.mips.Interpreter vm = null;
+    private int mem_allocated = 0;
+    private Runtime vm = null;
 
     private Res loadedStream = null;
 
     public void loadFontByteStream(Res res) {
         try {
-            Log.log(this, "loading font " + res);
+            Log.info(this, "loading font " + res);
             loadedStream = res;
             InputStream is = res.getInputStream();
             byte[] fontstream = InputStreamToByteArray.convert(is);
-            if (image == null) image = InputStreamToByteArray.convert(Main.builtin.getInputStream("freetype.mips"));
-            vm = new org.xwt.mips.Interpreter(image);
-            int baseAddr = vm.sbrk(FONT_RESERVED);
+            vm = new MIPSApps();
+            int baseAddr = vm.sbrk(fontstream.length);
             vm.copyout(fontstream, baseAddr, fontstream.length);
             vm.setUserInfo(0, baseAddr);
             vm.setUserInfo(1, fontstream.length);
-            vm.start(new String[]{ "freetype.mips" });
+            vm.start(new String[]{ "freetype" });
             vm.execute();
+            if(vm.getState() == Runtime.DONE) throw new Error("Freetype VM exited: " + vm.exitStatus());
         } catch (Exception e) {
-            Log.log(this, e);
+            Log.info(this, e);
         }
     }
 
     public synchronized void renderGlyph(Font.Glyph glyph) throws IOException {
-        int width = 0;
-        int height = 0;
-        byte[] data = null;
-        File cacheFile = null;
         try {
-            String key = glyph.font.res.getCacheKey() + ":" + glyph.c;
-            key = new String(Base64.encode(key.getBytes()));
-            cacheFile = new java.io.File(System.getProperty("user.home") +
-                                         java.io.File.separatorChar + ".xwt" +
-                                         java.io.File.separatorChar + "caches" +
-                                         java.io.File.separatorChar + "glyphs" +
-                                         java.io.File.separatorChar +
-                                         key);
-            new java.io.File(cacheFile.getParent()).mkdirs();
-        } catch (Res.NotCacheableException e) {
-            Log.log(Freetype.class, "note: glyph not cacheable");
-        }
-
-        if (cacheFile != null && cacheFile.exists()) {
-            DataInputStream dis = new DataInputStream(new FileInputStream(cacheFile));
-            width = dis.readInt();
-            height = dis.readInt();
-            glyph.font.max_ascent = dis.readInt();
-            glyph.font.max_descent = dis.readInt();
-            glyph.baseline = dis.readInt();
-            glyph.advance = dis.readInt();
-            data = new byte[width * height];
-            if (width != 0 && height != 0) dis.readFully(data);
-            
-        } else try {
-            System.out.println("cache miss!");
             if (loadedStream != glyph.font.res) loadFontByteStream(glyph.font.res);
             vm.setUserInfo(2, (int)glyph.c);
             vm.setUserInfo(3, (int)glyph.c);
@@ -81,29 +51,15 @@ public class Freetype {
             glyph.baseline = vm.getUserInfo(10);
             glyph.advance = vm.getUserInfo(11);
             
-            width = vm.getUserInfo(6);
-            height = vm.getUserInfo(7);
-
-            data = new byte[width * height];
+            glyph.width = vm.getUserInfo(6);
+            glyph.height = vm.getUserInfo(7);
+            
+            glyph.data = new byte[glyph.width * glyph.height];
             int addr = vm.getUserInfo(5);
-            vm.copyin(addr,data,width*height);
-            File tmp = new File(cacheFile.getCanonicalPath() + ".tmp");
-            DataOutputStream dis = new DataOutputStream(new FileOutputStream(tmp));
-            dis.writeInt(width);
-            dis.writeInt(height);
-            dis.writeInt(glyph.font.max_ascent);
-            dis.writeInt(glyph.font.max_descent);
-            dis.writeInt(glyph.baseline);
-            dis.writeInt(glyph.advance);
-            if (width != 0 && height != 0) dis.write(data, 0, data.length);
-            dis.close();
-            tmp.renameTo(cacheFile);
-
+            vm.copyin(addr, glyph.data, glyph.width * glyph.height);
+            
         } catch (Exception e) {
-            Log.log(this, e);
+            Log.info(this, e);
         }
-
-        if (width == 0 || height == 0) Log.log(Freetype.class, "warning glyph has zero width/height");
-        glyph.p = Platform.createAlphaOnlyPicture(data, width, height);
     }
 }