aboutsummaryrefslogtreecommitdiff
path: root/lib/gdi/picload.cpp
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-11-23 14:09:12 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-11-23 14:09:12 +0000
commita0f23d0986f3af9d66367c617677f8a275b72737 (patch)
treeba5c1f3386184b5a6e2420c98e233ab175397d75 /lib/gdi/picload.cpp
parentcac2aa02e62d9515f5a3f4a8ad9658b70bd6ed07 (diff)
downloadenigma2-a0f23d0986f3af9d66367c617677f8a275b72737.tar.gz
enigma2-a0f23d0986f3af9d66367c617677f8a275b72737.zip
fix python refcounting (memleaks)
Diffstat (limited to 'lib/gdi/picload.cpp')
-rw-r--r--lib/gdi/picload.cpp66
1 files changed, 37 insertions, 29 deletions
diff --git a/lib/gdi/picload.cpp b/lib/gdi/picload.cpp
index 28a89915..d724bfcf 100644
--- a/lib/gdi/picload.cpp
+++ b/lib/gdi/picload.cpp
@@ -335,54 +335,62 @@ static int png_load(const char *filename, int *x, int *y)
PyObject *getExif(const char *filename)
{
- PyObject *list = PyList_New(0);
+ PyObject *list = 0;
Cexif *m_exif = new Cexif();
if(m_exif->DecodeExif(filename))
{
-
if(m_exif->m_exifinfo->IsExif)
{
+ int pos=0;
char tmp[256];
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->Version));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->CameraMake));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->CameraModel));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->DateTime));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->Comments));
- PyList_Append(list, PyString_FromFormat("%d x %d", m_exif->m_exifinfo->Width, m_exif->m_exifinfo->Height));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->Orientation));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->MeteringMode));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->ExposureProgram));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->LightSource));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->FlashUsed));
- PyList_Append(list, PyString_FromFormat("%d", m_exif->m_exifinfo->CompressionLevel));
- PyList_Append(list, PyString_FromFormat("%d", m_exif->m_exifinfo->ISOequivalent));
+ list = PyList_New(22);
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->Version));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->CameraMake));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->CameraModel));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->DateTime));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->Comments));
+ PyList_SET_ITEM(list, pos++, PyString_FromFormat("%d x %d", m_exif->m_exifinfo->Width, m_exif->m_exifinfo->Height));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->Orientation));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->MeteringMode));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->ExposureProgram));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->LightSource));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->FlashUsed));
+ PyList_SET_ITEM(list, pos++, PyString_FromFormat("%d", m_exif->m_exifinfo->CompressionLevel));
+ PyList_SET_ITEM(list, pos++, PyString_FromFormat("%d", m_exif->m_exifinfo->ISOequivalent));
sprintf(tmp, "%.2f", m_exif->m_exifinfo->Xresolution);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
sprintf(tmp, "%.2f", m_exif->m_exifinfo->Yresolution);
- PyList_Append(list, PyString_FromString(tmp));
- PyList_Append(list, PyString_FromString(m_exif->m_exifinfo->ResolutionUnit));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(m_exif->m_exifinfo->ResolutionUnit));
sprintf(tmp, "%.2f", m_exif->m_exifinfo->Brightness);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
sprintf(tmp, "%.5f sec.", m_exif->m_exifinfo->ExposureTime);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
sprintf(tmp, "%.5f", m_exif->m_exifinfo->ExposureBias);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
sprintf(tmp, "%.5f", m_exif->m_exifinfo->Distance);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
sprintf(tmp, "%.5f", m_exif->m_exifinfo->CCDWidth);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
sprintf(tmp, "%.2f", m_exif->m_exifinfo->ApertureFNumber);
- PyList_Append(list, PyString_FromString(tmp));
+ PyList_SET_ITEM(list, pos++, PyString_FromString(tmp));
+ }
+ else
+ {
+ list = PyList_New(1);
+ PyList_SET_ITEM(list, 0, PyString_FromString(m_exif->m_szLastError));
}
- else PyList_Append(list, PyString_FromString(m_exif->m_szLastError));
-
m_exif->ClearExif();
}
- else PyList_Append(list, PyString_FromString(m_exif->m_szLastError));
+ else
+ {
+ list = PyList_New(1);
+ PyList_SET_ITEM(list, 0, PyString_FromString(m_exif->m_szLastError));
+ }
delete m_exif;
-
- return list;
+
+ return list ? list : PyList_New(0);
}
//---------------------------------------------------------------------------------------------