diff options
-rw-r--r-- | static/source/unoembindhelpers/PrimaryBindings.cxx | 12 | ||||
-rw-r--r-- | unotest/source/embindtest/embindtest.js | 10 |
2 files changed, 16 insertions, 6 deletions
diff --git a/static/source/unoembindhelpers/PrimaryBindings.cxx b/static/source/unoembindhelpers/PrimaryBindings.cxx index 8fb5ad39a6da..0aadc85f6086 100644 --- a/static/source/unoembindhelpers/PrimaryBindings.cxx +++ b/static/source/unoembindhelpers/PrimaryBindings.cxx @@ -17,6 +17,7 @@ #include <com/sun/star/uno/Type.hxx> #include <comphelper/processfactory.hxx> #include <o3tl/any.hxx> +#include <o3tl/temporary.hxx> #include <o3tl/unreachable.hxx> #include <rtl/ustring.hxx> #include <sal/log.hxx> @@ -283,7 +284,16 @@ EMSCRIPTEN_BINDINGS(PrimaryBindings) case TypeClass_SEQUENCE: return {}; //TODO case TypeClass_ENUM: - return {}; //TODO + { + emscripten::internal::EM_DESTRUCTORS destructors = nullptr; + emscripten::internal::EM_GENERIC_WIRE_TYPE result + = _emval_as(rObject.as_handle(), getTypeId(rUnoType), &destructors); + emscripten::internal::DestructorsRunner dr(destructors); + return css::uno::Any( + &o3tl::temporary( + emscripten::internal::fromGenericWireType<sal_Int32>(result)), + rUnoType); + } case TypeClass_STRUCT: return {}; //TODO case TypeClass_EXCEPTION: diff --git a/unotest/source/embindtest/embindtest.js b/unotest/source/embindtest/embindtest.js index 1c6cd5f2718e..21c0e5cf098e 100644 --- a/unotest/source/embindtest/embindtest.js +++ b/unotest/source/embindtest/embindtest.js @@ -269,11 +269,11 @@ Module.addOnPostRun(function() { console.assert(v.get() === uno.org.libreoffice.embindtest.Enum.E_2); console.assert(test.isAnyEnum(v)); v.delete(); - //TODO: let a = new Module.uno_Any( - //TODO: Module.uno_Type.Enum('org.libreoffice.embindtest.Enum'), - //TODO: uno.org.libreoffice.embindtest.Enum.E_2); - //TODO: console.assert(test.isAnyEnum(a)); - //TODO: a.delete(); + let a = new Module.uno_Any( + Module.uno_Type.Enum('org.libreoffice.embindtest.Enum'), + uno.org.libreoffice.embindtest.Enum.E_2); + console.assert(test.isAnyEnum(a)); + a.delete(); } { let v = test.getAnyStruct(); |