
This commit introduces a WEB_SET_PROTOTYPE_FOR_INTERFACE macro that caches the interface name in a local static FlyString. This means that we only pay for FlyString-from-literal lookup once per browser lifetime instead of every time the interface is instantiated.
62 lines
1.6 KiB
C++
62 lines
1.6 KiB
C++
/*
|
|
* Copyright (c) 2022, Andrew Kaster <akaster@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibJS/Runtime/Realm.h>
|
|
#include <LibWeb/Bindings/Intrinsics.h>
|
|
#include <LibWeb/Bindings/PlatformObject.h>
|
|
#include <LibWeb/FileAPI/FileList.h>
|
|
|
|
namespace Web::FileAPI {
|
|
|
|
JS_DEFINE_ALLOCATOR(FileList);
|
|
|
|
JS::NonnullGCPtr<FileList> FileList::create(JS::Realm& realm, Vector<JS::NonnullGCPtr<File>>&& files)
|
|
{
|
|
return realm.heap().allocate<FileList>(realm, realm, move(files));
|
|
}
|
|
|
|
FileList::FileList(JS::Realm& realm, Vector<JS::NonnullGCPtr<File>>&& files)
|
|
: Bindings::PlatformObject(realm)
|
|
, m_files(move(files))
|
|
{
|
|
m_legacy_platform_object_flags = LegacyPlatformObjectFlags { .supports_indexed_properties = 1 };
|
|
}
|
|
|
|
FileList::~FileList() = default;
|
|
|
|
void FileList::initialize(JS::Realm& realm)
|
|
{
|
|
Base::initialize(realm);
|
|
WEB_SET_PROTOTYPE_FOR_INTERFACE(FileList);
|
|
}
|
|
|
|
// https://w3c.github.io/FileAPI/#dfn-item
|
|
bool FileList::is_supported_property_index(u32 index) const
|
|
{
|
|
// Supported property indices are the numbers in the range zero to one less than the number of File objects represented by the FileList object.
|
|
// If there are no such File objects, then there are no supported property indices.
|
|
if (m_files.is_empty())
|
|
return false;
|
|
|
|
return index < m_files.size();
|
|
}
|
|
|
|
WebIDL::ExceptionOr<JS::Value> FileList::item_value(size_t index) const
|
|
{
|
|
if (index >= m_files.size())
|
|
return JS::js_undefined();
|
|
|
|
return m_files[index].ptr();
|
|
}
|
|
|
|
void FileList::visit_edges(Cell::Visitor& visitor)
|
|
{
|
|
Base::visit_edges(visitor);
|
|
for (auto file : m_files)
|
|
visitor.visit(file);
|
|
}
|
|
|
|
}
|