eina: restore ABI compatibility.
authorCedric BAIL <cedric.bail@free.fr>
Mon, 11 Apr 2011 17:45:01 +0000 (17:45 +0000)
committerCedric BAIL <cedric.bail@free.fr>
Mon, 11 Apr 2011 17:45:01 +0000 (17:45 +0000)
NOTE: if you did update the EFL during the last 3 hours, you will need to
      recompile them all at once.

SVN revision: 58561

legacy/eina/src/include/eina_inline_mempool.x
legacy/eina/src/lib/eina_mempool.c

index 72e70fe131bbd96af40ca1c1e34c3f8da5d26c14..e9f20b550b997881d5cacc79e9ba3285576558e3 100644 (file)
@@ -26,6 +26,9 @@
  */
 
 /* Memory Pool */
+typedef struct _Eina_Mempool_Backend_ABI1 Eina_Mempool_Backend_ABI1;
+typedef struct _Eina_Mempool_Backend_ABI2 Eina_Mempool_Backend_ABI2;
+
 struct _Eina_Mempool_Backend
 {
    const char *name;
@@ -39,10 +42,28 @@ struct _Eina_Mempool_Backend
    void (*repack)(void *data, Eina_Mempool_Repack_Cb cb, void *cb_data);
 };
 
+struct _Eina_Mempool_Backend_ABI1
+{
+   const char *name;
+   void *(*init)(const char *context, const char *options, va_list args);
+   void (*free)(void *data, void *element);
+   void *(*alloc)(void *data, unsigned int size);
+   void *(*realloc)(void *data, void *element, unsigned int size);
+   void (*garbage_collect)(void *data);
+   void (*statistics)(void *data);
+   void (*shutdown)(void *data);
+};
+
+struct _Eina_Mempool_Backend_ABI2
+{
+   void (*repack)(void *data, Eina_Mempool_Repack_Cb cb, void *cb_data);
+};
+
 struct _Eina_Mempool
 {
-   Eina_Mempool_Backend backend;
+   Eina_Mempool_Backend_ABI1 backend;
    void *backend_data;
+   Eina_Mempool_Backend_ABI2 backend2;
 };
 
 /**
index ddeabca6b4987d3f89d7473aed374c9be2e764d8..32a6831651500d063375087b9af84597bab17a0a 100644 (file)
@@ -80,8 +80,19 @@ _new_va(const char *name,
    if (!mp)
       goto on_error;
 
-   /* FIXME why backend is not a pointer? */
-   mp->backend = *be;
+   /* Work around ABI incompability introduced in Eina 1.1 */
+#define SBP(Property) mp->backend.Property = be->Property;
+   SBP(name);
+   SBP(init);
+   SBP(free);
+   SBP(alloc);
+   SBP(realloc);
+   SBP(garbage_collect);
+   SBP(statistics);
+   SBP(shutdown);
+#undef SBP
+   mp->backend2.repack = be->repack;
+   
    mp->backend_data = mp->backend.init(context, options, args);
 
    return mp;
@@ -324,7 +335,7 @@ EAPI void eina_mempool_repack(Eina_Mempool *mp, Eina_Mempool_Repack_Cb cb, void
    EINA_SAFETY_ON_NULL_RETURN(mp);
    EINA_SAFETY_ON_NULL_RETURN(mp->backend.shutdown);
    DBG("mp=%p", mp);
-   mp->backend.repack(mp->backend_data, cb, data);
+   mp->backend2.repack(mp->backend_data, cb, data);
 }
 
 EAPI void eina_mempool_gc(Eina_Mempool *mp)