Annotation of researchv9/X11/src/X.V11R1/lib/oldX/XDelAssoc.c, revision 1.1

1.1     ! root        1: #include "copyright.h"
        !             2: 
        !             3: /* $Header: XDelAssoc.c,v 10.17 87/09/11 07:56:34 toddb Exp $ */
        !             4: /* Copyright    Massachusetts Institute of Technology    1985  */
        !             5: 
        !             6: #include "Xlibint.h"
        !             7: #include "X10.h"
        !             8: void remque();
        !             9: struct qelem {
        !            10:        struct    qelem *q_forw;
        !            11:        struct    qelem *q_back;
        !            12:        char q_data[1];
        !            13: };
        !            14: 
        !            15: /*
        !            16:  * XDeleteAssoc - Delete an association in an XAssocTable keyed on
        !            17:  * an XId.  An association may be removed only once.  Redundant
        !            18:  * deletes are meaningless (but cause no problems).
        !            19:  */
        !            20: XDeleteAssoc(dpy, table, x_id)
        !            21:         register Display *dpy;
        !            22:        register XAssocTable *table;
        !            23:        register XID x_id;
        !            24: {
        !            25:        int hash;
        !            26:        register XAssoc *bucket;
        !            27:        register XAssoc *Entry;
        !            28: 
        !            29:        /* Hash the XId to get the bucket number. */
        !            30:        hash = x_id & (table->size - 1);
        !            31:        /* Look up the bucket to get the entries in that bucket. */
        !            32:        bucket = &table->buckets[hash];
        !            33:        /* Get the first entry in the bucket. */
        !            34:        Entry = bucket->next;
        !            35: 
        !            36:        /* Scan through the entries in the bucket for the right XId. */
        !            37:        for (; Entry != bucket; Entry = Entry->next) {
        !            38:                if (Entry->x_id == x_id) {
        !            39:                        /* We have the right XId. */
        !            40:                        if (Entry->display == dpy) {
        !            41:                                /* We have the right display. */
        !            42:                                /* We have the right entry! */
        !            43:                                /* Remove it from the queue and */
        !            44:                                /* free the entry. */
        !            45:                                remque((struct qelem *)Entry);
        !            46:                                Xfree((char *)Entry);
        !            47:                                return;
        !            48:                        }
        !            49:                        /* Oops, identical XId's on different displays! */
        !            50:                        continue;
        !            51:                }
        !            52:                if (Entry->x_id > x_id) {
        !            53:                        /* We have gone past where it should be. */
        !            54:                        /* It is apparently not in the table. */
        !            55:                        return;
        !            56:                }
        !            57:        }
        !            58:        /* It is apparently not in the table. */
        !            59:        return;
        !            60: }
        !            61: 

unix.superglobalmegacorp.com

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