source: trunk/include/talloc.h @ 177

Last change on this file since 177 was 168, checked in by tim, 15 years ago

merged remaining smb_deps items into regfi

began formatting API comments for use with doxygen

  • Property svn:keywords set to Id
File size: 7.4 KB
Line 
1/*
2   Unix SMB/CIFS implementation.
3   Samba temporary memory allocation functions
4
5   Copyright (C) Andrew Tridgell 2004-2005
6   Copyright (C) Stefan Metzmacher 2006
7   Copyright (C) Timothy D. Morgan 2009
8   
9     ** NOTE! The following LGPL license applies to the talloc library.
10     ** This does NOT imply that all of reglookup is released under the LGPL
11   
12   This library is free software; you can redistribute it and/or
13   modify it under the terms of the GNU Lesser General Public
14   License as published by the Free Software Foundation; either
15   version 3 of the License, or (at your option) any later version.
16
17   This library is distributed in the hope that it will be useful,
18   but WITHOUT ANY WARRANTY; without even the implied warranty of
19   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
20   Lesser General Public License for more details.
21
22   You should have received a copy of the GNU Lesser General Public
23   License along with this library; if not, see <http://www.gnu.org/licenses/>.
24*/
25/* $Id: talloc.h 168 2010-03-03 00:08:42Z tim $ */
26
27#ifndef _TALLOC_H_
28#define _TALLOC_H_
29
30#include <stdlib.h>
31#include <stdio.h>
32#include <stdarg.h>
33#include <string.h>
34#include <stdbool.h>
35
36#ifndef MAX
37#define MAX(a,b) ((a)>(b)?(a):(b))
38#endif
39
40#ifndef MIN
41#define MIN(a,b) ((a)<(b)?(a):(b))
42#endif
43
44/*
45  this uses a little trick to allow __LINE__ to be stringified
46*/
47#ifndef __location__
48#define __TALLOC_STRING_LINE1__(s)    #s
49#define __TALLOC_STRING_LINE2__(s)   __TALLOC_STRING_LINE1__(s)
50#define __TALLOC_STRING_LINE3__  __TALLOC_STRING_LINE2__(__LINE__)
51#define __location__ __FILE__ ":" __TALLOC_STRING_LINE3__
52#endif
53
54#ifndef TALLOC_DEPRECATED
55#define TALLOC_DEPRECATED 0
56#endif
57
58#ifndef PRINTF_ATTRIBUTE
59#if (__GNUC__ >= 3)
60/** Use gcc attribute to check printf fns.  a1 is the 1-based index of
61 * the parameter containing the format, and a2 the index of the first
62 * argument. Note that some gcc 2.x versions don't handle this
63 * properly **/
64#define PRINTF_ATTRIBUTE(a1, a2) __attribute__ ((format (__printf__, a1, a2)))
65#else
66#define PRINTF_ATTRIBUTE(a1, a2)
67#endif
68#endif
69
70#define talloc_set_destructor(ptr, function) \
71        _talloc_set_destructor((ptr), (int (*)(void *))(function))
72#define _TALLOC_TYPEOF(ptr) void *
73#define talloc_steal(ctx, ptr) (_TALLOC_TYPEOF(ptr))_talloc_steal((ctx),(ptr))
74
75#define talloc_reference(ctx, ptr) (_TALLOC_TYPEOF(ptr))_talloc_reference((ctx),(ptr))
76#define talloc_move(ctx, ptr) (_TALLOC_TYPEOF(*(ptr)))_talloc_move((ctx),(void *)(ptr))
77
78/* useful macros for creating type checked pointers */
79#define talloc(ctx, type) (type *)talloc_named_const(ctx, sizeof(type), #type)
80#define talloc_size(ctx, size) talloc_named_const(ctx, size, __location__)
81#define talloc_ptrtype(ctx, ptr) (_TALLOC_TYPEOF(ptr))talloc_size(ctx, sizeof(*(ptr)))
82
83#define talloc_new(ctx) talloc_named_const(ctx, 0, "talloc_new: " __location__)
84
85#define talloc_zero(ctx, type) (type *)_talloc_zero(ctx, sizeof(type), #type)
86#define talloc_zero_size(ctx, size) _talloc_zero(ctx, size, __location__)
87
88#define talloc_zero_array(ctx, type, count) (type *)_talloc_zero_array(ctx, sizeof(type), count, #type)
89#define talloc_array(ctx, type, count) (type *)_talloc_array(ctx, sizeof(type), count, #type)
90#define talloc_array_size(ctx, size, count) _talloc_array(ctx, size, count, __location__)
91#define talloc_array_ptrtype(ctx, ptr, count) (_TALLOC_TYPEOF(ptr))talloc_array_size(ctx, sizeof(*(ptr)), count)
92
93#define talloc_realloc(ctx, p, type, count) (type *)_talloc_realloc_array(ctx, p, sizeof(type), count, #type)
94#define talloc_realloc_size(ctx, ptr, size) _talloc_realloc(ctx, ptr, size, __location__)
95
96#define talloc_memdup(t, p, size) _talloc_memdup(t, p, size, __location__)
97
98#define talloc_set_type(ptr, type) talloc_set_name_const(ptr, #type)
99#define talloc_get_type(ptr, type) (type *)talloc_check_name(ptr, #type)
100
101#define talloc_find_parent_bytype(ptr, type) (type *)talloc_find_parent_byname(ptr, #type)
102
103/* The following definitions come from talloc.c  */
104void *_talloc(const void *context, size_t size);
105void *talloc_pool(const void *context, size_t size);
106void _talloc_set_destructor(const void *ptr, int (*destructor)(void *));
107int talloc_increase_ref_count(const void *ptr);
108size_t talloc_reference_count(const void *ptr);
109void *_talloc_reference(const void *context, const void *ptr);
110int talloc_unlink(const void *context, void *ptr);
111const char *talloc_set_name(const void *ptr, const char *fmt, ...) PRINTF_ATTRIBUTE(2,3);
112void talloc_set_name_const(const void *ptr, const char *name);
113void *talloc_named(const void *context, size_t size, 
114                   const char *fmt, ...) PRINTF_ATTRIBUTE(3,4);
115void *talloc_named_const(const void *context, size_t size, const char *name);
116const char *talloc_get_name(const void *ptr);
117void *talloc_check_name(const void *ptr, const char *name);
118void *talloc_parent(const void *ptr);
119const char *talloc_parent_name(const void *ptr);
120void *talloc_init(const char *fmt, ...) PRINTF_ATTRIBUTE(1,2);
121int talloc_free(void *ptr);
122void talloc_free_children(void *ptr);
123void *_talloc_realloc(const void *context, void *ptr, size_t size, const char *name);
124void *_talloc_steal(const void *new_ctx, const void *ptr);
125void *_talloc_move(const void *new_ctx, const void *pptr);
126size_t talloc_total_size(const void *ptr);
127size_t talloc_total_blocks(const void *ptr);
128void talloc_report_depth_cb(const void *ptr, int depth, int max_depth,
129                            void (*callback)(const void *ptr,
130                                             int depth, int max_depth,
131                                             int is_ref,
132                                             void *private_data),
133                            void *private_data);
134void talloc_report_depth_file(const void *ptr, int depth, int max_depth, FILE *f);
135void talloc_report_full(const void *ptr, FILE *f);
136void talloc_report(const void *ptr, FILE *f);
137void talloc_enable_null_tracking(void);
138void talloc_disable_null_tracking(void);
139void talloc_enable_leak_report(void);
140void talloc_enable_leak_report_full(void);
141void *_talloc_zero(const void *ctx, size_t size, const char *name);
142void *_talloc_memdup(const void *t, const void *p, size_t size, const char *name);
143void *_talloc_array(const void *ctx, size_t el_size, unsigned count, const char *name);
144void *_talloc_zero_array(const void *ctx, size_t el_size, unsigned count, const char *name);
145void *_talloc_realloc_array(const void *ctx, void *ptr, size_t el_size, unsigned count, const char *name);
146void *talloc_realloc_fn(const void *context, void *ptr, size_t size);
147void *talloc_autofree_context(void);
148size_t talloc_get_size(const void *ctx);
149void *talloc_find_parent_byname(const void *ctx, const char *name);
150void talloc_show_parents(const void *context, FILE *file);
151int talloc_is_parent(const void *context, const void *ptr);
152
153char *talloc_strdup(const void *t, const char *p);
154char *talloc_strdup_append(char *s, const char *a);
155char *talloc_strdup_append_buffer(char *s, const char *a);
156
157char *talloc_strndup(const void *t, const char *p, size_t n);
158char *talloc_strndup_append(char *s, const char *a, size_t n);
159char *talloc_strndup_append_buffer(char *s, const char *a, size_t n);
160
161char *talloc_vasprintf(const void *t, const char *fmt, va_list ap) PRINTF_ATTRIBUTE(2,0);
162char *talloc_vasprintf_append(char *s, const char *fmt, va_list ap) PRINTF_ATTRIBUTE(2,0);
163char *talloc_vasprintf_append_buffer(char *s, const char *fmt, va_list ap) PRINTF_ATTRIBUTE(2,0);
164
165char *talloc_asprintf(const void *t, const char *fmt, ...) PRINTF_ATTRIBUTE(2,3);
166char *talloc_asprintf_append(char *s, const char *fmt, ...) PRINTF_ATTRIBUTE(2,3);
167char *talloc_asprintf_append_buffer(char *s, const char *fmt, ...) PRINTF_ATTRIBUTE(2,3);
168
169#endif
Note: See TracBrowser for help on using the repository browser.