summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStephan Bergmann <stephan.bergmann@allotropia.de>2024-03-01 14:30:38 +0100
committerStephan Bergmann <stephan.bergmann@allotropia.de>2024-03-04 21:43:09 +0100
commit0bab5cda2123ecc7f3775d05ca5103bdef23bfe8 (patch)
treedf5128463025ae19e008fc6ae2d436c790a1bba1
parent8428368d79118f1d0e09615c5d2b92065b8838d4 (diff)
Add Embing'ing of UNO Any getter for enums
...which taps into the internals of emscripten::val, which is based on std::type_info identifiers, so we need an additional statically-built mapping between UNO (enum, for now) types and std::type_info Change-Id: I9fc1ff33fe31a1e1052504905de446ed2193e014 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/164359 Tested-by: Jenkins Reviewed-by: Stephan Bergmann <stephan.bergmann@allotropia.de>
-rw-r--r--include/static/unoembindhelpers/PrimaryBindings.hxx13
-rw-r--r--static/source/embindmaker/embindmaker.cxx1
-rw-r--r--static/source/unoembindhelpers/PrimaryBindings.cxx33
-rw-r--r--unotest/source/embindtest/embindtest.js2
4 files changed, 47 insertions, 2 deletions
diff --git a/include/static/unoembindhelpers/PrimaryBindings.hxx b/include/static/unoembindhelpers/PrimaryBindings.hxx
index 80b55d5278ac..13ddd05cce26 100644
--- a/include/static/unoembindhelpers/PrimaryBindings.hxx
+++ b/include/static/unoembindhelpers/PrimaryBindings.hxx
@@ -14,11 +14,14 @@
#include <cstdint>
#include <limits>
#include <stdexcept>
+#include <typeinfo>
#include <emscripten/bind.h>
#include <com/sun/star/uno/Reference.hxx>
#include <com/sun/star/uno/Sequence.hxx>
+#include <com/sun/star/uno/Type.hxx>
+#include <cppu/unotype.hxx>
#include <sal/types.h>
template <typename T> struct emscripten::smart_ptr_trait<css::uno::Reference<T>>
@@ -33,6 +36,11 @@ template <typename T> struct emscripten::smart_ptr_trait<css::uno::Reference<T>>
namespace unoembindhelpers
{
+namespace detail
+{
+void registerUnoType(css::uno::Type const& type, std::type_info const* id);
+}
+
enum class uno_Reference
{
FromAny
@@ -76,6 +84,11 @@ void checkSequenceAccess(css::uno::Sequence<T> const& sequence, sal_Int32 index)
}
}
+template <typename T> void registerUnoType()
+{
+ detail::registerUnoType(cppu::UnoType<T>::get(), &typeid(T));
+}
+
template <typename T> void registerSequence(char const* name)
{
emscripten::class_<css::uno::Sequence<T>>(name)
diff --git a/static/source/embindmaker/embindmaker.cxx b/static/source/embindmaker/embindmaker.cxx
index 89fdf834ea1d..36b1f56fd5a3 100644
--- a/static/source/embindmaker/embindmaker.cxx
+++ b/static/source/embindmaker/embindmaker.cxx
@@ -849,6 +849,7 @@ SAL_IMPLEMENT_MAIN()
<< mem.name << ")";
}
cppOut << ";\n";
+ cppOut << " ::unoembindhelpers::registerUnoType<" << cppName(enm) << ">();\n";
dumpRegisterFunctionEpilog(cppOut, n);
}
std::set<OUString> sequences;
diff --git a/static/source/unoembindhelpers/PrimaryBindings.cxx b/static/source/unoembindhelpers/PrimaryBindings.cxx
index 5b76b549cb13..7cf99c523f0d 100644
--- a/static/source/unoembindhelpers/PrimaryBindings.cxx
+++ b/static/source/unoembindhelpers/PrimaryBindings.cxx
@@ -31,6 +31,7 @@
#include <stdexcept>
#include <string>
#include <typeinfo>
+#include <utility>
using namespace emscripten;
using namespace css::uno;
@@ -166,6 +167,31 @@ Reference<css::frame::XModel> getCurrentModelFromViewSh()
}
return pSh->GetCurrentDocument();
}
+
+struct LessType
+{
+ bool operator()(css::uno::Type const& type1, css::uno::Type const& type2) const
+ {
+ return type1.getTypeLibType() < type2.getTypeLibType();
+ }
+};
+
+std::map<css::uno::Type, std::type_info const*, LessType> unoTypes;
+
+std::type_info const* getTypeId(css::uno::Type const& type)
+{
+ auto const i = unoTypes.find(type);
+ if (i == unoTypes.end())
+ {
+ throw std::runtime_error("unregistered UNO type");
+ }
+ return i->second;
+}
+}
+
+namespace unoembindhelpers::detail
+{
+void registerUnoType(css::uno::Type const& type, std::type_info const* id) { unoTypes[type] = id; }
}
EMSCRIPTEN_BINDINGS(PrimaryBindings)
@@ -263,7 +289,12 @@ EMSCRIPTEN_BINDINGS(PrimaryBindings)
case css::uno::TypeClass_SEQUENCE:
return emscripten::val::undefined(); //TODO
case css::uno::TypeClass_ENUM:
- return emscripten::val::undefined(); //TODO
+ {
+ emscripten::internal::WireTypePack argv(
+ std::move(*static_cast<sal_Int32 const*>(self.getValue())));
+ return emscripten::val::take_ownership(
+ _emval_take_value(getTypeId(self.getValueType()), argv));
+ }
case css::uno::TypeClass_STRUCT:
return emscripten::val::undefined(); //TODO
case css::uno::TypeClass_EXCEPTION:
diff --git a/unotest/source/embindtest/embindtest.js b/unotest/source/embindtest/embindtest.js
index ab50c859e13e..d391f5bd15f5 100644
--- a/unotest/source/embindtest/embindtest.js
+++ b/unotest/source/embindtest/embindtest.js
@@ -265,7 +265,7 @@ Module.addOnPostRun(function() {
{
let v = test.getAnyEnum();
console.log(v);
- //TODO: console.assert(v.get() === uno.org.libreoffice.embindtest.Enum.E_2);
+ console.assert(v.get() === uno.org.libreoffice.embindtest.Enum.E_2);
console.assert(test.isAnyEnum(v));
v.delete();
//TODO: let a = new Module.Any(