src/hbservers/hbthemeserver/hbsgimagerenderer.cpp
changeset 34 ed14f46c0e55
parent 2 06ff229162e9
--- a/src/hbservers/hbthemeserver/hbsgimagerenderer.cpp	Mon Oct 04 17:49:30 2010 +0300
+++ b/src/hbservers/hbthemeserver/hbsgimagerenderer.cpp	Mon Oct 18 18:23:13 2010 +0300
@@ -26,6 +26,7 @@
 #include "hbsgimagerenderer_p.h"
 #include "hbnvg_p.h"
 
+#include <sgresource/sgerror.h>
 #include <QDebug>
 QHash<unsigned long long, RSgImage*> HbSgImageRenderer::sgImageHash;
 
@@ -81,6 +82,7 @@
     }
 
     init = true;
+    errorCode = KErrNone;
     return true;
 }
 
@@ -101,6 +103,7 @@
         delete engine;
         engine = 0;
         init = false;
+        errorCode = KErrNone;
     }
 }
 
@@ -123,7 +126,11 @@
     }
 
     eglContext = eglCreateContext(display, eglConfig, EGL_NO_CONTEXT, 0);
-
+    if ( eglContext == EGL_NO_CONTEXT ) {
+        if ((eglGetError() == EGL_BAD_ALLOC)) {
+            setLastError(KErrNoGraphicsMemory);
+        }
+    }
     return eglContext != EGL_NO_CONTEXT;
 }
 
@@ -140,6 +147,9 @@
 
     currentSurface = eglCreatePixmapSurface(display, eglConfig, sgImage, KPixmapAttributes);
     if (currentSurface == EGL_NO_SURFACE) {
+        if ((eglGetError() == EGL_BAD_ALLOC)){
+            setLastError(KErrNoGraphicsMemory);
+        }
         return false;
     }
 
@@ -178,8 +188,15 @@
         sgImageHash.remove(id);
     }    
 }
+int HbSgImageRenderer::lastError()
+{
+    return errorCode;
+}
+void HbSgImageRenderer::setLastError(int lastError)
+{
+    errorCode = lastError;
+}
 
-#ifdef HB_ICON_CACHE_DEBUG
 unsigned long HbSgImageRenderer::totalGPUMemory()
 {
     qDebug() <<"Inside  HbSgImageRenderer::totalGPUMemory()  " ;
@@ -316,4 +333,3 @@
 
     return prof_data;
 }
-#endif //HB_ICON_CACHE_DEBUG