From 8f3147df3c309127382f800f9a2b19f355bd9d15 Mon Sep 17 00:00:00 2001 From: Lionel Elie Mamane Date: Fri, 17 May 2013 10:54:40 +0200 Subject: fdo#47951 flat text table: update m_nRowPos when moving by bookmark Change-Id: Iac154020b4b6309f92b1f68fa5bf79611dfcc91b Reviewed-on: https://gerrit.libreoffice.org/3962 Reviewed-by: Fridrich Strba Tested-by: Fridrich Strba --- connectivity/source/drivers/flat/ETable.cxx | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/connectivity/source/drivers/flat/ETable.cxx b/connectivity/source/drivers/flat/ETable.cxx index b7f61ed89ba5..fc1124ecde0c 100644 --- a/connectivity/source/drivers/flat/ETable.cxx +++ b/connectivity/source/drivers/flat/ETable.cxx @@ -873,15 +873,29 @@ sal_Bool OFlatTable::seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int break; case IResultSetHelper::BOOKMARK: { + m_nRowPos = 0; TRowPositionsInFile::const_iterator aFind = m_aFilePosToEndLinePos.find(nOffset); m_bNeedToReadLine = aFind != m_aFilePosToEndLinePos.end(); if ( m_bNeedToReadLine ) { m_nFilePos = aFind->first; nCurPos = aFind->second; + for(::std::map::const_iterator p = m_aRowPosToFilePos.begin(); + p != m_aRowPosToFilePos.end(); + ++p) + { + assert(p->second->first <= nOffset); + if(p->second->first == nOffset) + { + m_nRowPos = p->first; + break; + } + } + assert(m_nRowPos > 0); } else { + assert(false); m_nFilePos = nOffset; m_pFileStream->Seek(nOffset); if (m_pFileStream->IsEof() || !readLine(nCurPos) ) -- cgit v1.2.3