/* -*- 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 <queryentry.hxx>
#include <unotools/textsearch.hxx>
/*
* dialog returns the special field values "empty"/"not empty"
* as constants SC_EMPTYFIELDS and SC_NONEMPTYFIELDS respectively in nVal in
* conjunctions with the flag bQueryByString = FALSE.
*/
#define SC_EMPTYFIELDS (double(0x0042))
#define SC_NONEMPTYFIELDS (double(0x0043))
#define SC_TEXTCOLOR (double(0x0044))
#define SC_BACKGROUNDCOLOR (double(0x0045))
bool ScQueryEntry::Item::operator== (const Item& r) const
{
return meType == r.meType && mfVal == r.mfVal && maString == r.maString && mbMatchEmpty == r.mbMatchEmpty
&& mbRoundForFilter == r.mbRoundForFilter;
}
ScQueryEntry::ScQueryEntry() :
bDoQuery(false),
nField(0),
eOp(SC_EQUAL),
eConnect(SC_AND),
maQueryItems(1)
{
}
ScQueryEntry::ScQueryEntry(const ScQueryEntry& r) :
bDoQuery(r.bDoQuery),
nField(r.nField),
eOp(r.eOp),
eConnect(r.eConnect),
maQueryItems(r.maQueryItems)
{
}
ScQueryEntry::~ScQueryEntry()
{
}
ScQueryEntry& ScQueryEntry::operator=( const ScQueryEntry& r )
{
bDoQuery = r.bDoQuery;
eOp = r.eOp;
eConnect = r.eConnect;
nField = r.nField;
maQueryItems = r.maQueryItems;
pSearchParam.reset();
pSearchText.reset();
return *this;
}
void ScQueryEntry::SetQueryByEmpty()
{
eOp = SC_EQUAL;
maQueryItems.resize(1);
Item& rItem = maQueryItems[0];
rItem.meType = ByEmpty;
rItem.maString = svl::SharedString();
rItem.mfVal = SC_EMPTYFIELDS;
}
bool ScQueryEntry::IsQueryByEmpty() const
{
if (maQueryItems.size() != 1)
return false;
const Item& rItem = maQueryItems[0];
return eOp == SC_EQUAL &&
rItem.meType == ByEmpty &&
rItem.maString.isEmpty() &&
rItem.mfVal == SC_EMPTYFIELDS;
}
void ScQueryEntry::SetQueryByNonEmpty()
{
eOp = SC_EQUAL;
maQueryItems.resize(1);
Item& rItem = maQueryItems[0];
rItem.meType = ByEmpty;
rItem.maString = svl::SharedString();
rItem.mfVal = SC_NONEMPTYFIELDS;
}
bool ScQueryEntry::IsQueryByNonEmpty() const
{
if (maQueryItems.size() != 1)
return false;
const Item& rItem = maQueryItems[0];
return eOp == SC_EQUAL &&
rItem.meType == ByEmpty &&
rItem.maString.isEmpty() &&
rItem.mfVal == SC_NONEMPTYFIELDS;
}
void ScQueryEntry::SetQueryByTextColor(Color color)
{
eOp = SC_EQUAL;
maQueryItems.resize(1);
Item& rItem = maQueryItems[0];
rItem.meType = ByTextColor;
rItem.maString = svl::SharedString();
rItem.mfVal = SC_TEXTCOLOR;
rItem.maColor = color;
}
bool ScQueryEntry::IsQueryByTextColor() const
{
if (maQueryItems.size() != 1)
return false;
const Item& rItem = maQueryItems[0];
return eOp == SC_EQUAL &&
rItem.meType == ByTextColor;
}
void ScQueryEntry::SetQueryByBackgroundColor(Color color)
{
eOp = SC_EQUAL;
maQueryItems.resize(1);
Item& rItem = maQueryItems[0];
rItem.meType = ByBackgroundColor;
rItem.maString = svl::SharedString();
rItem.mfVal = SC_BACKGROUNDCOLOR;
rItem.maColor = color;
}
bool ScQueryEntry::IsQueryByBackgroundColor() const
{
if (maQueryItems.size() != 1)
return false;
const Item& rItem = maQueryItems[0];
return eOp == SC_EQUAL &&
rItem.meType == ByBackgroundColor;
}
ScQueryEntry::Item& ScQueryEntry::GetQueryItemImpl() const
{
if (maQueryItems.size() != 1)
// Reset to a single query mode.
maQueryItems.resize(1);
return maQueryItems[0];
}
void ScQueryEntry::Clear()
{
bDoQuery = false;
eOp = SC_EQUAL;
eConnect = SC_AND;
nField = 0;
maQueryItems.clear();
maQueryItems.emplace_back();
pSearchParam.reset();
pSearchText.reset();
}
bool ScQueryEntry::operator==( const ScQueryEntry& r ) const
{
return bDoQuery == r.bDoQuery
&& eOp == r.eOp
&& eConnect == r.eConnect
&& nField == r.nField
&& maQueryItems == r.maQueryItems;
// do not compare pSearchParam and pSearchText!
}
utl::TextSearch* ScQueryEntry::GetSearchTextPtr( utl::SearchParam::SearchType eSearchType, bool bCaseSens,
bool bWildMatchSel ) const
{
if ( !pSearchParam )
{
OUString aStr = maQueryItems[0].maString.getString();
pSearchParam.reset(new utl::SearchParam(
aStr, eSearchType, bCaseSens, '~', bWildMatchSel));
pSearchText.reset(new utl::TextSearch( *pSearchParam, ScGlobal::getCharClass() ));
}
return pSearchText.get();
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
↑ V794 The assignment operator should be protected from the case of 'this == &r'.