blob: 7b868fd9aee88e46c143b17e88e2ddc28e78bff4 [file] [log] [blame]
/*
* Copyright (C) 2003 Lars Knoll (knoll@kde.org)
* Copyright (C) 2004, 2005, 2006, 2008, 2009, 2010 Apple Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef CSSParserString_h
#define CSSParserString_h
#include "wtf/Allocator.h"
#include "wtf/text/AtomicString.h"
#include "wtf/text/WTFString.h"
namespace blink {
struct CSSParserString {
STACK_ALLOCATED();
void init(const LChar* characters, unsigned length)
{
m_data.characters8 = characters;
m_length = length;
m_is8Bit = true;
}
void init(const UChar* characters, unsigned length)
{
m_data.characters16 = characters;
m_length = length;
m_is8Bit = false;
}
void initRaw(const void* charactersRaw, unsigned length, bool is8Bit)
{
m_data.charactersRaw = charactersRaw;
m_length = length;
m_is8Bit = is8Bit;
}
void init(const String& string)
{
m_length = string.length();
if (string.isNull()) {
m_data.characters8 = 0;
m_is8Bit = true;
return;
}
if (string.is8Bit()) {
m_data.characters8 = const_cast<LChar*>(string.characters8());
m_is8Bit = true;
} else {
m_data.characters16 = const_cast<UChar*>(string.characters16());
m_is8Bit = false;
}
}
bool is8Bit() const { return m_is8Bit; }
const LChar* characters8() const { ASSERT(is8Bit()); return m_data.characters8; }
const UChar* characters16() const { ASSERT(!is8Bit()); return m_data.characters16; }
unsigned length() const { return m_length; }
UChar operator[](unsigned i) const
{
ASSERT_WITH_SECURITY_IMPLICATION(i < m_length);
if (is8Bit())
return m_data.characters8[i];
return m_data.characters16[i];
}
template<unsigned matchLength>
bool equalIgnoringASCIICase(const char (&match)[matchLength]) const
{
if (matchLength - 1 != length())
return false;
return is8Bit() ? WTF::equalIgnoringASCIICase(characters8(), match, length()) : WTF::equalIgnoringASCIICase(characters16(), match, length());
}
operator String() const { return is8Bit() ? String(m_data.characters8, m_length) : StringImpl::create8BitIfPossible(m_data.characters16, m_length); }
operator AtomicString() const { return is8Bit() ? AtomicString(m_data.characters8, m_length) : AtomicString(m_data.characters16, m_length); }
union {
const LChar* characters8;
const UChar* characters16;
const void* charactersRaw;
} m_data;
unsigned m_length;
bool m_is8Bit;
};
} // namespace blink
#endif