1 /* Copyright Massachusetts Institute of Technology 1985 */
8 #include <X11/Xresource.h>
25 * XMakeAssoc - Insert data into an XAssocTable keyed on an XId.
26 * Data is inserted into the table only once. Redundant inserts are
27 * meaningless (but cause no problems). The queue in each association
28 * bucket is sorted (lowest XId to highest XId).
30 XMakeAssoc(dpy
, table
, x_id
, data
)
31 register Display
*dpy
;
32 register XAssocTable
*table
;
34 register caddr_t data
;
37 register XAssoc
*bucket
;
38 register XAssoc
*Entry
;
39 register XAssoc
*new_entry
;
41 /* Hash the XId to get the bucket number. */
42 hash
= x_id
& (table
->size
- 1);
43 /* Look up the bucket to get the entries in that bucket. */
44 bucket
= &table
->buckets
[hash
];
45 /* Get the first entry in the bucket. */
48 /* If (Entry != bucket), the bucket is empty so make */
49 /* the new entry the first entry in the bucket. */
50 /* if (Entry == bucket), the we have to search the */
52 if (Entry
!= bucket
) {
53 /* The bucket isn't empty, begin searching. */
54 /* If we leave the for loop then we have either passed */
55 /* where the entry should be or hit the end of the bucket. */
56 /* In either case we should then insert the new entry */
57 /* before the current value of "Entry". */
58 for (; Entry
!= bucket
; Entry
= Entry
->next
) {
59 if (Entry
->x_id
== x_id
) {
60 /* Entry has the same XId... */
61 if (Entry
->display
== dpy
) {
62 /* Entry has the same Display... */
63 /* Therefore there is already an */
64 /* entry with this XId and Display, */
65 /* reset its data value and return. */
69 /* We found an association with the right */
70 /* id but the wrong display! */
73 /* If the current entry's XId is greater than the */
74 /* XId of the entry to be inserted then we have */
75 /* passed the location where the new XId should */
77 if (Entry
->x_id
> x_id
) break;
81 /* If we are here then the new entry should be inserted just */
82 /* before the current value of "Entry". */
83 /* Create a new XAssoc and load it with new provided data. */
84 new_entry
= (XAssoc
*) xmalloc(sizeof(XAssoc
));
85 new_entry
->display
= dpy
;
86 new_entry
->x_id
= x_id
;
87 new_entry
->data
= data
;
89 /* Insert the new entry. */
90 emacs_insque((struct qelem
*)new_entry
, (struct qelem
*)Entry
->prev
);
93 /* arch-tag: d7e3fb8a-f3b3-4c5d-a307-75ca67ec1b49
94 (do not change this comment) */