X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/4cdeb9ebe328382bb4ef6a01b67ff840adcc84ad..2c34a36b091994d17a50001faba2f1609c1a6231:/lib/service/service.cpp diff --git a/lib/service/service.cpp b/lib/service/service.cpp index a490c3d7..11f88b1f 100644 --- a/lib/service/service.cpp +++ b/lib/service/service.cpp @@ -1,19 +1,24 @@ #include #include +#include #include #include #include +#include eServiceReference::eServiceReference(const std::string &string) { const char *c=string.c_str(); int pathl=0; - if ( sscanf(c, "%d:%d:%x:%x:%x:%x:%x:%x:%x:%x:%n", &type, &flags, &data[0], &data[1], &data[2], &data[3], &data[4], &data[5], &data[6], &data[7], &pathl) < 8 ) + if (!string.length()) + type = idInvalid; + else if ( sscanf(c, "%d:%d:%x:%x:%x:%x:%x:%x:%x:%x:%n", &type, &flags, &data[0], &data[1], &data[2], &data[3], &data[4], &data[5], &data[6], &data[7], &pathl) < 8 ) { memset( data, 0, sizeof(data) ); eDebug("find old format eServiceReference string"); - sscanf(c, "%d:%d:%x:%x:%x:%x:%n", &type, &flags, &data[0], &data[1], &data[2], &data[3], &pathl); + if ( sscanf(c, "%d:%d:%x:%x:%x:%x:%n", &type, &flags, &data[0], &data[1], &data[2], &data[3], &pathl) < 2 ) + type = idInvalid; } if (pathl) @@ -187,4 +192,10 @@ std::string iServiceInformation::getInfoString(int w) return ""; } +PyObject* iServiceInformation::getInfoObject(int w) +{ + Py_INCREF(Py_None); + return Py_None; +} + eAutoInitPtr init_eServiceCenter(eAutoInitNumbers::service, "eServiceCenter");