Fri, 13 Mar 2020 22:11:34 -0500
Remove stringref from the docs.
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
1 | /* |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
2 | * Purple |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
3 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
4 | * Purple is the legal property of its developers, whose names are too |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
5 | * numerous to list here. Please refer to the COPYRIGHT file distributed |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
6 | * with this source distribution |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
7 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
8 | * This program is free software; you can redistribute it and/or modify |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
9 | * it under the terms of the GNU General Public License as published by |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
10 | * the Free Software Foundation; either version 2 of the License, or (at |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
11 | * your option) any later version. |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
12 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
13 | * This program is distributed in the hope that it will be useful, but |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
14 | * WITHOUT ANY WARRANTY; without even the implied warranty of |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
16 | * General Public License for more details. |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
17 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
18 | * You should have received a copy of the GNU General Public License |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
19 | * along with this program; if not, write to the Free Software |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
21 | */ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
22 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
23 | #ifndef PURPLE_MEMORY_POOL_H |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
24 | #define PURPLE_MEMORY_POOL_H |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
25 | /** |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
26 | * SECTION:memorypool |
|
35773
8c63d334ad44
Comments: PurpleTrie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35772
diff
changeset
|
27 | * @include:memorypool.h |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
28 | * @section_id: libpurple-memorypool |
|
35773
8c63d334ad44
Comments: PurpleTrie
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35772
diff
changeset
|
29 | * @short_description: a container for a large number of small chunks of memory |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
30 | * @title: Memory pools |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
31 | * |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
32 | * A #PurpleMemoryPool allows allocating many small objects within a single |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
33 | * memory range and releasing them all at once using a single call. This |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
34 | * prevents memory fragmentation and improves performance when used properly. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
35 | * It's purpose is to act as an internal storage for other object private |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
36 | * structures, like tree nodes, string chunks, list elements. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
37 | * |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
38 | * Current implementation is not optimized for releasing individual objects, |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
39 | * so it may be extremely inefficient, when misused. On every memory allocation, |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
40 | * it checks if there is enough space in current block. If there is not enough |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
41 | * room here, it creates another block of memory. On pool destruction or calling |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
42 | * #purple_memory_pool_cleanup, the whole block chain will be freed, using only |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
43 | * one #g_free call for every block. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
44 | */ |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
45 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
46 | #include <glib-object.h> |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
47 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
48 | #define PURPLE_TYPE_MEMORY_POOL (purple_memory_pool_get_type()) |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
49 | #define PURPLE_MEMORY_POOL(obj) \ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
50 | (G_TYPE_CHECK_INSTANCE_CAST((obj), PURPLE_TYPE_MEMORY_POOL, PurpleMemoryPool)) |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
51 | #define PURPLE_MEMORY_POOL_CLASS(klass) \ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
52 | (G_TYPE_CHECK_CLASS_CAST((klass), PURPLE_TYPE_MEMORY_POOL, PurpleMemoryPoolClass)) |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
53 | #define PURPLE_IS_MEMORY_POOL(obj) \ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
54 | (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_MEMORY_POOL)) |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
55 | #define PURPLE_IS_MEMORY_POOL_CLASS(klass) \ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
56 | (G_TYPE_CHECK_CLASS_TYPE((klass), PURPLE_TYPE_MEMORY_POOL)) |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
57 | #define PURPLE_MEMORY_POOL_GET_CLASS(obj) \ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
58 | (G_TYPE_INSTANCE_GET_CLASS((obj), PURPLE_TYPE_MEMORY_POOL, PurpleMemoryPoolClass)) |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
59 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
60 | typedef struct _PurpleMemoryPool PurpleMemoryPool; |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
61 | typedef struct _PurpleMemoryPoolClass PurpleMemoryPoolClass; |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
62 | |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
63 | /** |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
64 | * PurpleMemoryPool: |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
65 | * |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
66 | * The memory pool object instance. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
67 | */ |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
68 | struct _PurpleMemoryPool |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
69 | { |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
70 | /*< private >*/ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
71 | GObject parent_instance; |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
72 | }; |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
73 | |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
74 | /** |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
75 | * PurpleMemoryPoolClass: |
|
35774
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
76 | * @palloc: alloates memory for a specific memory pool subclass, |
|
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
77 | * see #purple_memory_pool_alloc. |
|
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
78 | * @pfree: frees memory allocated within a pool, see #purple_memory_pool_free. |
|
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
79 | * May be %NULL. |
|
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
80 | * @cleanup: frees (or marks as unused) all memory allocated within a pool. |
|
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
81 | * See #purple_memory_pool_cleanup. |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
82 | * |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
83 | * Base class for #PurpleMemoryPool objects. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
84 | */ |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
85 | struct _PurpleMemoryPoolClass |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
86 | { |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
87 | /*< private >*/ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
88 | GObjectClass parent_class; |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
89 | |
|
35774
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
90 | /*< public >*/ |
|
35652
1dc7369ff9f9
Trie, memory pool: we don't really need block_size pref to be that strict
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35651
diff
changeset
|
91 | gpointer (*palloc)(PurpleMemoryPool *pool, gsize size, guint alignment); |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
92 | gpointer (*pfree)(PurpleMemoryPool *pool, gpointer mem); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
93 | void (*cleanup)(PurpleMemoryPool *pool); |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
94 | |
|
35774
9227a7757e92
Comments: PurpleSmiley
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35773
diff
changeset
|
95 | /*< private >*/ |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
96 | void (*purple_reserved1)(void); |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
97 | void (*purple_reserved2)(void); |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
98 | void (*purple_reserved3)(void); |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
99 | void (*purple_reserved4)(void); |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
100 | }; |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
101 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
102 | G_BEGIN_DECLS |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
103 | |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
104 | /** |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
105 | * purple_memory_pool_get_type: |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
106 | * |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
107 | * Returns: the #GType for a #PurpleMemoryPool. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
108 | */ |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
109 | GType |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
110 | purple_memory_pool_get_type(void); |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
111 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
112 | /** |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
113 | * purple_memory_pool_new: |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
114 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
115 | * Creates a new memory pool. |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
116 | * |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
117 | * Returns: the new #PurpleMemoryPool. |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
118 | */ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
119 | PurpleMemoryPool * |
|
35652
1dc7369ff9f9
Trie, memory pool: we don't really need block_size pref to be that strict
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35651
diff
changeset
|
120 | purple_memory_pool_new(void); |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
121 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
122 | /** |
|
35666
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
123 | * purple_memory_pool_set_block_size: |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
124 | * @pool: the memory pool. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
125 | * @block_size: the new default block size. |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
126 | * |
|
35666
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
127 | * Sets new default block size for a memory pool. You might want to call this |
|
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
128 | * before any allocation, to have it applied to the every created block. |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
129 | */ |
|
35666
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
130 | void |
|
ca4afaddaffa
Memory pool: fix some issues
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35653
diff
changeset
|
131 | purple_memory_pool_set_block_size(PurpleMemoryPool *pool, gulong block_size); |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
132 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
133 | /** |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
134 | * purple_memory_pool_alloc: |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
135 | * @pool: the memory pool. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
136 | * @size: the size of memory to be allocated. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
137 | * @alignment: the alignment of memory block (should be a power of two). |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
138 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
139 | * Allocates an aligned memory block within a pool. |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
140 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
141 | * Returns: the pointer to a memory block. This should be freed with |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
142 | * a call to #purple_memory_pool_free. |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
143 | */ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
144 | gpointer |
|
35652
1dc7369ff9f9
Trie, memory pool: we don't really need block_size pref to be that strict
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35651
diff
changeset
|
145 | purple_memory_pool_alloc(PurpleMemoryPool *pool, gsize size, guint alignment); |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
146 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
147 | /** |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
148 | * purple_memory_pool_alloc0: |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
149 | * @pool: the memory pool. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
150 | * @size: the size of memory to be allocated. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
151 | * @alignment: the alignment of memory block (should be a power of two). |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
152 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
153 | * Allocates an aligned memory block within a pool and sets its contents to |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
154 | * zeros. |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
155 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
156 | * Returns: the pointer to a memory block. This should be freed with |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
157 | * a call to #purple_memory_pool_free. |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
158 | */ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
159 | gpointer |
|
35652
1dc7369ff9f9
Trie, memory pool: we don't really need block_size pref to be that strict
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35651
diff
changeset
|
160 | purple_memory_pool_alloc0(PurpleMemoryPool *pool, gsize size, guint alignment); |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
161 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
162 | /** |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
163 | * purple_memory_pool_free: |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
164 | * @pool: the memory pool. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
165 | * @mem: the pointer to a memory block. |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
166 | * |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
167 | * Frees a memory allocated within a memory pool. This can be a no-op in certain |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
168 | * implementations. Thus, it don't need to be called in every case. Thus, the |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
169 | * freed memory is wasted until you call #purple_memory_pool_cleanup |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
170 | * or destroy the @pool. |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
171 | */ |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
172 | void |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
173 | purple_memory_pool_free(PurpleMemoryPool *pool, gpointer mem); |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
174 | |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
175 | /** |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
176 | * purple_memory_pool_cleanup: |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
177 | * @pool: the memory pool. |
|
35653
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
178 | * |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
179 | * Marks all memory allocated within a memory pool as not used. It may free |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
180 | * resources, but don't have to. |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
181 | */ |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
182 | void |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
183 | purple_memory_pool_cleanup(PurpleMemoryPool *pool); |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
184 | |
|
b4a35c405e95
Trie: states allocation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35652
diff
changeset
|
185 | /** |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
186 | * purple_memory_pool_strdup: |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
187 | * @pool: the memory pool. |
|
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
188 | * @str: the string to duplicate. |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
189 | * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
190 | * Duplicates a string using a memory allocated within a memory pool. If @str is |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
191 | * %NULL, it returns %NULL. The returned string should be freed with g_free() |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
192 | * when no longer needed. |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
193 | * |
|
35772
2224568d8bd2
Comments: memory pool
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35666
diff
changeset
|
194 | * Returns: a newly-allocated copy of @str. |
|
35651
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
195 | */ |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
196 | gchar * |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
197 | purple_memory_pool_strdup(PurpleMemoryPool *pool, const gchar *str); |
|
95f34a3f4172
Initial trie class implementation
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
35649
diff
changeset
|
198 | |
|
35649
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
199 | G_END_DECLS |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
200 | |
|
eff51bb998b0
Implement PurpleMemoryPool class
Tomasz Wasilczyk <twasilczyk@pidgin.im>
parents:
diff
changeset
|
201 | #endif /* PURPLE_MEMORY_POOL_H */ |