2020-03-16 13:58:20 +00:00
|
|
|
/*
|
2024-10-04 11:19:50 +00:00
|
|
|
* Copyright (c) 2020, Andreas Kling <andreas@ladybird.org>
|
2023-04-12 22:47:15 +00:00
|
|
|
* Copyright (c) 2020-2023, Linus Groh <linusg@serenityos.org>
|
2020-05-01 05:14:57 +00:00
|
|
|
* Copyright (c) 2020, Emanuele Torre <torreemanuele6@gmail.com>
|
2020-03-16 13:58:20 +00:00
|
|
|
*
|
2021-04-22 08:24:48 +00:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-03-16 13:58:20 +00:00
|
|
|
*/
|
|
|
|
|
2020-05-01 13:19:43 +00:00
|
|
|
#include <LibJS/Console.h>
|
2020-03-16 13:58:20 +00:00
|
|
|
#include <LibJS/Runtime/ConsoleObject.h>
|
2024-08-08 18:21:06 +00:00
|
|
|
#include <LibJS/Runtime/ConsoleObjectPrototype.h>
|
2020-04-18 11:18:06 +00:00
|
|
|
#include <LibJS/Runtime/GlobalObject.h>
|
2020-03-16 13:58:20 +00:00
|
|
|
|
|
|
|
namespace JS {
|
|
|
|
|
2024-11-14 15:01:23 +00:00
|
|
|
GC_DEFINE_ALLOCATOR(ConsoleObject);
|
2023-11-19 08:45:05 +00:00
|
|
|
|
2024-11-14 15:01:23 +00:00
|
|
|
static GC::Ref<ConsoleObjectPrototype> create_console_prototype(Realm& realm)
|
2024-08-08 18:21:06 +00:00
|
|
|
{
|
2024-11-13 16:50:17 +00:00
|
|
|
return realm.create<ConsoleObjectPrototype>(realm);
|
2024-08-08 18:21:06 +00:00
|
|
|
}
|
|
|
|
|
2022-08-15 23:20:49 +00:00
|
|
|
ConsoleObject::ConsoleObject(Realm& realm)
|
2024-08-08 18:21:06 +00:00
|
|
|
: Object(ConstructWithPrototypeTag::Tag, create_console_prototype(realm))
|
2020-06-20 15:11:11 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2024-04-20 19:19:51 +00:00
|
|
|
ConsoleObject::~ConsoleObject() = default;
|
|
|
|
|
|
|
|
void ConsoleObject::visit_edges(Visitor& visitor)
|
|
|
|
{
|
|
|
|
Base::visit_edges(visitor);
|
|
|
|
visitor.visit(m_console);
|
|
|
|
}
|
|
|
|
|
2023-08-07 06:41:28 +00:00
|
|
|
void ConsoleObject::initialize(Realm& realm)
|
2020-03-16 13:58:20 +00:00
|
|
|
{
|
2020-10-13 22:03:58 +00:00
|
|
|
auto& vm = this->vm();
|
2023-08-07 06:41:28 +00:00
|
|
|
Base::initialize(realm);
|
2024-11-13 16:50:17 +00:00
|
|
|
m_console = realm.create<Console>(realm);
|
2021-07-05 22:12:54 +00:00
|
|
|
u8 attr = Attribute::Writable | Attribute::Enumerable | Attribute::Configurable;
|
2023-06-22 01:27:14 +00:00
|
|
|
define_native_function(realm, vm.names.assert, assert_, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.clear, clear, 0, attr);
|
2022-08-22 20:47:35 +00:00
|
|
|
define_native_function(realm, vm.names.debug, debug, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.error, error, 0, attr);
|
2023-06-22 01:27:14 +00:00
|
|
|
define_native_function(realm, vm.names.info, info, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.log, log, 0, attr);
|
2024-08-09 21:24:26 +00:00
|
|
|
define_native_function(realm, vm.names.table, table, 0, attr);
|
2022-08-22 20:47:35 +00:00
|
|
|
define_native_function(realm, vm.names.trace, trace, 0, attr);
|
2023-06-22 01:27:14 +00:00
|
|
|
define_native_function(realm, vm.names.warn, warn, 0, attr);
|
2023-06-22 01:29:24 +00:00
|
|
|
define_native_function(realm, vm.names.dir, dir, 0, attr);
|
2022-08-22 20:47:35 +00:00
|
|
|
define_native_function(realm, vm.names.count, count, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.countReset, count_reset, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.group, group, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.groupCollapsed, group_collapsed, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.groupEnd, group_end, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.time, time, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.timeLog, time_log, 0, attr);
|
|
|
|
define_native_function(realm, vm.names.timeEnd, time_end, 0, attr);
|
2024-08-08 19:30:34 +00:00
|
|
|
|
|
|
|
define_direct_property(vm.well_known_symbol_to_string_tag(), PrimitiveString::create(vm, "console"_string), Attribute::Configurable);
|
2020-03-16 13:58:20 +00:00
|
|
|
}
|
|
|
|
|
2023-06-22 01:27:14 +00:00
|
|
|
// 1.1.1. assert(condition, ...data), https://console.spec.whatwg.org/#assert
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::assert_)
|
2020-03-28 22:10:37 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
2023-06-22 01:27:14 +00:00
|
|
|
return console_object.console().assert_();
|
|
|
|
}
|
|
|
|
|
|
|
|
// 1.1.2. clear(), https://console.spec.whatwg.org/#clear
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::clear)
|
|
|
|
{
|
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().clear();
|
2020-04-12 16:00:06 +00:00
|
|
|
}
|
|
|
|
|
2021-06-12 23:22:35 +00:00
|
|
|
// 1.1.3. debug(...data), https://console.spec.whatwg.org/#debug
|
2021-10-28 21:28:04 +00:00
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::debug)
|
2020-04-12 16:00:06 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().debug();
|
2020-04-12 16:00:06 +00:00
|
|
|
}
|
|
|
|
|
2023-06-22 01:27:14 +00:00
|
|
|
// 1.1.4. error(...data), https://console.spec.whatwg.org/#error
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::error)
|
2020-04-12 16:00:06 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
2023-06-22 01:27:14 +00:00
|
|
|
return console_object.console().error();
|
2020-04-12 16:00:06 +00:00
|
|
|
}
|
|
|
|
|
2023-06-22 01:27:14 +00:00
|
|
|
// 1.1.5. info(...data), https://console.spec.whatwg.org/#info
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::info)
|
2020-04-12 16:00:06 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
2023-06-22 01:27:14 +00:00
|
|
|
return console_object.console().info();
|
2020-04-12 16:00:06 +00:00
|
|
|
}
|
|
|
|
|
2023-06-22 01:27:14 +00:00
|
|
|
// 1.1.6. log(...data), https://console.spec.whatwg.org/#log
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::log)
|
2020-04-12 16:00:06 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
2023-06-22 01:27:14 +00:00
|
|
|
return console_object.console().log();
|
2020-03-28 22:10:37 +00:00
|
|
|
}
|
|
|
|
|
2024-08-09 21:24:26 +00:00
|
|
|
// 1.1.7. table(tabularData, properties), https://console.spec.whatwg.org/#table
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::table)
|
|
|
|
{
|
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().table();
|
|
|
|
}
|
|
|
|
|
2021-06-12 23:22:35 +00:00
|
|
|
// 1.1.8. trace(...data), https://console.spec.whatwg.org/#trace
|
2021-10-28 21:28:04 +00:00
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::trace)
|
2020-04-11 11:57:13 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().trace();
|
2020-04-11 11:57:13 +00:00
|
|
|
}
|
|
|
|
|
2023-06-22 01:27:14 +00:00
|
|
|
// 1.1.9. warn(...data), https://console.spec.whatwg.org/#warn
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::warn)
|
|
|
|
{
|
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().warn();
|
|
|
|
}
|
|
|
|
|
2023-06-22 01:29:24 +00:00
|
|
|
// 1.1.10. dir(item, options), https://console.spec.whatwg.org/#warn
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::dir)
|
|
|
|
{
|
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().dir();
|
|
|
|
}
|
|
|
|
|
2021-06-12 23:22:35 +00:00
|
|
|
// 1.2.1. count(label), https://console.spec.whatwg.org/#count
|
2021-10-28 21:28:04 +00:00
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::count)
|
2020-05-01 05:14:57 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().count();
|
2020-05-01 05:14:57 +00:00
|
|
|
}
|
|
|
|
|
2021-06-12 23:22:35 +00:00
|
|
|
// 1.2.2. countReset(label), https://console.spec.whatwg.org/#countreset
|
2021-10-28 21:28:04 +00:00
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::count_reset)
|
2020-05-01 06:59:05 +00:00
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().count_reset();
|
2020-05-01 06:59:05 +00:00
|
|
|
}
|
|
|
|
|
2021-12-22 12:32:15 +00:00
|
|
|
// 1.3.1. group(...data), https://console.spec.whatwg.org/#group
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::group)
|
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().group();
|
2021-12-22 12:32:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 1.3.2. groupCollapsed(...data), https://console.spec.whatwg.org/#groupcollapsed
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::group_collapsed)
|
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().group_collapsed();
|
2021-12-22 12:32:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 1.3.3. groupEnd(), https://console.spec.whatwg.org/#groupend
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::group_end)
|
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().group_end();
|
2021-12-22 12:32:15 +00:00
|
|
|
}
|
|
|
|
|
2021-12-22 16:40:57 +00:00
|
|
|
// 1.4.1. time(label), https://console.spec.whatwg.org/#time
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::time)
|
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().time();
|
2021-12-22 16:40:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 1.4.2. timeLog(label, ...data), https://console.spec.whatwg.org/#timelog
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::time_log)
|
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().time_log();
|
2021-12-22 16:40:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 1.4.3. timeEnd(label), https://console.spec.whatwg.org/#timeend
|
|
|
|
JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::time_end)
|
|
|
|
{
|
2022-08-28 13:20:06 +00:00
|
|
|
auto& console_object = *vm.current_realm()->intrinsics().console_object();
|
|
|
|
return console_object.console().time_end();
|
2021-12-22 16:40:57 +00:00
|
|
|
}
|
|
|
|
|
2020-03-16 13:58:20 +00:00
|
|
|
}
|