src/hbcore/image/hbiconsource.cpp
branchGCC_SURGE
changeset 15 f378acbc9cfb
parent 7 923ff622b8b9
child 23 e6ad4ef83b23
--- a/src/hbcore/image/hbiconsource.cpp	Thu Jul 15 14:03:49 2010 +0100
+++ b/src/hbcore/image/hbiconsource.cpp	Thu Jul 22 16:36:53 2010 +0100
@@ -52,27 +52,26 @@
 {
     QString loweredIconPath = iconPath.toLower();
 
-    if (loweredIconPath.endsWith(".svgz") ) {
-        return "SVG";
+    if (loweredIconPath.endsWith(QLatin1String(".svgz"))) {
+        return QLatin1String("SVG");
     }
-    if (loweredIconPath.endsWith(".qpic") ) {
-        return "PIC";
+    if (loweredIconPath.endsWith(QLatin1String(".qpic"))) {
+        return QLatin1String("PIC");
     }
 
-    if (loweredIconPath.endsWith(".svg")
-        || loweredIconPath.endsWith(".png")
-        || loweredIconPath.endsWith(".mng")
-        || loweredIconPath.endsWith(".gif")
-        || loweredIconPath.endsWith(".xpm")
-        || loweredIconPath.endsWith(".jpg")
-        || loweredIconPath.endsWith(".nvg")) {
+    if (loweredIconPath.endsWith(QLatin1String(".svg"))
+            || loweredIconPath.endsWith(QLatin1String(".png"))
+            || loweredIconPath.endsWith(QLatin1String(".mng"))
+            || loweredIconPath.endsWith(QLatin1String(".gif"))
+            || loweredIconPath.endsWith(QLatin1String(".xpm"))
+            || loweredIconPath.endsWith(QLatin1String(".jpg"))
+            || loweredIconPath.endsWith(QLatin1String(".nvg"))) {
         return iconPath.right(3).toUpper();
     }
 
-    if (loweredIconPath.endsWith(".xml")
-        || loweredIconPath.endsWith(".axml")
-        || loweredIconPath.endsWith(".fxml"))
-    {
+    if (loweredIconPath.endsWith(QLatin1String(".xml"))
+            || loweredIconPath.endsWith(QLatin1String(".axml"))
+            || loweredIconPath.endsWith(QLatin1String(".fxml"))) {
         return "BLOB";
     }
 
@@ -86,21 +85,22 @@
 // to avoid NVG dependency in ThemeIndexer
 QSize nvgContentDimensions(const QByteArray &buffer)
 {
-    QSize ret(0,0);
-     if (buffer.length() < static_cast<qint32>(NVG_VIEWBOX_HEIGHT_OFS + sizeof (float))){
+    QSize ret(0, 0);
+    if (buffer.length() < static_cast<qint32>(NVG_VIEWBOX_HEIGHT_OFS + sizeof(float))) {
         ret = QSize(0, 0);
-        } 
-     
-    const quint8* lBuf = (quint8*) buffer.data();
-    if((buffer.length() > NVG_VIEWBOX_WIDTH_OFS) && (buffer.length() > NVG_VIEWBOX_HEIGHT_OFS)) {	
-	    float lViewboxWidth = * (float*)(lBuf + NVG_VIEWBOX_WIDTH_OFS);
-	    float lViewboxHeight = * (float*)(lBuf + NVG_VIEWBOX_HEIGHT_OFS);
+    }
 
-	    if (lViewboxWidth > 0 && lViewboxHeight > 0) {
-	        ret = QSize((int)lViewboxWidth, (int)lViewboxHeight);
-	    } else {
-	        ret = QSize(0, 0);
-	    }
+    const quint8 *lBuf = (quint8 *) buffer.data();
+    if ((buffer.length() > NVG_VIEWBOX_WIDTH_OFS) && (buffer.length() > NVG_VIEWBOX_HEIGHT_OFS)) {
+        // Do not change to qreal, no matter what krazy says.
+        float lViewboxWidth = * (float *)(lBuf + NVG_VIEWBOX_WIDTH_OFS);
+        float lViewboxHeight = * (float *)(lBuf + NVG_VIEWBOX_HEIGHT_OFS);
+
+        if (lViewboxWidth > 0 && lViewboxHeight > 0) {
+            ret = QSize((int)lViewboxWidth, (int)lViewboxHeight);
+        } else {
+            ret = QSize(0, 0);
+        }
     }
     return ret;
 }
@@ -110,7 +110,7 @@
 
 /*!
   \class HbIconSource
-  
+
   \brief Encapsulates access (size and pixel data reading) to image files.
 
   \internal
@@ -173,37 +173,35 @@
         if (mType == "NVG") {
 #ifndef HB_BOOTSTRAPPED
 #ifdef HB_NVG_CS_ICON
-        if(!mByteArray){
-            QFile file(mFilename);
-            if (!file.open(QIODevice::NotOpen | QIODevice::ReadOnly)) {
-                return QSizeF();
-            }                
-            mByteArray = new QByteArray(file.readAll());
-        }
-        HbNvgEngine nvgEngine; 
-        mDefaultSize = nvgEngine.contentDimensions(*mByteArray);
+            if (!mByteArray) {
+                QFile file(mFilename);
+                if (!file.open(QIODevice::NotOpen | QIODevice::ReadOnly)) {
+                    return QSizeF();
+                }
+                mByteArray = new QByteArray(file.readAll());
+            }
+            HbNvgEngine nvgEngine;
+            mDefaultSize = nvgEngine.contentDimensions(*mByteArray);
 #endif // HB_NVG_CS_ICON
 #else // HB_BOOTSTRAPPED
 
-        if(!mByteArray){
-            QFile file(mFilename);
-            if (!file.open(QIODevice::NotOpen | QIODevice::ReadOnly)) {
-                return QSizeF();
-            }                
-            mByteArray = new QByteArray (file.readAll());
-        }
+            if (!mByteArray) {
+                QFile file(mFilename);
+                if (!file.open(QIODevice::NotOpen | QIODevice::ReadOnly)) {
+                    return QSizeF();
+                }
+                mByteArray = new QByteArray(file.readAll());
+            }
 
-        mDefaultSize = nvgContentDimensions(*mByteArray);
+            mDefaultSize = nvgContentDimensions(*mByteArray);
 #endif
-        }
-        else if (mType == "SVG") {
+        } else if (mType == "SVG") {
             QSvgRenderer *renderer = svgRenderer();
             if (renderer) { // isValid() is already checked in svgRenderer()
                 mDefaultSize = renderer->defaultSize();
             }
             releaseSvgRenderer();
-        }
-        else if (mType == "PIC") {
+        } else if (mType == "PIC") {
             if (!mPicture) {
                 mPicture = new QPicture;
                 mPicture->load(mFilename);
@@ -229,8 +227,7 @@
                 }
             }
             releaseImageReader();
-        }
-        else if (mType != "BLOB") {
+        } else if (mType != "BLOB") {
             if (!mPixmap) {
                 mPixmap = new QPixmap(mFilename);
             }
@@ -270,20 +267,20 @@
 {
     mSvgRenderer = 0;
 }
-    
-QByteArray* HbIconSource::byteArray()
+
+QByteArray *HbIconSource::byteArray()
 {
     if (!mByteArray) {
-    #ifdef HB_NVG_CS_ICON
+#ifdef HB_NVG_CS_ICON
         QFile file(mFilename);
         if (!file.open(QIODevice::NotOpen | QIODevice::ReadOnly)) {
             return 0;
         }
-        mByteArray = new QByteArray (file.readAll());
-    #endif//nvg 
+        mByteArray = new QByteArray(file.readAll());
+#endif
     }
-    
-    if (!mByteArray->isEmpty()) {
+
+    if (mByteArray && !mByteArray->isEmpty()) {
         return mByteArray;
     } else {
         return 0;
@@ -306,6 +303,7 @@
 QImageReader *HbIconSource::imageReader()
 {
     if (!mImageReader) {
+        type(); // make sure type is initialized
         mImageReader = new QImageReader(mFilename, mType.toLatin1());
     }
     return mImageReader && mImageReader->canRead() ? mImageReader : 0;