123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- /*
- * SGI FREE SOFTWARE LICENSE B (Version 2.0, Sept. 18, 2008)
- * Copyright (C) 1991-2000 Silicon Graphics, Inc. All Rights Reserved.
- *
- * 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 including the dates of first publication and
- * either this permission notice or a reference to
- * http://oss.sgi.com/projects/FreeB/
- * 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
- * SILICON GRAPHICS, INC. 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 name of Silicon Graphics, Inc.
- * shall not be used in advertising or otherwise to promote the sale, use or
- * other dealings in this Software without prior written authorization from
- * Silicon Graphics, Inc.
- */
- /*
- ** Author: Eric Veach, July 1994.
- **
- */
- #include <stddef.h>
- #include "dict-list.h"
- #include "memalloc.h"
- /* really __gl_dictListNewDict */
- Dict *dictNewDict( void *frame,
- int (*leq)(void *frame, DictKey key1, DictKey key2) )
- {
- Dict *dict = (Dict *) memAlloc( sizeof( Dict ));
- DictNode *head;
- if (dict == NULL) return NULL;
- head = &dict->head;
- head->key = NULL;
- head->next = head;
- head->prev = head;
- dict->frame = frame;
- dict->leq = leq;
- return dict;
- }
- /* really __gl_dictListDeleteDict */
- void dictDeleteDict( Dict *dict )
- {
- DictNode *node, *next;
- for( node = dict->head.next; node != &dict->head; node = next ) {
- next = node->next;
- memFree( node );
- }
- memFree( dict );
- }
- /* really __gl_dictListInsertBefore */
- DictNode *dictInsertBefore( Dict *dict, DictNode *node, DictKey key )
- {
- DictNode *newNode;
- do {
- node = node->prev;
- } while( node->key != NULL && ! (*dict->leq)(dict->frame, node->key, key));
- newNode = (DictNode *) memAlloc( sizeof( DictNode ));
- if (newNode == NULL) return NULL;
- newNode->key = key;
- newNode->next = node->next;
- node->next->prev = newNode;
- newNode->prev = node;
- node->next = newNode;
- return newNode;
- }
- /* really __gl_dictListDelete */
- void dictDelete( Dict *dict, DictNode *node ) /*ARGSUSED*/
- {
- node->next->prev = node->prev;
- node->prev->next = node->next;
- memFree( node );
- }
- /* really __gl_dictListSearch */
- DictNode *dictSearch( Dict *dict, DictKey key )
- {
- DictNode *node = &dict->head;
- do {
- node = node->next;
- } while( node->key != NULL && ! (*dict->leq)(dict->frame, key, node->key));
- return node;
- }
|