1/* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License, Version 1.0 only 6 * (the "License"). You may not use this file except in compliance 7 * with the License. 8 * 9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10 * or http://www.opensolaris.org/os/licensing. 11 * See the License for the specific language governing permissions 12 * and limitations under the License. 13 * 14 * When distributing Covered Code, include this CDDL HEADER in each 15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16 * If applicable, add the following below this CDDL HEADER, with the 17 * fields enclosed by brackets "[]" replaced with your own identifying 18 * information: Portions Copyright [yyyy] [name of copyright owner] 19 * 20 * CDDL HEADER END 21 */ 22/* 23 * Copyright (c) 2002-2003, Network Appliance, Inc. All rights reserved. 24 */ 25 26/* 27 * Copyright 2003 Sun Microsystems, Inc. All rights reserved. 28 * Use is subject to license terms. 29 */ 30 31/* 32 * 33 * HEADER: dat_dictionary.h 34 * 35 * PURPOSE: dictionary data structure 36 * 37 * $Id: dat_dictionary.h,v 1.6 2003/08/05 19:01:48 jlentini Exp $ 38 */ 39 40#ifndef _DAT_DICTIONARY_H_ 41#define _DAT_DICTIONARY_H_ 42 43#pragma ident "%Z%%M% %I% %E% SMI" 44 45#include <dat_osd.h> 46 47#ifdef __cplusplus 48extern "C" { 49#endif 50 51/* 52 * 53 * Typedefs 54 * 55 */ 56 57typedef struct DAT_DICTIONARY DAT_DICTIONARY; 58typedef void *DAT_DICTIONARY_DATA; 59typedef void *DAT_DICTIONARY_ENTRY; 60 61 62/* 63 * 64 * Function Prototypes 65 * 66 */ 67 68extern DAT_RETURN 69dat_dictionary_create( 70 OUT DAT_DICTIONARY **pp_dictionary); 71 72extern DAT_RETURN 73dat_dictionary_destroy( 74 IN DAT_DICTIONARY *p_dictionary); 75 76extern DAT_RETURN 77dat_dictionary_size( 78 IN DAT_DICTIONARY *p_dictionary, 79 OUT DAT_COUNT *p_size); 80 81extern DAT_RETURN 82dat_dictionary_entry_create( 83 OUT DAT_DICTIONARY_ENTRY *p_entry); 84 85extern DAT_RETURN 86dat_dictionary_entry_destroy( 87 IN DAT_DICTIONARY_ENTRY entry); 88 89extern DAT_RETURN 90dat_dictionary_insert( 91 IN DAT_DICTIONARY *p_dictionary, 92 IN DAT_DICTIONARY_ENTRY entry, 93 IN const DAT_PROVIDER_INFO *key, 94 IN DAT_DICTIONARY_DATA data); 95 96extern DAT_RETURN 97dat_dictionary_search( 98 IN DAT_DICTIONARY *p_dictionary, 99 IN const DAT_PROVIDER_INFO *key, 100 OUT DAT_DICTIONARY_DATA *p_data); 101 102extern DAT_RETURN 103dat_dictionary_enumerate( 104 IN DAT_DICTIONARY *p_dictionary, 105 IN DAT_DICTIONARY_DATA array[], 106 IN DAT_COUNT array_size); 107 108 109extern DAT_RETURN 110dat_dictionary_remove( 111 IN DAT_DICTIONARY *p_dictionary, 112 IN DAT_DICTIONARY_ENTRY *p_entry, 113 IN const DAT_PROVIDER_INFO *key, 114 OUT DAT_DICTIONARY_DATA *p_data); 115 116#ifdef __cplusplus 117} 118#endif 119 120#endif /* _DAT_DICTIONARY_H_ */ 121