Changeset: 976e16e04954 for MonetDB
URL: https://dev.monetdb.org/hg/MonetDB/rev/976e16e04954
Modified Files:
        sql/storage/bat/bat_storage.c
Branch: Dec2023
Log Message:

Partial backout of changeset a10aa621f79d (only the incorrect bit).
A bug had accidentally been introduced in merge_updates.


diffs (58 lines):

diff --git a/sql/storage/bat/bat_storage.c b/sql/storage/bat/bat_storage.c
--- a/sql/storage/bat/bat_storage.c
+++ b/sql/storage/bat/bat_storage.c
@@ -730,6 +730,18 @@ merge_updates( BAT *ui, BAT **UV, BAT *o
        int err = 0;
        BAT *uv = *UV;
        BUN cnt = BATcount(ui)+BATcount(oi);
+       BAT *ni = bat_new(TYPE_oid, cnt, SYSTRANS);
+       BAT *nv = uv?bat_new(uv->ttype, cnt, SYSTRANS):NULL;
+
+       if (!ni || (uv && !nv)) {
+               bat_destroy(ni);
+               bat_destroy(nv);
+               bat_destroy(ui);
+               bat_destroy(uv);
+               bat_destroy(oi);
+               bat_destroy(ov);
+               return NULL;
+       }
        BATiter uvi;
        BATiter ovi;
 
@@ -751,35 +763,6 @@ merge_updates( BAT *ui, BAT **UV, BAT *o
                uipt = uii.base;
        if (!BATtdensebi(&oii))
                oipt = oii.base;
-
-       if (uiseqb == oiseqb && uie == oie) { /* full overlap, no values */
-               if (uv) {
-                       bat_iterator_end(&uvi);
-                       bat_iterator_end(&ovi);
-               }
-               bat_iterator_end(&uii);
-               bat_iterator_end(&oii);
-               if (uv) {
-                       *UV = uv;
-               } else {
-                       bat_destroy(uv);
-               }
-               bat_destroy(oi);
-               bat_destroy(ov);
-               return ui;
-       }
-       BAT *ni = bat_new(TYPE_oid, cnt, SYSTRANS);
-       BAT *nv = uv?bat_new(uv->ttype, cnt, SYSTRANS):NULL;
-
-       if (!ni || (uv && !nv)) {
-               bat_destroy(ni);
-               bat_destroy(nv);
-               bat_destroy(ui);
-               bat_destroy(uv);
-               bat_destroy(oi);
-               bat_destroy(ov);
-               return NULL;
-       }
        while (uip < uie && oip < oie && !err) {
                oid uiid = (uipt)?uipt[uip]: uiseqb+uip;
                oid oiid = (oipt)?oipt[oip]: oiseqb+oip;
_______________________________________________
checkin-list mailing list -- checkin-list@monetdb.org
To unsubscribe send an email to checkin-list-le...@monetdb.org

Reply via email to