/* * Copyright © 2008 Ian Osgood <iano@quirkster.com> * Copyright © 2008 Josh Triplett <josh@freedesktop.org> * Copyright © 2008 Thomas Hunger <hto@arco.de> * * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, copy, * modify, merge, publish, distribute, sublicense, and/or sell copies * of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * Except as contained in this notice, the names of the authors or * their institutions shall not be used in advertising or otherwise to * promote the sale, use or other dealings in this Software without * prior written authorization from the authors. */ #include <stdlib.h> #include "xcb_wm.h" typedef struct node node; struct node { node *next; uint32_t key; void *value; }; struct table_t { node *head; }; table_t *alloc_table() { return calloc(1, sizeof(table_t)); } void free_table(table_t *table) { free(table); } int table_put(table_t *table, uint32_t key, void *value) { node *record = malloc(sizeof(node)); if(!record) return 0; record->next = table->head; record->key = key; record->value = value; table->head = record; return 1; } void *table_get(table_t *table, uint32_t key) { node *cur; for(cur = table->head; cur; cur = cur->next) if(cur->key == key) return cur->value; return 0; } void *table_remove(table_t *table, uint32_t key) { node **cur; for(cur = &table->head; *cur; cur = &(*cur)->next) if((*cur)->key == key) { node *tmp = *cur; void *ret = tmp->value; *cur = (*cur)->next; free(tmp); return ret; } return 0; }