From 6b946f228397c370e09f487c470bafd9d046eee5 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 --- connectivity/source/drivers/flat/ETable.cxx | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'connectivity') diff --git a/connectivity/source/drivers/flat/ETable.cxx b/connectivity/source/drivers/flat/ETable.cxx index 083cad497a01..19918efd1cb3 100644 --- a/connectivity/source/drivers/flat/ETable.cxx +++ b/connectivity/source/drivers/flat/ETable.cxx @@ -863,15 +863,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