File: CacheOpChild.h

package info (click to toggle)
firefox 147.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,324 kB
  • sloc: cpp: 7,607,156; javascript: 6,532,492; ansic: 3,775,158; python: 1,415,368; xml: 634,556; asm: 438,949; java: 186,241; sh: 62,751; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (109 lines) | stat: -rw-r--r-- 3,951 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=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_dom_cache_CacheOpChild_h
#define mozilla_dom_cache_CacheOpChild_h

#include "mozilla/InitializedOnce.h"
#include "mozilla/RefPtr.h"
#include "mozilla/dom/cache/ActorChild.h"
#include "mozilla/dom/cache/BoundStorageKey.h"
#include "mozilla/dom/cache/PCacheOpChild.h"
#include "mozilla/dom/cache/TypeUtils.h"

class nsIGlobalObject;

namespace mozilla::dom {
class Promise;

namespace cache {
class CacheOpChild final : public PCacheOpChild,
                           public CacheActorChild,
                           public TypeUtils {
  friend class CacheChild;
  friend class CacheStorageChild;
  friend class PCacheOpChild;

 public:
  NS_INLINE_DECL_REFCOUNTING(CacheOpChild, override)

 private:
  // CacheOpChild can be used by Cache, CacheStorage and BoundStorageKey APIs.
  // It can handle two promise types; where Cache works with dom::Promise,
  // BoundStorageKey APIs works with MozPromise (represented by
  // CacheStoragePromise below)
  using PromiseType =
      Variant<RefPtr<mozilla::dom::Promise>, RefPtr<CacheStoragePromise>>;

  template <typename T>
  struct PromiseTrait;

  // This class must be constructed by CacheChild or CacheStorageChild using
  // their ExecuteOp() factory method.
  CacheOpChild(SafeRefPtr<CacheWorkerRef> aWorkerRef, nsIGlobalObject* aGlobal,
               nsISupports* aParent, RefPtr<Promise>& aPromise,
               ActorChild* aParentActor);

  // Below overload is used by BoundStorageKey APIs; passing in
  // CacheStoragePromise
  CacheOpChild(SafeRefPtr<CacheWorkerRef> aWorkerRef, nsIGlobalObject* aGlobal,
               nsISupports* aParent, RefPtr<CacheStoragePromise>& aPromise,
               ActorChild* aParentActor);

  ~CacheOpChild();

  // PCacheOpChild methods
  virtual void ActorDestroy(ActorDestroyReason aReason) override;

  mozilla::ipc::IPCResult Recv__delete__(ErrorResult&& aRv,
                                         const CacheOpResult& aResult);

  // ActorChild methods
  virtual void StartDestroy() override;

  // TypeUtils methods
  virtual nsIGlobalObject* GetGlobalObject() const override;

#ifdef DEBUG
  virtual void AssertOwningThread() const override;
#endif

  // Utility methods

  /* Generic method to handle all response types, formats responses before
   * resolving for the underlying promises */
  template <CacheOpResult::Type OP_TYPE, typename TResponse>
  void HandleAndSettle(TResponse&& aRes);

  // generic settle overload which routes the control to one of two
  // SettlePromise method overloads below depending if we are resolving for
  // native JS promise vs MozPromise
  template <CacheOpResult::Type OP_TYPE, typename ResultType>
  void Settle(ResultType&& aRes, ErrorResult&& aRv = ErrorResult(NS_OK));

  // settles promise for BoundStorageKeyCache; which is of type MozPromise
  template <CacheOpResult::Type OP_TYPE, typename ResultType>
  void SettlePromise(ResultType&& aRes, ErrorResult&& aRv,
                     const RefPtr<CacheStoragePromise>& aThePromise);

  // settles promise for cache, which is of type dom::Promise
  template <typename CacheOpResult::Type OP_TYPE, typename ResultType>
  void SettlePromise(ResultType&& aRes, ErrorResult&& aRv,
                     const RefPtr<Promise>& aThePromise);

  nsCOMPtr<nsIGlobalObject> mGlobal;

  // Hold the parent Cache or CacheStorage object alive until this async
  // operation completes.
  nsCOMPtr<nsISupports> mParent;
  LazyInitializedOnceEarlyDestructible<const PromiseType> mPromise;
  ActorChild* mParentActor;
};

}  // namespace cache
}  // namespace mozilla::dom

#endif  // mozilla_dom_cache_CacheOpChild_h