Annotation of 43BSD/ingres/source/iutil/insert_mbtree.c, revision 1.1

1.1     ! root        1: # include      <ingres.h>
        !             2: # include      <access.h>
        !             3: # include      <catalog.h>
        !             4: # include      <btree.h>
        !             5: # include      <sccs.h>
        !             6: 
        !             7: SCCSID(@(#)insert_mbtree.c     8.1     12/31/84)
        !             8: 
        !             9: insert_mbtree(d, btree, lid, tid, tidpos)
        !            10: 
        !            11: register DESC *d;
        !            12: char *btree;
        !            13: long lid[];
        !            14: long *tid;
        !            15: TID *tidpos;
        !            16: {
        !            17:        register int    i, j;
        !            18:        long            page;
        !            19:        long            l;
        !            20:        long            last_lid();
        !            21:        struct locator  tidloc;
        !            22:        long            ntid;
        !            23:        long            t;
        !            24:        struct BTreeNode        junk;
        !            25: 
        !            26:        page = RT;
        !            27:        for (i = 0; i < d->reldum.reldim - 1; ++i)
        !            28:        {
        !            29:                if (lid[i] && lid[i+1])
        !            30:                {
        !            31:                        if ((t = get_tid(page, lid[i], &tidloc)) < -1)
        !            32:                                return(-1);
        !            33:                        if (t != -1)
        !            34:                                page = t;
        !            35:                }
        !            36:                if (!lid[i] || t == -1 || !lid[i+1])
        !            37:                {
        !            38:                        for (j = i; j < d->reldum.reldim - 1; ++j)
        !            39:                        {
        !            40:                                if (j != i)
        !            41:                                        lid[j] = 1;
        !            42:                                else if (t == -1 || !lid[i])
        !            43:                                        lid[j] = last_lid(page);
        !            44:                                insert_btree(btree, page, lid[j], &ntid, tidpos, j + 2);
        !            45:                                page = ntid;
        !            46:                        }
        !            47:                        lid[d->reldum.reldim - 1] = 1;
        !            48:                        break;
        !            49:                }
        !            50:        }
        !            51:        l = last_lid(page);
        !            52:        if (lid[d->reldum.reldim - 1] < 0 || lid[d->reldum.reldim - 1] >  l)
        !            53:                return(-1);
        !            54:        if (!lid[d->reldum.reldim - 1])
        !            55:                lid[d->reldum.reldim - 1] = l;
        !            56:        insert_btree(btree, page, lid[d->reldum.reldim - 1], tid, tidpos, 0);
        !            57: 
        !            58:        return (0);
        !            59: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.