#define TextTrackLoader_h
#include "core/fetch/RawResource.h"
-#include "core/fetch/ResourcePtr.h"
-#include "core/html/track/WebVTTParser.h"
+#include "core/fetch/ResourceOwner.h"
+#include "core/html/track/vtt/VTTParser.h"
#include "platform/Timer.h"
#include "wtf/OwnPtr.h"
class Document;
class TextTrackLoader;
-class TextTrackLoaderClient {
+class TextTrackLoaderClient : public ResourceOwner<RawResource> {
public:
virtual ~TextTrackLoaderClient() { }
virtual void newRegionsAvailable(TextTrackLoader*) = 0;
};
-class TextTrackLoader : public RawResourceClient, private WebVTTParserClient {
+class TextTrackLoader FINAL : public ResourceOwner<RawResource>, private VTTParserClient {
WTF_MAKE_NONCOPYABLE(TextTrackLoader);
WTF_MAKE_FAST_ALLOCATED;
public:
}
virtual ~TextTrackLoader();
- bool load(const KURL&, const String& crossOriginMode);
+ bool load(const KURL&, const AtomicString& crossOriginMode);
void cancelLoad();
enum State { Idle, Loading, Finished, Failed };
State loadState() { return m_state; }
- void getNewCues(Vector<RefPtr<TextTrackCue> >& outputCues);
+ void getNewCues(Vector<RefPtr<VTTCue> >& outputCues);
void getNewRegions(Vector<RefPtr<VTTRegion> >& outputRegions);
private:
virtual void dataReceived(Resource*, const char* data, int length) OVERRIDE;
virtual void notifyFinished(Resource*) OVERRIDE;
- // WebVTTParserClient
+ // VTTParserClient
virtual void newCuesParsed() OVERRIDE;
virtual void newRegionsParsed() OVERRIDE;
virtual void fileFailedToParse() OVERRIDE;
TextTrackLoader(TextTrackLoaderClient&, Document&);
void cueLoadTimerFired(Timer<TextTrackLoader>*);
- void corsPolicyPreventedLoad();
+ void corsPolicyPreventedLoad(SecurityOrigin*, const KURL&);
TextTrackLoaderClient& m_client;
- OwnPtr<WebVTTParser> m_cueParser;
- ResourcePtr<RawResource> m_resource;
+ OwnPtr<VTTParser> m_cueParser;
// FIXME: Remove this pointer and get the Document from m_client.
Document& m_document;
Timer<TextTrackLoader> m_cueLoadTimer;
- String m_crossOriginMode;
State m_state;
bool m_newCuesAvailable;
};