torture: include config.h before any glibc headers
[Samba.git] / lib / ldb / pyldb.h
blobf8aea2242b4851148acc92b41eacc75164d54625
1 /*
2 Unix SMB/CIFS implementation.
4 Python interface to ldb.
6 Copyright (C) 2007-2008 Jelmer Vernooij <jelmer@samba.org>
8 ** NOTE! The following LGPL license applies to the ldb
9 ** library. This does NOT imply that all of Samba is released
10 ** under the LGPL
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.
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.
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/>.
26 #ifndef _PYLDB_H_
27 #define _PYLDB_H_
29 #include <talloc.h>
31 typedef struct {
32 PyObject_HEAD
33 TALLOC_CTX *mem_ctx;
34 struct ldb_context *ldb_ctx;
35 } PyLdbObject;
37 #define pyldb_Ldb_AsLdbContext(pyobj) ((PyLdbObject *)pyobj)->ldb_ctx
39 typedef struct {
40 PyObject_HEAD
41 TALLOC_CTX *mem_ctx;
42 struct ldb_dn *dn;
43 } PyLdbDnObject;
45 PyObject *pyldb_Dn_FromDn(struct ldb_dn *);
46 bool pyldb_Object_AsDn(TALLOC_CTX *mem_ctx, PyObject *object, struct ldb_context *ldb_ctx, struct ldb_dn **dn);
47 #define pyldb_Dn_AsDn(pyobj) ((PyLdbDnObject *)pyobj)->dn
49 typedef struct {
50 PyObject_HEAD
51 TALLOC_CTX *mem_ctx;
52 struct ldb_message *msg;
53 } PyLdbMessageObject;
54 #define pyldb_Message_AsMessage(pyobj) ((PyLdbMessageObject *)pyobj)->msg
56 typedef struct {
57 PyObject_HEAD
58 TALLOC_CTX *mem_ctx;
59 struct ldb_module *mod;
60 } PyLdbModuleObject;
61 #define pyldb_Module_AsModule(pyobj) ((PyLdbModuleObject *)pyobj)->mod
63 typedef struct {
64 PyObject_HEAD
65 TALLOC_CTX *mem_ctx;
66 struct ldb_message_element *el;
67 } PyLdbMessageElementObject;
68 #define pyldb_MessageElement_AsMessageElement(pyobj) ((PyLdbMessageElementObject *)pyobj)->el
70 typedef struct {
71 PyObject_HEAD
72 TALLOC_CTX *mem_ctx;
73 struct ldb_parse_tree *tree;
74 } PyLdbTreeObject;
75 #define pyldb_Tree_AsTree(pyobj) ((PyLdbTreeObject *)pyobj)->tree
77 typedef struct {
78 PyObject_HEAD
79 TALLOC_CTX *mem_ctx;
80 PyObject *msgs;
81 PyObject *referals;
82 PyObject *controls;
83 } PyLdbResultObject;
85 typedef struct {
86 PyObject_HEAD
87 TALLOC_CTX *mem_ctx;
88 struct ldb_control *data;
89 } PyLdbControlObject;
91 #define PyErr_LDB_ERROR_IS_ERR_RAISE(err,ret,ldb) \
92 if (ret != LDB_SUCCESS) { \
93 PyErr_SetLdbError(err, ret, ldb); \
94 return NULL; \
97 /* Picked out of thin air. To do this properly, we should probably have some part of the
98 * errors in LDB be allocated to bindings ? */
99 #define LDB_ERR_PYTHON_EXCEPTION 142
101 #endif /* _PYLDB_H_ */