mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 01:17:34 +00:00
LibWeb: Add the missing ProgressEvent IDL constructor
This commit is contained in:
parent
1e8ba0d9d3
commit
4d71f22673
4 changed files with 32 additions and 9 deletions
|
@ -2468,6 +2468,7 @@ using namespace Web::DOM;
|
||||||
using namespace Web::Geometry;
|
using namespace Web::Geometry;
|
||||||
using namespace Web::HTML;
|
using namespace Web::HTML;
|
||||||
using namespace Web::RequestIdleCallback;
|
using namespace Web::RequestIdleCallback;
|
||||||
|
using namespace Web::XHR;
|
||||||
|
|
||||||
namespace Web::Bindings {
|
namespace Web::Bindings {
|
||||||
|
|
||||||
|
|
|
@ -13,13 +13,23 @@ namespace Web::XHR {
|
||||||
// FIXME: All the "u32"s should be "u64"s, however LibJS doesn't currently support constructing values with u64,
|
// FIXME: All the "u32"s should be "u64"s, however LibJS doesn't currently support constructing values with u64,
|
||||||
// and the IDL parser doesn't properly parse "unsigned long long".
|
// and the IDL parser doesn't properly parse "unsigned long long".
|
||||||
|
|
||||||
|
struct ProgressEventInit : public DOM::EventInit {
|
||||||
|
bool length_computable { false };
|
||||||
|
u32 loaded { 0 };
|
||||||
|
u32 total { 0 };
|
||||||
|
};
|
||||||
|
|
||||||
class ProgressEvent : public DOM::Event {
|
class ProgressEvent : public DOM::Event {
|
||||||
public:
|
public:
|
||||||
using WrapperType = Bindings::ProgressEventWrapper;
|
using WrapperType = Bindings::ProgressEventWrapper;
|
||||||
|
|
||||||
static NonnullRefPtr<ProgressEvent> create(const FlyString& event_name, u32 transmitted, u32 length)
|
static NonnullRefPtr<ProgressEvent> create(FlyString const& event_name, ProgressEventInit const& event_init)
|
||||||
{
|
{
|
||||||
return adopt_ref(*new ProgressEvent(event_name, transmitted, length));
|
return adopt_ref(*new ProgressEvent(event_name, event_init));
|
||||||
|
}
|
||||||
|
static NonnullRefPtr<ProgressEvent> create_with_global_object(Bindings::WindowObject&, FlyString const& event_name, ProgressEventInit const& event_init)
|
||||||
|
{
|
||||||
|
return ProgressEvent::create(event_name, event_init);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~ProgressEvent() override { }
|
virtual ~ProgressEvent() override { }
|
||||||
|
@ -29,11 +39,11 @@ public:
|
||||||
u32 total() const { return m_total; }
|
u32 total() const { return m_total; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
ProgressEvent(const FlyString& event_name, u32 transmitted, u32 length)
|
ProgressEvent(FlyString const& event_name, ProgressEventInit const& event_init)
|
||||||
: Event(event_name)
|
: Event(event_name, event_init)
|
||||||
, m_length_computable(length != 0)
|
, m_length_computable(event_init.length_computable)
|
||||||
, m_loaded(transmitted)
|
, m_loaded(event_init.loaded)
|
||||||
, m_total(length)
|
, m_total(event_init.total)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,15 @@
|
||||||
|
#import <DOM/Event.idl>
|
||||||
|
|
||||||
interface ProgressEvent : Event {
|
interface ProgressEvent : Event {
|
||||||
|
constructor(DOMString type, optional ProgressEventInit eventInitDict = {});
|
||||||
|
|
||||||
readonly attribute boolean lengthComputable;
|
readonly attribute boolean lengthComputable;
|
||||||
readonly attribute unsigned long loaded;
|
readonly attribute unsigned long loaded;
|
||||||
readonly attribute unsigned long total;
|
readonly attribute unsigned long total;
|
||||||
|
};
|
||||||
|
|
||||||
|
dictionary ProgressEventInit : EventInit {
|
||||||
|
boolean lengthComputable = false;
|
||||||
|
unsigned long loaded = 0;
|
||||||
|
unsigned long total = 0;
|
||||||
};
|
};
|
||||||
|
|
|
@ -45,7 +45,11 @@ void XMLHttpRequest::set_ready_state(ReadyState ready_state)
|
||||||
|
|
||||||
void XMLHttpRequest::fire_progress_event(const String& event_name, u64 transmitted, u64 length)
|
void XMLHttpRequest::fire_progress_event(const String& event_name, u64 transmitted, u64 length)
|
||||||
{
|
{
|
||||||
dispatch_event(ProgressEvent::create(event_name, transmitted, length));
|
ProgressEventInit event_init {};
|
||||||
|
event_init.length_computable = true;
|
||||||
|
event_init.loaded = transmitted;
|
||||||
|
event_init.total = length;
|
||||||
|
dispatch_event(ProgressEvent::create(event_name, event_init));
|
||||||
}
|
}
|
||||||
|
|
||||||
String XMLHttpRequest::response_text() const
|
String XMLHttpRequest::response_text() const
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue