pkghash.h 1.92 KB
Newer Older
1
2
3
/*
 *  pkghash.h
 *
Allan McRae's avatar
Allan McRae committed
4
 *  Copyright (c) 2011-2022 Pacman Development Team <pacman-dev@lists.archlinux.org>
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

20
21
#ifndef ALPM_PKGHASH_H
#define ALPM_PKGHASH_H
22
23
24
25
26
27
28
29

#include <stdlib.h>

#include "alpm.h"
#include "alpm_list.h"


/**
Allan McRae's avatar
Allan McRae committed
30
 * @brief A hash table for holding alpm_pkg_t objects.
31
32
33
34
 *
 * A combination of a hash table and a list, allowing for fast look-up
 * by package name but also iteration over the packages.
 */
35
struct _alpm_pkghash_t {
36
37
38
39
	/** data held by the hash table */
	alpm_list_t **hash_table;
	/** head node of the hash table data in normal list format */
	alpm_list_t *list;
Dan McGee's avatar
Dan McGee committed
40
41
42
43
44
45
	/** number of buckets in hash table */
	unsigned int buckets;
	/** number of entries in hash table */
	unsigned int entries;
	/** max number of entries before a resize is needed */
	unsigned int limit;
46
47
};

48
typedef struct _alpm_pkghash_t alpm_pkghash_t;
49

Dan McGee's avatar
Dan McGee committed
50
alpm_pkghash_t *_alpm_pkghash_create(unsigned int size);
51

52
53
alpm_pkghash_t *_alpm_pkghash_add(alpm_pkghash_t **hash, alpm_pkg_t *pkg);
alpm_pkghash_t *_alpm_pkghash_add_sorted(alpm_pkghash_t **hash, alpm_pkg_t *pkg);
54
alpm_pkghash_t *_alpm_pkghash_remove(alpm_pkghash_t *hash, alpm_pkg_t *pkg, alpm_pkg_t **data);
55

56
void _alpm_pkghash_free(alpm_pkghash_t *hash);
57

58
alpm_pkg_t *_alpm_pkghash_find(alpm_pkghash_t *hash, const char *name);
59

60
#endif /* ALPM_PKGHASH_H */