Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013 Apple Inc. All rights reserved. | 2 * Copyright (C) 2007, 2008, 2009, 2010, 2011, 2012, 2013 Apple 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 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| (...skipping 266 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 277 , m_tracksAreReady(true) | 277 , m_tracksAreReady(true) |
| 278 , m_haveVisibleTextTrack(false) | 278 , m_haveVisibleTextTrack(false) |
| 279 , m_processingPreferenceChange(false) | 279 , m_processingPreferenceChange(false) |
| 280 #if ENABLE(OILPAN) | 280 #if ENABLE(OILPAN) |
| 281 , m_isFinalizing(false) | 281 , m_isFinalizing(false) |
| 282 #endif | 282 #endif |
| 283 , m_lastTextTrackUpdateTime(-1) | 283 , m_lastTextTrackUpdateTime(-1) |
| 284 , m_textTracks(nullptr) | 284 , m_textTracks(nullptr) |
| 285 , m_ignoreTrackDisplayUpdate(0) | 285 , m_ignoreTrackDisplayUpdate(0) |
| 286 #if ENABLE(WEB_AUDIO) | 286 #if ENABLE(WEB_AUDIO) |
| 287 , m_audioSourceNode(0) | 287 , m_audioSourceNode(nullptr) |
| 288 #endif | 288 #endif |
| 289 { | 289 { |
| 290 ASSERT(RuntimeEnabledFeatures::mediaEnabled()); | 290 ASSERT(RuntimeEnabledFeatures::mediaEnabled()); |
| 291 | 291 |
| 292 WTF_LOG(Media, "HTMLMediaElement::HTMLMediaElement"); | 292 WTF_LOG(Media, "HTMLMediaElement::HTMLMediaElement"); |
| 293 ScriptWrappable::init(this); | 293 ScriptWrappable::init(this); |
| 294 | 294 |
| 295 if (document.settings() && document.settings()->mediaPlaybackRequiresUserGes ture()) | 295 if (document.settings() && document.settings()->mediaPlaybackRequiresUserGes ture()) |
| 296 m_userGestureRequiredForPlay = true; | 296 m_userGestureRequiredForPlay = true; |
| 297 | 297 |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 365 // supplementable table.) Handled for now by entering an | 365 // supplementable table.) Handled for now by entering an |
| 366 // is-finalizing state, which is explicitly checked for if the | 366 // is-finalizing state, which is explicitly checked for if the |
| 367 // player tries to access the media element during shutdown. | 367 // player tries to access the media element during shutdown. |
| 368 // | 368 // |
| 369 // FIXME: Oilpan: move the media player to the heap instead and | 369 // FIXME: Oilpan: move the media player to the heap instead and |
| 370 // avoid having to finalize it from here; this whole #if block | 370 // avoid having to finalize it from here; this whole #if block |
| 371 // could then be removed (along with the state bit it depends on.) | 371 // could then be removed (along with the state bit it depends on.) |
| 372 // crbug.com/378229 | 372 // crbug.com/378229 |
| 373 m_isFinalizing = true; | 373 m_isFinalizing = true; |
| 374 #endif | 374 #endif |
| 375 clearMediaPlayerAndAudioSourceProviderClient(); | 375 |
| 376 // The m_audioSourceNode is either dead already or it is dying together with | |
| 377 // this HTMLMediaElement which it strongly keeps alive. | |
| 378 #if !ENABLE(OILPAN) | |
| 379 ASSERT(!m_audioSourceNode); | |
| 380 #endif | |
| 381 clearMediaPlayerAndAudioSourceProviderClientWithoutLocking(); | |
| 376 | 382 |
| 377 #if !ENABLE(OILPAN) | 383 #if !ENABLE(OILPAN) |
| 378 document().decrementLoadEventDelayCount(); | 384 document().decrementLoadEventDelayCount(); |
| 379 #endif | 385 #endif |
| 380 } | 386 } |
| 381 | 387 |
| 382 void HTMLMediaElement::didMoveToNewDocument(Document& oldDocument) | 388 void HTMLMediaElement::didMoveToNewDocument(Document& oldDocument) |
| 383 { | 389 { |
| 384 WTF_LOG(Media, "HTMLMediaElement::didMoveToNewDocument"); | 390 WTF_LOG(Media, "HTMLMediaElement::didMoveToNewDocument"); |
| 385 | 391 |
| (...skipping 2726 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3112 | 3118 |
| 3113 // 6 - Abort the overall resource selection algorithm. | 3119 // 6 - Abort the overall resource selection algorithm. |
| 3114 m_currentSourceNode = nullptr; | 3120 m_currentSourceNode = nullptr; |
| 3115 | 3121 |
| 3116 // Reset m_readyState since m_player is gone. | 3122 // Reset m_readyState since m_player is gone. |
| 3117 m_readyState = HAVE_NOTHING; | 3123 m_readyState = HAVE_NOTHING; |
| 3118 updateMediaController(); | 3124 updateMediaController(); |
| 3119 updateActiveTextTrackCues(0); | 3125 updateActiveTextTrackCues(0); |
| 3120 } | 3126 } |
| 3121 | 3127 |
| 3122 void HTMLMediaElement::clearMediaPlayerAndAudioSourceProviderClient() | 3128 void HTMLMediaElement::clearMediaPlayerAndAudioSourceProviderClientWithoutLockin g() |
| 3123 { | 3129 { |
| 3124 #if ENABLE(WEB_AUDIO) | 3130 #if ENABLE(WEB_AUDIO) |
| 3125 if (m_audioSourceNode) | |
| 3126 m_audioSourceNode->lock(); | |
| 3127 | |
| 3128 if (audioSourceProvider()) | 3131 if (audioSourceProvider()) |
| 3129 audioSourceProvider()->setClient(0); | 3132 audioSourceProvider()->setClient(0); |
| 3130 #endif | 3133 #endif |
| 3131 | |
| 3132 m_player.clear(); | 3134 m_player.clear(); |
| 3133 | |
| 3134 #if ENABLE(WEB_AUDIO) | |
| 3135 if (m_audioSourceNode) | |
| 3136 m_audioSourceNode->unlock(); | |
| 3137 #endif | |
| 3138 } | 3135 } |
| 3139 | 3136 |
| 3140 void HTMLMediaElement::clearMediaPlayer(int flags) | 3137 void HTMLMediaElement::clearMediaPlayer(int flags) |
| 3141 { | 3138 { |
| 3142 forgetResourceSpecificTracks(); | 3139 forgetResourceSpecificTracks(); |
| 3143 | 3140 |
| 3144 closeMediaSource(); | 3141 closeMediaSource(); |
| 3145 | 3142 |
| 3146 m_delayingLoadForPreloadNone = false; | 3143 m_delayingLoadForPreloadNone = false; |
| 3147 | 3144 |
| 3148 clearMediaPlayerAndAudioSourceProviderClient(); | 3145 #if ENABLE(WEB_AUDIO) |
| 3146 if (m_audioSourceNode) | |
| 3147 m_audioSourceNode->lock(); | |
| 3148 #endif | |
| 3149 | |
| 3150 clearMediaPlayerAndAudioSourceProviderClientWithoutLocking(); | |
| 3151 | |
| 3152 #if ENABLE(WEB_AUDIO) | |
| 3153 if (m_audioSourceNode) | |
| 3154 m_audioSourceNode->unlock(); | |
| 3155 #endif | |
| 3149 | 3156 |
| 3150 stopPeriodicTimers(); | 3157 stopPeriodicTimers(); |
| 3151 m_loadTimer.stop(); | 3158 m_loadTimer.stop(); |
| 3152 | 3159 |
| 3153 m_pendingActionFlags &= ~flags; | 3160 m_pendingActionFlags &= ~flags; |
| 3154 m_loadState = WaitingForSource; | 3161 m_loadState = WaitingForSource; |
| 3155 | 3162 |
| 3156 if (m_textTracks) | 3163 if (m_textTracks) |
| 3157 configureTextTrackDisplay(AssumeNoVisibleChange); | 3164 configureTextTrackDisplay(AssumeNoVisibleChange); |
| 3158 } | 3165 } |
| (...skipping 490 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3649 HTMLElement::defaultEventHandler(event); | 3656 HTMLElement::defaultEventHandler(event); |
| 3650 } | 3657 } |
| 3651 | 3658 |
| 3652 void HTMLMediaElement::trace(Visitor* visitor) | 3659 void HTMLMediaElement::trace(Visitor* visitor) |
| 3653 { | 3660 { |
| 3654 visitor->trace(m_error); | 3661 visitor->trace(m_error); |
| 3655 visitor->trace(m_currentSourceNode); | 3662 visitor->trace(m_currentSourceNode); |
| 3656 visitor->trace(m_nextChildNodeToConsider); | 3663 visitor->trace(m_nextChildNodeToConsider); |
| 3657 visitor->trace(m_textTracks); | 3664 visitor->trace(m_textTracks); |
| 3658 visitor->trace(m_textTracksWhenResourceSelectionBegan); | 3665 visitor->trace(m_textTracksWhenResourceSelectionBegan); |
| 3666 visitor->registerWeakMembers<HTMLMediaElement, &HTMLMediaElement::clearWeakM embers>(this); | |
| 3659 WillBeHeapSupplementable<HTMLMediaElement>::trace(visitor); | 3667 WillBeHeapSupplementable<HTMLMediaElement>::trace(visitor); |
| 3660 HTMLElement::trace(visitor); | 3668 HTMLElement::trace(visitor); |
| 3661 } | 3669 } |
| 3662 | 3670 |
| 3671 void HTMLMediaElement::clearWeakMembers(Visitor* visitor) | |
| 3672 { | |
| 3673 if (!visitor->isAlive(m_audioSourceNode) && audioSourceProvider()) | |
| 3674 audioSourceProvider()->setClient(0); | |
|
haraken
2014/06/11 01:19:49
This looks OK but it would be better to just call
zerny-chromium
2014/06/11 06:26:57
I don't think so, since m_audioSourceNode is dying
| |
| 3663 } | 3675 } |
| 3676 | |
| 3677 } | |
| OLD | NEW |