diff options
Diffstat (limited to 'lldb/scripts/Python')
-rw-r--r-- | lldb/scripts/Python/interface/SBCommandReturnObject.i | 2 | ||||
-rw-r--r-- | lldb/scripts/Python/python-typemaps.swig | 23 |
2 files changed, 24 insertions, 1 deletions
diff --git a/lldb/scripts/Python/interface/SBCommandReturnObject.i b/lldb/scripts/Python/interface/SBCommandReturnObject.i index e72c1e2..7cec069 100644 --- a/lldb/scripts/Python/interface/SBCommandReturnObject.i +++ b/lldb/scripts/Python/interface/SBCommandReturnObject.i @@ -84,7 +84,7 @@ public: SetImmediateErrorFile (FILE *fh); void - PutCString(const char* string, int len = -1); + PutCString(const char* string, int len); // wrapping the variadic Printf() with a plain Print() // because it is hard to support varargs in SWIG bridgings diff --git a/lldb/scripts/Python/python-typemaps.swig b/lldb/scripts/Python/python-typemaps.swig index 1a67f7b..8af1446 100644 --- a/lldb/scripts/Python/python-typemaps.swig +++ b/lldb/scripts/Python/python-typemaps.swig @@ -442,3 +442,26 @@ #endif $result = PyFile_FromFile($1, const_cast<char*>(""), mode, fclose); } + +%typemap(in) (const char* string, int len) { + if ($input == Py_None) + { + $1 = NULL; + $2 = 0; + } + else if (PyUnicode_Check($input)) + { + $1 = PyString_AsString(PyUnicode_AsUTF8String($input)); + $2 = strlen($1); + } + else if (PyString_Check($input)) + { + $1 = PyString_AsString($input); + $2 = PyString_Size($input); + } + else + { + PyErr_SetString(PyExc_TypeError,"not a string-like object"); + return NULL; + } +} |