From 7cef5fd077cb99343df3fff0c9145e15bce563d7 Mon Sep 17 00:00:00 2001 From: Tim Potter Date: Sat, 2 Oct 2004 11:22:20 +0000 Subject: r2780: Add conversion routines for DATA_BLOB. I'm not convinced that DATA_BLOB's should be treated as scalar types though. (This used to be commit c9e96038f821783c30b5cf509334176f982403d9) --- source4/scripting/swig/dcerpc.i | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'source4/scripting/swig') diff --git a/source4/scripting/swig/dcerpc.i b/source4/scripting/swig/dcerpc.i index 6be0b639f0..5c3ce0ceec 100644 --- a/source4/scripting/swig/dcerpc.i +++ b/source4/scripting/swig/dcerpc.i @@ -246,6 +246,35 @@ 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) +{ + 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 (!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); + + return ret; +} + +PyObject *DATA_BLOB_to_python(DATA_BLOB obj) +{ + return PyString_FromStringAndSize(obj.data, obj.length); +} + %} %include "samba.i" -- cgit