/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef SC_DOCOPTIO_HXX #define SC_DOCOPTIO_HXX #include #include #include #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 GetCalcPropertyNames(); com::sun::star::uno::Sequence GetLayoutPropertyNames(); public: ScDocCfg(); void SetOptions( const ScDocOptions& rNew ); }; #endif