mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 01:19:45 +00:00 
			
		
		
		
	Properties marked with the [[Unimplemented]] attribute behave as normal but invoke the `VM::on_unimplemented_property_access callback` when they are accessed.
		
			
				
	
	
		
			90 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, Matthew Olsson <mattco@serenityos.org>
 | |
|  * Copyright (c) 2021, Linus Groh <linusg@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/ByteString.h>
 | |
| #include <AK/Format.h>
 | |
| #include <AK/Types.h>
 | |
| #include <AK/Vector.h>
 | |
| 
 | |
| namespace JS {
 | |
| 
 | |
| struct Attribute {
 | |
|     enum {
 | |
|         Writable = 1 << 0,
 | |
|         Enumerable = 1 << 1,
 | |
|         Configurable = 1 << 2,
 | |
|         // AD-HOC: This is used for reporting unimplemented IDL interfaces.
 | |
|         Unimplemented = 1 << 3,
 | |
|     };
 | |
| };
 | |
| 
 | |
| // 6.1.7.1 Property Attributes, https://tc39.es/ecma262/#sec-property-attributes
 | |
| class PropertyAttributes {
 | |
| public:
 | |
|     PropertyAttributes(u8 bits = 0)
 | |
|         : m_bits(bits)
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     [[nodiscard]] bool is_writable() const { return m_bits & Attribute::Writable; }
 | |
|     [[nodiscard]] bool is_enumerable() const { return m_bits & Attribute::Enumerable; }
 | |
|     [[nodiscard]] bool is_configurable() const { return m_bits & Attribute::Configurable; }
 | |
|     [[nodiscard]] bool is_unimplemented() const { return m_bits & Attribute::Unimplemented; }
 | |
| 
 | |
|     void set_writable(bool writable = true)
 | |
|     {
 | |
|         if (writable)
 | |
|             m_bits |= Attribute::Writable;
 | |
|         else
 | |
|             m_bits &= ~Attribute::Writable;
 | |
|     }
 | |
| 
 | |
|     void set_enumerable(bool enumerable = true)
 | |
|     {
 | |
|         if (enumerable)
 | |
|             m_bits |= Attribute::Enumerable;
 | |
|         else
 | |
|             m_bits &= ~Attribute::Enumerable;
 | |
|     }
 | |
| 
 | |
|     void set_configurable(bool configurable = true)
 | |
|     {
 | |
|         if (configurable)
 | |
|             m_bits |= Attribute::Configurable;
 | |
|         else
 | |
|             m_bits &= ~Attribute::Configurable;
 | |
|     }
 | |
| 
 | |
|     bool operator==(PropertyAttributes const& other) const { return m_bits == other.m_bits; }
 | |
| 
 | |
|     [[nodiscard]] u8 bits() const { return m_bits; }
 | |
| 
 | |
| private:
 | |
|     u8 m_bits;
 | |
| };
 | |
| 
 | |
| PropertyAttributes const default_attributes = Attribute::Configurable | Attribute::Writable | Attribute::Enumerable;
 | |
| 
 | |
| }
 | |
| 
 | |
| namespace AK {
 | |
| 
 | |
| template<>
 | |
| struct Formatter<JS::PropertyAttributes> : Formatter<StringView> {
 | |
|     ErrorOr<void> format(FormatBuilder& builder, JS::PropertyAttributes const& property_attributes)
 | |
|     {
 | |
|         Vector<ByteString> parts;
 | |
|         parts.append(ByteString::formatted("[[Writable]]: {}", property_attributes.is_writable()));
 | |
|         parts.append(ByteString::formatted("[[Enumerable]]: {}", property_attributes.is_enumerable()));
 | |
|         parts.append(ByteString::formatted("[[Configurable]]: {}", property_attributes.is_configurable()));
 | |
|         return Formatter<StringView>::format(builder, ByteString::formatted("PropertyAttributes {{ {} }}", ByteString::join(", "sv, parts)));
 | |
|     }
 | |
| };
 | |
| 
 | |
| }
 |