summaryrefslogtreecommitdiffstats
path: root/static/source/unoembindhelpers
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
commit267c6f2ac71f92999e969232431ba04678e7437e (patch)
tree358c9467650e1d0a1d7227a21dac2e3d08b622b2 /static/source/unoembindhelpers
parentInitial commit. (diff)
downloadlibreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz
libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'static/source/unoembindhelpers')
-rw-r--r--static/source/unoembindhelpers/PrimaryBindings.cxx121
1 files changed, 121 insertions, 0 deletions
diff --git a/static/source/unoembindhelpers/PrimaryBindings.cxx b/static/source/unoembindhelpers/PrimaryBindings.cxx
new file mode 100644
index 0000000000..e9a0c49631
--- /dev/null
+++ b/static/source/unoembindhelpers/PrimaryBindings.cxx
@@ -0,0 +1,121 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ */
+#ifdef EMSCRIPTEN
+#include <com/sun/star/frame/XModel.hpp>
+#include <com/sun/star/uno/XReference.hpp>
+
+#include <emscripten/bind.h>
+
+#include <sal/log.hxx>
+#include <sfx2/viewsh.hxx>
+
+using namespace emscripten;
+using namespace css::uno;
+
+namespace
+{
+Reference<css::frame::XModel> getCurrentModelFromViewSh()
+{
+ SfxViewShell* pSh = nullptr;
+ pSh = SfxViewShell::Current();
+ if (!pSh)
+ {
+ return {};
+ }
+ return pSh->GetCurrentDocument();
+}
+}
+
+EMSCRIPTEN_BINDINGS(PrimaryBindings)
+{
+ // Reference bits
+ class_<BaseReference>("BaseReference");
+ enum_<UnoReference_Query>("UnoReference_Query").value("UNO_QUERY", UNO_QUERY);
+
+ class_<OUString>("OUString")
+ .constructor(
+ +[](const std::string& rString) -> OUString {
+ return OUString::fromUtf8(std::string_view{ rString.c_str() });
+ },
+ allow_raw_pointers())
+ .function("toString", +[](const OUString& rSelf) -> std::string {
+ return std::string{ rSelf.toUtf8() };
+ });
+
+ // Types used for Any construction
+ enum_<TypeClass>("UnoType")
+ .value("void", TypeClass::TypeClass_VOID)
+ .value("char", TypeClass::TypeClass_CHAR)
+ .value("bool", TypeClass::TypeClass_BOOLEAN)
+ .value("byte", TypeClass::TypeClass_BYTE)
+ .value("short", TypeClass::TypeClass_SHORT)
+ .value("unsigned_short", TypeClass::TypeClass_UNSIGNED_SHORT)
+ .value("long", TypeClass::TypeClass_LONG)
+ .value("unsigned_long", TypeClass::TypeClass_UNSIGNED_LONG)
+ .value("hyper", TypeClass::TypeClass_HYPER)
+ .value("unsigned_hyper", TypeClass::TypeClass_UNSIGNED_HYPER)
+ .value("float", TypeClass::TypeClass_FLOAT)
+ .value("double", TypeClass::TypeClass_DOUBLE)
+ .value("string", TypeClass::TypeClass_STRING);
+
+ // Any
+ class_<Any>("Any").constructor(
+ +[](const val& rObject, const TypeClass& rUnoType) -> Any {
+ switch (rUnoType)
+ {
+ case TypeClass_VOID:
+ break;
+ case TypeClass_CHAR:
+ return Any{ rObject.as<sal_Int8>() };
+ case TypeClass_BOOLEAN:
+ return Any{ rObject.as<bool>() };
+ case TypeClass_BYTE:
+ return Any{ rObject.as<sal_Int8>() };
+ case TypeClass_SHORT:
+ return Any{ rObject.as<sal_Int16>() };
+ case TypeClass_UNSIGNED_SHORT:
+ return Any{ rObject.as<sal_uInt16>() };
+ case TypeClass_LONG:
+ return Any{ rObject.as<sal_Int32>() };
+ case TypeClass_UNSIGNED_LONG:
+ return Any{ rObject.as<sal_uInt32>() };
+ case TypeClass_HYPER:
+ return Any{ rObject.as<sal_Int64>() };
+ case TypeClass_UNSIGNED_HYPER:
+ return Any{ rObject.as<sal_uInt64>() };
+ case TypeClass_FLOAT:
+ return Any{ rObject.as<float>() };
+ case TypeClass_DOUBLE:
+ return Any{ rObject.as<double>() };
+ case TypeClass_STRING:
+ return Any{ OUString::fromUtf8(std::string_view{ rObject.as<std::string>() }) };
+ case TypeClass_TYPE:
+ case TypeClass_ANY:
+ case TypeClass_ENUM:
+ case TypeClass_STRUCT:
+ case TypeClass_EXCEPTION:
+ case TypeClass_SEQUENCE:
+ case TypeClass_INTERFACE:
+ case TypeClass_TYPEDEF:
+ case TypeClass_SERVICE:
+ case TypeClass_MODULE:
+ case TypeClass_INTERFACE_METHOD:
+ case TypeClass_INTERFACE_ATTRIBUTE:
+ default:
+ break;
+ }
+ return {};
+ },
+ allow_raw_pointers());
+
+ function("getCurrentModelFromViewSh", &getCurrentModelFromViewSh);
+}
+#endif
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */