Index: Source/modules/mediastream/MediaStreamTrack.cpp |
diff --git a/Source/modules/mediastream/MediaStreamTrack.cpp b/Source/modules/mediastream/MediaStreamTrack.cpp |
index d12d45b5d23cdcfef64c59dae0c54415fb7de17c..38a01dcaf433b04a370f3fe01d3421d576c6c455 100644 |
--- a/Source/modules/mediastream/MediaStreamTrack.cpp |
+++ b/Source/modules/mediastream/MediaStreamTrack.cpp |
@@ -59,7 +59,6 @@ MediaStreamTrack::MediaStreamTrack(ExecutionContext* context, MediaStreamCompone |
MediaStreamTrack::~MediaStreamTrack() |
{ |
- m_component->source()->removeObserver(this); |
} |
String MediaStreamTrack::kind() const |
@@ -147,9 +146,9 @@ void MediaStreamTrack::stopTrack(ExceptionState& exceptionState) |
MediaStreamTrack* MediaStreamTrack::clone(ExecutionContext* context) |
{ |
- RefPtr<MediaStreamComponent> clonedComponent = MediaStreamComponent::create(component()->source()); |
- MediaStreamTrack* clonedTrack = MediaStreamTrack::create(context, clonedComponent.get()); |
- MediaStreamCenter::instance().didCreateMediaStreamTrack(clonedComponent.get()); |
+ MediaStreamComponent* clonedComponent = MediaStreamComponent::create(component()->source()); |
+ MediaStreamTrack* clonedTrack = MediaStreamTrack::create(context, clonedComponent); |
+ MediaStreamCenter::instance().didCreateMediaStreamTrack(clonedComponent); |
return clonedTrack; |
} |
@@ -230,7 +229,9 @@ ExecutionContext* MediaStreamTrack::executionContext() const |
void MediaStreamTrack::trace(Visitor* visitor) |
{ |
visitor->trace(m_registeredMediaStreams); |
+ visitor->trace(m_component); |
EventTargetWithInlineData::trace(visitor); |
+ MediaStreamSource::Observer::trace(visitor); |
} |
} // namespace blink |