aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorghost <andreas.monzner@multimedia-labs.de>2010-07-05 16:59:47 +0200
committerghost <andreas.monzner@multimedia-labs.de>2010-07-05 17:00:25 +0200
commit762f51fe809fd762369b870d44db6e70e1a611e6 (patch)
tree31ad73c8799004cf0e305a06460f33f93fba02d2 /lib
parent547a6fbb55113fb70f39adb4ae96699f4f679d03 (diff)
downloadenigma2-762f51fe809fd762369b870d44db6e70e1a611e6.tar.gz
enigma2-762f51fe809fd762369b870d44db6e70e1a611e6.zip
lib/base/console.cpp: fix eConsoleAppContainer write (when called with one string only)
Diffstat (limited to 'lib')
-rw-r--r--lib/base/console.cpp23
1 files changed, 13 insertions, 10 deletions
diff --git a/lib/base/console.cpp b/lib/base/console.cpp
index add87066..43f9f61e 100644
--- a/lib/base/console.cpp
+++ b/lib/base/console.cpp
@@ -516,18 +516,15 @@ eConsolePy_write(eConsolePy* self, PyObject *args)
{
int len;
char *data;
- if (PyArg_ParseTuple(args, "si", &data, &len))
- ;
- else
+ int ret = -1;
+ Py_ssize_t argc = PyTuple_Size(args);
+ if (argc > 1)
+ ret = PyArg_ParseTuple(args, "si", &data, &len);
+ else if (argc == 1)
{
PyObject *ob;
- if (!PyArg_ParseTuple(args, "O", &ob) || !PyString_Check(ob))
- {
- PyErr_SetString(PyExc_TypeError,
- "1st arg must be a string, optionaly 2nd arg can be the string length");
- return NULL;
- }
- else
+ ret = !PyArg_ParseTuple(args, "O", &ob) || !PyString_Check(ob);
+ if (!ret)
{
Py_ssize_t length;
if (!PyString_AsStringAndSize(ob, &data, &length))
@@ -536,6 +533,12 @@ eConsolePy_write(eConsolePy* self, PyObject *args)
len = 0;
}
}
+ if (ret)
+ {
+ PyErr_SetString(PyExc_TypeError,
+ "1st arg must be a string, optionaly 2nd arg can be the string length");
+ return NULL;
+ }
self->cont->write(data, len);
Py_RETURN_NONE;
}