/* $OpenBSD: expand.c,v 1.1 2009/11/08 23:15:03 gilles Exp $ */ /* * Copyright (c) 2009 Gilles Chehade * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include "smtpd.h" struct expand_node * expandtree_lookup(struct expandtree *expandtree, struct expand_node *node) { struct expand_node key; key = *node; return RB_FIND(expandtree, expandtree, &key); } void expandtree_insert(struct expandtree *expandtree, struct expand_node *node) { node->id = generate_uid(); RB_INSERT(expandtree, expandtree, node); } void expandtree_remove(struct expandtree *expandtree, struct expand_node *node) { struct expand_node *p; p = expandtree_lookup(expandtree, node); if (p == NULL) fatalx("expandtree_remove: node doesn't exist."); RB_REMOVE(expandtree, expandtree, node); } int expand_cmp(struct expand_node *e1, struct expand_node *e2) { if (e1->id < e2->id) return -1; if (e1->id > e2->id) return 1; return 0; } RB_GENERATE(expandtree, expand_node, entry, expand_cmp);