Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Do not enforce that the idx is within the bounds for xbt_dynar_insert since the dynar...
[simgrid.git] / src / xbt / dynar.c
index bead04b..45c3190 100644 (file)
@@ -463,7 +463,6 @@ static XBT_INLINE void *_xbt_dynar_insert_at_ptr(xbt_dynar_t const dynar,
 
   _sanity_check_dynar(dynar);
   _sanity_check_idx(idx);
-  _check_sloppy_inbound_idx(dynar, idx);
 
   old_used = dynar->used;
   new_used = old_used + 1;
@@ -725,6 +724,29 @@ XBT_INLINE void xbt_dynar_sort(xbt_dynar_t dynar,
   _dynar_unlock(dynar);
 }
 
+/*
+ * Return 0 if d1 and d2 are equal and 1 if not equal
+ */
+XBT_INLINE int xbt_dynar_compare(xbt_dynar_t d1, xbt_dynar_t d2,
+                                       int(*compar)(const void *, const void *))
+{
+       int i ;
+       int size;
+       if((!d1) && (!d2)) return 0;
+       if((!d1) || (!d2)) return 1;
+       if((d1->elmsize)!=(d2->elmsize)) return 1; // xbt_die
+       if(xbt_dynar_length(d1) != xbt_dynar_length(d2)) return 1;
+
+       size = xbt_dynar_length(d1);
+       for(i=0;i<size;i++)
+       {
+               void *data1 = xbt_dynar_get_as(d1, i, void *);
+               void *data2 = xbt_dynar_get_as(d2, i, void *);
+               if(!compar(data1,data2)) return 1;
+       }
+       return 0;
+}
+
 #ifdef SIMGRID_TEST
 
 #define NB_ELEM 5000