98e7acd
From 5bc702e5487ba931b2707770a5e25a883bd89b76 Mon Sep 17 00:00:00 2001
98e7acd
From: =?UTF-8?q?Caol=C3=A1n=20McNamara?= <caolanm@redhat.com>
98e7acd
Date: Fri, 27 May 2011 15:33:40 +0100
98e7acd
Subject: [PATCH] Resolves: rhbz#707317 avoid crash in getRowSpan (cherry
98e7acd
 picked from commit
98e7acd
 23c4f82e9084f8b15f149b074a8ad4ff6a7a4204)
98e7acd
98e7acd
---
98e7acd
 sw/source/core/crsr/swcrsr.cxx |    7 +++----
98e7acd
 1 files changed, 3 insertions(+), 4 deletions(-)
98e7acd
98e7acd
diff --git a/sw/source/core/crsr/swcrsr.cxx b/sw/source/core/crsr/swcrsr.cxx
98e7acd
index 4f646d2..c27d8f7 100644
98e7acd
--- a/sw/source/core/crsr/swcrsr.cxx
98e7acd
+++ b/sw/source/core/crsr/swcrsr.cxx
98e7acd
@@ -1665,8 +1665,7 @@ sal_Bool SwCursor::LeftRight( sal_Bool bLeft, sal_uInt16 nCnt, sal_uInt16 nMode,
98e7acd
             {
98e7acd
                 // Set cursor to start/end of covered cell:
98e7acd
                 SwTableBox* pTableBox = pOldTabBoxSttNode->GetTblBox();
98e7acd
-                const long nRowSpan = pTableBox->getRowSpan();
98e7acd
-                if ( nRowSpan > 1 )
98e7acd
+                if ( pTableBox && pTableBox->getRowSpan() > 1 )
98e7acd
                 {
98e7acd
                     pTableBox = & pTableBox->FindEndOfRowSpan( pOldTabSttNode->GetTable(), (sal_uInt16)(pTableBox->getRowSpan() + mnRowSpanOffset ) );
98e7acd
                     SwNodeIndex& rPtIdx = GetPoint()->nNode;
98e7acd
@@ -1953,7 +1952,7 @@ sal_Bool SwCursor::GoPrevNextCell( sal_Bool bNext, sal_uInt16 nCnt )
98e7acd
         // proceeding:
98e7acd
         if ( mnRowSpanOffset )
98e7acd
         {
98e7acd
-            if ( pTableBox->getRowSpan() > 1 )
98e7acd
+            if ( pTableBox && pTableBox->getRowSpan() > 1 )
98e7acd
             {
98e7acd
                 pTableBox = & pTableBox->FindEndOfRowSpan( pTblNd->GetTable(), (sal_uInt16)(pTableBox->getRowSpan() + mnRowSpanOffset) );
98e7acd
                 SwNodeIndex aNewIdx( *pTableBox->GetSttNd() );
98e7acd
@@ -1976,7 +1975,7 @@ sal_Bool SwCursor::GoPrevNextCell( sal_Bool bNext, sal_uInt16 nCnt )
98e7acd
 
98e7acd
         pTableBoxStartNode = rPtIdx.GetNode().FindTableBoxStartNode();
98e7acd
         pTableBox = pTableBoxStartNode->GetTblBox();
98e7acd
-        if ( pTableBox->getRowSpan() < 1 )
98e7acd
+        if ( pTableBox && pTableBox->getRowSpan() < 1 )
98e7acd
         {
98e7acd
             mnRowSpanOffset = pTableBox->getRowSpan();
98e7acd
             // move cursor to non-covered cell:
98e7acd
-- 
98e7acd
1.7.5.1
98e7acd