Chromium Code Reviews

Unified Diff: Source/core/html/track/vtt/VTTToken.h

Issue 81113003: Turn VTTToken into an immutable object (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
« no previous file with comments | « Source/core/html/track/vtt/VTTParser.cpp ('k') | Source/core/html/track/vtt/VTTTokenizer.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/core/html/track/vtt/VTTToken.h
diff --git a/Source/core/html/track/vtt/VTTToken.h b/Source/core/html/track/vtt/VTTToken.h
index f324aa3f17c448cfaa472a66a194f48c0b90a072..c95134f08c4ce6fc56201a49d66af3f63d5424e8 100644
--- a/Source/core/html/track/vtt/VTTToken.h
+++ b/Source/core/html/track/vtt/VTTToken.h
@@ -31,8 +31,6 @@
#ifndef VTTToken_h
#define VTTToken_h
-#include "wtf/text/StringBuilder.h"
-
namespace WebCore {
class VTTTokenTypes {
@@ -47,77 +45,46 @@ public:
};
class VTTToken {
- WTF_MAKE_NONCOPYABLE(VTTToken);
- WTF_MAKE_FAST_ALLOCATED;
public:
typedef VTTTokenTypes Type;
- VTTToken() { clear(); }
-
- Type::Type type() const { return m_type; }
- void setType(Type::Type type) { m_type = type; }
+ VTTToken() : m_type(Type::Uninitialized) { }
- StringBuilder& name()
+ static VTTToken StringToken(const String& characterData)
{
- return m_data;
+ return VTTToken(Type::Character, characterData);
}
-
- StringBuilder& characters()
+ static VTTToken StartTag(const String& tagName, const AtomicString& classes = emptyAtom, const AtomicString& annotation = emptyAtom)
{
- return m_data;
+ VTTToken token(Type::StartTag, tagName);
+ token.m_classes = classes;
+ token.m_annotation = annotation;
+ return token;
}
-
- void appendToData(char character)
+ static VTTToken EndTag(const String& tagName)
{
- m_data.append(character);
+ return VTTToken(Type::EndTag, tagName);
}
-
- void appendToData(UChar character)
+ static VTTToken TimestampTag(const String& timestampData)
{
- m_data.append(character);
+ return VTTToken(Type::TimestampTag, timestampData);
}
- void appendToData(const StringBuilder& characters)
- {
- m_data.append(characters);
- }
-
- void addNewClass(const StringBuilder& s)
- {
- if (!m_classes.isEmpty())
- m_classes.append(' ');
- m_classes.append(s);
- }
-
- StringBuilder& classes()
- {
- return m_classes;
- }
-
- void addNewAnnotation(const StringBuilder& s)
- {
- m_annotation.clear();
- m_annotation.append(s);
- }
-
- StringBuilder& annotation()
- {
- return m_annotation;
- }
-
- void clear()
- {
- m_type = Type::Uninitialized;
- m_data.clear();
- m_annotation.clear();
- m_classes.clear();
- }
+ Type::Type type() const { return m_type; }
+ const String& name() const { return m_data; }
+ const String& characters() const { return m_data; }
+ const AtomicString& classes() const { return m_classes; }
+ const AtomicString& annotation() const { return m_annotation; }
private:
+ VTTToken(Type::Type type, const String& data)
+ : m_type(type)
+ , m_data(data) { }
+
Type::Type m_type;
- StringBuilder m_data;
- StringBuilder m_annotation;
- StringBuilder m_classes;
+ String m_data;
+ AtomicString m_annotation;
+ AtomicString m_classes;
};
}
« no previous file with comments | « Source/core/html/track/vtt/VTTParser.cpp ('k') | Source/core/html/track/vtt/VTTTokenizer.h » ('j') | no next file with comments »

Powered by Google App Engine