#include "CSSFontFace.h"
#include "CSSPropertyNames.h"
-#include "JSDOMPromise.h"
+#include "DOMPromiseProxy.h"
+#include <wtf/Variant.h>
#include <wtf/WeakPtr.h>
+namespace JSC {
+class ArrayBuffer;
+class ArrayBufferView;
+}
+
namespace WebCore {
class FontFace final : public RefCounted<FontFace>, private CSSFontFace::Client {
String variant;
String featureSettings;
};
- static RefPtr<FontFace> create(JSC::ExecState&, Document&, const String& family, JSC::JSValue source, const Descriptors&, ExceptionCode&);
+
+ using Source = Variant<String, RefPtr<JSC::ArrayBuffer>, RefPtr<JSC::ArrayBufferView>>;
+ static ExceptionOr<Ref<FontFace>> create(Document&, const String& family, Source&&, const Descriptors&);
static Ref<FontFace> create(CSSFontFace&);
virtual ~FontFace();
- void setFamily(const String&, ExceptionCode&);
- void setStyle(const String&, ExceptionCode&);
- void setWeight(const String&, ExceptionCode&);
- void setStretch(const String&, ExceptionCode&);
- void setUnicodeRange(const String&, ExceptionCode&);
- void setVariant(const String&, ExceptionCode&);
- void setFeatureSettings(const String&, ExceptionCode&);
+ ExceptionOr<void> setFamily(const String&);
+ ExceptionOr<void> setStyle(const String&);
+ ExceptionOr<void> setWeight(const String&);
+ ExceptionOr<void> setStretch(const String&);
+ ExceptionOr<void> setUnicodeRange(const String&);
+ ExceptionOr<void> setVariant(const String&);
+ ExceptionOr<void> setFeatureSettings(const String&);
String family() const;
String style() const;
enum class LoadStatus { Unloaded, Loading, Loaded, Error };
LoadStatus status() const;
- typedef DOMPromise<FontFace&, ExceptionCode> Promise;
- void registerLoaded(Promise&&);
+ using LoadedPromise = DOMPromiseProxyWithResolveCallback<IDLInterface<FontFace>>;
+ LoadedPromise& loaded() { return m_loadedPromise; }
+ LoadedPromise& load();
- void load();
+ void adopt(CSSFontFace&);
CSSFontFace& backing() { return m_backing; }
void fontStateChanged(CSSFontFace&, CSSFontFace::Status oldState, CSSFontFace::Status newState) final;
- WeakPtr<FontFace> createWeakPtr() const;
+ WeakPtr<FontFace> createWeakPtr();
void ref() final { RefCounted::ref(); }
void deref() final { RefCounted::deref(); }
explicit FontFace(CSSFontSelector&);
explicit FontFace(CSSFontFace&);
+ // Callback for LoadedPromise.
+ FontFace& loadedPromiseResolve();
+
WeakPtrFactory<FontFace> m_weakPtrFactory;
Ref<CSSFontFace> m_backing;
- Optional<Promise> m_promise;
+ LoadedPromise m_loadedPromise;
};
}