[Libreoffice-commits] .: Branch 'libreoffice-3-5' - sc/source

Kohei Yoshida kohei at kemper.freedesktop.org
Thu Dec 8 20:05:42 PST 2011


 sc/source/core/data/column3.cxx |   46 ++++++++++++++++++++++++++--------------
 sc/source/core/data/table3.cxx  |    7 +++++-
 2 files changed, 36 insertions(+), 17 deletions(-)

New commits:
commit 27b8382d07b8b0edafd6665906b59bc1cca9dcfe
Author: Kohei Yoshida <kohei.yoshida at suse.com>
Date:   Thu Dec 8 23:02:26 2011 -0500

    bnc#656073: Allow filtering by error value.
    
    The old way was that an error cell was evaulated as having a value of 0.
    The error cell also showed up as blank in the popup.  Using the error
    string is much more intuitive (and some users apparently want this
    behavior).

diff --git a/sc/source/core/data/column3.cxx b/sc/source/core/data/column3.cxx
index 898edfd..fbeb951 100644
--- a/sc/source/core/data/column3.cxx
+++ b/sc/source/core/data/column3.cxx
@@ -1575,9 +1575,9 @@ void ScColumn::GetFilterEntries(SCROW nStartRow, SCROW nEndRow, TypedScStrCollec
 
     while ( (nIndex < nCount) ? ((nRow=pItems[nIndex].nRow) <= nEndRow) : false )
     {
-        ScBaseCell*          pCell    = pItems[nIndex].pCell;
-        TypedStrData*        pData;
-        sal_uLong                nFormat  = GetNumberFormat( nRow );
+        ScBaseCell* pCell = pItems[nIndex].pCell;
+        TypedStrData* pData = NULL;
+        sal_uLong nFormat = GetNumberFormat( nRow );
 
         ScCellFormat::GetInputString( pCell, nFormat, aString, *pFormatter );
 
@@ -1585,7 +1585,7 @@ void ScColumn::GetFilterEntries(SCROW nStartRow, SCROW nEndRow, TypedScStrCollec
             pData = new TypedStrData( aString );
         else
         {
-            double nValue;
+            double nValue = 0.0;
 
             switch ( pCell->GetCellType() )
             {
@@ -1594,26 +1594,40 @@ void ScColumn::GetFilterEntries(SCROW nStartRow, SCROW nEndRow, TypedScStrCollec
                     break;
 
                 case CELLTYPE_FORMULA:
-                    nValue = ((ScFormulaCell*)pCell)->GetValue();
-                    break;
+                {
+                    ScFormulaCell* pFC = static_cast<ScFormulaCell*>(pCell);
+                    sal_uInt16 nErr = pFC->GetErrCode();
+                    if (nErr)
+                    {
+                        // Error cell is evaluated as string (for now).
+                        String aErr = ScGlobal::GetErrorString(nErr);
+                        if (aErr.Len())
+                            pData = new TypedStrData(aErr);
+                    }
+                    else
+                        nValue = pFC->GetValue();
+                }
+                break;
 
                 default:
-                    nValue = 0.0;
+                    ;
             }
 
-            if (pFormatter)
+            if (!pData)
             {
-                short nType = pFormatter->GetType(nFormat);
-                if ((nType & NUMBERFORMAT_DATE) && !(nType & NUMBERFORMAT_TIME))
+                if (pFormatter)
                 {
-                    // special case for date values.  Disregard the time
-                    // element if the number format is of date type.
-                    nValue = ::rtl::math::approxFloor(nValue);
-                    bHasDates = true;
+                    short nType = pFormatter->GetType(nFormat);
+                    if ((nType & NUMBERFORMAT_DATE) && !(nType & NUMBERFORMAT_TIME))
+                    {
+                        // special case for date values.  Disregard the time
+                        // element if the number format is of date type.
+                        nValue = ::rtl::math::approxFloor(nValue);
+                        bHasDates = true;
+                    }
                 }
+                pData = new TypedStrData( aString, nValue, SC_STRTYPE_VALUE );
             }
-
-            pData = new TypedStrData( aString, nValue, SC_STRTYPE_VALUE );
         }
 
         if ( !rStrings.Insert( pData ) )
diff --git a/sc/source/core/data/table3.cxx b/sc/source/core/data/table3.cxx
index 1be106f..ffd5d6f 100644
--- a/sc/source/core/data/table3.cxx
+++ b/sc/source/core/data/table3.cxx
@@ -1277,7 +1277,12 @@ public:
 
         if ( pCell )
         {
-            if (pCell->GetCellType() != CELLTYPE_NOTE)
+            if (pCell->GetCellType() == CELLTYPE_FORMULA && pCell->GetErrorCode())
+            {
+                // Error cell is evaluated as string (for now).
+                aCellStr = ScGlobal::GetErrorString(pCell->GetErrorCode());
+            }
+            else if (pCell->GetCellType() != CELLTYPE_NOTE)
             {
                 sal_uLong nFormat = mrTab.GetNumberFormat( static_cast<SCCOL>(rEntry.nField), nRow );
                 ScCellFormat::GetInputString(pCell, nFormat, aCellStr, *mrDoc.GetFormatTable());


More information about the Libreoffice-commits mailing list