2003/09/25 12:13:46
[org.ibex.core.git] / src / org / xwt / plat / GCJ.cc
index 3050a2b..bba04f8 100644 (file)
@@ -14,12 +14,13 @@ extern "C" {
 #include <setjmp.h>
 #include "jpeglib.h"
 }
+#include <org/xwt/Platform.h>
+#include <org/xwt/Picture.h>
 #include <org/xwt/plat/GCJ.h>
 #include <java/io/InputStream.h>
 #include <java/io/ByteArrayInputStream.h>
 #include <java/lang/RuntimeException.h>
 #include <org/xwt/plat/GCJ.h>
-#include <org/xwt/plat/GCJ$JPEG.h>
 
 
 
@@ -42,7 +43,9 @@ java::io::InputStream* org::xwt::plat::GCJ::_getBuiltinInputStream() {
 
 typedef struct {
     struct jpeg_source_mgr pub;
+    /* FIXME
     org::xwt::plat::GCJ$JPEG* myself;
+    */
 } source_manager;
 
 void jpeg_error_handler (j_common_ptr cinfo) {
@@ -54,6 +57,7 @@ void term_source (j_decompress_ptr cinfo) { }
 void init_source (j_decompress_ptr cinfo) { }
 
 boolean fill_input_buffer (j_decompress_ptr cinfo) {
+  /* FIXME
   source_manager* src = (source_manager*)cinfo->src;
   jint nbytes = src->myself->is->read(src->myself->buffer, 0, INPUT_BUF_SIZE);
   if (nbytes <= 0) {
@@ -64,6 +68,7 @@ boolean fill_input_buffer (j_decompress_ptr cinfo) {
   }
   src->pub.next_input_byte = (JOCTET*)elements(src->myself->buffer);
   src->pub.bytes_in_buffer = nbytes;
+  */
   return 1;
 }
 
@@ -79,8 +84,11 @@ void skip_input_data (j_decompress_ptr cinfo, long num_bytes) {
   }
 }
 
-void org::xwt::plat::GCJ$JPEG::nativeDecompress() {
+org::xwt::Picture* org::xwt::plat::GCJ::_decodeJPEG(java::io::InputStream* is, jstring name) {
     struct jpeg_decompress_struct cinfo;
+    jintArray data;
+    jint width;
+    jint height;
   
     // set up our error handler
     struct jpeg_error_mgr error_handler;
@@ -90,14 +98,18 @@ void org::xwt::plat::GCJ$JPEG::nativeDecompress() {
     jpeg_create_decompress(&cinfo);
     try {
        source_manager src;
+       /*
        buffer = JvNewByteArray(INPUT_BUF_SIZE);
+       */
        src.pub.init_source = init_source;
        src.pub.fill_input_buffer = fill_input_buffer;
        src.pub.skip_input_data = skip_input_data;
        src.pub.resync_to_restart = jpeg_resync_to_restart;
        src.pub.term_source = term_source;
+       /*
        src.myself = this;
        src.pub.next_input_byte = (JOCTET*)elements(buffer);
+       */
        src.pub.bytes_in_buffer = 0;
        cinfo.src = (jpeg_source_mgr*)&src;
 
@@ -123,6 +135,7 @@ void org::xwt::plat::GCJ$JPEG::nativeDecompress() {
         throw t;
     }
     jpeg_destroy_decompress(&cinfo);
+    return org::xwt::Platform::createPicture(data, width, height);
 }
 
 // C++ new/delete operators (JvMalloc never fails)