2022-08-27 00:54:55 +01:00
|
|
|
/*
|
2023-01-09 23:59:08 +00:00
|
|
|
* Copyright (c) 2022-2023, Linus Groh <linusg@serenityos.org>
|
2025-01-23 18:20:29 +01:00
|
|
|
* Copyright (c) 2020-2025, Andreas Kling <andreas@ladybird.org>
|
2022-08-27 00:54:55 +01:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2025-02-03 21:32:41 -05:00
|
|
|
#include <LibGC/CellAllocator.h>
|
2025-07-19 13:49:30 -07:00
|
|
|
#include <LibJS/Export.h>
|
2022-08-27 00:54:55 +01:00
|
|
|
#include <LibJS/Forward.h>
|
|
|
|
#include <LibJS/Heap/Cell.h>
|
|
|
|
|
|
|
|
namespace JS {
|
|
|
|
|
2025-07-19 13:49:30 -07:00
|
|
|
class JS_API Intrinsics final : public Cell {
|
2024-11-15 04:01:23 +13:00
|
|
|
GC_CELL(Intrinsics, Cell);
|
|
|
|
GC_DECLARE_ALLOCATOR(Intrinsics);
|
2022-08-28 22:11:20 +02:00
|
|
|
|
2022-08-27 00:54:55 +01:00
|
|
|
public:
|
2025-02-03 21:33:19 -05:00
|
|
|
static GC::Ref<Intrinsics> create(Realm&);
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Shape> empty_object_shape() { return *m_empty_object_shape; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Shape> new_object_shape() { return *m_new_object_shape; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
[[nodiscard]] GC::Ref<Shape> iterator_result_object_shape() { return *m_iterator_result_object_shape; }
|
2023-12-07 22:30:53 +01:00
|
|
|
[[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; }
|
|
|
|
|
2025-03-25 19:16:11 +00:00
|
|
|
[[nodiscard]] GC::Ref<Shape> normal_function_prototype_shape() { return *m_normal_function_prototype_shape; }
|
|
|
|
[[nodiscard]] u32 normal_function_prototype_constructor_offset() const { return m_normal_function_prototype_constructor_offset; }
|
|
|
|
|
2025-03-25 20:08:38 +00:00
|
|
|
[[nodiscard]] GC::Ref<Shape> normal_function_shape() { return *m_normal_function_shape; }
|
|
|
|
[[nodiscard]] u32 normal_function_length_offset() const { return m_normal_function_length_offset; }
|
|
|
|
[[nodiscard]] u32 normal_function_name_offset() const { return m_normal_function_name_offset; }
|
|
|
|
[[nodiscard]] u32 normal_function_prototype_offset() const { return m_normal_function_prototype_offset; }
|
|
|
|
|
2025-04-08 22:23:28 +02:00
|
|
|
[[nodiscard]] GC::Ref<Shape> native_function_shape() { return *m_native_function_shape; }
|
|
|
|
[[nodiscard]] u32 native_function_length_offset() const { return m_native_function_length_offset; }
|
|
|
|
[[nodiscard]] u32 native_function_name_offset() const { return m_native_function_name_offset; }
|
|
|
|
|
2025-04-14 23:41:31 +02:00
|
|
|
[[nodiscard]] GC::Ref<Shape> unmapped_arguments_object_shape() { return *m_unmapped_arguments_object_shape; }
|
|
|
|
[[nodiscard]] u32 unmapped_arguments_object_length_offset() const { return m_unmapped_arguments_object_length_offset; }
|
|
|
|
[[nodiscard]] u32 unmapped_arguments_object_well_known_symbol_iterator_offset() const { return m_unmapped_arguments_object_well_known_symbol_iterator_offset; }
|
|
|
|
[[nodiscard]] u32 unmapped_arguments_object_callee_offset() const { return m_unmapped_arguments_object_callee_offset; }
|
|
|
|
|
2025-04-18 18:11:10 +02:00
|
|
|
[[nodiscard]] GC::Ref<Shape> mapped_arguments_object_shape() { return *m_mapped_arguments_object_shape; }
|
|
|
|
[[nodiscard]] u32 mapped_arguments_object_length_offset() const { return m_mapped_arguments_object_length_offset; }
|
|
|
|
[[nodiscard]] u32 mapped_arguments_object_well_known_symbol_iterator_offset() const { return m_mapped_arguments_object_well_known_symbol_iterator_offset; }
|
|
|
|
[[nodiscard]] u32 mapped_arguments_object_callee_offset() const { return m_mapped_arguments_object_callee_offset; }
|
|
|
|
|
2025-05-22 19:46:08 +03:00
|
|
|
[[nodiscard]] GC::Ref<Shape> default_array_prototype_shape() const { return *m_default_array_prototype_shape; }
|
|
|
|
[[nodiscard]] GC::Ref<Shape> default_object_prototype_shape() const { return *m_default_object_prototype_shape; }
|
|
|
|
|
2025-04-14 23:41:31 +02:00
|
|
|
[[nodiscard]] GC::Ref<Accessor> throw_type_error_accessor() { return *m_throw_type_error_accessor; }
|
|
|
|
|
2022-08-27 00:54:55 +01:00
|
|
|
// Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct prototype
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<ProxyConstructor> proxy_constructor() { return *m_proxy_constructor; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
// Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct constructor
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Object> async_from_sync_iterator_prototype() { return *m_async_from_sync_iterator_prototype; }
|
|
|
|
GC::Ref<Object> async_generator_prototype() { return *m_async_generator_prototype; }
|
|
|
|
GC::Ref<Object> generator_prototype() { return *m_generator_prototype; }
|
|
|
|
GC::Ref<Object> wrap_for_valid_iterator_prototype() { return *m_wrap_for_valid_iterator_prototype; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
// Alias for the AsyncGenerator Prototype Object used by the spec (%AsyncGeneratorFunction.prototype.prototype%)
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Object> async_generator_function_prototype_prototype() { return *m_async_generator_prototype; }
|
2022-08-27 00:54:55 +01:00
|
|
|
// Alias for the Generator Prototype Object used by the spec (%GeneratorFunction.prototype.prototype%)
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Object> generator_function_prototype_prototype() { return *m_generator_prototype; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
// Not included in JS_ENUMERATE_INTL_OBJECTS due to missing distinct constructor
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Object> intl_segments_prototype() { return *m_intl_segments_prototype; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2022-08-28 17:09:31 +01:00
|
|
|
// Global object functions
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<FunctionObject> eval_function() const { return *m_eval_function; }
|
|
|
|
GC::Ref<FunctionObject> is_finite_function() const { return *m_is_finite_function; }
|
|
|
|
GC::Ref<FunctionObject> is_nan_function() const { return *m_is_nan_function; }
|
|
|
|
GC::Ref<FunctionObject> parse_float_function() const { return *m_parse_float_function; }
|
|
|
|
GC::Ref<FunctionObject> parse_int_function() const { return *m_parse_int_function; }
|
|
|
|
GC::Ref<FunctionObject> decode_uri_function() const { return *m_decode_uri_function; }
|
|
|
|
GC::Ref<FunctionObject> decode_uri_component_function() const { return *m_decode_uri_component_function; }
|
|
|
|
GC::Ref<FunctionObject> encode_uri_function() const { return *m_encode_uri_function; }
|
|
|
|
GC::Ref<FunctionObject> encode_uri_component_function() const { return *m_encode_uri_component_function; }
|
|
|
|
GC::Ref<FunctionObject> escape_function() const { return *m_escape_function; }
|
|
|
|
GC::Ref<FunctionObject> unescape_function() const { return *m_unescape_function; }
|
2022-08-28 17:09:31 +01:00
|
|
|
|
|
|
|
// Namespace/constructor object functions
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<FunctionObject> array_prototype_values_function() const { return *m_array_prototype_values_function; }
|
|
|
|
GC::Ref<FunctionObject> date_constructor_now_function() const { return *m_date_constructor_now_function; }
|
|
|
|
GC::Ref<FunctionObject> json_parse_function() const { return *m_json_parse_function; }
|
|
|
|
GC::Ref<FunctionObject> json_stringify_function() const { return *m_json_stringify_function; }
|
|
|
|
GC::Ref<FunctionObject> object_prototype_to_string_function() const { return *m_object_prototype_to_string_function; }
|
|
|
|
GC::Ref<FunctionObject> throw_type_error_function() const { return *m_throw_type_error_function; }
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<ConstructorName> snake_name##_constructor(); \
|
|
|
|
GC::Ref<Object> snake_name##_prototype();
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_BUILTIN_TYPES
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Intl::ConstructorName> intl_##snake_name##_constructor(); \
|
|
|
|
GC::Ref<Object> intl_##snake_name##_prototype();
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_INTL_OBJECTS
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \
|
|
|
|
GC::Ref<Temporal::ConstructorName> temporal_##snake_name##_constructor(); \
|
|
|
|
GC::Ref<Object> temporal_##snake_name##_prototype();
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_TEMPORAL_OBJECTS
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<ClassName> snake_name##_object();
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_BUILTIN_NAMESPACE_OBJECTS
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name) \
|
|
|
|
GC::Ref<Object> snake_name##_prototype() \
|
|
|
|
{ \
|
|
|
|
return *m_##snake_name##_prototype; \
|
2022-08-27 00:54:55 +01:00
|
|
|
}
|
|
|
|
JS_ENUMERATE_ITERATOR_PROTOTYPES
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
2025-01-23 18:20:29 +01:00
|
|
|
[[nodiscard]] GC::Ref<Intl::Collator> default_collator();
|
|
|
|
|
2022-08-27 00:54:55 +01:00
|
|
|
private:
|
2022-11-23 12:55:31 -05:00
|
|
|
Intrinsics(Realm& realm)
|
|
|
|
: m_realm(realm)
|
|
|
|
{
|
|
|
|
}
|
2022-08-28 23:51:28 +02:00
|
|
|
|
2022-08-27 00:54:55 +01:00
|
|
|
virtual void visit_edges(Visitor&) override;
|
|
|
|
|
2025-02-03 21:33:19 -05:00
|
|
|
void initialize_intrinsics(Realm&);
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2022-11-23 12:55:31 -05:00
|
|
|
#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
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ref<Realm> m_realm;
|
2022-11-23 12:55:31 -05:00
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Shape> m_empty_object_shape;
|
|
|
|
GC::Ptr<Shape> m_new_object_shape;
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Shape> m_iterator_result_object_shape;
|
2023-12-07 22:30:53 +01:00
|
|
|
u32 m_iterator_result_object_value_offset { 0 };
|
|
|
|
u32 m_iterator_result_object_done_offset { 0 };
|
|
|
|
|
2025-03-25 19:16:11 +00:00
|
|
|
GC::Ptr<Shape> m_normal_function_prototype_shape;
|
|
|
|
u32 m_normal_function_prototype_constructor_offset { 0 };
|
|
|
|
|
2025-03-25 20:08:38 +00:00
|
|
|
GC::Ptr<Shape> m_normal_function_shape;
|
|
|
|
u32 m_normal_function_length_offset { 0 };
|
|
|
|
u32 m_normal_function_name_offset { 0 };
|
|
|
|
u32 m_normal_function_prototype_offset { 0 };
|
|
|
|
|
2025-04-08 22:23:28 +02:00
|
|
|
GC::Ptr<Shape> m_native_function_shape;
|
|
|
|
u32 m_native_function_length_offset { 0 };
|
|
|
|
u32 m_native_function_name_offset { 0 };
|
|
|
|
|
2025-04-14 23:41:31 +02:00
|
|
|
GC::Ptr<Shape> m_unmapped_arguments_object_shape;
|
|
|
|
u32 m_unmapped_arguments_object_length_offset { 0 };
|
|
|
|
u32 m_unmapped_arguments_object_well_known_symbol_iterator_offset { 0 };
|
|
|
|
u32 m_unmapped_arguments_object_callee_offset { 0 };
|
|
|
|
|
2025-04-18 18:11:10 +02:00
|
|
|
GC::Ptr<Shape> m_mapped_arguments_object_shape;
|
|
|
|
u32 m_mapped_arguments_object_length_offset { 0 };
|
|
|
|
u32 m_mapped_arguments_object_well_known_symbol_iterator_offset { 0 };
|
|
|
|
u32 m_mapped_arguments_object_callee_offset { 0 };
|
|
|
|
|
2025-05-22 19:46:08 +03:00
|
|
|
GC::Ptr<Shape> m_default_array_prototype_shape;
|
|
|
|
GC::Ptr<Shape> m_default_object_prototype_shape;
|
|
|
|
|
2025-04-14 23:41:31 +02:00
|
|
|
GC::Ptr<Accessor> m_throw_type_error_accessor;
|
|
|
|
|
2022-08-27 00:54:55 +01:00
|
|
|
// Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct prototype
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<ProxyConstructor> m_proxy_constructor;
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
// Not included in JS_ENUMERATE_NATIVE_OBJECTS due to missing distinct constructor
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Object> m_async_from_sync_iterator_prototype;
|
|
|
|
GC::Ptr<Object> m_async_generator_prototype;
|
|
|
|
GC::Ptr<Object> m_generator_prototype;
|
|
|
|
GC::Ptr<Object> m_wrap_for_valid_iterator_prototype;
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
// Not included in JS_ENUMERATE_INTL_OBJECTS due to missing distinct constructor
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Object> m_intl_segments_prototype;
|
2022-08-27 00:54:55 +01:00
|
|
|
|
2022-08-28 17:09:31 +01:00
|
|
|
// Global object functions
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<FunctionObject> m_eval_function;
|
|
|
|
GC::Ptr<FunctionObject> m_is_finite_function;
|
|
|
|
GC::Ptr<FunctionObject> m_is_nan_function;
|
|
|
|
GC::Ptr<FunctionObject> m_parse_float_function;
|
|
|
|
GC::Ptr<FunctionObject> m_parse_int_function;
|
|
|
|
GC::Ptr<FunctionObject> m_decode_uri_function;
|
|
|
|
GC::Ptr<FunctionObject> m_decode_uri_component_function;
|
|
|
|
GC::Ptr<FunctionObject> m_encode_uri_function;
|
|
|
|
GC::Ptr<FunctionObject> m_encode_uri_component_function;
|
|
|
|
GC::Ptr<FunctionObject> m_escape_function;
|
|
|
|
GC::Ptr<FunctionObject> m_unescape_function;
|
2022-08-28 17:09:31 +01:00
|
|
|
|
|
|
|
// Namespace/constructor object functions
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<FunctionObject> m_array_prototype_values_function;
|
|
|
|
GC::Ptr<FunctionObject> m_date_constructor_now_function;
|
|
|
|
GC::Ptr<FunctionObject> m_json_parse_function;
|
|
|
|
GC::Ptr<FunctionObject> m_json_stringify_function;
|
|
|
|
GC::Ptr<FunctionObject> m_object_prototype_to_string_function;
|
|
|
|
GC::Ptr<FunctionObject> m_throw_type_error_function;
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<ConstructorName> m_##snake_name##_constructor; \
|
|
|
|
GC::Ptr<Object> m_##snake_name##_prototype;
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_BUILTIN_TYPES
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Intl::ConstructorName> m_intl_##snake_name##_constructor; \
|
|
|
|
GC::Ptr<Object> m_intl_##snake_name##_prototype;
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_INTL_OBJECTS
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
2023-02-26 16:09:02 -07:00
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Temporal::ConstructorName> m_temporal_##snake_name##_constructor; \
|
|
|
|
GC::Ptr<Object> m_temporal_##snake_name##_prototype;
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_TEMPORAL_OBJECTS
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<ClassName> m_##snake_name##_object;
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_BUILTIN_NAMESPACE_OBJECTS
|
|
|
|
#undef __JS_ENUMERATE
|
|
|
|
|
|
|
|
#define __JS_ENUMERATE(ClassName, snake_name) \
|
2024-11-15 04:01:23 +13:00
|
|
|
GC::Ptr<Object> m_##snake_name##_prototype;
|
2022-08-27 00:54:55 +01:00
|
|
|
JS_ENUMERATE_ITERATOR_PROTOTYPES
|
|
|
|
#undef __JS_ENUMERATE
|
2025-01-23 18:20:29 +01:00
|
|
|
|
|
|
|
GC::Ptr<Intl::Collator> m_default_collator;
|
2022-08-27 00:54:55 +01:00
|
|
|
};
|
|
|
|
|
2025-07-19 10:41:08 -07:00
|
|
|
void add_restricted_function_properties(FunctionObject&, Realm&);
|
2022-08-27 00:54:55 +01:00
|
|
|
|
|
|
|
}
|