fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * CDDL HEADER START
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * The contents of this file are subject to the terms of the
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Common Development and Distribution License (the "License").
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * You may not use this file except in compliance with the License.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * See the License for the specific language governing permissions
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * and limitations under the License.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * When distributing Covered Code, include this CDDL HEADER in each
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * If applicable, add the following below this CDDL HEADER, with the
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * fields enclosed by brackets "[]" replaced with your own identifying
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * information: Portions Copyright [yyyy] [name of copyright owner]
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * CDDL HEADER END
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Use is subject to license terms.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Fortestatic int calc_hash(const char *);
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte hash = (hash_node_t **)calloc(HASH_PRIME, sizeof (hash_node_t *));
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Fortensc_insert_node(hash_node_t **hash, void *data, const char *key)
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte node = (hash_node_t *)malloc(sizeof (hash_node_t));
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte return (-1);
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * possible enhancement would be to search
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * in this index for a duplicate
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Description:
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Searches the hash to find a node.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Return values:
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * 0 if not found.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * pointer to node if found.
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte /* did we find it? */
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Fortensc_remove_all(hash_node_t **hash, void (*callback)(void *))
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte for (i = 0; i < HASH_PRIME; i++) {
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte/* ---------------------------------------------------------------------- */
fcf3ce441efd61da9bb2884968af01cb7c1452ccJohn Forte * Basic rotating hash, as per Knuth.