Bug 1880216 - Migrate Fenix docs into Sphinx. r=owlish,geckoview-reviewers,android...
[gecko.git] / dom / midi / MIDIAccessManager.h
blob606c73d26887e43d18aabe78370bfaba34868089
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* vim:set ts=2 sw=2 sts=2 et cindent: */
3 /* This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
7 #ifndef mozilla_dom_MIDIAccessManager_h
8 #define mozilla_dom_MIDIAccessManager_h
10 #include "nsPIDOMWindow.h"
11 #include "mozilla/dom/MIDITypes.h"
12 #include "mozilla/Observer.h"
14 namespace mozilla::dom {
16 class MIDIAccess;
17 class MIDIManagerChild;
18 struct MIDIOptions;
19 class MIDIPortChangeEvent;
20 class MIDIPortInfo;
21 class Promise;
23 /**
24 * MIDIAccessManager manages creation and lifetime of MIDIAccess objects for the
25 * process it lives in. It is in charge of dealing with permission requests,
26 * creating new MIDIAccess objects, and updating live MIDIAccess objects with
27 * new device listings.
29 * While a process/window can have many MIDIAccess objects, there is only one
30 * MIDIAccessManager for any one process.
32 class MIDIAccessManager final {
33 public:
34 NS_INLINE_DECL_REFCOUNTING(MIDIAccessManager);
35 // Handles requests from Navigator for MIDI permissions and MIDIAccess
36 // creation.
37 already_AddRefed<Promise> RequestMIDIAccess(nsPIDOMWindowInner* aWindow,
38 const MIDIOptions& aOptions,
39 ErrorResult& aRv);
40 // Creates a new MIDIAccess object
41 void CreateMIDIAccess(nsPIDOMWindowInner* aWindow, bool aNeedsSysex,
42 Promise* aPromise);
43 // Getter for manager singleton
44 static MIDIAccessManager* Get();
45 // True if manager singleton has been created
46 static bool IsRunning();
47 // Send device connection updates to all known MIDIAccess objects.
48 void Update(const MIDIPortList& aPortList);
49 // Adds a device update observer (usually a MIDIAccess object)
50 bool AddObserver(Observer<MIDIPortList>* aObserver);
51 // Removes a device update observer (usually a MIDIAccess object)
52 void RemoveObserver(Observer<MIDIPortList>* aObserver);
53 // Requests the service to update the list of devices
54 void SendRefresh();
56 private:
57 MIDIAccessManager();
58 ~MIDIAccessManager();
59 void StartActor();
60 // True if object has received a device list from the MIDI platform service.
61 bool mHasPortList;
62 // List of known ports for the system.
63 MIDIPortList mPortList;
64 // Holds MIDIAccess objects until we've received the first list of devices
65 // from the MIDI Service.
66 nsTArray<RefPtr<MIDIAccess>> mAccessHolder;
67 // Device state update observers (usually MIDIAccess objects)
68 ObserverList<MIDIPortList> mChangeObservers;
69 // IPC Object for MIDIManager. Created on first MIDIAccess object creation,
70 // destroyed on last MIDIAccess object destruction.
71 RefPtr<MIDIManagerChild> mChild;
74 } // namespace mozilla::dom
76 #endif // mozilla_dom_MIDIAccessManager_h