1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef SC_VALIDAT_HXX
21 #define SC_VALIDAT_HXX
23 #include "conditio.hxx"
24 #include <com/sun/star/sheet/TableValidationVisibility.hpp>
27 namespace ValidListType
= ::com::sun::star::sheet::TableValidationVisibility
;
45 enum ScValidErrorStyle
54 // Entry for validation (only one condition exists)
57 class SC_DLLPUBLIC ScValidationData
: public ScConditionEntry
59 sal_uInt32 nKey
; // index in attributes
61 ScValidationMode eDataMode
;
64 ScValidErrorStyle eErrorStyle
;
65 sal_Int16 mnListType
; // selection list type: none, unsorted, sorted.
71 sal_Bool bIsUsed
; // temporary during saving
73 sal_Bool
DoMacro( const ScAddress
& rPos
, const String
& rInput
,
74 ScFormulaCell
* pCell
, Window
* pParent
) const;
76 sal_Bool
DoScript( const ScAddress
& rPos
, const String
& rInput
,
77 ScFormulaCell
* pCell
, Window
* pParent
) const;
79 using ScConditionEntry::operator==;
82 ScValidationData( ScValidationMode eMode
, ScConditionMode eOper
,
83 const String
& rExpr1
, const String
& rExpr2
,
84 ScDocument
* pDocument
, const ScAddress
& rPos
,
85 const String
& rExprNmsp1
= EMPTY_STRING
, const String
& rExprNmsp2
= EMPTY_STRING
,
86 formula::FormulaGrammar::Grammar eGrammar1
= formula::FormulaGrammar::GRAM_DEFAULT
,
87 formula::FormulaGrammar::Grammar eGrammar2
= formula::FormulaGrammar::GRAM_DEFAULT
);
88 ScValidationData( ScValidationMode eMode
, ScConditionMode eOper
,
89 const ScTokenArray
* pArr1
, const ScTokenArray
* pArr2
,
90 ScDocument
* pDocument
, const ScAddress
& rPos
);
91 ScValidationData( const ScValidationData
& r
);
92 ScValidationData( ScDocument
* pDocument
, const ScValidationData
& r
);
93 virtual ~ScValidationData();
95 ScValidationData
* Clone() const // real copy
96 { return new ScValidationData( GetDocument(), *this ); }
97 ScValidationData
* Clone(ScDocument
* pNew
) const
98 { return new ScValidationData( pNew
, *this ); }
102 void SetInput( const String
& rTitle
, const String
& rMsg
);
103 void SetError( const String
& rTitle
, const String
& rMsg
,
104 ScValidErrorStyle eStyle
);
106 sal_Bool
GetInput( String
& rTitle
, String
& rMsg
) const
107 { rTitle
= aInputTitle
; rMsg
= aInputMessage
; return bShowInput
; }
108 sal_Bool
GetErrMsg( String
& rTitle
, String
& rMsg
, ScValidErrorStyle
& rStyle
) const;
110 sal_Bool
HasErrMsg() const { return bShowError
; }
112 ScValidationMode
GetDataMode() const { return eDataMode
; }
114 inline sal_Int16
GetListType() const { return mnListType
; }
115 inline void SetListType( sal_Int16 nListType
) { mnListType
= nListType
; }
117 /** Returns true, if the validation cell will show a selection list.
118 @descr Use this instead of GetListType() which returns the raw property
119 regardless of the validation type. */
120 bool HasSelectionList() const;
121 /** Tries to fill the passed collection with list validation entries.
122 @descr Fills the list only, if this is a list validation and IsShowList() is enabled.
123 @param rStrings (out-param) The string list to fill with list validation entires.
124 @return true = rStrings has been filled with at least one entry. */
125 bool FillSelectionList(std::vector
<ScTypedStrData
>& rStrings
, const ScAddress
& rPos
) const;
127 // with string: during input, with cell: for detective / RC_FORCED
128 sal_Bool
IsDataValid( const String
& rTest
, const ScPatternAttr
& rPattern
,
129 const ScAddress
& rPos
) const;
130 sal_Bool
IsDataValid( ScBaseCell
* pCell
, const ScAddress
& rPos
) const;
133 sal_Bool
DoError( Window
* pParent
, const String
& rInput
, const ScAddress
& rPos
) const;
134 void DoCalcError( ScFormulaCell
* pCell
) const;
136 sal_Bool
IsEmpty() const;
137 sal_uInt32
GetKey() const { return nKey
; }
138 void SetKey(sal_uInt32 nNew
) { nKey
= nNew
; } // only if not inserted!
140 void SetUsed(sal_Bool bSet
) { bIsUsed
= bSet
; }
141 sal_Bool
IsUsed() const { return bIsUsed
; }
143 sal_Bool
EqualEntries( const ScValidationData
& r
) const; // for undo
145 // sort (using std::set) by index
146 // operator== only for sorting
147 bool operator ==( const ScValidationData
& r
) const { return nKey
== r
.nKey
; }
148 bool operator < ( const ScValidationData
& r
) const { return nKey
< r
.nKey
; }
151 /** Tries to fill the passed collection with list validation entries.
152 @descr Fills the list only if it is non-NULL,
153 @param pStrings (out-param) Optionally NULL, string list to fill with list validation entires.
154 @param pCell can be NULL if it is not necessary to which element in the list is selected.
155 @param rPos the base address for relative references.
156 @param rTokArr Formula token array.
157 @param rMatch (out-param) the index of the first item that matched, -1 if nothing matched.
158 @return true = Cell range found, rRange is valid, or an error entry stuffed into the list if pCell==NULL. */
159 bool GetSelectionFromFormula(
160 std::vector
<ScTypedStrData
>* pStrings
, ScBaseCell
* pCell
, const ScAddress
& rPos
,
161 const ScTokenArray
& rTokArr
, int& rMatch
) const;
163 /** Tests, if pCell is equal to what the passed token array represents. */
164 bool IsEqualToTokenArray( ScBaseCell
* pCell
, const ScAddress
& rPos
, const ScTokenArray
& rTokArr
) const;
166 /** Tests, if contents of pCell occur in cell range referenced by own formula, or in a string list. */
167 bool IsListValid( ScBaseCell
* pCell
, const ScAddress
& rPos
) const;
171 // list of contitions:
174 struct CompareScValidationDataPtr
176 bool operator()( ScValidationData
* const& lhs
, ScValidationData
* const& rhs
) const { return (*lhs
)<(*rhs
); }
179 class ScValidationDataList
: public std::set
<ScValidationData
*, CompareScValidationDataPtr
>
182 ScValidationDataList() {}
183 ScValidationDataList(const ScValidationDataList
& rList
);
184 ScValidationDataList(ScDocument
* pNewDoc
, const ScValidationDataList
& rList
);
185 ~ScValidationDataList() {}
187 void InsertNew( ScValidationData
* pNew
)
188 { if (!insert(pNew
).second
) delete pNew
; }
190 ScValidationData
* GetData( sal_uInt32 nKey
);
193 void UpdateReference( UpdateRefMode eUpdateRefMode
,
194 const ScRange
& rRange
, SCsCOL nDx
, SCsROW nDy
, SCsTAB nDz
);
195 void UpdateMoveTab( SCTAB nOldPos
, SCTAB nNewPos
);
197 sal_Bool
operator==( const ScValidationDataList
& r
) const; // for ref-undo
202 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */