/* * Copyright (c) 2022-2023, Linus Groh * Copyright (c) 2020-2025, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace JS { class Intrinsics final : public Cell { GC_CELL(Intrinsics, Cell); GC_DECLARE_ALLOCATOR(Intrinsics); public: static GC::Ref create(Realm&); GC::Ref empty_object_shape() { return *m_empty_object_shape; } GC::Ref new_object_shape() { return *m_new_object_shape; } [[nodiscard]] GC::Ref iterator_result_object_shape() { return *m_iterator_result_object_shape; } [[nodiscard]] u32 iterator_result_object_value_offset() { return m_iterator_result_object_value_offset; } [[nodiscard]] u32 iterator_result_object_done_offset() { return m_iterator_result_object_done_offset; } // Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct prototype GC::Ref proxy_constructor() { return *m_proxy_constructor; } // Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct constructor GC::Ref async_from_sync_iterator_prototype() { return *m_async_from_sync_iterator_prototype; } GC::Ref async_generator_prototype() { return *m_async_generator_prototype; } GC::Ref generator_prototype() { return *m_generator_prototype; } GC::Ref wrap_for_valid_iterator_prototype() { return *m_wrap_for_valid_iterator_prototype; } // Alias for the AsyncGenerator Prototype Object used by the spec (%AsyncGeneratorFunction.prototype.prototype%) GC::Ref async_generator_function_prototype_prototype() { return *m_async_generator_prototype; } // Alias for the Generator Prototype Object used by the spec (%GeneratorFunction.prototype.prototype%) GC::Ref generator_function_prototype_prototype() { return *m_generator_prototype; } // Not included in JS_ENUMERATE_INTL_OBJECTS due to missing distinct constructor GC::Ref intl_segments_prototype() { return *m_intl_segments_prototype; } // Global object functions GC::Ref eval_function() const { return *m_eval_function; } GC::Ref is_finite_function() const { return *m_is_finite_function; } GC::Ref is_nan_function() const { return *m_is_nan_function; } GC::Ref parse_float_function() const { return *m_parse_float_function; } GC::Ref parse_int_function() const { return *m_parse_int_function; } GC::Ref decode_uri_function() const { return *m_decode_uri_function; } GC::Ref decode_uri_component_function() const { return *m_decode_uri_component_function; } GC::Ref encode_uri_function() const { return *m_encode_uri_function; } GC::Ref encode_uri_component_function() const { return *m_encode_uri_component_function; } GC::Ref escape_function() const { return *m_escape_function; } GC::Ref unescape_function() const { return *m_unescape_function; } // Namespace/constructor object functions GC::Ref array_prototype_values_function() const { return *m_array_prototype_values_function; } GC::Ref date_constructor_now_function() const { return *m_date_constructor_now_function; } GC::Ref json_parse_function() const { return *m_json_parse_function; } GC::Ref json_stringify_function() const { return *m_json_stringify_function; } GC::Ref object_prototype_to_string_function() const { return *m_object_prototype_to_string_function; } GC::Ref throw_type_error_function() const { return *m_throw_type_error_function; } #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \ GC::Ref snake_name##_constructor(); \ GC::Ref snake_name##_prototype(); JS_ENUMERATE_BUILTIN_TYPES #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \ GC::Ref intl_##snake_name##_constructor(); \ GC::Ref intl_##snake_name##_prototype(); JS_ENUMERATE_INTL_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \ GC::Ref temporal_##snake_name##_constructor(); \ GC::Ref temporal_##snake_name##_prototype(); JS_ENUMERATE_TEMPORAL_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name) \ GC::Ref snake_name##_object(); JS_ENUMERATE_BUILTIN_NAMESPACE_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name) \ GC::Ref snake_name##_prototype() \ { \ return *m_##snake_name##_prototype; \ } JS_ENUMERATE_ITERATOR_PROTOTYPES #undef __JS_ENUMERATE [[nodiscard]] GC::Ref default_collator(); private: Intrinsics(Realm& realm) : m_realm(realm) { } virtual void visit_edges(Visitor&) override; void initialize_intrinsics(Realm&); #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \ void initialize_##snake_name(); JS_ENUMERATE_BUILTIN_TYPES #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \ void initialize_intl_##snake_name(); JS_ENUMERATE_INTL_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \ void initialize_temporal_##snake_name(); JS_ENUMERATE_TEMPORAL_OBJECTS #undef __JS_ENUMERATE GC::Ref m_realm; GC::Ptr m_empty_object_shape; GC::Ptr m_new_object_shape; GC::Ptr m_iterator_result_object_shape; u32 m_iterator_result_object_value_offset { 0 }; u32 m_iterator_result_object_done_offset { 0 }; // Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct prototype GC::Ptr m_proxy_constructor; // Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct constructor GC::Ptr m_async_from_sync_iterator_prototype; GC::Ptr m_async_generator_prototype; GC::Ptr m_generator_prototype; GC::Ptr m_wrap_for_valid_iterator_prototype; // Not included in JS_ENUMERATE_INTL_OBJECTS due to missing distinct constructor GC::Ptr m_intl_segments_prototype; // Global object functions GC::Ptr m_eval_function; GC::Ptr m_is_finite_function; GC::Ptr m_is_nan_function; GC::Ptr m_parse_float_function; GC::Ptr m_parse_int_function; GC::Ptr m_decode_uri_function; GC::Ptr m_decode_uri_component_function; GC::Ptr m_encode_uri_function; GC::Ptr m_encode_uri_component_function; GC::Ptr m_escape_function; GC::Ptr m_unescape_function; // Namespace/constructor object functions GC::Ptr m_array_prototype_values_function; GC::Ptr m_date_constructor_now_function; GC::Ptr m_json_parse_function; GC::Ptr m_json_stringify_function; GC::Ptr m_object_prototype_to_string_function; GC::Ptr m_throw_type_error_function; #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \ GC::Ptr m_##snake_name##_constructor; \ GC::Ptr m_##snake_name##_prototype; JS_ENUMERATE_BUILTIN_TYPES #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \ GC::Ptr m_intl_##snake_name##_constructor; \ GC::Ptr m_intl_##snake_name##_prototype; JS_ENUMERATE_INTL_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \ GC::Ptr m_temporal_##snake_name##_constructor; \ GC::Ptr m_temporal_##snake_name##_prototype; JS_ENUMERATE_TEMPORAL_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name) \ GC::Ptr m_##snake_name##_object; JS_ENUMERATE_BUILTIN_NAMESPACE_OBJECTS #undef __JS_ENUMERATE #define __JS_ENUMERATE(ClassName, snake_name) \ GC::Ptr m_##snake_name##_prototype; JS_ENUMERATE_ITERATOR_PROTOTYPES #undef __JS_ENUMERATE GC::Ptr m_default_collator; }; void add_restricted_function_properties(FunctionObject&, Realm&); }