Enlightenment CVS committal

Author  : raster
Project : e17
Module  : libs/evas

Dir     : e17/libs/evas/src/modules/engines/xrender_xcb


Modified Files:
        evas_engine.c evas_engine_font.c evas_engine_gradient.c 
        evas_engine_image.c 


Log Message:


cedric's cache changes patch

===================================================================
RCS file: /cvs/e/e17/libs/evas/src/modules/engines/xrender_xcb/evas_engine.c,v
retrieving revision 1.14
retrieving revision 1.15
diff -u -3 -r1.14 -r1.15
--- evas_engine.c       17 Jun 2007 03:02:22 -0000      1.14
+++ evas_engine.c       12 Apr 2008 00:32:29 -0000      1.15
@@ -761,35 +761,31 @@
 static void
 eng_font_draw(void *data, void *context, void *surface, void *font, int x, int 
y, int w, int h, int ow, int oh, const char *text)
 {
-   Render_Engine *re;
+   Render_Engine        *re;
+   RGBA_Image           *im;
 
    re = (Render_Engine *)data;
-     {
-       static RGBA_Image *im = NULL;
 
-       if (!im)
-         {
-            im = evas_common_image_new();
-            im->image = evas_common_image_surface_new(im);
-            im->image->no_free = 1;
-         }
-       im->image->w = ((Xcb_Render_Surface *)surface)->w;
-       im->image->h = ((Xcb_Render_Surface *)surface)->h;
-       _xr_render_surface_clips_set((Xcb_Render_Surface *)surface, 
(RGBA_Draw_Context *)context, x, y, w, h);
-       im->image->data = surface;
-       evas_common_draw_context_font_ext_set(context,
-                                             re->xcbinf,
-                                             _xre_font_surface_new,
-                                             _xre_font_surface_free,
-                                             _xre_font_surface_draw);
-       evas_common_font_draw(im, context, font, x, y, text);
-       evas_common_draw_context_font_ext_set(context,
-                                             NULL,
-                                             NULL,
-                                             NULL,
-                                             NULL);
-       evas_common_cpu_end_opt();
-     }
+   im = (RGBA_Image *) evas_cache_image_data(evas_common_image_cache_get(),
+                                             ((Xcb_Render_Surface 
*)surface)->w,
+                                             ((Xcb_Render_Surface 
*)surface)->h,
+                                             surface,
+                                             0, EVAS_COLORSPACE_ARGB8888);
+
+   _xr_render_surface_clips_set((Xcb_Render_Surface *)surface, 
(RGBA_Draw_Context *)context, x, y, w, h);
+
+   evas_common_draw_context_font_ext_set(context,
+                                         re->xcbinf,
+                                         _xre_font_surface_new,
+                                         _xre_font_surface_free,
+                                         _xre_font_surface_draw);
+   evas_common_font_draw(im, context, font, x, y, text);
+   evas_common_draw_context_font_ext_set(context,
+                                         NULL,
+                                         NULL,
+                                         NULL,
+                                         NULL);
+   evas_common_cpu_end_opt();
 }
 
 /* module advertising code */
===================================================================
RCS file: 
/cvs/e/e17/libs/evas/src/modules/engines/xrender_xcb/evas_engine_font.c,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -3 -r1.5 -r1.6
--- evas_engine_font.c  8 Feb 2008 20:42:10 -0000       1.5
+++ evas_engine_font.c  12 Apr 2008 00:32:29 -0000      1.6
@@ -167,7 +167,7 @@
    
    fs = fg->ext_dat;
    if (!fs) return;
-   target_surface = (Xcb_Render_Surface *)(surface->image->data);
+   target_surface = (Xcb_Render_Surface *)(surface->image.data);
    a = (dc->col.col >> 24) & 0xff;
    r = (dc->col.col >> 16) & 0xff;
    g = (dc->col.col >> 8 ) & 0xff;
===================================================================
RCS file: 
/cvs/e/e17/libs/evas/src/modules/engines/xrender_xcb/evas_engine_gradient.c,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -3 -r1.5 -r1.6
--- evas_engine_gradient.c      1 Oct 2006 18:26:47 -0000       1.5
+++ evas_engine_gradient.c      12 Apr 2008 00:32:29 -0000      1.6
@@ -159,18 +159,19 @@
        int op = dc->render_op, cuse = dc->clip.use;
        RGBA_Image  *im;
 
-       im = evas_common_image_create(w, h);
-       if (!im) 
+        im = (RGBA_Image*) 
evas_cache_image_empty(evas_common_image_cache_get());
+       if (!im)
          {
            _xr_render_surface_free(gr->surface);
            gr->surface = NULL;
            return;
          }
+        evas_cache_image_surface_alloc(&im->cache_entry, w, h);
        dc->render_op = _EVAS_RENDER_FILL;
        dc->clip.use = 0;
        evas_common_gradient_draw(im, dc, 0, 0, w, h, gr->grad);
-       _xr_render_surface_argb_pixels_fill(gr->surface, w, h, im->image->data, 
0, 0, w, h);
-       evas_common_image_free(im);
+       _xr_render_surface_argb_pixels_fill(gr->surface, w, h, im->image.data, 
0, 0, w, h);
+        evas_cache_image_drop(&im->cache_entry);
        dc->render_op = op;
        dc->clip.use = cuse;
      }
===================================================================
RCS file: 
/cvs/e/e17/libs/evas/src/modules/engines/xrender_xcb/evas_engine_image.c,v
retrieving revision 1.10
retrieving revision 1.11
diff -u -3 -r1.10 -r1.11
--- evas_engine_image.c 16 Jul 2007 07:25:35 -0000      1.10
+++ evas_engine_image.c 12 Apr 2008 00:32:29 -0000      1.11
@@ -105,8 +105,8 @@
    im->fkey = strdup(buf);
    im->file = (char *)evas_stringshare_add(file);
    if (key) im->key = (char *)evas_stringshare_add(key);
-   im->w = im->im->image->w;
-   im->h = im->im->image->h;
+   im->w = im->im->cache_entry.w;
+   im->h = im->im->cache_entry.h;
    im->references = 1;
    if (lo) im->load_opts = *lo;
    if (im->im->info.comment) im->comment = (char 
*)evas_stringshare_add(im->im->info.comment);
@@ -199,7 +199,7 @@
    if (im->file) evas_stringshare_del(im->file);
    if (im->key) evas_stringshare_del(im->key);
    if (im->fkey) free(im->fkey);
-   if (im->im) evas_cache_image_drop(im->im);
+   if (im->im) evas_cache_image_drop(&im->im->cache_entry);
    if ((im->data) && (im->dirty)) __xre_image_dirty_hash_del(im);
    if ((im->free_data) && (im->data)) free(im->data);
    if (im->surface) _xr_render_surface_free(im->surface);
@@ -263,8 +263,8 @@
        if (!im->im) im->im = evas_common_load_image_from_file(im->file, 
im->key, &(im->load_opts));
        if (im->im)
          {
-            evas_common_load_image_data_from_file(im->im);
-            data = im->im->image->data;
+             evas_cache_image_load_data(&im->im->cache_entry);
+            data = im->im->image.data;
          }
      }
    if (!data) return NULL;
@@ -272,7 +272,7 @@
    if (im2) im2->alpha = im->alpha;
    if ((im->im) && (!im->dirty))
      {
-       evas_cache_image_drop(im->im);
+       evas_cache_image_drop(&im->im->cache_entry);
        im->im = NULL;
      }
    return im2;
@@ -337,7 +337,7 @@
        RGBA_Image *im_old;
 
        im_old = im->im;
-       im->im = evas_cache_image_empty(evas_common_image_cache_get());
+       im->im = (RGBA_Image*) 
evas_cache_image_empty(evas_common_image_cache_get());
        if (!im->im)
          {
             im->im = im_old;
@@ -348,11 +348,8 @@
               }
             return;
          }
-        im->im->image->w = w;
-        im->im->image->h = h;
-        evas_common_image_surface_alloc(im->im->image);
-       evas_common_load_image_data_from_file(im_old);
-       if (im_old->image->data)
+        evas_cache_image_load_data(&im->im->cache_entry);
+       if (im_old->image.data)
          {
             int x = 0, y = 0, ww, hh;
 
@@ -363,11 +360,11 @@
          }
        im->free_data = 1;
         /* FIXME: Hum ? */
-       im->data = im->im->image->data;
-       im->im->image->data = NULL;
-        evas_cache_image_drop(im->im);
+       im->data = im->im->image.data;
+       im->im->image.data = NULL;
+        evas_cache_image_drop(&im->im->cache_entry);
        im->im = NULL;
-        evas_cache_image_drop(im_old);
+        evas_cache_image_drop(&im_old->cache_entry);
        __xre_image_dirty_hash_add(im);
      }
    else
@@ -391,8 +388,8 @@
        if (!im->im) im->im = evas_common_load_image_from_file(im->file, 
im->key, &(im->load_opts));
        if (im->im)
          {
-            evas_common_load_image_data_from_file(im->im);
-            data = im->im->image->data;
+             evas_cache_image_load_data(&im->im->cache_entry);
+            data = im->im->image.data;
          }
      }
    return data;
@@ -426,11 +423,11 @@
      }
    else
      {
-       if (im->im) imdata = im->im->image->data;
+       if (im->im) imdata = im->im->image.data;
        if (data == imdata) return;
        if (im->im)
          {
-             evas_cache_image_drop(im->im);
+             evas_cache_image_drop(&im->im->cache_entry);
             im->im = NULL;
          }
      }
@@ -525,8 +522,8 @@
        if (!im->im) im->im = evas_common_load_image_from_file(im->file, 
im->key, &(im->load_opts));
        if (im->im)
          {
-            evas_common_load_image_data_from_file(im->im);
-            data = im->im->image->data;
+             evas_cache_image_load_data(&im->im->cache_entry);
+            data = im->im->image.data;
          }
      }
    if (!data) return;
@@ -584,7 +581,7 @@
                           1, 1);
    if ((im->im) && (!im->dirty))
      {
-        evas_cache_image_drop(im->im);
+        evas_cache_image_drop(&im->im->cache_entry);
        im->im = NULL;
      }
 }



-------------------------------------------------------------------------
This SF.net email is sponsored by the 2008 JavaOne(SM) Conference 
Don't miss this year's exciting event. There's still time to save $100. 
Use priority code J8TL2D2. 
http://ad.doubleclick.net/clk;198757673;13503038;p?http://java.sun.com/javaone
_______________________________________________
enlightenment-cvs mailing list
enlightenment-cvs@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs

Reply via email to