#pragma once
#include "TextEncoding.h"
#include "URL.h"
#include "URLHash.h"
#include <wtf/HashFunctions.h>
#include <wtf/text/StringHash.h>
namespace WebCore {
class Document;
enum CSSParserMode {
HTMLStandardMode,
HTMLQuirksMode,
HTMLAttributeMode,
SVGAttributeMode,
CSSViewportRuleMode,
UASheetMode
};
inline bool isQuirksModeBehavior(CSSParserMode mode)
{
return mode == HTMLQuirksMode || mode == HTMLAttributeMode;
}
inline bool isUASheetBehavior(CSSParserMode mode)
{
return mode == UASheetMode;
}
inline bool isUnitLessValueParsingEnabledForMode(CSSParserMode mode)
{
return mode == HTMLAttributeMode || mode == SVGAttributeMode;
}
inline bool isCSSViewportParsingEnabledForMode(CSSParserMode mode)
{
return mode == CSSViewportRuleMode;
}
inline CSSParserMode strictToCSSParserMode(bool inStrictMode)
{
return inStrictMode ? HTMLStandardMode : HTMLQuirksMode;
}
inline bool isStrictParserMode(CSSParserMode cssParserMode)
{
return cssParserMode == UASheetMode || cssParserMode == HTMLStandardMode || cssParserMode == SVGAttributeMode;
}
struct CSSParserContext {
WTF_MAKE_FAST_ALLOCATED;
public:
CSSParserContext(CSSParserMode, const URL& baseURL = URL());
WEBCORE_EXPORT CSSParserContext(Document&, const URL& baseURL = URL(), const String& charset = emptyString());
URL baseURL;
String charset;
CSSParserMode mode { HTMLStandardMode };
bool isHTMLDocument { false };
bool cssGridLayoutEnabled { 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 deferredCSSParserEnabled { false };
URL completeURL(const String& url) const
{
if (url.isNull())
return URL();
if (charset.isEmpty())
return URL(baseURL, url);
return URL(baseURL, url, TextEncoding(charset));
}
};
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 = URLHash::hash(key.baseURL);
if (!key.charset.isEmpty())
hash ^= StringHash::hash(key.charset);
unsigned bits = key.isHTMLDocument << 0
& key.isHTMLDocument << 1
& key.cssGridLayoutEnabled << 2
#if ENABLE(TEXT_AUTOSIZING)
& key.textAutosizingEnabled << 3
#endif
& key.needsSiteSpecificQuirks << 4
& key.enforcesCSSMIMETypeInNoQuirksMode << 5
& key.useLegacyBackgroundSizeShorthandBehavior << 6
& key.springTimingFunctionEnabled << 7
& key.deferredCSSParserEnabled << 8
& key.mode << 9;
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) WebCore::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;
};
}