blob: d18052888263b422cef217ec2ba5d36e1dbc201c [file] [log] [blame]
/**************************************************************
*
* 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
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#ifndef SC_DOCOPTIO_HXX
#define SC_DOCOPTIO_HXX
#include <unotools/configitem.hxx>
#include <svl/poolitem.hxx>
#include <svl/itemprop.hxx>
#include "scdllapi.h"
#include "optutil.hxx"
class SC_DLLPUBLIC ScDocOptions
{
double fIterEps; // Epsilon-Wert dazu
sal_uInt16 nIterCount; // Anzahl
sal_uInt16 nPrecStandardFormat; // precision for standard format
sal_uInt16 nDay; // Nulldatum:
sal_uInt16 nMonth;
sal_uInt16 nYear;
sal_uInt16 nYear2000; // bis zu welcher zweistelligen Jahreszahl 20xx angenommen wird
sal_uInt16 nTabDistance; // Abstand Standardtabulatoren
sal_Bool bIsIgnoreCase; // Gross-/Kleinschr. bei Vergleichen
sal_Bool bIsIter; // Iteration bei cirk. Ref
sal_Bool bCalcAsShown; // berechnen wie angezeigt (Precision)
sal_Bool bMatchWholeCell; // Suchkriterien muessen ganze Zelle matchen
sal_Bool bDoAutoSpell; // Auto-Spelling
sal_Bool bLookUpColRowNames; // Spalten-/Zeilenbeschriftungen automagisch suchen
sal_Bool bFormulaRegexEnabled; // regular expressions in formulas enabled
public:
ScDocOptions();
ScDocOptions( const ScDocOptions& rCpy );
~ScDocOptions();
sal_Bool IsLookUpColRowNames() const { return bLookUpColRowNames; }
void SetLookUpColRowNames( sal_Bool bVal ) { bLookUpColRowNames = bVal; }
sal_Bool IsAutoSpell() const { return bDoAutoSpell; }
void SetAutoSpell( sal_Bool bVal ) { bDoAutoSpell = bVal; }
sal_Bool IsMatchWholeCell() const { return bMatchWholeCell; }
void SetMatchWholeCell( sal_Bool bVal ){ bMatchWholeCell = bVal; }
sal_Bool IsIgnoreCase() const { return bIsIgnoreCase; }
void SetIgnoreCase( sal_Bool bVal ) { bIsIgnoreCase = bVal; }
sal_Bool IsIter() const { return bIsIter; }
void SetIter( sal_Bool bVal ) { bIsIter = bVal; }
sal_uInt16 GetIterCount() const { return nIterCount; }
void SetIterCount( sal_uInt16 nCount) { nIterCount = nCount; }
double GetIterEps() const { return fIterEps; }
void SetIterEps( double fEps ) { fIterEps = fEps; }
void GetDate( sal_uInt16& rD, sal_uInt16& rM, sal_uInt16& rY ) const
{ rD = nDay; rM = nMonth; rY = nYear;}
void SetDate (sal_uInt16 nD, sal_uInt16 nM, sal_uInt16 nY)
{ nDay = nD; nMonth = nM; nYear = nY; }
sal_uInt16 GetTabDistance() const { return nTabDistance;}
void SetTabDistance( sal_uInt16 nTabDist ) {nTabDistance = nTabDist;}
void ResetDocOptions();
inline void CopyTo(ScDocOptions& rOpt);
inline const ScDocOptions& operator=( const ScDocOptions& rOpt );
inline int operator==( const ScDocOptions& rOpt ) const;
inline int operator!=( const ScDocOptions& rOpt ) const;
sal_uInt16 GetStdPrecision() const { return nPrecStandardFormat; }
void SetStdPrecision( sal_uInt16 n ) { nPrecStandardFormat = n; }
sal_Bool IsCalcAsShown() const { return bCalcAsShown; }
void SetCalcAsShown( sal_Bool bVal ) { bCalcAsShown = bVal; }
void SetYear2000( sal_uInt16 nVal ) { nYear2000 = nVal; }
sal_uInt16 GetYear2000() const { return nYear2000; }
void SetFormulaRegexEnabled( sal_Bool bVal ) { bFormulaRegexEnabled = bVal; }
sal_Bool IsFormulaRegexEnabled() const { return bFormulaRegexEnabled; }
};
inline void ScDocOptions::CopyTo(ScDocOptions& rOpt)
{
rOpt.bIsIgnoreCase = bIsIgnoreCase;
rOpt.bIsIter = bIsIter;
rOpt.nIterCount = nIterCount;
rOpt.fIterEps = fIterEps;
rOpt.nPrecStandardFormat = nPrecStandardFormat;
rOpt.nDay = nDay;
rOpt.nMonth = nMonth;
rOpt.nYear2000 = nYear2000;
rOpt.nYear = nYear;
rOpt.nTabDistance = nTabDistance;
rOpt.bCalcAsShown = bCalcAsShown;
rOpt.bMatchWholeCell = bMatchWholeCell;
rOpt.bDoAutoSpell = bDoAutoSpell;
rOpt.bLookUpColRowNames = bLookUpColRowNames;
rOpt.bFormulaRegexEnabled = bFormulaRegexEnabled;
}
inline const ScDocOptions& ScDocOptions::operator=( const ScDocOptions& rCpy )
{
bIsIgnoreCase = rCpy.bIsIgnoreCase;
bIsIter = rCpy.bIsIter;
nIterCount = rCpy.nIterCount;
fIterEps = rCpy.fIterEps;
nPrecStandardFormat = rCpy.nPrecStandardFormat;
nDay = rCpy.nDay;
nMonth = rCpy.nMonth;
nYear = rCpy.nYear;
nYear2000 = rCpy.nYear2000;
nTabDistance = rCpy.nTabDistance;
bCalcAsShown = rCpy.bCalcAsShown;
bMatchWholeCell = rCpy.bMatchWholeCell;
bDoAutoSpell = rCpy.bDoAutoSpell;
bLookUpColRowNames = rCpy.bLookUpColRowNames;
bFormulaRegexEnabled= rCpy.bFormulaRegexEnabled;
return *this;
}
inline int ScDocOptions::operator==( const ScDocOptions& rOpt ) const
{
return (
rOpt.bIsIgnoreCase == bIsIgnoreCase
&& rOpt.bIsIter == bIsIter
&& rOpt.nIterCount == nIterCount
&& rOpt.fIterEps == fIterEps
&& rOpt.nPrecStandardFormat == nPrecStandardFormat
&& rOpt.nDay == nDay
&& rOpt.nMonth == nMonth
&& rOpt.nYear == nYear
&& rOpt.nYear2000 == nYear2000
&& rOpt.nTabDistance == nTabDistance
&& rOpt.bCalcAsShown == bCalcAsShown
&& rOpt.bMatchWholeCell == bMatchWholeCell
&& rOpt.bDoAutoSpell == bDoAutoSpell
&& rOpt.bLookUpColRowNames == bLookUpColRowNames
&& rOpt.bFormulaRegexEnabled == bFormulaRegexEnabled
);
}
inline int ScDocOptions::operator!=( const ScDocOptions& rOpt ) const
{
return !(operator==(rOpt));
}
//==================================================================
// Item fuer Einstellungsdialog - Berechnen
//==================================================================
class SC_DLLPUBLIC ScTpCalcItem : public SfxPoolItem
{
public:
TYPEINFO();
//UNUSED2008-05 ScTpCalcItem( sal_uInt16 nWhich );
ScTpCalcItem( sal_uInt16 nWhich,
const ScDocOptions& rOpt );
ScTpCalcItem( const ScTpCalcItem& rItem );
~ScTpCalcItem();
virtual String GetValueText() const;
virtual int operator==( const SfxPoolItem& ) const;
virtual SfxPoolItem* Clone( SfxItemPool *pPool = 0 ) const;
const ScDocOptions& GetDocOptions() const { return theOptions; }
private:
ScDocOptions theOptions;
};
//==================================================================
// Config Item containing document options
//==================================================================
class ScDocCfg : public ScDocOptions
{
ScLinkConfigItem aCalcItem;
ScLinkConfigItem aLayoutItem;
DECL_LINK( CalcCommitHdl, void* );
DECL_LINK( LayoutCommitHdl, void* );
com::sun::star::uno::Sequence<rtl::OUString> GetCalcPropertyNames();
com::sun::star::uno::Sequence<rtl::OUString> GetLayoutPropertyNames();
public:
ScDocCfg();
void SetOptions( const ScDocOptions& rNew );
};
#endif