Coverage Report

Created: 2018-09-25 14:53

/work/obj-fuzz/dist/include/mozilla/dom/WebSocketBinding.h
Line
Count
Source (jump to first uncovered line)
1
/* THIS FILE IS AUTOGENERATED FROM WebSocket.webidl BY Codegen.py - DO NOT EDIT */
2
3
#ifndef mozilla_dom_WebSocketBinding_h
4
#define mozilla_dom_WebSocketBinding_h
5
6
#include "GeckoProfiler.h"
7
#include "js/RootingAPI.h"
8
#include "jspubtd.h"
9
#include "mozilla/ErrorResult.h"
10
#include "mozilla/dom/BindingDeclarations.h"
11
#include "mozilla/dom/Nullable.h"
12
#include "mozilla/dom/PrototypeList.h"
13
14
namespace mozilla {
15
namespace dom {
16
17
struct NativePropertyHooks;
18
class ProtoAndIfaceCache;
19
class WebSocket;
20
struct WebSocketAtoms;
21
22
} // namespace dom
23
} // namespace mozilla
24
25
namespace mozilla {
26
namespace dom {
27
28
enum class BinaryType : uint8_t {
29
  Blob,
30
  Arraybuffer,
31
  EndGuard_
32
};
33
34
namespace BinaryTypeValues {
35
extern const EnumEntry strings[3];
36
} // namespace BinaryTypeValues
37
38
bool
39
ToJSValue(JSContext* aCx, BinaryType aArgument, JS::MutableHandle<JS::Value> aValue);
40
41
42
namespace WebSocket_Binding {
43
44
  typedef mozilla::dom::WebSocket NativeType;
45
46
  static const uint16_t CONNECTING = 0;
47
  static const uint16_t OPEN = 1;
48
  static const uint16_t CLOSING = 2;
49
  static const uint16_t CLOSED = 3;
50
  const JSClass*
51
  GetJSClass();
52
53
  bool
54
  Wrap(JSContext* aCx, mozilla::dom::WebSocket* aObject, nsWrapperCache* aCache, JS::Handle<JSObject*> aGivenProto, JS::MutableHandle<JSObject*> aReflector);
55
56
  template <class T>
57
  inline JSObject* Wrap(JSContext* aCx, T* aObject, JS::Handle<JSObject*> aGivenProto)
58
0
  {
59
0
    JS::Rooted<JSObject*> reflector(aCx);
60
0
    return Wrap(aCx, aObject, aObject, aGivenProto, &reflector) ? reflector.get() : nullptr;
61
0
  }
62
63
  // We declare this as an array so that retrieving a pointer to this
64
  // binding's property hooks only requires compile/link-time resolvable
65
  // address arithmetic.  Declaring it as a pointer instead would require
66
  // doing a run-time load to fetch a pointer to this binding's property
67
  // hooks.  And then structures which embedded a pointer to this structure
68
  // would require a run-time load for proper initialization, which would
69
  // then induce static constructors.  Lots of static constructors.
70
  extern const NativePropertyHooks sNativePropertyHooks[];
71
72
  void
73
  CreateInterfaceObjects(JSContext* aCx, JS::Handle<JSObject*> aGlobal, ProtoAndIfaceCache& aProtoAndIfaceCache, bool aDefineOnGlobal);
74
75
  inline JS::Handle<JSObject*> GetProtoObjectHandle(JSContext* aCx)
76
0
  {
77
0
    /* Get the interface prototype object for this class.  This will create the
78
0
       object as needed. */
79
0
    return GetPerInterfaceObjectHandle(aCx, prototypes::id::WebSocket,
80
0
                                       &CreateInterfaceObjects,
81
0
                                       /* aDefineOnGlobal = */ true);
82
0
83
0
  }
84
85
  inline JS::Handle<JSObject*> GetConstructorObjectHandle(JSContext* aCx, bool aDefineOnGlobal = true)
86
0
  {
87
0
    /* Get the interface object for this class.  This will create the object as
88
0
       needed. */
89
0
90
0
    return GetPerInterfaceObjectHandle(aCx, constructors::id::WebSocket,
91
0
                                       &CreateInterfaceObjects,
92
0
                                       aDefineOnGlobal);
93
0
  }
94
95
  JSObject*
96
  GetConstructorObject(JSContext* aCx);
97
98
} // namespace WebSocket_Binding
99
100
101
102
} // namespace dom
103
} // namespace mozilla
104
105
#endif // mozilla_dom_WebSocketBinding_h