CSSParserContext.h [plain text]
#pragma once
#include "CSSParserMode.h"
#include "TextEncoding.h"
#include <wtf/HashFunctions.h>
#include <wtf/URL.h>
#include <wtf/URLHash.h>
#include <wtf/text/StringHash.h>
namespace WebCore {
class Document;
struct CSSParserContext {
WTF_MAKE_FAST_ALLOCATED;
public:
CSSParserContext(CSSParserMode, const URL& baseURL = URL());
WEBCORE_EXPORT CSSParserContext(const Document&, const URL& baseURL = URL(), const String& charset = emptyString());
URL baseURL;
String charset;
CSSParserMode mode { HTMLStandardMode };
bool isHTMLDocument { false };
#if ENABLE(TEXT_AUTOSIZING)
bool textAutosizingEnabled { false };
#endif
bool needsSiteSpecificQuirks { false };
bool enforcesCSSMIMETypeInNoQuirksMode { true };
bool useLegacyBackgroundSizeShorthandBehavior { false };
bool springTimingFunctionEnabled { false };
bool constantPropertiesEnabled { false };
bool colorFilterEnabled { false };
#if ENABLE(ATTACHMENT_ELEMENT)
bool attachmentEnabled { false };
#endif
bool deferredCSSParserEnabled { false };
bool hasDocumentSecurityOrigin { false };
bool useSystemAppearance { false };
URL completeURL(const String& url) const
{
if (url.isNull())
return URL();
if (charset.isEmpty())
return URL(baseURL, url);
TextEncoding encoding(charset);
auto& encodingForURLParsing = encoding.encodingForFormSubmissionOrURLParsing();
return URL(baseURL, url, encodingForURLParsing == UTF8Encoding() ? nullptr : &encodingForURLParsing);
}
bool isContentOpaque { false };
};
bool operator==(const CSSParserContext&, const CSSParserContext&);
inline bool operator!=(const CSSParserContext& a, const CSSParserContext& b) { return !(a == b); }
WEBCORE_EXPORT const CSSParserContext& strictCSSParserContext();
struct CSSParserContextHash {
static unsigned hash(const CSSParserContext& key)
{
auto hash = WTF::URLHash::hash(key.baseURL);
if (!key.charset.isEmpty())
hash ^= StringHash::hash(key.charset);
unsigned bits = key.isHTMLDocument << 0
#if ENABLE(TEXT_AUTOSIZING)
& key.textAutosizingEnabled << 1
#endif
& key.needsSiteSpecificQuirks << 2
& key.enforcesCSSMIMETypeInNoQuirksMode << 3
& key.useLegacyBackgroundSizeShorthandBehavior << 4
& key.springTimingFunctionEnabled << 5
& key.constantPropertiesEnabled << 6
& key.colorFilterEnabled << 7
& key.deferredCSSParserEnabled << 8
& key.hasDocumentSecurityOrigin << 9
& key.useSystemAppearance << 10
#if ENABLE(ATTACHMENT_ELEMENT)
& key.attachmentEnabled << 11
#endif
& key.mode << 12; hash ^= WTF::intHash(bits);
return hash;
}
static bool equal(const CSSParserContext& a, const CSSParserContext& b)
{
return a == b;
}
static const bool safeToCompareToEmptyOrDeleted = false;
};
}
namespace WTF {
template<> struct HashTraits<WebCore::CSSParserContext> : GenericHashTraits<WebCore::CSSParserContext> {
static void constructDeletedValue(WebCore::CSSParserContext& slot) { new (NotNull, &slot.baseURL) URL(WTF::HashTableDeletedValue); }
static bool isDeletedValue(const WebCore::CSSParserContext& value) { return value.baseURL.isHashTableDeletedValue(); }
static WebCore::CSSParserContext emptyValue() { return WebCore::CSSParserContext(WebCore::HTMLStandardMode); }
};
template<> struct DefaultHash<WebCore::CSSParserContext> {
typedef WebCore::CSSParserContextHash Hash;
};
}