OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 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 | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * | 7 * |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. 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 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
(...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
196 return getChannelData(channelIndex); | 196 return getChannelData(channelIndex); |
197 } | 197 } |
198 | 198 |
199 DOMFloat32Array* AudioBuffer::getChannelData(unsigned channelIndex) { | 199 DOMFloat32Array* AudioBuffer::getChannelData(unsigned channelIndex) { |
200 if (channelIndex >= m_channels.size()) | 200 if (channelIndex >= m_channels.size()) |
201 return nullptr; | 201 return nullptr; |
202 | 202 |
203 return m_channels[channelIndex].get(); | 203 return m_channels[channelIndex].get(); |
204 } | 204 } |
205 | 205 |
206 void AudioBuffer::copyFromChannel(DOMFloat32Array* destination, | 206 void AudioBuffer::copyFromChannel( |
207 long channelNumber, | 207 const MaybeShared<DOMFloat32Array>& destination, |
208 ExceptionState& exceptionState) { | 208 long channelNumber, |
| 209 ExceptionState& exceptionState) { |
209 return copyFromChannel(destination, channelNumber, 0, exceptionState); | 210 return copyFromChannel(destination, channelNumber, 0, exceptionState); |
210 } | 211 } |
211 | 212 |
212 void AudioBuffer::copyFromChannel(DOMFloat32Array* destination, | 213 void AudioBuffer::copyFromChannel( |
213 long channelNumber, | 214 const MaybeShared<DOMFloat32Array>& destination, |
214 unsigned long startInChannel, | 215 long channelNumber, |
215 ExceptionState& exceptionState) { | 216 unsigned long startInChannel, |
| 217 ExceptionState& exceptionState) { |
216 if (channelNumber < 0 || | 218 if (channelNumber < 0 || |
217 channelNumber >= static_cast<long>(m_channels.size())) { | 219 channelNumber >= static_cast<long>(m_channels.size())) { |
218 exceptionState.throwDOMException( | 220 exceptionState.throwDOMException( |
219 IndexSizeError, ExceptionMessages::indexOutsideRange( | 221 IndexSizeError, ExceptionMessages::indexOutsideRange( |
220 "channelNumber", channelNumber, 0L, | 222 "channelNumber", channelNumber, 0L, |
221 ExceptionMessages::InclusiveBound, | 223 ExceptionMessages::InclusiveBound, |
222 static_cast<long>(m_channels.size() - 1), | 224 static_cast<long>(m_channels.size() - 1), |
223 ExceptionMessages::InclusiveBound)); | 225 ExceptionMessages::InclusiveBound)); |
224 return; | 226 return; |
225 } | 227 } |
226 | 228 |
227 DOMFloat32Array* channelData = m_channels[channelNumber].get(); | 229 DOMFloat32Array* channelData = m_channels[channelNumber].get(); |
228 | 230 |
229 if (startInChannel >= channelData->length()) { | 231 if (startInChannel >= channelData->length()) { |
230 exceptionState.throwDOMException( | 232 exceptionState.throwDOMException( |
231 IndexSizeError, ExceptionMessages::indexOutsideRange( | 233 IndexSizeError, ExceptionMessages::indexOutsideRange( |
232 "startInChannel", startInChannel, 0UL, | 234 "startInChannel", startInChannel, 0UL, |
233 ExceptionMessages::InclusiveBound, | 235 ExceptionMessages::InclusiveBound, |
234 static_cast<unsigned long>(channelData->length()), | 236 static_cast<unsigned long>(channelData->length()), |
235 ExceptionMessages::ExclusiveBound)); | 237 ExceptionMessages::ExclusiveBound)); |
236 | 238 |
237 return; | 239 return; |
238 } | 240 } |
239 | 241 |
| 242 if (destination.isShared()) { |
| 243 exceptionState.throwTypeError( |
| 244 "destination can not be backed by a SharedArrayBuffer."); |
| 245 return; |
| 246 } |
| 247 |
240 unsigned count = channelData->length() - startInChannel; | 248 unsigned count = channelData->length() - startInChannel; |
241 count = std::min(destination->length(), count); | 249 count = std::min(destination.viewNotShared()->length(), count); |
242 | 250 |
243 const float* src = channelData->data(); | 251 const float* src = channelData->data(); |
244 float* dst = destination->data(); | 252 float* dst = destination.viewNotShared()->data(); |
245 | 253 |
246 DCHECK(src); | 254 DCHECK(src); |
247 DCHECK(dst); | 255 DCHECK(dst); |
248 | 256 |
249 memcpy(dst, src + startInChannel, count * sizeof(*src)); | 257 memcpy(dst, src + startInChannel, count * sizeof(*src)); |
250 } | 258 } |
251 | 259 |
252 void AudioBuffer::copyToChannel(DOMFloat32Array* source, | 260 void AudioBuffer::copyToChannel(const MaybeShared<DOMFloat32Array>& source, |
253 long channelNumber, | 261 long channelNumber, |
254 ExceptionState& exceptionState) { | 262 ExceptionState& exceptionState) { |
255 return copyToChannel(source, channelNumber, 0, exceptionState); | 263 return copyToChannel(source, channelNumber, 0, exceptionState); |
256 } | 264 } |
257 | 265 |
258 void AudioBuffer::copyToChannel(DOMFloat32Array* source, | 266 void AudioBuffer::copyToChannel(const MaybeShared<DOMFloat32Array>& source, |
259 long channelNumber, | 267 long channelNumber, |
260 unsigned long startInChannel, | 268 unsigned long startInChannel, |
261 ExceptionState& exceptionState) { | 269 ExceptionState& exceptionState) { |
262 if (channelNumber < 0 || | 270 if (channelNumber < 0 || |
263 channelNumber >= static_cast<long>(m_channels.size())) { | 271 channelNumber >= static_cast<long>(m_channels.size())) { |
264 exceptionState.throwDOMException( | 272 exceptionState.throwDOMException( |
265 IndexSizeError, ExceptionMessages::indexOutsideRange( | 273 IndexSizeError, ExceptionMessages::indexOutsideRange( |
266 "channelNumber", channelNumber, 0L, | 274 "channelNumber", channelNumber, 0L, |
267 ExceptionMessages::InclusiveBound, | 275 ExceptionMessages::InclusiveBound, |
268 static_cast<long>(m_channels.size() - 1), | 276 static_cast<long>(m_channels.size() - 1), |
269 ExceptionMessages::InclusiveBound)); | 277 ExceptionMessages::InclusiveBound)); |
270 return; | 278 return; |
271 } | 279 } |
272 | 280 |
273 DOMFloat32Array* channelData = m_channels[channelNumber].get(); | 281 DOMFloat32Array* channelData = m_channels[channelNumber].get(); |
274 | 282 |
275 if (startInChannel >= channelData->length()) { | 283 if (startInChannel >= channelData->length()) { |
276 exceptionState.throwDOMException( | 284 exceptionState.throwDOMException( |
277 IndexSizeError, ExceptionMessages::indexOutsideRange( | 285 IndexSizeError, ExceptionMessages::indexOutsideRange( |
278 "startInChannel", startInChannel, 0UL, | 286 "startInChannel", startInChannel, 0UL, |
279 ExceptionMessages::InclusiveBound, | 287 ExceptionMessages::InclusiveBound, |
280 static_cast<unsigned long>(channelData->length()), | 288 static_cast<unsigned long>(channelData->length()), |
281 ExceptionMessages::ExclusiveBound)); | 289 ExceptionMessages::ExclusiveBound)); |
282 | 290 |
283 return; | 291 return; |
284 } | 292 } |
285 | 293 |
| 294 if (source.isShared()) { |
| 295 exceptionState.throwTypeError( |
| 296 "source can not be backed by a SharedArrayBuffer."); |
| 297 return; |
| 298 } |
| 299 |
286 unsigned count = channelData->length() - startInChannel; | 300 unsigned count = channelData->length() - startInChannel; |
287 count = std::min(source->length(), count); | 301 count = std::min(source.viewNotShared()->length(), count); |
288 | 302 |
289 const float* src = source->data(); | 303 const float* src = source.viewNotShared()->data(); |
290 float* dst = channelData->data(); | 304 float* dst = channelData->data(); |
291 | 305 |
292 DCHECK(src); | 306 DCHECK(src); |
293 DCHECK(dst); | 307 DCHECK(dst); |
294 | 308 |
295 memcpy(dst + startInChannel, src, count * sizeof(*dst)); | 309 memcpy(dst + startInChannel, src, count * sizeof(*dst)); |
296 } | 310 } |
297 | 311 |
298 void AudioBuffer::zero() { | 312 void AudioBuffer::zero() { |
299 for (unsigned i = 0; i < m_channels.size(); ++i) { | 313 for (unsigned i = 0; i < m_channels.size(); ++i) { |
300 if (DOMFloat32Array* array = getChannelData(i)) { | 314 if (DOMFloat32Array* array = getChannelData(i)) { |
301 float* data = array->data(); | 315 float* data = array->data(); |
302 memset(data, 0, length() * sizeof(*data)); | 316 memset(data, 0, length() * sizeof(*data)); |
303 } | 317 } |
304 } | 318 } |
305 } | 319 } |
306 | 320 |
307 } // namespace blink | 321 } // namespace blink |
OLD | NEW |