mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 10:24:13 +00:00 
			
		
		
		
	 c5c1a8fcc7
			
		
	
	
		c5c1a8fcc7
		
	
	
	
	
		
			
			This removes some ambiguity about what the return value should be if the index is out of range. Previously, we would sometimes return a JS null, and other times a JS undefined. It will also let us fold together the checks for whether an index is a supported property index, followed by getting the value just afterwards.
		
			
				
	
	
		
			103 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Andrew Kaster <akaster@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibJS/Runtime/Realm.h>
 | |
| #include <LibWeb/Bindings/FileListPrototype.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));
 | |
| }
 | |
| 
 | |
| JS::NonnullGCPtr<FileList> FileList::create(JS::Realm& realm)
 | |
| {
 | |
|     return realm.heap().allocate<FileList>(realm, realm);
 | |
| }
 | |
| 
 | |
| 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(JS::Realm& realm)
 | |
|     : Bindings::PlatformObject(realm)
 | |
| {
 | |
|     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();
 | |
| }
 | |
| 
 | |
| Optional<JS::Value> FileList::item_value(size_t index) const
 | |
| {
 | |
|     if (index >= m_files.size())
 | |
|         return {};
 | |
| 
 | |
|     return m_files[index].ptr();
 | |
| }
 | |
| 
 | |
| void FileList::visit_edges(Cell::Visitor& visitor)
 | |
| {
 | |
|     Base::visit_edges(visitor);
 | |
|     visitor.visit(m_files);
 | |
| }
 | |
| 
 | |
| WebIDL::ExceptionOr<void> FileList::serialization_steps(HTML::SerializationRecord& serialized, bool for_storage, HTML::SerializationMemory& memory)
 | |
| {
 | |
|     auto& vm = this->vm();
 | |
| 
 | |
|     // 1. Set serialized.[[Files]] to an empty list.
 | |
|     // 2. For each file in value, append the sub-serialization of file to serialized.[[Files]].
 | |
|     HTML::serialize_primitive_type(serialized, m_files.size());
 | |
|     for (auto& file : m_files)
 | |
|         serialized.extend(TRY(HTML::structured_serialize_internal(vm, file, for_storage, memory)));
 | |
| 
 | |
|     return {};
 | |
| }
 | |
| 
 | |
| WebIDL::ExceptionOr<void> FileList::deserialization_steps(ReadonlySpan<u32> const& serialized, size_t& position, HTML::DeserializationMemory& memory)
 | |
| {
 | |
|     auto& vm = this->vm();
 | |
|     auto& realm = *vm.current_realm();
 | |
| 
 | |
|     // 1. For each file of serialized.[[Files]], add the sub-deserialization of file to value.
 | |
|     auto size = HTML::deserialize_primitive_type<size_t>(serialized, position);
 | |
|     for (size_t i = 0; i < size; ++i) {
 | |
|         auto deserialized_record = TRY(HTML::structured_deserialize_internal(vm, serialized, realm, memory, position));
 | |
|         if (deserialized_record.value.has_value() && is<File>(deserialized_record.value.value().as_object()))
 | |
|             m_files.append(dynamic_cast<File&>(deserialized_record.value.release_value().as_object()));
 | |
|         position = deserialized_record.position;
 | |
|     }
 | |
| 
 | |
|     return {};
 | |
| }
 | |
| 
 | |
| }
 |