summaryrefslogtreecommitdiffstats
path: root/accessible/ipc/extension/mac
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /accessible/ipc/extension/mac
parentInitial commit. (diff)
downloadfirefox-upstream.tar.xz
firefox-upstream.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.cpp248
-rw-r--r--accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.h82
-rw-r--r--accessible/ipc/extension/mac/DocAccessiblePlatformExtParent.h19
-rw-r--r--accessible/ipc/extension/mac/PDocAccessiblePlatformExt.ipdl62
-rw-r--r--accessible/ipc/extension/mac/moz.build28
5 files changed, 439 insertions, 0 deletions
diff --git a/accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.cpp b/accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.cpp
new file mode 100644
index 0000000000..6086ade230
--- /dev/null
+++ b/accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.cpp
@@ -0,0 +1,248 @@
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=2 et sw=2 tw=80: */
+/* 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/. */
+
+#include "DocAccessiblePlatformExtChild.h"
+
+#include "DocAccessibleChild.h"
+#include "HyperTextAccessibleWrap.h"
+
+#define UNIQUE_ID(acc) \
+ !acc || acc->Document() == acc ? 0 \
+ : reinterpret_cast<uint64_t>(acc->UniqueID())
+
+namespace mozilla {
+namespace a11y {
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvRangeAt(
+ const uint64_t& aID, const int32_t& aOffset, const EWhichRange& aRangeType,
+ uint64_t* aStartContainer, int32_t* aStartOffset, uint64_t* aEndContainer,
+ int32_t* aEndOffset) {
+ *aStartContainer = 0;
+ *aStartOffset = 0;
+ *aEndContainer = 0;
+ *aEndOffset = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ if (!acc) {
+ return IPC_OK();
+ }
+
+ HyperTextAccessible* startContainer = nullptr;
+ HyperTextAccessible* endContainer = nullptr;
+
+ acc->RangeAt(aOffset, aRangeType, &startContainer, aStartOffset,
+ &endContainer, aEndOffset);
+
+ MOZ_ASSERT(!startContainer || startContainer->Document() == acc->Document());
+ MOZ_ASSERT(!endContainer || endContainer->Document() == acc->Document());
+
+ *aStartContainer = UNIQUE_ID(startContainer);
+ *aEndContainer = UNIQUE_ID(endContainer);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvNextClusterAt(
+ const uint64_t& aID, const int32_t& aOffset, uint64_t* aNextContainer,
+ int32_t* aNextOffset) {
+ *aNextContainer = 0;
+ *aNextOffset = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ if (!acc) {
+ return IPC_OK();
+ }
+
+ HyperTextAccessible* nextContainer = nullptr;
+
+ acc->NextClusterAt(aOffset, &nextContainer, aNextOffset);
+
+ MOZ_ASSERT(!nextContainer || nextContainer->Document() == acc->Document());
+
+ *aNextContainer = UNIQUE_ID(nextContainer);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvPreviousClusterAt(
+ const uint64_t& aID, const int32_t& aOffset, uint64_t* aPrevContainer,
+ int32_t* aPrevOffset) {
+ *aPrevContainer = 0;
+ *aPrevOffset = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ if (!acc) {
+ return IPC_OK();
+ }
+
+ HyperTextAccessible* prevContainer = nullptr;
+
+ acc->PreviousClusterAt(aOffset, &prevContainer, aPrevOffset);
+
+ MOZ_ASSERT(!prevContainer || prevContainer->Document() == acc->Document());
+
+ *aPrevContainer = UNIQUE_ID(prevContainer);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvTextForRange(
+ const uint64_t& aID, const int32_t& aStartOffset,
+ const uint64_t& aEndContainer, const int32_t& aEndOffset, nsString* aText) {
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ HyperTextAccessibleWrap* endContainer =
+ IdToHyperTextAccessibleWrap(aEndContainer);
+ if (!acc || !endContainer) {
+ return IPC_OK();
+ }
+
+ acc->TextForRange(*aText, aStartOffset, endContainer, aEndOffset);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvBoundsForRange(
+ const uint64_t& aID, const int32_t& aStartOffset,
+ const uint64_t& aEndContainer, const int32_t& aEndOffset,
+ nsIntRect* aBounds) {
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ HyperTextAccessibleWrap* endContainer =
+ IdToHyperTextAccessibleWrap(aEndContainer);
+ if (!acc || !endContainer) {
+ *aBounds = nsIntRect();
+ return IPC_OK();
+ }
+
+ *aBounds = acc->BoundsForRange(aStartOffset, endContainer, aEndOffset);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvLengthForRange(
+ const uint64_t& aID, const int32_t& aStartOffset,
+ const uint64_t& aEndContainer, const int32_t& aEndOffset,
+ int32_t* aLength) {
+ *aLength = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ HyperTextAccessibleWrap* endContainer =
+ IdToHyperTextAccessibleWrap(aEndContainer);
+ if (!acc || !endContainer) {
+ return IPC_OK();
+ }
+
+ *aLength = acc->LengthForRange(aStartOffset, endContainer, aEndOffset);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvOffsetAtIndex(
+ const uint64_t& aID, const int32_t& aIndex, uint64_t* aContainer,
+ int32_t* aOffset) {
+ *aContainer = 0;
+ *aOffset = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ if (!acc) {
+ return IPC_OK();
+ }
+
+ HyperTextAccessible* container = nullptr;
+
+ acc->OffsetAtIndex(aIndex, &container, aOffset);
+
+ MOZ_ASSERT(!container || container->Document() == acc->Document());
+
+ *aContainer = UNIQUE_ID(container);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvRangeOfChild(
+ const uint64_t& aID, const uint64_t& aChild, int32_t* aStartOffset,
+ int32_t* aEndOffset) {
+ *aStartOffset = 0;
+ *aEndOffset = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ Accessible* child =
+ static_cast<DocAccessibleChild*>(Manager())->IdToAccessible(aChild);
+ if (!acc || !child) {
+ return IPC_OK();
+ }
+
+ acc->RangeOfChild(child, aStartOffset, aEndOffset);
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvLeafAtOffset(
+ const uint64_t& aID, const int32_t& aOffset, uint64_t* aLeaf) {
+ *aLeaf = 0;
+
+ HyperTextAccessibleWrap* acc = IdToHyperTextAccessibleWrap(aID);
+ if (!acc) {
+ return IPC_OK();
+ }
+
+ Accessible* leaf = acc->LeafAtOffset(aOffset);
+
+ MOZ_ASSERT(!leaf || leaf->Document() == acc->Document());
+
+ *aLeaf = UNIQUE_ID(leaf);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult DocAccessiblePlatformExtChild::RecvSelectRange(
+ const uint64_t& aID, const int32_t& aStartOffset,
+ const uint64_t& aEndContainer, const int32_t& aEndOffset) {
+ RefPtr<HyperTextAccessibleWrap> acc = IdToHyperTextAccessibleWrap(aID);
+ RefPtr<HyperTextAccessibleWrap> endContainer =
+ IdToHyperTextAccessibleWrap(aEndContainer);
+ if (!acc || !endContainer) {
+ return IPC_OK();
+ }
+
+ acc->SelectRange(aStartOffset, endContainer, aEndOffset);
+
+ return IPC_OK();
+}
+
+mozilla::ipc::IPCResult
+DocAccessiblePlatformExtChild::RecvApplyPostSearchFilter(
+ const nsTArray<uint64_t>& aAccessibles, const int32_t& aLimit,
+ const EWhichPostFilter& aSearchKey, const nsString& aSearchText,
+ nsTArray<uint64_t>* aMatches) {
+ if (aSearchKey != EWhichPostFilter::eContainsText) {
+ return IPC_OK();
+ }
+
+ DocAccessibleChild* ipcDoc = static_cast<DocAccessibleChild*>(Manager());
+ for (size_t i = 0; i < aAccessibles.Length(); i++) {
+ AccessibleWrap* acc = static_cast<AccessibleWrap*>(
+ ipcDoc->IdToAccessible(aAccessibles.ElementAt(i)));
+ if (!acc) {
+ continue;
+ }
+
+ if (acc->ApplyPostFilter(aSearchKey, aSearchText)) {
+ aMatches->AppendElement(UNIQUE_ID(acc));
+ }
+ }
+
+ return IPC_OK();
+}
+
+HyperTextAccessibleWrap*
+DocAccessiblePlatformExtChild::IdToHyperTextAccessibleWrap(
+ const uint64_t& aID) const {
+ return static_cast<HyperTextAccessibleWrap*>(
+ static_cast<DocAccessibleChild*>(Manager())->IdToHyperTextAccessible(
+ aID));
+}
+
+} // namespace a11y
+} // namespace mozilla
diff --git a/accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.h b/accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.h
new file mode 100644
index 0000000000..e372a96885
--- /dev/null
+++ b/accessible/ipc/extension/mac/DocAccessiblePlatformExtChild.h
@@ -0,0 +1,82 @@
+/* vim: set ts=2 et sw=2 tw=80: */
+/* 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/. */
+
+#ifndef mozilla_a11y_DocAccessiblePlatformExtChild_h
+#define mozilla_a11y_DocAccessiblePlatformExtChild_h
+
+#include "mozilla/a11y/PDocAccessiblePlatformExtChild.h"
+
+namespace mozilla {
+namespace a11y {
+
+class HyperTextAccessibleWrap;
+class DocAccessibleChild;
+
+class DocAccessiblePlatformExtChild : public PDocAccessiblePlatformExtChild {
+ public:
+ mozilla::ipc::IPCResult RecvRangeAt(
+ const uint64_t& aID, const int32_t& aOffset,
+ const EWhichRange& aRangeType, uint64_t* aStartContainer,
+ int32_t* aStartOffset, uint64_t* aEndContainer, int32_t* aEndOffset);
+
+ mozilla::ipc::IPCResult RecvNextClusterAt(const uint64_t& aID,
+ const int32_t& aOffset,
+ uint64_t* aNextContainer,
+ int32_t* aNextOffset);
+
+ mozilla::ipc::IPCResult RecvPreviousClusterAt(const uint64_t& aID,
+ const int32_t& aOffset,
+ uint64_t* aPrevContainer,
+ int32_t* aPrevOffset);
+
+ mozilla::ipc::IPCResult RecvTextForRange(const uint64_t& aID,
+ const int32_t& aStartOffset,
+ const uint64_t& aEndContainer,
+ const int32_t& aEndOffset,
+ nsString* aText);
+
+ mozilla::ipc::IPCResult RecvBoundsForRange(const uint64_t& aID,
+ const int32_t& aStartOffset,
+ const uint64_t& aEndContainer,
+ const int32_t& aEndOffset,
+ nsIntRect* aBounds);
+
+ mozilla::ipc::IPCResult RecvLengthForRange(const uint64_t& aID,
+ const int32_t& aStartOffset,
+ const uint64_t& aEndContainer,
+ const int32_t& aEndOffset,
+ int32_t* aLength);
+
+ mozilla::ipc::IPCResult RecvOffsetAtIndex(const uint64_t& aID,
+ const int32_t& aIndex,
+ uint64_t* aContainer,
+ int32_t* aOffset);
+
+ mozilla::ipc::IPCResult RecvRangeOfChild(const uint64_t& aID,
+ const uint64_t& aChild,
+ int32_t* aStartOffset,
+ int32_t* aEndOffset);
+
+ mozilla::ipc::IPCResult RecvLeafAtOffset(const uint64_t& aID,
+ const int32_t& aOffset,
+ uint64_t* aLeaf);
+
+ MOZ_CAN_RUN_SCRIPT_BOUNDARY mozilla::ipc::IPCResult RecvSelectRange(
+ const uint64_t& aID, const int32_t& aStartOffset,
+ const uint64_t& aEndContainer, const int32_t& aEndOffset);
+
+ mozilla::ipc::IPCResult RecvApplyPostSearchFilter(
+ const nsTArray<uint64_t>& aAccessibles, const int32_t& aLimit,
+ const EWhichPostFilter& aSearchKey, const nsString& aSearchText,
+ nsTArray<uint64_t>* aMatches);
+
+ private:
+ HyperTextAccessibleWrap* IdToHyperTextAccessibleWrap(
+ const uint64_t& aID) const;
+};
+} // namespace a11y
+} // namespace mozilla
+
+#endif
diff --git a/accessible/ipc/extension/mac/DocAccessiblePlatformExtParent.h b/accessible/ipc/extension/mac/DocAccessiblePlatformExtParent.h
new file mode 100644
index 0000000000..07e65c6e2d
--- /dev/null
+++ b/accessible/ipc/extension/mac/DocAccessiblePlatformExtParent.h
@@ -0,0 +1,19 @@
+/* vim: set ts=2 et sw=2 tw=80: */
+/* 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/. */
+
+#ifndef mozilla_a11y_DocAccessiblePlatformExtParent_h
+#define mozilla_a11y_DocAccessiblePlatformExtParent_h
+
+#include "mozilla/a11y/PDocAccessiblePlatformExtParent.h"
+
+namespace mozilla {
+namespace a11y {
+class DocAccessiblePlatformExtParent : public PDocAccessiblePlatformExtParent {
+
+};
+} // namespace a11y
+} // namespace mozilla
+
+#endif
diff --git a/accessible/ipc/extension/mac/PDocAccessiblePlatformExt.ipdl b/accessible/ipc/extension/mac/PDocAccessiblePlatformExt.ipdl
new file mode 100644
index 0000000000..2aec735b16
--- /dev/null
+++ b/accessible/ipc/extension/mac/PDocAccessiblePlatformExt.ipdl
@@ -0,0 +1,62 @@
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=2 et sw=2 tw=80: */
+/* 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/. */
+
+include protocol PDocAccessible;
+
+include "mozilla/GfxMessageUtils.h";
+
+using mozilla::a11y::EWhichRange from "mozilla/a11y/IPCTypes.h";
+using mozilla::a11y::EWhichPostFilter from "mozilla/a11y/IPCTypes.h";
+using nsIntRect from "nsRect.h";
+
+namespace mozilla {
+namespace a11y {
+
+nested(upto inside_sync) sync protocol PDocAccessiblePlatformExt {
+ manager PDocAccessible;
+
+child:
+ async __delete__();
+
+ nested(inside_sync) sync RangeAt(uint64_t aID, int32_t aOffset, EWhichRange aRangeType)
+ returns(uint64_t aStartContainer, int32_t aStartOffset,
+ uint64_t aEndContainer, int32_t aEndOffset);
+
+ nested(inside_sync) sync NextClusterAt(uint64_t aID, int32_t aOffset)
+ returns(uint64_t aNextContainer, int32_t aNextOffset);
+
+ nested(inside_sync) sync PreviousClusterAt(uint64_t aID, int32_t aOffset)
+ returns(uint64_t aNextContainer, int32_t aNextOffset);
+
+ nested(inside_sync) sync TextForRange(uint64_t aID, int32_t aStartOffset, uint64_t aEndContainer, int32_t aEndOffset)
+ returns(nsString aText);
+
+ nested(inside_sync) sync BoundsForRange(uint64_t aID, int32_t aStartOffset, uint64_t aEndContainer, int32_t aEndOffset)
+ returns(nsIntRect aRetVal);
+
+ nested(inside_sync) sync LengthForRange(uint64_t aID, int32_t aStartOffset, uint64_t aEndContainer, int32_t aEndOffset)
+ returns(int32_t aLength);
+
+ nested(inside_sync) sync OffsetAtIndex(uint64_t aID, int32_t aIndex)
+ returns(uint64_t aContainer, int32_t aOffset);
+
+ nested(inside_sync) sync RangeOfChild(uint64_t aID, uint64_t aChild)
+ returns(int32_t aStartOffset, int32_t aEndOffset);
+
+ nested(inside_sync) sync LeafAtOffset(uint64_t aID, int32_t aOffset)
+ returns(uint64_t aLeaf);
+
+ async SelectRange(uint64_t aID, int32_t aStartOffset, uint64_t aEndContainer, int32_t aEndOffset);
+
+ // A filter that can be applied to search predicate results.
+ nested(inside_sync) sync ApplyPostSearchFilter(uint64_t[] aAccessibles, int32_t aLimit,
+ EWhichPostFilter aSearchKey, nsString aSearchText)
+ returns(uint64_t[] aMatches);
+
+};
+
+} // namespace a11y
+} // namespace mozilla
diff --git a/accessible/ipc/extension/mac/moz.build b/accessible/ipc/extension/mac/moz.build
new file mode 100644
index 0000000000..e7a7bf3bf8
--- /dev/null
+++ b/accessible/ipc/extension/mac/moz.build
@@ -0,0 +1,28 @@
+# -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
+# vim: set filetype=python:
+# 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/.
+
+if CONFIG["ACCESSIBILITY"]:
+ IPDL_SOURCES += ["PDocAccessiblePlatformExt.ipdl"]
+
+ EXPORTS.mozilla.a11y += [
+ "DocAccessiblePlatformExtChild.h",
+ "DocAccessiblePlatformExtParent.h",
+ ]
+
+ SOURCES += [
+ "DocAccessiblePlatformExtChild.cpp",
+ ]
+
+ LOCAL_INCLUDES += [
+ "/accessible/base",
+ "/accessible/generic",
+ "/accessible/ipc/other",
+ "/accessible/mac",
+ ]
+
+include("/ipc/chromium/chromium-config.mozbuild")
+
+FINAL_LIBRARY = "xul"