diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/fetch/FetchStreamUtils.cpp | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/fetch/FetchStreamUtils.cpp')
-rw-r--r-- | dom/fetch/FetchStreamUtils.cpp | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/dom/fetch/FetchStreamUtils.cpp b/dom/fetch/FetchStreamUtils.cpp new file mode 100644 index 0000000000..d9cb762526 --- /dev/null +++ b/dom/fetch/FetchStreamUtils.cpp @@ -0,0 +1,83 @@ +/* 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 "FetchStreamUtils.h" + +#include "mozilla/NotNull.h" +#include "mozilla/RemoteLazyInputStreamChild.h" +#include "mozilla/RemoteLazyInputStreamStorage.h" +#include "mozilla/dom/FetchTypes.h" +#include "mozilla/dom/IPCBlob.h" +#include "mozilla/ipc/IPCStreamUtils.h" +#include "nsContentUtils.h" +#include "nsXULAppAPI.h" + +namespace mozilla::dom { + +namespace { + +RefPtr<RemoteLazyInputStreamStorage> GetRemoteLazyInputStreamStorage() { + auto storageOrErr = RemoteLazyInputStreamStorage::Get(); + MOZ_ASSERT(storageOrErr.isOk()); + return storageOrErr.unwrap(); +} + +} // namespace + +NotNull<nsCOMPtr<nsIInputStream>> ToInputStream( + const ParentToParentStream& aStream) { + MOZ_ASSERT(XRE_IsParentProcess()); + return WrapNotNull( + GetRemoteLazyInputStreamStorage()->ForgetStream(aStream.uuid())); +} + +NotNull<nsCOMPtr<nsIInputStream>> ToInputStream( + const ParentToChildStream& aStream) { + MOZ_ASSERT(XRE_IsContentProcess()); + nsCOMPtr<nsIInputStream> result; + if (aStream.type() == ParentToChildStream::TRemoteLazyInputStream) { + result = aStream.get_RemoteLazyInputStream(); + } else { + result = DeserializeIPCStream(aStream.get_IPCStream()); + } + return WrapNotNull(result); +} + +ParentToParentStream ToParentToParentStream( + const NotNull<nsCOMPtr<nsIInputStream>>& aStream, int64_t aStreamSize) { + MOZ_ASSERT(XRE_IsParentProcess()); + + ParentToParentStream stream; + stream.uuid() = nsID::GenerateUUID(); + GetRemoteLazyInputStreamStorage()->AddStream(aStream.get(), stream.uuid()); + return stream; +} + +ParentToChildStream ToParentToChildStream( + const NotNull<nsCOMPtr<nsIInputStream>>& aStream, int64_t aStreamSize, + NotNull<mozilla::ipc::PBackgroundParent*> aBackgroundParent, + bool aSerializeAsLazy) { + MOZ_ASSERT(XRE_IsParentProcess()); + + ParentToChildStream result; + if (aSerializeAsLazy) { + result = RemoteLazyInputStream::WrapStream(aStream.get()); + } else { + nsCOMPtr<nsIInputStream> stream(aStream.get()); + mozilla::ipc::IPCStream ipcStream; + Unused << NS_WARN_IF( + !mozilla::ipc::SerializeIPCStream(stream.forget(), ipcStream, false)); + result = ipcStream; + } + return result; +} + +ParentToChildStream ToParentToChildStream( + const ParentToParentStream& aStream, int64_t aStreamSize, + NotNull<mozilla::ipc::PBackgroundParent*> aBackgroundParent) { + return ToParentToChildStream(ToInputStream(aStream), aStreamSize, + aBackgroundParent); +} + +} // namespace mozilla::dom |