summaryrefslogtreecommitdiff
path: root/source4/scripting/swig
diff options
context:
space:
mode:
Diffstat (limited to 'source4/scripting/swig')
-rw-r--r--source4/scripting/swig/dcerpc.i20
1 files changed, 10 insertions, 10 deletions
diff --git a/source4/scripting/swig/dcerpc.i b/source4/scripting/swig/dcerpc.i
index 606f236f35..918445d7e3 100644
--- a/source4/scripting/swig/dcerpc.i
+++ b/source4/scripting/swig/dcerpc.i
@@ -254,28 +254,28 @@ PyObject *string_ptr_to_python(TALLOC_CTX *mem_ctx, char *obj)
#define dom_sid2_ptr_to_python dom_sid_ptr_to_python
#define dom_sid2_ptr_from_python dom_sid_ptr_from_python
-DATA_BLOB DATA_BLOB_from_python(PyObject *obj, char *name)
+void DATA_BLOB_ptr_from_python(TALLOC_CTX *mem_ctx, DATA_BLOB **s,
+ PyObject *obj, char *name)
{
- DATA_BLOB ret;
-
- /* Because we treat DATA_BLOB as a scalar type (why?) there
- doesn't seem to be a way to pass back when an error has
- occured. */
-
if (obj == NULL) {
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
return;
}
+ if (obj == Py_None) {
+ *s = NULL;
+ return;
+ }
+
if (!PyString_Check(obj)) {
PyErr_Format(PyExc_TypeError, "Expecting string value for key '%s'", name);
return;
}
- ret.length = PyString_Size(obj);
- ret.data = PyString_AsString(obj);
+ *s = talloc(mem_ctx, sizeof(DATA_BLOB));
- return ret;
+ (*s)->length = PyString_Size(obj);
+ (*s)->data = PyString_AsString(obj);
}
PyObject *DATA_BLOB_to_python(DATA_BLOB obj)