LibHTML: Ignore completed image loads for already-destroyed <img>'s

Capture a weak pointer to the element and pass that to the load finish
callback in HTMLImageElement::load_image(). This allows us to ignore
completed loads if the <img> element is no longer around.
This commit is contained in:
Andreas Kling 2019-10-19 09:43:05 +02:00
parent 877ff6bc13
commit a5f3f332ed
Notes: sideshowbarker 2024-07-19 11:38:38 +09:00

View file

@ -23,7 +23,11 @@ void HTMLImageElement::parse_attribute(const String& name, const String& value)
void HTMLImageElement::load_image(const String& src)
{
URL src_url = document().complete_url(src);
ResourceLoader::the().load(src_url, [this](auto data) {
ResourceLoader::the().load(src_url, [this, weak_element = make_weak_ptr()](auto data) {
if (!weak_element) {
dbg() << "HTMLImageElement: Load completed after element destroyed.";
return;
}
if (data.is_null()) {
dbg() << "HTMLImageElement: Failed to load " << this->src();
return;