Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(305)

Side by Side Diff: Source/modules/webmidi/MIDIAccess.cpp

Issue 962523005: Web MIDI: add open() and close() to MIDIPort (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: cast and win build fix Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 29 matching lines...) Expand all
40 #include "modules/webmidi/MIDIInput.h" 40 #include "modules/webmidi/MIDIInput.h"
41 #include "modules/webmidi/MIDIInputMap.h" 41 #include "modules/webmidi/MIDIInputMap.h"
42 #include "modules/webmidi/MIDIOutput.h" 42 #include "modules/webmidi/MIDIOutput.h"
43 #include "modules/webmidi/MIDIOutputMap.h" 43 #include "modules/webmidi/MIDIOutputMap.h"
44 #include "modules/webmidi/MIDIPort.h" 44 #include "modules/webmidi/MIDIPort.h"
45 #include "platform/AsyncMethodRunner.h" 45 #include "platform/AsyncMethodRunner.h"
46 #include <v8.h> 46 #include <v8.h>
47 47
48 namespace blink { 48 namespace blink {
49 49
50 using PortState = MIDIAccessor::MIDIPortState;
51
50 MIDIAccess::MIDIAccess(PassOwnPtr<MIDIAccessor> accessor, bool sysexEnabled, con st Vector<MIDIAccessInitializer::PortDescriptor>& ports, ExecutionContext* execu tionContext) 52 MIDIAccess::MIDIAccess(PassOwnPtr<MIDIAccessor> accessor, bool sysexEnabled, con st Vector<MIDIAccessInitializer::PortDescriptor>& ports, ExecutionContext* execu tionContext)
51 : ActiveDOMObject(executionContext) 53 : ActiveDOMObject(executionContext)
52 , m_accessor(accessor) 54 , m_accessor(accessor)
53 , m_sysexEnabled(sysexEnabled) 55 , m_sysexEnabled(sysexEnabled)
54 { 56 {
55 m_accessor->setClient(this); 57 m_accessor->setClient(this);
56 for (size_t i = 0; i < ports.size(); ++i) { 58 for (size_t i = 0; i < ports.size(); ++i) {
57 const MIDIAccessInitializer::PortDescriptor& port = ports[i]; 59 const MIDIAccessInitializer::PortDescriptor& port = ports[i];
58 if (port.type == MIDIPort::MIDIPortTypeInput) { 60 if (port.type == MIDIPort::MIDIPortTypeInput) {
59 m_inputs.append(MIDIInput::create(this, port.id, port.manufacturer, port.name, port.version, port.isActive)); 61 m_inputs.append(MIDIInput::create(this, port.id, port.manufacturer, port.name, port.version, port.state));
60 } else { 62 } else {
61 m_outputs.append(MIDIOutput::create(this, m_outputs.size(), port.id, port.manufacturer, port.name, port.version, port.isActive)); 63 m_outputs.append(MIDIOutput::create(this, m_outputs.size(), port.id, port.manufacturer, port.name, port.version, port.state));
62 } 64 }
63 } 65 }
64 } 66 }
65 67
66 MIDIAccess::~MIDIAccess() 68 MIDIAccess::~MIDIAccess()
67 { 69 {
68 } 70 }
69 71
70 MIDIInputMap* MIDIAccess::inputs() const 72 MIDIInputMap* MIDIAccess::inputs() const
71 { 73 {
72 HeapHashMap<String, Member<MIDIInput>> inputs; 74 HeapHashMap<String, Member<MIDIInput>> inputs;
73 size_t inactiveCount = 0; 75 size_t inactiveCount = 0;
74 for (size_t i = 0; i < m_inputs.size(); ++i) { 76 for (size_t i = 0; i < m_inputs.size(); ++i) {
75 MIDIInput* input = m_inputs[i]; 77 MIDIInput* input = m_inputs[i];
76 if (input->isActive()) 78 if (input->getState() != PortState::MIDIPortStateDisconnected)
77 inputs.add(input->id(), input); 79 inputs.add(input->id(), input);
78 else 80 else
79 inactiveCount++; 81 inactiveCount++;
80 } 82 }
81 if ((inputs.size() + inactiveCount) != m_inputs.size()) { 83 if ((inputs.size() + inactiveCount) != m_inputs.size()) {
82 // There is id duplication that violates the spec. 84 // There is id duplication that violates the spec.
83 inputs.clear(); 85 inputs.clear();
84 } 86 }
85 return new MIDIInputMap(inputs); 87 return new MIDIInputMap(inputs);
86 } 88 }
87 89
88 MIDIOutputMap* MIDIAccess::outputs() const 90 MIDIOutputMap* MIDIAccess::outputs() const
89 { 91 {
90 HeapHashMap<String, Member<MIDIOutput>> outputs; 92 HeapHashMap<String, Member<MIDIOutput>> outputs;
91 size_t inactiveCount = 0; 93 size_t inactiveCount = 0;
92 for (size_t i = 0; i < m_outputs.size(); ++i) { 94 for (size_t i = 0; i < m_outputs.size(); ++i) {
93 MIDIOutput* output = m_outputs[i]; 95 MIDIOutput* output = m_outputs[i];
94 if (output->isActive()) 96 if (output->getState() != PortState::MIDIPortStateDisconnected)
95 outputs.add(output->id(), output); 97 outputs.add(output->id(), output);
96 else 98 else
97 inactiveCount++; 99 inactiveCount++;
98 } 100 }
99 if ((outputs.size() + inactiveCount) != m_outputs.size()) { 101 if ((outputs.size() + inactiveCount) != m_outputs.size()) {
100 // There is id duplication that violates the spec. 102 // There is id duplication that violates the spec.
101 outputs.clear(); 103 outputs.clear();
102 } 104 }
103 return new MIDIOutputMap(outputs); 105 return new MIDIOutputMap(outputs);
104 } 106 }
105 107
106 void MIDIAccess::didAddInputPort(const String& id, const String& manufacturer, c onst String& name, const String& version, bool isActive) 108 void MIDIAccess::didAddInputPort(const String& id, const String& manufacturer, c onst String& name, const String& version, PortState state)
107 { 109 {
108 ASSERT(isMainThread()); 110 ASSERT(isMainThread());
109 MIDIInput* port = MIDIInput::create(this, id, manufacturer, name, version, i sActive); 111 MIDIInput* port = MIDIInput::create(this, id, manufacturer, name, version, s tate);
110 m_inputs.append(port); 112 m_inputs.append(port);
111 dispatchEvent(MIDIConnectionEvent::create(port)); 113 dispatchEvent(MIDIConnectionEvent::create(port));
112 } 114 }
113 115
114 void MIDIAccess::didAddOutputPort(const String& id, const String& manufacturer, const String& name, const String& version, bool isActive) 116 void MIDIAccess::didAddOutputPort(const String& id, const String& manufacturer, const String& name, const String& version, PortState state)
115 { 117 {
116 ASSERT(isMainThread()); 118 ASSERT(isMainThread());
117 unsigned portIndex = m_outputs.size(); 119 unsigned portIndex = m_outputs.size();
118 MIDIOutput* port = MIDIOutput::create(this, portIndex, id, manufacturer, nam e, version, isActive); 120 MIDIOutput* port = MIDIOutput::create(this, portIndex, id, manufacturer, nam e, version, state);
119 m_outputs.append(port); 121 m_outputs.append(port);
120 dispatchEvent(MIDIConnectionEvent::create(port)); 122 dispatchEvent(MIDIConnectionEvent::create(port));
121 } 123 }
122 124
123 void MIDIAccess::didSetInputPortState(unsigned portIndex, bool isActive) 125 void MIDIAccess::didSetInputPortState(unsigned portIndex, PortState state)
124 { 126 {
125 ASSERT(isMainThread()); 127 ASSERT(isMainThread());
126 if (portIndex >= m_inputs.size()) 128 if (portIndex >= m_inputs.size())
127 return; 129 return;
128 130
129 m_inputs[portIndex]->setActiveState(isActive); 131 m_inputs[portIndex]->setState(state);
130 dispatchEvent(MIDIConnectionEvent::create(m_inputs[portIndex])); 132 dispatchEvent(MIDIConnectionEvent::create(m_inputs[portIndex]));
131 } 133 }
132 134
133 void MIDIAccess::didSetOutputPortState(unsigned portIndex, bool isActive) 135 void MIDIAccess::didSetOutputPortState(unsigned portIndex, PortState state)
134 { 136 {
135 ASSERT(isMainThread()); 137 ASSERT(isMainThread());
136 if (portIndex >= m_outputs.size()) 138 if (portIndex >= m_outputs.size())
137 return; 139 return;
138 140
139 m_outputs[portIndex]->setActiveState(isActive); 141 m_outputs[portIndex]->setState(state);
140 dispatchEvent(MIDIConnectionEvent::create(m_outputs[portIndex])); 142 dispatchEvent(MIDIConnectionEvent::create(m_outputs[portIndex]));
141 } 143 }
142 144
143 void MIDIAccess::didReceiveMIDIData(unsigned portIndex, const unsigned char* dat a, size_t length, double timeStamp) 145 void MIDIAccess::didReceiveMIDIData(unsigned portIndex, const unsigned char* dat a, size_t length, double timeStamp)
144 { 146 {
145 ASSERT(isMainThread()); 147 ASSERT(isMainThread());
146 if (portIndex >= m_inputs.size()) 148 if (portIndex >= m_inputs.size())
147 return; 149 return;
148 150
149 // Convert from time in seconds which is based on the time coordinate system of monotonicallyIncreasingTime() 151 // Convert from time in seconds which is based on the time coordinate system of monotonicallyIncreasingTime()
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
186 188
187 DEFINE_TRACE(MIDIAccess) 189 DEFINE_TRACE(MIDIAccess)
188 { 190 {
189 visitor->trace(m_inputs); 191 visitor->trace(m_inputs);
190 visitor->trace(m_outputs); 192 visitor->trace(m_outputs);
191 RefCountedGarbageCollectedEventTargetWithInlineData<MIDIAccess>::trace(visit or); 193 RefCountedGarbageCollectedEventTargetWithInlineData<MIDIAccess>::trace(visit or);
192 ActiveDOMObject::trace(visitor); 194 ActiveDOMObject::trace(visitor);
193 } 195 }
194 196
195 } // namespace blink 197 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698