connectivity: partially merge OWriterTable and OCalcTable
Factor out the common code of these into a new OComponentTable. Change-Id: I57abac05c9b64cde69d17568e325e86b3c530b20 Reviewed-on: https://gerrit.libreoffice.org/40648 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Miklos Vajna <vmiklos@collabora.co.uk>
This commit is contained in:
parent
9561e0f392
commit
8a24df0bed
7 changed files with 303 additions and 315 deletions
|
@ -45,6 +45,7 @@ $(eval $(call gb_Library_add_exception_objects,file,\
|
|||
connectivity/source/drivers/component/CPreparedStatement \
|
||||
connectivity/source/drivers/component/CResultSet \
|
||||
connectivity/source/drivers/component/CStatement \
|
||||
connectivity/source/drivers/component/CTable \
|
||||
connectivity/source/drivers/file/FCatalog \
|
||||
connectivity/source/drivers/file/FColumns \
|
||||
connectivity/source/drivers/file/FConnection \
|
||||
|
|
|
@ -521,7 +521,6 @@ OCalcTable::OCalcTable(sdbcx::OCollection* _pTables,OCalcConnection* _pConnectio
|
|||
,m_nStartCol(0)
|
||||
,m_nStartRow(0)
|
||||
,m_nDataCols(0)
|
||||
,m_nDataRows(0)
|
||||
,m_bHasHeaders(false)
|
||||
,m_aNullDate(::Date::EMPTY)
|
||||
{
|
||||
|
@ -609,28 +608,6 @@ void OCalcTable::construct()
|
|||
refreshColumns();
|
||||
}
|
||||
|
||||
void OCalcTable::refreshColumns()
|
||||
{
|
||||
::osl::MutexGuard aGuard( m_aMutex );
|
||||
|
||||
TStringVector aVector;
|
||||
|
||||
OSQLColumns::Vector::const_iterator aEnd = m_aColumns->get().end();
|
||||
for(OSQLColumns::Vector::const_iterator aIter = m_aColumns->get().begin();aIter != aEnd;++aIter)
|
||||
aVector.push_back(Reference< XNamed>(*aIter,UNO_QUERY)->getName());
|
||||
|
||||
if(m_pColumns)
|
||||
m_pColumns->reFill(aVector);
|
||||
else
|
||||
m_pColumns = new component::OComponentColumns(this,m_aMutex,aVector);
|
||||
}
|
||||
|
||||
void OCalcTable::refreshIndexes()
|
||||
{
|
||||
// Calc table has no index
|
||||
}
|
||||
|
||||
|
||||
void SAL_CALL OCalcTable::disposing()
|
||||
{
|
||||
OFileTable::disposing();
|
||||
|
@ -642,43 +619,6 @@ void SAL_CALL OCalcTable::disposing()
|
|||
|
||||
}
|
||||
|
||||
Sequence< Type > SAL_CALL OCalcTable::getTypes( )
|
||||
{
|
||||
Sequence< Type > aTypes = OTable_TYPEDEF::getTypes();
|
||||
std::vector<Type> aOwnTypes;
|
||||
aOwnTypes.reserve(aTypes.getLength());
|
||||
|
||||
const Type* pBegin = aTypes.getConstArray();
|
||||
const Type* pEnd = pBegin + aTypes.getLength();
|
||||
for(;pBegin != pEnd;++pBegin)
|
||||
{
|
||||
if(!( *pBegin == cppu::UnoType<XKeysSupplier>::get()||
|
||||
*pBegin == cppu::UnoType<XIndexesSupplier>::get()||
|
||||
*pBegin == cppu::UnoType<XRename>::get()||
|
||||
*pBegin == cppu::UnoType<XAlterTable>::get()||
|
||||
*pBegin == cppu::UnoType<XDataDescriptorFactory>::get()))
|
||||
aOwnTypes.push_back(*pBegin);
|
||||
}
|
||||
aOwnTypes.push_back(cppu::UnoType<css::lang::XUnoTunnel>::get());
|
||||
|
||||
return Sequence< Type >(aOwnTypes.data(), aOwnTypes.size());
|
||||
}
|
||||
|
||||
|
||||
Any SAL_CALL OCalcTable::queryInterface( const Type & rType )
|
||||
{
|
||||
if( rType == cppu::UnoType<XKeysSupplier>::get()||
|
||||
rType == cppu::UnoType<XIndexesSupplier>::get()||
|
||||
rType == cppu::UnoType<XRename>::get()||
|
||||
rType == cppu::UnoType<XAlterTable>::get()||
|
||||
rType == cppu::UnoType<XDataDescriptorFactory>::get())
|
||||
return Any();
|
||||
|
||||
const Any aRet = ::cppu::queryInterface(rType,static_cast< css::lang::XUnoTunnel*> (this));
|
||||
return aRet.hasValue() ? aRet : OTable_TYPEDEF::queryInterface(rType);
|
||||
}
|
||||
|
||||
|
||||
Sequence< sal_Int8 > OCalcTable::getUnoTunnelImplementationId()
|
||||
{
|
||||
static ::cppu::OImplementationId implId;
|
||||
|
@ -695,82 +635,6 @@ sal_Int64 OCalcTable::getSomething( const Sequence< sal_Int8 > & rId )
|
|||
: OCalcTable_BASE::getSomething(rId);
|
||||
}
|
||||
|
||||
sal_Int32 OCalcTable::getCurrentLastPos() const
|
||||
{
|
||||
return m_nDataRows;
|
||||
}
|
||||
|
||||
bool OCalcTable::seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos)
|
||||
{
|
||||
// prepare positioning:
|
||||
|
||||
sal_uInt32 nNumberOfRecords = m_nDataRows;
|
||||
sal_uInt32 nTempPos = m_nFilePos;
|
||||
m_nFilePos = nCurPos;
|
||||
|
||||
switch(eCursorPosition)
|
||||
{
|
||||
case IResultSetHelper::NEXT:
|
||||
m_nFilePos++;
|
||||
break;
|
||||
case IResultSetHelper::PRIOR:
|
||||
if (m_nFilePos > 0)
|
||||
m_nFilePos--;
|
||||
break;
|
||||
case IResultSetHelper::FIRST:
|
||||
m_nFilePos = 1;
|
||||
break;
|
||||
case IResultSetHelper::LAST:
|
||||
m_nFilePos = nNumberOfRecords;
|
||||
break;
|
||||
case IResultSetHelper::RELATIVE1:
|
||||
m_nFilePos = (m_nFilePos + nOffset < 0) ? 0L
|
||||
: (sal_uInt32)(m_nFilePos + nOffset);
|
||||
break;
|
||||
case IResultSetHelper::ABSOLUTE1:
|
||||
case IResultSetHelper::BOOKMARK:
|
||||
m_nFilePos = (sal_uInt32)nOffset;
|
||||
break;
|
||||
}
|
||||
|
||||
if (m_nFilePos > (sal_Int32)nNumberOfRecords)
|
||||
m_nFilePos = (sal_Int32)nNumberOfRecords + 1;
|
||||
|
||||
if (m_nFilePos == 0 || m_nFilePos == (sal_Int32)nNumberOfRecords + 1)
|
||||
goto Error;
|
||||
else
|
||||
{
|
||||
//! read buffer / setup row object etc?
|
||||
}
|
||||
goto End;
|
||||
|
||||
Error:
|
||||
switch(eCursorPosition)
|
||||
{
|
||||
case IResultSetHelper::PRIOR:
|
||||
case IResultSetHelper::FIRST:
|
||||
m_nFilePos = 0;
|
||||
break;
|
||||
case IResultSetHelper::LAST:
|
||||
case IResultSetHelper::NEXT:
|
||||
case IResultSetHelper::ABSOLUTE1:
|
||||
case IResultSetHelper::RELATIVE1:
|
||||
if (nOffset > 0)
|
||||
m_nFilePos = nNumberOfRecords + 1;
|
||||
else if (nOffset < 0)
|
||||
m_nFilePos = 0;
|
||||
break;
|
||||
case IResultSetHelper::BOOKMARK:
|
||||
m_nFilePos = nTempPos; // previous position
|
||||
}
|
||||
// aStatus.Set(SDB_STAT_NO_DATA_FOUND);
|
||||
return false;
|
||||
|
||||
End:
|
||||
nCurPos = m_nFilePos;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool OCalcTable::fetchRow( OValueRefRow& _rRow, const OSQLColumns & _rCols,
|
||||
bool bRetrieveData )
|
||||
{
|
||||
|
@ -801,12 +665,4 @@ bool OCalcTable::fetchRow( OValueRefRow& _rRow, const OSQLColumns & _rCols,
|
|||
return true;
|
||||
}
|
||||
|
||||
void OCalcTable::FileClose()
|
||||
{
|
||||
::osl::MutexGuard aGuard(m_aMutex);
|
||||
|
||||
OCalcTable_BASE::FileClose();
|
||||
}
|
||||
|
||||
|
||||
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
||||
|
|
226
connectivity/source/drivers/component/CTable.cxx
Normal file
226
connectivity/source/drivers/component/CTable.cxx
Normal file
|
@ -0,0 +1,226 @@
|
|||
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
||||
/*
|
||||
* This file is part of the LibreOffice project.
|
||||
*
|
||||
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
*
|
||||
* This file incorporates work covered by the following license notice:
|
||||
*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed
|
||||
* with this work for additional information regarding copyright
|
||||
* ownership. The ASF licenses this file to you under the Apache
|
||||
* License, Version 2.0 (the "License"); you may not use this file
|
||||
* except in compliance with the License. You may obtain a copy of
|
||||
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
||||
*/
|
||||
|
||||
#include "component/CTable.hxx"
|
||||
#include <com/sun/star/sdbc/ColumnValue.hpp>
|
||||
#include <com/sun/star/sdbc/DataType.hpp>
|
||||
#include <com/sun/star/sdbc/XRow.hpp>
|
||||
#include <com/sun/star/sheet/XSpreadsheetDocument.hpp>
|
||||
#include <com/sun/star/sheet/XSpreadsheet.hpp>
|
||||
#include <com/sun/star/sheet/XCellRangeAddressable.hpp>
|
||||
#include <com/sun/star/sheet/XCellRangesQuery.hpp>
|
||||
#include <com/sun/star/sheet/XDatabaseRanges.hpp>
|
||||
#include <com/sun/star/sheet/XDatabaseRange.hpp>
|
||||
#include <com/sun/star/sheet/XCellRangeReferrer.hpp>
|
||||
#include <com/sun/star/sheet/XUsedAreaCursor.hpp>
|
||||
#include <com/sun/star/sheet/CellFlags.hpp>
|
||||
#include <com/sun/star/sheet/FormulaResult.hpp>
|
||||
#include <com/sun/star/util/NumberFormat.hpp>
|
||||
#include <com/sun/star/util/XNumberFormatsSupplier.hpp>
|
||||
#include <com/sun/star/text/XText.hpp>
|
||||
#include <svl/converter.hxx>
|
||||
#include "component/CColumns.hxx"
|
||||
#include <connectivity/sdbcx/VColumn.hxx>
|
||||
#include <rtl/ustrbuf.hxx>
|
||||
#include <osl/thread.h>
|
||||
#include <cppuhelper/queryinterface.hxx>
|
||||
#include <comphelper/sequence.hxx>
|
||||
#include <svl/zforlist.hxx>
|
||||
#include <rtl/math.hxx>
|
||||
#include <comphelper/extract.hxx>
|
||||
#include <connectivity/dbexception.hxx>
|
||||
#include <connectivity/dbconversion.hxx>
|
||||
#include <comphelper/types.hxx>
|
||||
|
||||
using namespace connectivity;
|
||||
using namespace connectivity::component;
|
||||
using namespace connectivity::file;
|
||||
using namespace ::cppu;
|
||||
using namespace ::dbtools;
|
||||
using namespace ::com::sun::star::uno;
|
||||
using namespace ::com::sun::star::beans;
|
||||
using namespace ::com::sun::star::sdbcx;
|
||||
using namespace ::com::sun::star::sdbc;
|
||||
using namespace ::com::sun::star::container;
|
||||
using namespace ::com::sun::star::lang;
|
||||
using namespace ::com::sun::star::sheet;
|
||||
using namespace ::com::sun::star::table;
|
||||
using namespace ::com::sun::star::text;
|
||||
using namespace ::com::sun::star::util;
|
||||
|
||||
|
||||
OComponentTable::OComponentTable(sdbcx::OCollection* _pTables,file::OConnection* _pConnection,
|
||||
const OUString& Name,
|
||||
const OUString& Type,
|
||||
const OUString& Description ,
|
||||
const OUString& SchemaName,
|
||||
const OUString& CatalogName
|
||||
) : OComponentTable_BASE(_pTables,_pConnection,Name,
|
||||
Type,
|
||||
Description,
|
||||
SchemaName,
|
||||
CatalogName)
|
||||
,m_nDataRows(0)
|
||||
{
|
||||
}
|
||||
|
||||
void OComponentTable::refreshColumns()
|
||||
{
|
||||
::osl::MutexGuard aGuard( m_aMutex );
|
||||
|
||||
TStringVector aVector;
|
||||
|
||||
OSQLColumns::Vector::const_iterator aEnd = m_aColumns->get().end();
|
||||
for(OSQLColumns::Vector::const_iterator aIter = m_aColumns->get().begin();aIter != aEnd;++aIter)
|
||||
aVector.push_back(Reference< XNamed>(*aIter,UNO_QUERY)->getName());
|
||||
|
||||
if(m_pColumns)
|
||||
m_pColumns->reFill(aVector);
|
||||
else
|
||||
m_pColumns = new component::OComponentColumns(this,m_aMutex,aVector);
|
||||
}
|
||||
|
||||
void OComponentTable::refreshIndexes()
|
||||
{
|
||||
// Writer or Calc table has no index
|
||||
}
|
||||
|
||||
|
||||
Sequence< Type > SAL_CALL OComponentTable::getTypes( )
|
||||
{
|
||||
Sequence< Type > aTypes = OTable_TYPEDEF::getTypes();
|
||||
std::vector<Type> aOwnTypes;
|
||||
aOwnTypes.reserve(aTypes.getLength());
|
||||
|
||||
const Type* pBegin = aTypes.getConstArray();
|
||||
const Type* pEnd = pBegin + aTypes.getLength();
|
||||
for(;pBegin != pEnd;++pBegin)
|
||||
{
|
||||
if(!( *pBegin == cppu::UnoType<XKeysSupplier>::get()||
|
||||
*pBegin == cppu::UnoType<XIndexesSupplier>::get()||
|
||||
*pBegin == cppu::UnoType<XRename>::get()||
|
||||
*pBegin == cppu::UnoType<XAlterTable>::get()||
|
||||
*pBegin == cppu::UnoType<XDataDescriptorFactory>::get()))
|
||||
aOwnTypes.push_back(*pBegin);
|
||||
}
|
||||
aOwnTypes.push_back(cppu::UnoType<css::lang::XUnoTunnel>::get());
|
||||
|
||||
return Sequence< Type >(aOwnTypes.data(), aOwnTypes.size());
|
||||
}
|
||||
|
||||
|
||||
Any SAL_CALL OComponentTable::queryInterface( const Type & rType )
|
||||
{
|
||||
if( rType == cppu::UnoType<XKeysSupplier>::get()||
|
||||
rType == cppu::UnoType<XIndexesSupplier>::get()||
|
||||
rType == cppu::UnoType<XRename>::get()||
|
||||
rType == cppu::UnoType<XAlterTable>::get()||
|
||||
rType == cppu::UnoType<XDataDescriptorFactory>::get())
|
||||
return Any();
|
||||
|
||||
const Any aRet = ::cppu::queryInterface(rType,static_cast< css::lang::XUnoTunnel*> (this));
|
||||
return aRet.hasValue() ? aRet : OTable_TYPEDEF::queryInterface(rType);
|
||||
}
|
||||
|
||||
|
||||
sal_Int32 OComponentTable::getCurrentLastPos() const
|
||||
{
|
||||
return m_nDataRows;
|
||||
}
|
||||
|
||||
bool OComponentTable::seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos)
|
||||
{
|
||||
// prepare positioning:
|
||||
|
||||
sal_uInt32 nNumberOfRecords = m_nDataRows;
|
||||
sal_uInt32 nTempPos = m_nFilePos;
|
||||
m_nFilePos = nCurPos;
|
||||
|
||||
switch(eCursorPosition)
|
||||
{
|
||||
case IResultSetHelper::NEXT:
|
||||
m_nFilePos++;
|
||||
break;
|
||||
case IResultSetHelper::PRIOR:
|
||||
if (m_nFilePos > 0)
|
||||
m_nFilePos--;
|
||||
break;
|
||||
case IResultSetHelper::FIRST:
|
||||
m_nFilePos = 1;
|
||||
break;
|
||||
case IResultSetHelper::LAST:
|
||||
m_nFilePos = nNumberOfRecords;
|
||||
break;
|
||||
case IResultSetHelper::RELATIVE1:
|
||||
m_nFilePos = (m_nFilePos + nOffset < 0) ? 0L
|
||||
: (sal_uInt32)(m_nFilePos + nOffset);
|
||||
break;
|
||||
case IResultSetHelper::ABSOLUTE1:
|
||||
case IResultSetHelper::BOOKMARK:
|
||||
m_nFilePos = (sal_uInt32)nOffset;
|
||||
break;
|
||||
}
|
||||
|
||||
if (m_nFilePos > (sal_Int32)nNumberOfRecords)
|
||||
m_nFilePos = (sal_Int32)nNumberOfRecords + 1;
|
||||
|
||||
if (m_nFilePos == 0 || m_nFilePos == (sal_Int32)nNumberOfRecords + 1)
|
||||
goto Error;
|
||||
else
|
||||
{
|
||||
//! read buffer / setup row object etc?
|
||||
}
|
||||
goto End;
|
||||
|
||||
Error:
|
||||
switch(eCursorPosition)
|
||||
{
|
||||
case IResultSetHelper::PRIOR:
|
||||
case IResultSetHelper::FIRST:
|
||||
m_nFilePos = 0;
|
||||
break;
|
||||
case IResultSetHelper::LAST:
|
||||
case IResultSetHelper::NEXT:
|
||||
case IResultSetHelper::ABSOLUTE1:
|
||||
case IResultSetHelper::RELATIVE1:
|
||||
if (nOffset > 0)
|
||||
m_nFilePos = nNumberOfRecords + 1;
|
||||
else if (nOffset < 0)
|
||||
m_nFilePos = 0;
|
||||
break;
|
||||
case IResultSetHelper::BOOKMARK:
|
||||
m_nFilePos = nTempPos; // previous position
|
||||
}
|
||||
// aStatus.Set(SDB_STAT_NO_DATA_FOUND);
|
||||
return false;
|
||||
|
||||
End:
|
||||
nCurPos = m_nFilePos;
|
||||
return true;
|
||||
}
|
||||
|
||||
void OComponentTable::FileClose()
|
||||
{
|
||||
::osl::MutexGuard aGuard(m_aMutex);
|
||||
|
||||
OComponentTable_BASE::FileClose();
|
||||
}
|
||||
|
||||
|
||||
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
|
@ -186,7 +186,6 @@ OWriterTable::OWriterTable(sdbcx::OCollection* _pTables, OWriterConnection* _pCo
|
|||
,m_nStartCol(0)
|
||||
,m_nStartRow(0)
|
||||
,m_nDataCols(0)
|
||||
,m_nDataRows(0)
|
||||
,m_bHasHeaders(false)
|
||||
{
|
||||
}
|
||||
|
@ -218,28 +217,6 @@ void OWriterTable::construct()
|
|||
refreshColumns();
|
||||
}
|
||||
|
||||
void OWriterTable::refreshColumns()
|
||||
{
|
||||
::osl::MutexGuard aGuard(m_aMutex);
|
||||
|
||||
TStringVector aVector;
|
||||
|
||||
OSQLColumns::Vector::const_iterator aEnd = m_aColumns->get().end();
|
||||
for (OSQLColumns::Vector::const_iterator aIter = m_aColumns->get().begin(); aIter != aEnd; ++aIter)
|
||||
aVector.push_back(uno::Reference<XNamed>(*aIter, uno::UNO_QUERY)->getName());
|
||||
|
||||
if (m_pColumns)
|
||||
m_pColumns->reFill(aVector);
|
||||
else
|
||||
m_pColumns = new component::OComponentColumns(this, m_aMutex, aVector);
|
||||
}
|
||||
|
||||
void OWriterTable::refreshIndexes()
|
||||
{
|
||||
// Writer table has no index
|
||||
}
|
||||
|
||||
|
||||
void SAL_CALL OWriterTable::disposing()
|
||||
{
|
||||
OFileTable::disposing();
|
||||
|
@ -251,43 +228,6 @@ void SAL_CALL OWriterTable::disposing()
|
|||
|
||||
}
|
||||
|
||||
uno::Sequence< uno::Type > SAL_CALL OWriterTable::getTypes()
|
||||
{
|
||||
uno::Sequence< uno::Type > aTypes = file::OTable_TYPEDEF::getTypes();
|
||||
std::vector<uno::Type> aOwnTypes;
|
||||
aOwnTypes.reserve(aTypes.getLength());
|
||||
|
||||
const uno::Type* pBegin = aTypes.getConstArray();
|
||||
const uno::Type* pEnd = pBegin + aTypes.getLength();
|
||||
for (; pBegin != pEnd; ++pBegin)
|
||||
{
|
||||
if (!(*pBegin == cppu::UnoType<XKeysSupplier>::get()||
|
||||
*pBegin == cppu::UnoType<XIndexesSupplier>::get()||
|
||||
*pBegin == cppu::UnoType<XRename>::get()||
|
||||
*pBegin == cppu::UnoType<XAlterTable>::get()||
|
||||
*pBegin == cppu::UnoType<XDataDescriptorFactory>::get()))
|
||||
aOwnTypes.push_back(*pBegin);
|
||||
}
|
||||
aOwnTypes.push_back(cppu::UnoType<css::lang::XUnoTunnel>::get());
|
||||
|
||||
return uno::Sequence< uno::Type >(aOwnTypes.data(), aOwnTypes.size());
|
||||
}
|
||||
|
||||
|
||||
uno::Any SAL_CALL OWriterTable::queryInterface(const uno::Type& rType)
|
||||
{
|
||||
if (rType == cppu::UnoType<XKeysSupplier>::get()||
|
||||
rType == cppu::UnoType<XIndexesSupplier>::get()||
|
||||
rType == cppu::UnoType<XRename>::get()||
|
||||
rType == cppu::UnoType<XAlterTable>::get()||
|
||||
rType == cppu::UnoType<XDataDescriptorFactory>::get())
|
||||
return uno::Any();
|
||||
|
||||
const uno::Any aRet = ::cppu::queryInterface(rType,static_cast< css::lang::XUnoTunnel*>(this));
|
||||
return aRet.hasValue() ? aRet : file::OTable_TYPEDEF::queryInterface(rType);
|
||||
}
|
||||
|
||||
|
||||
uno::Sequence< sal_Int8 > OWriterTable::getUnoTunnelImplementationId()
|
||||
{
|
||||
static ::cppu::OImplementationId implId;
|
||||
|
@ -302,82 +242,6 @@ sal_Int64 OWriterTable::getSomething(const uno::Sequence< sal_Int8 >& rId)
|
|||
: OWriterTable_BASE::getSomething(rId);
|
||||
}
|
||||
|
||||
sal_Int32 OWriterTable::getCurrentLastPos() const
|
||||
{
|
||||
return m_nDataRows;
|
||||
}
|
||||
|
||||
bool OWriterTable::seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos)
|
||||
{
|
||||
// prepare positioning:
|
||||
|
||||
sal_uInt32 nNumberOfRecords = m_nDataRows;
|
||||
sal_uInt32 nTempPos = m_nFilePos;
|
||||
m_nFilePos = nCurPos;
|
||||
|
||||
switch (eCursorPosition)
|
||||
{
|
||||
case IResultSetHelper::NEXT:
|
||||
m_nFilePos++;
|
||||
break;
|
||||
case IResultSetHelper::PRIOR:
|
||||
if (m_nFilePos > 0)
|
||||
m_nFilePos--;
|
||||
break;
|
||||
case IResultSetHelper::FIRST:
|
||||
m_nFilePos = 1;
|
||||
break;
|
||||
case IResultSetHelper::LAST:
|
||||
m_nFilePos = nNumberOfRecords;
|
||||
break;
|
||||
case IResultSetHelper::RELATIVE1:
|
||||
m_nFilePos = (m_nFilePos + nOffset < 0) ? 0L
|
||||
: (sal_uInt32)(m_nFilePos + nOffset);
|
||||
break;
|
||||
case IResultSetHelper::ABSOLUTE1:
|
||||
case IResultSetHelper::BOOKMARK:
|
||||
m_nFilePos = (sal_uInt32)nOffset;
|
||||
break;
|
||||
}
|
||||
|
||||
if (m_nFilePos > (sal_Int32)nNumberOfRecords)
|
||||
m_nFilePos = (sal_Int32)nNumberOfRecords + 1;
|
||||
|
||||
if (m_nFilePos == 0 || m_nFilePos == (sal_Int32)nNumberOfRecords + 1)
|
||||
goto Error;
|
||||
else
|
||||
{
|
||||
//! read buffer / setup row object etc?
|
||||
}
|
||||
goto End;
|
||||
|
||||
Error:
|
||||
switch (eCursorPosition)
|
||||
{
|
||||
case IResultSetHelper::PRIOR:
|
||||
case IResultSetHelper::FIRST:
|
||||
m_nFilePos = 0;
|
||||
break;
|
||||
case IResultSetHelper::LAST:
|
||||
case IResultSetHelper::NEXT:
|
||||
case IResultSetHelper::ABSOLUTE1:
|
||||
case IResultSetHelper::RELATIVE1:
|
||||
if (nOffset > 0)
|
||||
m_nFilePos = nNumberOfRecords + 1;
|
||||
else if (nOffset < 0)
|
||||
m_nFilePos = 0;
|
||||
break;
|
||||
case IResultSetHelper::BOOKMARK:
|
||||
m_nFilePos = nTempPos; // previous position
|
||||
}
|
||||
// aStatus.Set(SDB_STAT_NO_DATA_FOUND);
|
||||
return false;
|
||||
|
||||
End:
|
||||
nCurPos = m_nFilePos;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool OWriterTable::fetchRow(OValueRefRow& _rRow, const OSQLColumns& _rCols,
|
||||
bool bRetrieveData)
|
||||
{
|
||||
|
@ -406,13 +270,6 @@ bool OWriterTable::fetchRow(OValueRefRow& _rRow, const OSQLColumns& _rCols,
|
|||
return true;
|
||||
}
|
||||
|
||||
void OWriterTable::FileClose()
|
||||
{
|
||||
::osl::MutexGuard aGuard(m_aMutex);
|
||||
|
||||
OWriterTable_BASE::FileClose();
|
||||
}
|
||||
|
||||
} // namespace writer
|
||||
} // namespace connectivity
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
#ifndef INCLUDED_CONNECTIVITY_SOURCE_INC_CALC_CTABLE_HXX
|
||||
#define INCLUDED_CONNECTIVITY_SOURCE_INC_CALC_CTABLE_HXX
|
||||
|
||||
#include "file/FTable.hxx"
|
||||
#include "component/CTable.hxx"
|
||||
#include <tools/date.hxx>
|
||||
|
||||
namespace com { namespace sun { namespace star { namespace sheet {
|
||||
|
@ -36,7 +36,7 @@ namespace connectivity
|
|||
{
|
||||
namespace calc
|
||||
{
|
||||
typedef file::OFileTable OCalcTable_BASE;
|
||||
typedef component::OComponentTable OCalcTable_BASE;
|
||||
class OCalcConnection;
|
||||
|
||||
class OCalcTable : public OCalcTable_BASE
|
||||
|
@ -50,19 +50,12 @@ namespace connectivity
|
|||
sal_Int32 m_nStartCol;
|
||||
sal_Int32 m_nStartRow;
|
||||
sal_Int32 m_nDataCols;
|
||||
sal_Int32 m_nDataRows;
|
||||
bool m_bHasHeaders;
|
||||
css::uno::Reference< css::util::XNumberFormats > m_xFormats;
|
||||
::Date m_aNullDate;
|
||||
|
||||
void fillColumns();
|
||||
|
||||
protected:
|
||||
virtual void FileClose() override;
|
||||
public:
|
||||
virtual void refreshColumns() override;
|
||||
virtual void refreshIndexes() override;
|
||||
|
||||
public:
|
||||
OCalcTable( sdbcx::OCollection* _pTables,OCalcConnection* _pConnection,
|
||||
const OUString& Name,
|
||||
|
@ -72,13 +65,8 @@ namespace connectivity
|
|||
const OUString& CatalogName = OUString()
|
||||
);
|
||||
|
||||
virtual sal_Int32 getCurrentLastPos() const override;
|
||||
virtual bool seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos) override;
|
||||
virtual bool fetchRow(OValueRefRow& _rRow, const OSQLColumns& _rCols, bool bRetrieveData) override;
|
||||
|
||||
virtual css::uno::Any SAL_CALL queryInterface( const css::uno::Type & rType ) override;
|
||||
//XTypeProvider
|
||||
virtual css::uno::Sequence< css::uno::Type > SAL_CALL getTypes( ) override;
|
||||
virtual void SAL_CALL disposing() override;
|
||||
|
||||
// css::lang::XUnoTunnel
|
||||
|
|
72
connectivity/source/inc/component/CTable.hxx
Normal file
72
connectivity/source/inc/component/CTable.hxx
Normal file
|
@ -0,0 +1,72 @@
|
|||
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
||||
/*
|
||||
* This file is part of the LibreOffice project.
|
||||
*
|
||||
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
*
|
||||
* This file incorporates work covered by the following license notice:
|
||||
*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed
|
||||
* with this work for additional information regarding copyright
|
||||
* ownership. The ASF licenses this file to you under the Apache
|
||||
* License, Version 2.0 (the "License"); you may not use this file
|
||||
* except in compliance with the License. You may obtain a copy of
|
||||
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
||||
*/
|
||||
|
||||
#ifndef INCLUDED_CONNECTIVITY_SOURCE_INC_COMPONENT_CTABLE_HXX
|
||||
#define INCLUDED_CONNECTIVITY_SOURCE_INC_COMPONENT_CTABLE_HXX
|
||||
|
||||
#include "file/FTable.hxx"
|
||||
#include <tools/date.hxx>
|
||||
|
||||
namespace com { namespace sun { namespace star { namespace sheet {
|
||||
class XSpreadsheet;
|
||||
} } } }
|
||||
|
||||
namespace com { namespace sun { namespace star { namespace util {
|
||||
class XNumberFormats;
|
||||
} } } }
|
||||
|
||||
|
||||
namespace connectivity
|
||||
{
|
||||
namespace component
|
||||
{
|
||||
typedef file::OFileTable OComponentTable_BASE;
|
||||
|
||||
/// Shared Table base class for Writer tables and Calc sheets.
|
||||
class OOO_DLLPUBLIC_FILE OComponentTable : public OComponentTable_BASE
|
||||
{
|
||||
protected:
|
||||
sal_Int32 m_nDataRows;
|
||||
|
||||
virtual void FileClose() override;
|
||||
public:
|
||||
OComponentTable( sdbcx::OCollection* _pTables,file::OConnection* _pConnection,
|
||||
const OUString& Name,
|
||||
const OUString& Type,
|
||||
const OUString& Description = OUString(),
|
||||
const OUString& SchemaName = OUString(),
|
||||
const OUString& CatalogName = OUString()
|
||||
);
|
||||
|
||||
virtual void refreshColumns() override;
|
||||
virtual void refreshIndexes() override;
|
||||
|
||||
virtual sal_Int32 getCurrentLastPos() const override;
|
||||
virtual bool seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos) override;
|
||||
|
||||
virtual css::uno::Any SAL_CALL queryInterface( const css::uno::Type & rType ) override;
|
||||
//XTypeProvider
|
||||
virtual css::uno::Sequence< css::uno::Type > SAL_CALL getTypes( ) override;
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
#endif // INCLUDED_CONNECTIVITY_SOURCE_INC_COMPONENT_CTABLE_HXX
|
||||
|
||||
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
|
@ -20,7 +20,7 @@
|
|||
#ifndef INCLUDED_CONNECTIVITY_SOURCE_INC_WRITER_WTABLE_HXX
|
||||
#define INCLUDED_CONNECTIVITY_SOURCE_INC_WRITER_WTABLE_HXX
|
||||
|
||||
#include "file/FTable.hxx"
|
||||
#include "component/CTable.hxx"
|
||||
#include <tools/date.hxx>
|
||||
|
||||
namespace com
|
||||
|
@ -56,7 +56,7 @@ namespace connectivity
|
|||
{
|
||||
namespace writer
|
||||
{
|
||||
typedef file::OFileTable OWriterTable_BASE;
|
||||
typedef component::OComponentTable OWriterTable_BASE;
|
||||
class OWriterConnection;
|
||||
|
||||
class OWriterTable : public OWriterTable_BASE
|
||||
|
@ -70,18 +70,11 @@ private:
|
|||
sal_Int32 m_nStartCol;
|
||||
sal_Int32 m_nStartRow;
|
||||
sal_Int32 m_nDataCols;
|
||||
sal_Int32 m_nDataRows;
|
||||
bool m_bHasHeaders;
|
||||
css::uno::Reference< css::util::XNumberFormats > m_xFormats;
|
||||
|
||||
void fillColumns();
|
||||
|
||||
protected:
|
||||
virtual void FileClose() override;
|
||||
public:
|
||||
virtual void refreshColumns() override;
|
||||
virtual void refreshIndexes() override;
|
||||
|
||||
public:
|
||||
OWriterTable(sdbcx::OCollection* _pTables, OWriterConnection* _pConnection,
|
||||
const OUString& Name,
|
||||
|
@ -91,13 +84,8 @@ public:
|
|||
const OUString& CatalogName = OUString()
|
||||
);
|
||||
|
||||
virtual sal_Int32 getCurrentLastPos() const override;
|
||||
virtual bool seekRow(IResultSetHelper::Movement eCursorPosition, sal_Int32 nOffset, sal_Int32& nCurPos) override;
|
||||
virtual bool fetchRow(OValueRefRow& _rRow, const OSQLColumns& _rCols, bool bRetrieveData) override;
|
||||
|
||||
virtual css::uno::Any SAL_CALL queryInterface(const css::uno::Type& rType) override;
|
||||
//XTypeProvider
|
||||
virtual css::uno::Sequence< css::uno::Type > SAL_CALL getTypes() override;
|
||||
virtual void SAL_CALL disposing() override;
|
||||
|
||||
// css::lang::XUnoTunnel
|
||||
|
|
Loading…
Reference in a new issue