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_PARCLASS_HXX
21 #define SC_PARCLASS_HXX
23 #include "formula/opcode.hxx"
24 #include <sys/types.h>
31 class ScParameterClassification
37 Unknown
= 0, // MUST be zero for initialization mechanism!
39 /** Out of bounds, function doesn't expect that many parameters.
40 However, not necessarily returned. */
43 /** In array formula: single value to be passed. Results in JumpMatrix
44 being created and multiple calls to function. Functions handling a
45 formula::svDoubleRef by means of DoubleRefToPosSingleRef() or
46 PopDoubleRefOrSingleRef() or GetDouble() or GetString() should have
50 /** In array formula: area reference must stay reference. Otherwise
51 don't care. Functions handling a formula::svDoubleRef by means of
52 PopDoubleRefOrSingleRef() should not have this. */
55 /** In array formula: convert area reference to array. Function will be
56 called only once if no Value type is involved. Functions able to
57 handle a svMatrix parameter but not a formula::svDoubleRef parameter as area
61 /** Area reference must be converted to array in any case, and must
62 also be propagated to subsequent operators and functions being part
63 of a parameter of this function. */
66 /** Area reference is not converted to array, but ForceArray must be
67 propagated to subsequent operators and functions being part of a
68 parameter of this function. Used with functions that treat
69 references separately from arrays, but need the forced array
70 calculation of parameters that are not references.*/
74 /// MUST be called once before any other method.
79 /** Get one parameter type for function eOp.
81 Which parameter, 0-based */
82 static Type
GetParameterType( const formula::FormulaToken
* pToken
,
83 sal_uInt16 nParameter
);
85 /** Whether OpCode has a parameter of type
86 ForceArray or ReferenceOrForceArray. */
87 static inline bool HasForceArray( OpCode eOp
)
89 return 0 <= (short)eOp
&&
90 eOp
<= SC_OPCODE_LAST_OPCODE_ID
&&
91 pData
[eOp
].bHasForceArray
;
98 const static sal_Int32 nMaxParams
= 7;
100 Type nParam
[nMaxParams
];
101 sal_uInt8 nRepeatLast
;
104 // SUNWS7 needs a forward declared friend, otherwise members of the outer
105 // class are not accessible (in this case CommonData).
107 friend struct ScParameterClassification::RawData
;
115 friend struct ScParameterClassification::RunData
;
119 sal_uInt8 nMinParams
; // fix or minimum, or repeat start
123 static const RawData pRawData
[];
124 static RunData
* pData
;
127 static Type
GetExternalParameterType(
128 const formula::FormulaToken
* pToken
, sal_uInt16 nParameter
);
130 #if OSL_DEBUG_LEVEL > 1
131 // Generate documentation to stdout if environment variable
132 // OOO_CALC_GENPARCLASSDOC is set.
133 static void GenerateDocumentation();
135 /* OpCodes not specified in the implementation are taken from the global
136 * function list and all parameters, if any, are assumed to be of type
137 * Value. This could also be done in the product version if needed, but we
138 * don't want to spoil startup time. However, doing so could propagate the
139 * minimum parameter count to the formula compiler, which, together with
140 * additional information about optional parameters, could react on missing
141 * parameters then. */
142 static void MergeArgumentsFromFunctionResource();
144 /** Minimum number of parameters, or fix number
145 of parameters if HasRepeatParameters()
146 returns sal_False. For opcodes not specified in
147 the implementation a parameter count of 1
148 is assumed, for opcodes out of range 0 is
149 assumed. If HasRepeatParameters() returns
150 sal_True, information is NOT related to whether
151 any parameters are optional, only the type
152 of parameters is significant. */
153 static inline sal_uInt8
GetMinimumParameters( OpCode eOp
)
155 if ( eOp
<= SC_OPCODE_LAST_OPCODE_ID
)
156 return pData
[eOp
].aData
.nParam
[0]
158 pData
[eOp
].nMinParams
;
162 /** Whether last parameter types are repeated. */
163 static inline bool HasRepeatParameters( OpCode eOp
)
165 return eOp
<= SC_OPCODE_LAST_OPCODE_ID
166 && pData
[eOp
].aData
.nRepeatLast
> 0;
168 #endif // OSL_DEBUG_LEVEL
171 #endif // SC_PARCLASS_HXX
173 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */