Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 117 { | 117 { |
| 118 IntSize s = sizeFor(video); | 118 IntSize s = sizeFor(video); |
| 119 return createImageBitmap(scriptState, eventTarget, video, 0, 0, s.width(), s .height(), exceptionState); | 119 return createImageBitmap(scriptState, eventTarget, video, 0, 0, s.width(), s .height(), exceptionState); |
| 120 } | 120 } |
| 121 | 121 |
| 122 ScriptPromise ImageBitmapFactories::createImageBitmap(ScriptState* scriptState, EventTarget& eventTarget, HTMLVideoElement* video, int sx, int sy, int sw, int s h, ExceptionState& exceptionState) | 122 ScriptPromise ImageBitmapFactories::createImageBitmap(ScriptState* scriptState, EventTarget& eventTarget, HTMLVideoElement* video, int sx, int sy, int sw, int s h, ExceptionState& exceptionState) |
| 123 { | 123 { |
| 124 // This variant does not work in worker threads. | 124 // This variant does not work in worker threads. |
| 125 ASSERT(eventTarget.toDOMWindow()); | 125 ASSERT(eventTarget.toDOMWindow()); |
| 126 | 126 |
| 127 if (!video->webMediaPlayer()) { | |
| 128 exceptionState.throwDOMException(InvalidStateError, "No player can be re trieved from the provided video element."); | |
| 129 return ScriptPromise(); | |
| 130 } | |
| 127 if (video->networkState() == HTMLMediaElement::NETWORK_EMPTY) { | 131 if (video->networkState() == HTMLMediaElement::NETWORK_EMPTY) { |
| 128 exceptionState.throwDOMException(InvalidStateError, "The provided elemen t has not retrieved data."); | 132 exceptionState.throwDOMException(InvalidStateError, "The provided elemen t has not retrieved data."); |
| 129 return ScriptPromise(); | 133 return ScriptPromise(); |
| 130 } | 134 } |
| 131 if (video->readyState() <= HTMLMediaElement::HAVE_METADATA) { | 135 if (video->readyState() <= HTMLMediaElement::HAVE_METADATA) { |
|
acolwell GONE FROM CHROMIUM
2014/06/09 23:09:36
nit: I think you should probably just make the nul
Srirama
2014/06/10 05:50:25
Done.
| |
| 132 exceptionState.throwDOMException(InvalidStateError, "The provided elemen t's player has no current data."); | 136 exceptionState.throwDOMException(InvalidStateError, "The provided elemen t's player has no current data."); |
| 133 return ScriptPromise(); | 137 return ScriptPromise(); |
| 134 } | 138 } |
| 135 if (!sw || !sh) { | 139 if (!sw || !sh) { |
| 136 exceptionState.throwDOMException(IndexSizeError, String::format("The sou rce %s provided is 0.", sw ? "height" : "width")); | 140 exceptionState.throwDOMException(IndexSizeError, String::format("The sou rce %s provided is 0.", sw ? "height" : "width")); |
| 137 return ScriptPromise(); | 141 return ScriptPromise(); |
| 138 } | 142 } |
| 139 if (!video->hasSingleSecurityOrigin()) { | 143 if (!video->hasSingleSecurityOrigin()) { |
| 140 exceptionState.throwSecurityError("The source video contains image data from multiple origins."); | 144 exceptionState.throwSecurityError("The source video contains image data from multiple origins."); |
| 141 return ScriptPromise(); | 145 return ScriptPromise(); |
| (...skipping 189 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 331 { | 335 { |
| 332 rejectPromise(); | 336 rejectPromise(); |
| 333 } | 337 } |
| 334 | 338 |
| 335 void ImageBitmapFactories::ImageBitmapLoader::trace(Visitor* visitor) | 339 void ImageBitmapFactories::ImageBitmapLoader::trace(Visitor* visitor) |
| 336 { | 340 { |
| 337 visitor->trace(m_factory); | 341 visitor->trace(m_factory); |
| 338 } | 342 } |
| 339 | 343 |
| 340 } // namespace WebCore | 344 } // namespace WebCore |
| OLD | NEW |