summaryrefslogtreecommitdiff
path: root/sc
diff options
context:
space:
mode:
Diffstat (limited to 'sc')
-rw-r--r--sc/inc/funcdesc.hxx8
-rw-r--r--sc/source/core/data/funcdesc.cxx15
-rw-r--r--sc/source/ui/src/scfuncs.src16
3 files changed, 32 insertions, 7 deletions
diff --git a/sc/inc/funcdesc.hxx b/sc/inc/funcdesc.hxx
index 1c2bccda5bc6..b078644cac28 100644
--- a/sc/inc/funcdesc.hxx
+++ b/sc/inc/funcdesc.hxx
@@ -102,6 +102,13 @@ public:
*/
virtual OString getHelpId() const override ;
+ /** Returns whether function is hidden and not offered in the Function
+ Wizard unless used in an expression.
+
+ @return flag whether function is hidden
+ */
+ virtual bool isHidden() const override;
+
/**
Returns number of arguments
@@ -216,6 +223,7 @@ public:
OString sHelpId; /**< HelpId of function */
bool bIncomplete :1; /**< Incomplete argument info (set for add-in info from configuration) */
bool bHasSuppressedArgs :1; /**< Whether there is any suppressed parameter. */
+ bool mbHidden :1; /**< Whether function is hidden */
};
/**
diff --git a/sc/source/core/data/funcdesc.cxx b/sc/source/core/data/funcdesc.cxx
index 729590b07694..10c070b8275b 100644
--- a/sc/source/core/data/funcdesc.cxx
+++ b/sc/source/core/data/funcdesc.cxx
@@ -69,7 +69,8 @@ ScFuncDesc::ScFuncDesc() :
nArgCount (0),
nVarArgsStart (0),
bIncomplete (false),
- bHasSuppressedArgs(false)
+ bHasSuppressedArgs(false),
+ mbHidden (false)
{}
ScFuncDesc::~ScFuncDesc()
@@ -105,6 +106,7 @@ void ScFuncDesc::Clear()
sHelpId.clear();
bIncomplete = false;
bHasSuppressedArgs = false;
+ mbHidden = false;
}
OUString ScFuncDesc::GetParamList() const
@@ -354,6 +356,11 @@ OString ScFuncDesc::getHelpId() const
return sHelpId;
}
+bool ScFuncDesc::isHidden() const
+{
+ return mbHidden;
+}
+
sal_uInt32 ScFuncDesc::getParameterCount() const
{
return nArgCount;
@@ -799,7 +806,11 @@ sal_Unicode ScFunctionMgr::getSingleToken(const formula::IFunctionManager::EToke
ScFuncRes::ScFuncRes( ResId &aRes, ScFuncDesc* pDesc, bool & rbSuppressed )
: Resource(aRes)
{
- rbSuppressed = (bool)GetNum();
+ sal_uInt16 nFunctionFlags = GetNum();
+ // Bit 1: entirely suppressed
+ // Bit 2: hidden unless used
+ rbSuppressed = ((nFunctionFlags & 1) != 0);
+ pDesc->mbHidden = ((nFunctionFlags & 2) != 0);
pDesc->nCategory = GetNum();
pDesc->sHelpId = ReadByteStringRes();
pDesc->nArgCount = GetNum();
diff --git a/sc/source/ui/src/scfuncs.src b/sc/source/ui/src/scfuncs.src
index 122815fdd713..632cd4317877 100644
--- a/sc/source/ui/src/scfuncs.src
+++ b/sc/source/ui/src/scfuncs.src
@@ -31,11 +31,17 @@
*
* ExtraData block with:
*
- * Boolean flag whether function is suppressed. Usually 0. This may be
- * used to add UI string resources before UI freeze if implementation
- * isn't ready yet without displaying them in the function wizard,
- * most recent used list and other UI elements. Also not available via
- * API then.
+ * 16-bit value:
+ *
+ * Bit 1: boolean flag whether function is suppressed. Usually 0. This
+ * may be used to add UI string resources before UI freeze if
+ * implementation isn't ready yet without displaying them in the
+ * function wizard, most recent used list and other UI elements. Also
+ * not available via API then.
+ *
+ * Bit 2: boolean flag whether function is hidden in the Function
+ * Wizard unless used in an expression.
+ *
*
* Function group (text, math, ...), one of ID_FUNCTION_GRP_...
*