2009-09-09 10:57:16 -04:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
|
|
*
|
|
|
|
* $RCSfile: interpr4.cxx,v $
|
|
|
|
* $Revision: 1.57.92.5 $
|
|
|
|
*
|
|
|
|
* This file is part of OpenOffice.org.
|
|
|
|
*
|
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_sc.hxx"
|
|
|
|
|
|
|
|
// INCLUDE ---------------------------------------------------------------
|
|
|
|
|
|
|
|
#include "queryparam.hxx"
|
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
using ::std::vector;
|
|
|
|
|
2009-09-09 10:57:16 -04:00
|
|
|
// ============================================================================
|
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
ScQueryParamBase::ScQueryParamBase()
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
2009-09-09 23:58:50 -04:00
|
|
|
Resize( MAXQUERY );
|
|
|
|
for (USHORT i=0; i<MAXQUERY; i++)
|
2009-09-16 17:38:14 -04:00
|
|
|
maEntries[i].Clear();
|
2009-09-09 10:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
ScQueryParamBase::ScQueryParamBase(const ScQueryParamBase& r) :
|
|
|
|
bHasHeader(r.bHasHeader), bByRow(r.bByRow), bInplace(r.bInplace), bCaseSens(r.bCaseSens),
|
2009-09-16 17:38:14 -04:00
|
|
|
bRegExp(r.bRegExp), bDuplicate(r.bDuplicate), bMixedComparison(r.bMixedComparison),
|
|
|
|
maEntries(r.maEntries)
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScQueryParamBase::~ScQueryParamBase()
|
|
|
|
{
|
2009-09-16 17:38:14 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
SCSIZE ScQueryParamBase::GetEntryCount() const
|
|
|
|
{
|
|
|
|
return maEntries.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
ScQueryEntry& ScQueryParamBase::GetEntry(SCSIZE n) const
|
|
|
|
{
|
|
|
|
return maEntries[n];
|
2009-09-09 10:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void ScQueryParamBase::Resize(SCSIZE nNew)
|
|
|
|
{
|
|
|
|
if ( nNew < MAXQUERY )
|
|
|
|
nNew = MAXQUERY; // nie weniger als MAXQUERY
|
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
vector<ScQueryEntry> aNewEntries(nNew);
|
|
|
|
SCSIZE nCopy = ::std::min(maEntries.size(), nNew);
|
2009-09-09 10:57:16 -04:00
|
|
|
for (SCSIZE i=0; i<nCopy; i++)
|
2009-09-16 17:38:14 -04:00
|
|
|
aNewEntries[i] = maEntries[i];
|
2009-09-09 10:57:16 -04:00
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
maEntries.swap(aNewEntries);
|
2009-09-09 10:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void ScQueryParamBase::DeleteQuery( SCSIZE nPos )
|
|
|
|
{
|
2009-09-16 17:38:14 -04:00
|
|
|
if (nPos >= maEntries.size())
|
|
|
|
return;
|
2009-09-09 10:57:16 -04:00
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
size_t n = maEntries.size();
|
|
|
|
vector<ScQueryEntry> aNewEntries;
|
2009-11-26 00:25:40 -05:00
|
|
|
aNewEntries.reserve(n);
|
2009-09-16 17:38:14 -04:00
|
|
|
for (size_t i = 0; i < n; ++i)
|
|
|
|
if (i != nPos)
|
|
|
|
aNewEntries.push_back(maEntries[i]);
|
|
|
|
|
2009-11-26 00:25:40 -05:00
|
|
|
// Don't forget to append an empty entry to make up for the removed one.
|
|
|
|
// The size of the entries is not supposed to change.
|
|
|
|
aNewEntries.push_back(ScQueryEntry());
|
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
maEntries.swap(aNewEntries);
|
2009-09-09 10:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void ScQueryParamBase::FillInExcelSyntax(String& aCellStr, SCSIZE nIndex)
|
|
|
|
{
|
|
|
|
if (aCellStr.Len() > 0)
|
|
|
|
{
|
2009-09-16 17:38:14 -04:00
|
|
|
if ( nIndex >= maEntries.size() )
|
2009-09-09 10:57:16 -04:00
|
|
|
Resize( nIndex+1 );
|
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
ScQueryEntry& rEntry = GetEntry(nIndex);
|
2009-09-09 10:57:16 -04:00
|
|
|
|
|
|
|
rEntry.bDoQuery = TRUE;
|
|
|
|
// Operatoren herausfiltern
|
|
|
|
if (aCellStr.GetChar(0) == '<')
|
|
|
|
{
|
|
|
|
if (aCellStr.GetChar(1) == '>')
|
|
|
|
{
|
|
|
|
*rEntry.pStr = aCellStr.Copy(2);
|
|
|
|
rEntry.eOp = SC_NOT_EQUAL;
|
|
|
|
}
|
|
|
|
else if (aCellStr.GetChar(1) == '=')
|
|
|
|
{
|
|
|
|
*rEntry.pStr = aCellStr.Copy(2);
|
|
|
|
rEntry.eOp = SC_LESS_EQUAL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
*rEntry.pStr = aCellStr.Copy(1);
|
|
|
|
rEntry.eOp = SC_LESS;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (aCellStr.GetChar(0) == '>')
|
|
|
|
{
|
|
|
|
if (aCellStr.GetChar(1) == '=')
|
|
|
|
{
|
|
|
|
*rEntry.pStr = aCellStr.Copy(2);
|
|
|
|
rEntry.eOp = SC_GREATER_EQUAL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
*rEntry.pStr = aCellStr.Copy(1);
|
|
|
|
rEntry.eOp = SC_GREATER;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (aCellStr.GetChar(0) == '=')
|
|
|
|
*rEntry.pStr = aCellStr.Copy(1);
|
|
|
|
else
|
|
|
|
*rEntry.pStr = aCellStr;
|
|
|
|
rEntry.eOp = SC_EQUAL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-09-09 23:58:50 -04:00
|
|
|
// ============================================================================
|
|
|
|
|
|
|
|
ScQueryParamTable::ScQueryParamTable()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScQueryParamTable::ScQueryParamTable(const ScQueryParamTable& r) :
|
|
|
|
nCol1(r.nCol1),nRow1(r.nRow1),nCol2(r.nCol2),nRow2(r.nRow2),nTab(r.nTab)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScQueryParamTable::~ScQueryParamTable()
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// ============================================================================
|
|
|
|
|
|
|
|
ScQueryParam::ScQueryParam() :
|
2009-09-09 23:58:50 -04:00
|
|
|
ScQueryParamBase(),
|
2010-03-05 18:23:10 -05:00
|
|
|
ScQueryParamTable(),
|
|
|
|
bDestPers(true),
|
|
|
|
nDestTab(0),
|
|
|
|
nDestCol(0),
|
|
|
|
nDestRow(0)
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
Clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
|
|
|
|
ScQueryParam::ScQueryParam( const ScQueryParam& r ) :
|
|
|
|
ScQueryParamBase(r),
|
2009-09-09 23:58:50 -04:00
|
|
|
ScQueryParamTable(r),
|
2010-09-15 15:11:13 +02:00
|
|
|
bDestPers(r.bDestPers), nDestTab(r.nDestTab), nDestCol(r.nDestCol), nDestRow(r.nDestRow),
|
|
|
|
nDynamicEndRow(r.nDynamicEndRow), bUseDynamicRange(r.bUseDynamicRange)
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-09-16 16:18:38 -04:00
|
|
|
ScQueryParam::ScQueryParam( const ScDBQueryParamInternal& r ) :
|
|
|
|
ScQueryParamBase(r),
|
|
|
|
ScQueryParamTable(r),
|
|
|
|
bDestPers(true),
|
|
|
|
nDestTab(0),
|
|
|
|
nDestCol(0),
|
2010-09-15 15:11:13 +02:00
|
|
|
nDestRow(0),
|
|
|
|
nDynamicEndRow(0),
|
|
|
|
bUseDynamicRange(false)
|
2009-09-16 16:18:38 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-09 10:57:16 -04:00
|
|
|
//------------------------------------------------------------------------
|
|
|
|
|
|
|
|
ScQueryParam::~ScQueryParam()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
|
|
|
|
void ScQueryParam::Clear()
|
|
|
|
{
|
2009-09-16 16:18:38 -04:00
|
|
|
nCol1=nCol2 = 0;
|
|
|
|
nRow1=nRow2 = 0;
|
2009-09-09 10:57:16 -04:00
|
|
|
nTab = SCTAB_MAX;
|
|
|
|
bHasHeader = bCaseSens = bRegExp = bMixedComparison = FALSE;
|
2009-09-16 16:18:38 -04:00
|
|
|
bInplace = bByRow = bDuplicate = TRUE;
|
2009-09-09 10:57:16 -04:00
|
|
|
|
|
|
|
Resize( MAXQUERY );
|
|
|
|
for (USHORT i=0; i<MAXQUERY; i++)
|
2009-09-16 17:38:14 -04:00
|
|
|
maEntries[i].Clear();
|
2009-09-16 16:18:38 -04:00
|
|
|
|
|
|
|
ClearDestParams();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ScQueryParam::ClearDestParams()
|
|
|
|
{
|
|
|
|
bDestPers = true;
|
|
|
|
nDestTab = 0;
|
|
|
|
nDestCol = 0;
|
|
|
|
nDestRow = 0;
|
2010-09-15 15:11:13 +02:00
|
|
|
nDynamicEndRow = 0;
|
|
|
|
bUseDynamicRange = false;
|
2009-09-09 10:57:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
|
|
|
|
ScQueryParam& ScQueryParam::operator=( const ScQueryParam& r )
|
|
|
|
{
|
|
|
|
nCol1 = r.nCol1;
|
|
|
|
nRow1 = r.nRow1;
|
|
|
|
nCol2 = r.nCol2;
|
|
|
|
nRow2 = r.nRow2;
|
|
|
|
nTab = r.nTab;
|
|
|
|
nDestTab = r.nDestTab;
|
|
|
|
nDestCol = r.nDestCol;
|
|
|
|
nDestRow = r.nDestRow;
|
|
|
|
bHasHeader = r.bHasHeader;
|
|
|
|
bInplace = r.bInplace;
|
|
|
|
bCaseSens = r.bCaseSens;
|
|
|
|
bRegExp = r.bRegExp;
|
|
|
|
bMixedComparison = r.bMixedComparison;
|
|
|
|
bDuplicate = r.bDuplicate;
|
|
|
|
bByRow = r.bByRow;
|
|
|
|
bDestPers = r.bDestPers;
|
2010-09-15 15:11:13 +02:00
|
|
|
nDynamicEndRow = r.nDynamicEndRow;
|
|
|
|
bUseDynamicRange = r.bUseDynamicRange;
|
2009-09-09 10:57:16 -04:00
|
|
|
|
2009-09-16 17:38:14 -04:00
|
|
|
maEntries = r.maEntries;
|
2009-09-09 10:57:16 -04:00
|
|
|
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
|
|
|
|
BOOL ScQueryParam::operator==( const ScQueryParam& rOther ) const
|
|
|
|
{
|
|
|
|
BOOL bEqual = FALSE;
|
|
|
|
|
|
|
|
// Anzahl der Queries gleich?
|
2009-09-16 17:38:14 -04:00
|
|
|
SCSIZE nUsed = 0;
|
|
|
|
SCSIZE nOtherUsed = 0;
|
|
|
|
SCSIZE nEntryCount = GetEntryCount();
|
|
|
|
SCSIZE nOtherEntryCount = rOther.GetEntryCount();
|
|
|
|
|
|
|
|
while ( nUsed<nEntryCount && maEntries[nUsed].bDoQuery ) ++nUsed;
|
|
|
|
while ( nOtherUsed<nOtherEntryCount && rOther.maEntries[nOtherUsed].bDoQuery )
|
2009-09-09 10:57:16 -04:00
|
|
|
++nOtherUsed;
|
|
|
|
|
|
|
|
if ( (nUsed == nOtherUsed)
|
|
|
|
&& (nCol1 == rOther.nCol1)
|
|
|
|
&& (nRow1 == rOther.nRow1)
|
|
|
|
&& (nCol2 == rOther.nCol2)
|
|
|
|
&& (nRow2 == rOther.nRow2)
|
|
|
|
&& (nTab == rOther.nTab)
|
|
|
|
&& (bHasHeader == rOther.bHasHeader)
|
|
|
|
&& (bByRow == rOther.bByRow)
|
|
|
|
&& (bInplace == rOther.bInplace)
|
|
|
|
&& (bCaseSens == rOther.bCaseSens)
|
|
|
|
&& (bRegExp == rOther.bRegExp)
|
|
|
|
&& (bMixedComparison == rOther.bMixedComparison)
|
|
|
|
&& (bDuplicate == rOther.bDuplicate)
|
|
|
|
&& (bDestPers == rOther.bDestPers)
|
|
|
|
&& (nDestTab == rOther.nDestTab)
|
|
|
|
&& (nDestCol == rOther.nDestCol)
|
2010-09-15 15:11:13 +02:00
|
|
|
&& (nDestRow == rOther.nDestRow)
|
|
|
|
&& (nDynamicEndRow == rOther.nDynamicEndRow)
|
|
|
|
&& (bUseDynamicRange == rOther.bUseDynamicRange) )
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
bEqual = TRUE;
|
2009-09-16 17:38:14 -04:00
|
|
|
for ( SCSIZE i=0; i<nUsed && bEqual; i++ )
|
|
|
|
bEqual = maEntries[i] == rOther.maEntries[i];
|
2009-09-09 10:57:16 -04:00
|
|
|
}
|
|
|
|
return bEqual;
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
|
|
|
|
void ScQueryParam::MoveToDest()
|
|
|
|
{
|
|
|
|
if (!bInplace)
|
|
|
|
{
|
|
|
|
SCsCOL nDifX = ((SCsCOL) nDestCol) - ((SCsCOL) nCol1);
|
|
|
|
SCsROW nDifY = ((SCsROW) nDestRow) - ((SCsROW) nRow1);
|
|
|
|
SCsTAB nDifZ = ((SCsTAB) nDestTab) - ((SCsTAB) nTab);
|
|
|
|
|
|
|
|
nCol1 = sal::static_int_cast<SCCOL>( nCol1 + nDifX );
|
|
|
|
nRow1 = sal::static_int_cast<SCROW>( nRow1 + nDifY );
|
|
|
|
nCol2 = sal::static_int_cast<SCCOL>( nCol2 + nDifX );
|
|
|
|
nRow2 = sal::static_int_cast<SCROW>( nRow2 + nDifY );
|
|
|
|
nTab = sal::static_int_cast<SCTAB>( nTab + nDifZ );
|
2010-09-15 15:11:13 +02:00
|
|
|
nDynamicEndRow = sal::static_int_cast<SCROW>( nDynamicEndRow + nDifY );
|
2009-09-16 17:38:14 -04:00
|
|
|
size_t n = maEntries.size();
|
|
|
|
for (size_t i=0; i<n; i++)
|
|
|
|
maEntries[i].nField += nDifX;
|
2009-09-09 10:57:16 -04:00
|
|
|
|
|
|
|
bInplace = TRUE;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
DBG_ERROR("MoveToDest, bInplace == TRUE");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ============================================================================
|
|
|
|
|
2009-09-09 23:58:50 -04:00
|
|
|
ScDBQueryParamBase::ScDBQueryParamBase(DataType eType) :
|
|
|
|
ScQueryParamBase(),
|
|
|
|
mnField(-1),
|
2009-09-16 10:58:37 -04:00
|
|
|
mbSkipString(true),
|
2009-09-09 23:58:50 -04:00
|
|
|
meType(eType)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScDBQueryParamBase::~ScDBQueryParamBase()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScDBQueryParamBase::DataType ScDBQueryParamBase::GetType() const
|
|
|
|
{
|
|
|
|
return meType;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ============================================================================
|
|
|
|
|
|
|
|
ScDBQueryParamInternal::ScDBQueryParamInternal() :
|
|
|
|
ScDBQueryParamBase(ScDBQueryParamBase::INTERNAL),
|
|
|
|
ScQueryParamTable()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScDBQueryParamInternal::~ScDBQueryParamInternal()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// ============================================================================
|
|
|
|
|
|
|
|
ScDBQueryParamMatrix::ScDBQueryParamMatrix() :
|
|
|
|
ScDBQueryParamBase(ScDBQueryParamBase::MATRIX)
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-09-09 23:58:50 -04:00
|
|
|
ScDBQueryParamMatrix::~ScDBQueryParamMatrix()
|
2009-09-09 10:57:16 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|