#ifndef CSSValueList_h
#define CSSValueList_h
#include "core/css/CSSValue.h"
#include "wtf/PassRefPtr.h"
#include "wtf/Vector.h"
namespace WebCore {
class CSSParserValueList;
class CSSValueList : public CSSValue {
public:
static PassRefPtrWillBeRawPtr<CSSValueList> createCommaSeparated()
{
return adoptRefWillBeRefCountedGarbageCollected(new CSSValueList(CommaSeparator));
}
static PassRefPtrWillBeRawPtr<CSSValueList> createSpaceSeparated()
{
return adoptRefWillBeRefCountedGarbageCollected(new CSSValueList(SpaceSeparator));
}
static PassRefPtrWillBeRawPtr<CSSValueList> createSlashSeparated()
{
return adoptRefWillBeRefCountedGarbageCollected(new CSSValueList(SlashSeparator));
}
static PassRefPtrWillBeRawPtr<CSSValueList> createFromParserValueList(CSSParserValueList* list)
{
return adoptRefWillBeRefCountedGarbageCollected(new CSSValueList(list));
}
size_t length() const { return m_values.size(); }
CSSValue* item(size_t index) { return index < m_values.size() ? m_values[index].get() : 0; }
const CSSValue* item(size_t index) const { return index < m_values.size() ? m_values[index].get() : 0; }
CSSValue* itemWithoutBoundsCheck(size_t index) { return m_values[index].get(); }
void append(PassRefPtrWillBeRawPtr<CSSValue> value) { m_values.append(value); }
void prepend(PassRefPtrWillBeRawPtr<CSSValue> value) { m_values.prepend(value); }
bool removeAll(CSSValue*);
bool hasValue(CSSValue*) const;
PassRefPtrWillBeRawPtr<CSSValueList> copy();
String customCSSText(CSSTextFormattingFlags = QuoteCSSStringIfNeeded) const;
bool equals(const CSSValueList&) const;
bool equals(const CSSValue&) const;
bool hasFailedOrCanceledSubresources() const;
PassRefPtrWillBeRawPtr<CSSValueList> cloneForCSSOM() const;
void traceAfterDispatch(Visitor*);
protected:
CSSValueList(ClassType, ValueListSeparator);
CSSValueList(const CSSValueList& cloneFrom);
private:
explicit CSSValueList(ValueListSeparator);
explicit CSSValueList(CSSParserValueList*);
WillBeHeapVector<RefPtrWillBeMember<CSSValue>, 4> m_values;
};
DEFINE_CSS_VALUE_TYPE_CASTS(CSSValueList, isValueList());
class CSSValueListInspector {
STACK_ALLOCATED();
public:
CSSValueListInspector(CSSValue* value) : m_list((value && value->isValueList()) ? toCSSValueList(value) : 0) { }
CSSValue* item(size_t index) const { ASSERT_WITH_SECURITY_IMPLICATION(index < length()); return m_list->itemWithoutBoundsCheck(index); }
CSSValue* first() const { return item(0); }
CSSValue* second() const { return item(1); }
size_t length() const { return m_list ? m_list->length() : 0; }
private:
RawPtrWillBeMember<CSSValueList> m_list;
};
class CSSValueListIterator {
STACK_ALLOCATED();
public:
CSSValueListIterator(CSSValue* value) : m_inspector(value), m_position(0) { }
bool hasMore() const { return m_position < m_inspector.length(); }
CSSValue* value() const { return m_inspector.item(m_position); }
bool isPrimitiveValue() const { return value()->isPrimitiveValue(); }
void advance() { m_position++; ASSERT(m_position <= m_inspector.length());}
size_t index() const { return m_position; }
private:
CSSValueListInspector m_inspector;
size_t m_position;
};
}
#endif