/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "mozilla/dom/HTMLTrackElement.h" #include "mozilla/dom/TextTrackCue.h" #include "nsComponentManagerUtils.h" #include "mozilla/ClearOnShutdown.h" namespace mozilla { namespace dom { NS_IMPL_CYCLE_COLLECTION_INHERITED_4(TextTrackCue, nsDOMEventTargetHelper, mDocument, mTrack, mTrackElement, mDisplayState) NS_IMPL_ADDREF_INHERITED(TextTrackCue, nsDOMEventTargetHelper) NS_IMPL_RELEASE_INHERITED(TextTrackCue, nsDOMEventTargetHelper) NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION_INHERITED(TextTrackCue) NS_INTERFACE_MAP_END_INHERITING(nsDOMEventTargetHelper) StaticRefPtr TextTrackCue::sParserWrapper; // Set cue setting defaults based on step 19 & seq. // in http://dev.w3.org/html5/webvtt/#parsing void TextTrackCue::SetDefaultCueSettings() { mPosition = 50; mPositionAlign = AlignSetting::Middle; mSize = 100; mPauseOnExit = false; mSnapToLines = true; mLineIsAutoKeyword = true; mAlign = AlignSetting::Middle; mLineAlign = AlignSetting::Start; mVertical = DirectionSetting::_empty; } TextTrackCue::TextTrackCue(nsISupports* aGlobal, double aStartTime, double aEndTime, const nsAString& aText, ErrorResult& aRv) : mText(aText) , mStartTime(aStartTime) , mEndTime(aEndTime) , mReset(false) { SetDefaultCueSettings(); MOZ_ASSERT(aGlobal); SetIsDOMBinding(); if (NS_FAILED(StashDocument(aGlobal))) { aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR); } } TextTrackCue::TextTrackCue(nsISupports* aGlobal, double aStartTime, double aEndTime, const nsAString& aText, HTMLTrackElement* aTrackElement, ErrorResult& aRv) : mText(aText) , mStartTime(aStartTime) , mEndTime(aEndTime) , mTrackElement(aTrackElement) , mReset(false) { SetDefaultCueSettings(); MOZ_ASSERT(aGlobal); SetIsDOMBinding(); if (NS_FAILED(StashDocument(aGlobal))) { aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR); } } /** Save a reference to our creating document so we don't have to * keep getting it from our window. */ nsresult TextTrackCue::StashDocument(nsISupports* aGlobal) { nsCOMPtr window(do_QueryInterface(aGlobal)); if (!window) { return NS_ERROR_NO_INTERFACE; } mDocument = window->GetDoc(); if (!mDocument) { return NS_ERROR_NOT_AVAILABLE; } return NS_OK; } already_AddRefed TextTrackCue::GetCueAsHTML() { // mDocument may be null during cycle collector shutdown. // See bug 941701. if (!mDocument) { return nullptr; } if (!sParserWrapper) { nsresult rv; nsCOMPtr parserWrapper = do_CreateInstance(NS_WEBVTTPARSERWRAPPER_CONTRACTID, &rv); if (NS_FAILED(rv)) { return mDocument->CreateDocumentFragment(); } sParserWrapper = parserWrapper; ClearOnShutdown(&sParserWrapper); } nsPIDOMWindow* window = mDocument->GetWindow(); if (!window) { return mDocument->CreateDocumentFragment(); } nsCOMPtr div; sParserWrapper->ConvertCueToDOMTree(window, this, getter_AddRefs(div)); if (!div) { return mDocument->CreateDocumentFragment(); } nsRefPtr docFrag = mDocument->CreateDocumentFragment(); nsCOMPtr throwAway; docFrag->AppendChild(div, getter_AddRefs(throwAway)); return docFrag.forget(); } void TextTrackCue::SetTrackElement(HTMLTrackElement* aTrackElement) { mTrackElement = aTrackElement; } JSObject* TextTrackCue::WrapObject(JSContext* aCx, JS::Handle aScope) { return VTTCueBinding::Wrap(aCx, aScope, this); } void TextTrackCue::CueChanged() { if (mTrack) { mTrack->CueChanged(*this); } } } // namespace dom } // namespace mozilla