16155fdc39
Patches contributed by Herbert Duerr i#118735 prevent endless loop if vlookup/hlookup doesn't find anything http://svn.apache.org/viewvc?view=revision&revision=1239673 Patches contributed by Andre Fischer remove lp_solver http://svn.apache.org/viewvc?view=revision&revision=1199180 i#118160: Added external CoinMP library. http://svn.apache.org/viewvc?view=revision&revision=1233909 Patches contributed by Armin Le-Grand i#118485 - Styles for OLEs are not saved. http://svn.apache.org/viewvc?view=revision&revision=1182166 i#118524: apply patch, followup fixes to 118485 http://svn.apache.org/viewvc?view=revision&revision=1186077 Patches contributed by lihuiibm i#108860 - Fix range validation. http://svn.apache.org/viewvc?view=revision&revision=1242846 i#118954 Chart data will lost after copy to different file http://svn.apache.org/viewvc?view=revision&revision=1301345 Patches contributed by Ariel Constenla-Haile Fix Linux build breaker: extra qualification on member http://svn.apache.org/viewvc?view=revision&revision=1301591 i#118696 - i#118697 - Fix some Sheet Tab Color API issues http://svn.apache.org/viewvc?view=revision&revision=1225428 i#118697 - Fix uninitialized variable http://svn.apache.org/viewvc?view=revision&revision=1225859 i#118771 - ScUndoImportTab should preserve tab background color http://svn.apache.org/viewvc?view=revision&revision=1230356 i#118921 - Repaint linked sheet tab background color after updating link http://svn.apache.org/viewvc?view=revision&revision=1245177 i#118927 - Undo/Redo "Update Link" does not reset sheet tab color http://svn.apache.org/viewvc?view=revision&revision=1245241 i#118747 - Copy tab color when transferring sheets across documents http://svn.apache.org/viewvc?view=revision&revision=1230355 Patch contributed by Oliver Rainer-Wittman i#118012 - methods <ScBroadcastAreaSlot::AreaBroadcast(..)> and <ScBroadcastAreaSlot::AreaBroadcastInRange(..)> adapt stl-container iteration in order to avoid destroyed iterators during iteration. http://svn.apache.org/viewvc?view=revision&revision=1297916 Patches contributed by Mathias Bauer gnumake4 work variously http://svn.apache.org/viewvc?view=revision&revision=1394707 http://svn.apache.org/viewvc?view=revision&revision=1394326 http://svn.apache.org/viewvc?view=revision&revision=1396797 http://svn.apache.org/viewvc?view=revision&revision=1397315 Patch contributed by Daniel Rentz calc69: #i116936# fix VBA symbol Cells http://svn.apache.org/viewvc?view=revision&revision=1172135 Patches contributed by leiw: i#118546 CPU 100% on switched off AutoCalculate with Conditional Formatting on date values http://svn.apache.org/viewvc?view=revision&revision=1301380 Re-add new function documentation. Many various cleanups. Add missing calc66: #o11817313# also look at formula result number format, remove redundant binaries.
215 lines
6.3 KiB
C++
215 lines
6.3 KiB
C++
/* -*- 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_SC_LOOKUPCACHE_HXX
|
|
#define INCLUDED_SC_LOOKUPCACHE_HXX
|
|
|
|
#include "address.hxx"
|
|
#include "global.hxx"
|
|
#include "formula/token.hxx"
|
|
#include <svl/listener.hxx>
|
|
#include <tools/string.hxx>
|
|
|
|
#include <boost/unordered_map.hpp>
|
|
|
|
class ScDocument;
|
|
struct ScQueryEntry;
|
|
|
|
/** Lookup cache for one range used with interpreter functions such as VLOOKUP
|
|
and MATCH. Caches query for a specific row and the resulting address looked
|
|
up, in case other lookups of the same query in the same row are to be
|
|
performed, which usually occur to obtain a different offset column of the
|
|
same query.
|
|
*/
|
|
|
|
class ScLookupCache : public SvtListener
|
|
{
|
|
public:
|
|
|
|
enum Result
|
|
{
|
|
NOT_CACHED, /// Query not found in cache.
|
|
CRITERIA_DIFFERENT, /// Different criteria for same query position exists.
|
|
NOT_AVAILABLE, /// Criteria not available in lookup range.
|
|
FOUND /// Criteria found.
|
|
};
|
|
|
|
enum QueryOp
|
|
{
|
|
UNKNOWN,
|
|
EQUAL,
|
|
LESS_EQUAL,
|
|
GREATER_EQUAL
|
|
};
|
|
|
|
class QueryCriteria
|
|
{
|
|
union
|
|
{
|
|
double mfVal;
|
|
const String * mpStr;
|
|
};
|
|
bool mbAlloc : 1;
|
|
bool mbString : 1;
|
|
QueryOp meOp : 2;
|
|
|
|
void deleteString()
|
|
{
|
|
if (mbAlloc && mbString)
|
|
delete mpStr;
|
|
}
|
|
|
|
// prevent usage
|
|
QueryCriteria();
|
|
QueryCriteria & operator=( const QueryCriteria & r );
|
|
|
|
public:
|
|
|
|
explicit QueryCriteria( const ScQueryEntry & rEntry );
|
|
QueryCriteria( const QueryCriteria & r );
|
|
~QueryCriteria();
|
|
|
|
QueryOp getQueryOp() const { return meOp; }
|
|
|
|
void setDouble( double fVal )
|
|
{
|
|
deleteString();
|
|
mbAlloc = mbString = false;
|
|
mfVal = fVal;
|
|
}
|
|
|
|
void setString( const String * pStr )
|
|
{
|
|
deleteString();
|
|
mbAlloc = false;
|
|
mbString = true;
|
|
mpStr = pStr;
|
|
}
|
|
|
|
void setString( const String & rStr )
|
|
{
|
|
deleteString();
|
|
mbAlloc = mbString = true;
|
|
mpStr = new String( rStr);
|
|
}
|
|
|
|
bool operator==( const QueryCriteria & r ) const
|
|
{
|
|
return meOp == r.meOp && mbString == r.mbString &&
|
|
(mbString ? (*mpStr == *r.mpStr) : (mfVal == r.mfVal));
|
|
}
|
|
|
|
};
|
|
|
|
/// MUST be new'd because Notify() deletes.
|
|
ScLookupCache( ScDocument * pDoc, const ScRange & rRange );
|
|
virtual ~ScLookupCache();
|
|
/// Remove from document structure and delete (!) cache on modify hint.
|
|
virtual void Notify( SvtBroadcaster & rBC, const SfxHint & rHint );
|
|
|
|
/// @returns document address in o_rAddress if Result==FOUND
|
|
Result lookup( ScAddress & o_rResultAddress,
|
|
const QueryCriteria & rCriteria,
|
|
const ScAddress & rQueryAddress ) const;
|
|
|
|
/** Insert query and result.
|
|
@param bAvailable
|
|
Pass sal_False if the search didn't deliver a result. A subsequent
|
|
lookup() then will return Result::NOT_AVAILABLE.
|
|
@returns successful insertion.
|
|
*/
|
|
bool insert( const ScAddress & rResultAddress,
|
|
const QueryCriteria & rCriteria,
|
|
const ScAddress & rQueryAddress,
|
|
const bool bAvailable );
|
|
|
|
inline const ScRange& getRange() const { return maRange; }
|
|
|
|
struct Hash
|
|
{
|
|
size_t operator()( const ScRange & rRange ) const
|
|
{
|
|
// Lookups are performed on the first column.
|
|
return rRange.hashStartColumn();
|
|
}
|
|
};
|
|
|
|
private:
|
|
|
|
struct QueryKey
|
|
{
|
|
SCROW mnRow;
|
|
SCTAB mnTab;
|
|
QueryOp meOp : 2;
|
|
|
|
QueryKey( const ScAddress & rAddress, const QueryOp eOp ) :
|
|
mnRow( rAddress.Row()),
|
|
mnTab( rAddress.Tab()),
|
|
meOp( eOp)
|
|
{
|
|
}
|
|
|
|
bool operator==( const QueryKey & r ) const
|
|
{
|
|
return mnRow == r.mnRow && mnTab == r.mnTab && meOp == r.meOp && meOp != UNKNOWN;
|
|
}
|
|
|
|
struct Hash
|
|
{
|
|
size_t operator()( const QueryKey & r ) const
|
|
{
|
|
return (static_cast<size_t>(r.mnTab) << 24) ^
|
|
(static_cast<size_t>(r.meOp) << 22) ^
|
|
static_cast<size_t>(r.mnRow);
|
|
}
|
|
};
|
|
};
|
|
|
|
struct QueryCriteriaAndResult
|
|
{
|
|
QueryCriteria maCriteria;
|
|
ScAddress maAddress;
|
|
|
|
QueryCriteriaAndResult( const QueryCriteria & rCriteria, const ScAddress & rAddress ) :
|
|
maCriteria( rCriteria),
|
|
maAddress( rAddress)
|
|
{
|
|
}
|
|
~QueryCriteriaAndResult()
|
|
{
|
|
}
|
|
};
|
|
|
|
typedef ::boost::unordered_map< QueryKey, QueryCriteriaAndResult, QueryKey::Hash, ::std::equal_to< QueryKey > > QueryMap;
|
|
QueryMap maQueryMap;
|
|
ScRange maRange;
|
|
ScDocument * mpDoc;
|
|
|
|
// prevent usage
|
|
ScLookupCache( const ScLookupCache & );
|
|
ScLookupCache & operator=( const ScLookupCache & );
|
|
|
|
};
|
|
|
|
|
|
typedef ::boost::unordered_map< ScRange, ScLookupCache*, ScLookupCache::Hash, ::std::equal_to< ScRange > > ScLookupCacheMap;
|
|
|
|
#endif
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|