| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (c) 2020, Andreas Kling <kling@serenityos.org> | 
					
						
							| 
									
										
										
										
											2023-04-13 00:47:15 +02:00
										 |  |  |  * Copyright (c) 2020-2023, Linus Groh <linusg@serenityos.org> | 
					
						
							| 
									
										
										
										
											2020-05-01 07:14:57 +02:00
										 |  |  |  * Copyright (c) 2020, Emanuele Torre <torreemanuele6@gmail.com> | 
					
						
							| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2021-04-22 01:24:48 -07:00
										 |  |  |  * SPDX-License-Identifier: BSD-2-Clause | 
					
						
							| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-01 15:19:43 +02:00
										 |  |  | #include <LibJS/Console.h>
 | 
					
						
							| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  | #include <LibJS/Runtime/ConsoleObject.h>
 | 
					
						
							| 
									
										
										
										
											2024-08-08 20:21:06 +02:00
										 |  |  | #include <LibJS/Runtime/ConsoleObjectPrototype.h>
 | 
					
						
							| 
									
										
										
										
											2020-04-18 13:18:06 +02:00
										 |  |  | #include <LibJS/Runtime/GlobalObject.h>
 | 
					
						
							| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace JS { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-19 09:45:05 +01:00
										 |  |  | JS_DEFINE_ALLOCATOR(ConsoleObject); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-08 20:21:06 +02:00
										 |  |  | static NonnullGCPtr<ConsoleObjectPrototype> create_console_prototype(Realm& realm) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return realm.heap().allocate<ConsoleObjectPrototype>(realm, realm); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-16 00:20:49 +01:00
										 |  |  | ConsoleObject::ConsoleObject(Realm& realm) | 
					
						
							| 
									
										
										
										
											2024-08-08 20:21:06 +02:00
										 |  |  |     : Object(ConstructWithPrototypeTag::Tag, create_console_prototype(realm)) | 
					
						
							| 
									
										
										
										
											2020-06-20 17:11:11 +02:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-20 21:19:51 +02:00
										 |  |  | ConsoleObject::~ConsoleObject() = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ConsoleObject::visit_edges(Visitor& visitor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     Base::visit_edges(visitor); | 
					
						
							|  |  |  |     visitor.visit(m_console); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-07 08:41:28 +02:00
										 |  |  | void ConsoleObject::initialize(Realm& realm) | 
					
						
							| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-10-14 00:03:58 +02:00
										 |  |  |     auto& vm = this->vm(); | 
					
						
							| 
									
										
										
										
											2023-08-07 08:41:28 +02:00
										 |  |  |     Base::initialize(realm); | 
					
						
							| 
									
										
										
										
											2024-04-20 21:19:51 +02:00
										 |  |  |     m_console = vm.heap().allocate<Console>(realm, realm); | 
					
						
							| 
									
										
										
										
											2021-07-06 01:12:54 +03:00
										 |  |  |     u8 attr = Attribute::Writable | Attribute::Enumerable | Attribute::Configurable; | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  |     define_native_function(realm, vm.names.assert, assert_, 0, attr); | 
					
						
							|  |  |  |     define_native_function(realm, vm.names.clear, clear, 0, attr); | 
					
						
							| 
									
										
										
										
											2022-08-22 21:47:35 +01:00
										 |  |  |     define_native_function(realm, vm.names.debug, debug, 0, attr); | 
					
						
							|  |  |  |     define_native_function(realm, vm.names.error, error, 0, attr); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  |     define_native_function(realm, vm.names.info, info, 0, attr); | 
					
						
							|  |  |  |     define_native_function(realm, vm.names.log, log, 0, attr); | 
					
						
							| 
									
										
										
										
											2022-08-22 21:47:35 +01:00
										 |  |  |     define_native_function(realm, vm.names.trace, trace, 0, attr); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  |     define_native_function(realm, vm.names.warn, warn, 0, attr); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:29:24 -04:00
										 |  |  |     define_native_function(realm, vm.names.dir, dir, 0, attr); | 
					
						
							| 
									
										
										
										
											2022-08-22 21:47:35 +01: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 21:30:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     define_direct_property(vm.well_known_symbol_to_string_tag(), PrimitiveString::create(vm, "console"_string), Attribute::Configurable); | 
					
						
							| 
									
										
										
										
											2020-03-16 14:58:20 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  | // 1.1.1. assert(condition, ...data), https://console.spec.whatwg.org/#assert
 | 
					
						
							|  |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::assert_) | 
					
						
							| 
									
										
										
										
											2020-03-28 23:10:37 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04: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 17:00:06 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-13 00:22:35 +01:00
										 |  |  | // 1.1.3. debug(...data), https://console.spec.whatwg.org/#debug
 | 
					
						
							| 
									
										
										
										
											2021-10-29 00:28:04 +03:00
										 |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::debug) | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							|  |  |  |     return console_object.console().debug(); | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  | // 1.1.4. error(...data), https://console.spec.whatwg.org/#error
 | 
					
						
							|  |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::error) | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  |     return console_object.console().error(); | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  | // 1.1.5. info(...data), https://console.spec.whatwg.org/#info
 | 
					
						
							|  |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::info) | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  |     return console_object.console().info(); | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  | // 1.1.6. log(...data), https://console.spec.whatwg.org/#log
 | 
					
						
							|  |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::log) | 
					
						
							| 
									
										
										
										
											2020-04-12 17:00:06 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04:00
										 |  |  |     return console_object.console().log(); | 
					
						
							| 
									
										
										
										
											2020-03-28 23:10:37 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-13 00:22:35 +01:00
										 |  |  | // 1.1.8. trace(...data), https://console.spec.whatwg.org/#trace
 | 
					
						
							| 
									
										
										
										
											2021-10-29 00:28:04 +03:00
										 |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::trace) | 
					
						
							| 
									
										
										
										
											2020-04-11 12:57:13 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							|  |  |  |     return console_object.console().trace(); | 
					
						
							| 
									
										
										
										
											2020-04-11 12:57:13 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 21:27:14 -04: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-21 21:29:24 -04: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-13 00:22:35 +01:00
										 |  |  | // 1.2.1. count(label), https://console.spec.whatwg.org/#count
 | 
					
						
							| 
									
										
										
										
											2021-10-29 00:28:04 +03:00
										 |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::count) | 
					
						
							| 
									
										
										
										
											2020-05-01 07:14:57 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							|  |  |  |     return console_object.console().count(); | 
					
						
							| 
									
										
										
										
											2020-05-01 07:14:57 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-13 00:22:35 +01:00
										 |  |  | // 1.2.2. countReset(label), https://console.spec.whatwg.org/#countreset
 | 
					
						
							| 
									
										
										
										
											2021-10-29 00:28:04 +03:00
										 |  |  | JS_DEFINE_NATIVE_FUNCTION(ConsoleObject::count_reset) | 
					
						
							| 
									
										
										
										
											2020-05-01 08:59:05 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-08-28 14:20:06 +01:00
										 |  |  |     auto& console_object = *vm.current_realm()->intrinsics().console_object(); | 
					
						
							|  |  |  |     return console_object.console().count_reset(); | 
					
						
							| 
									
										
										
										
											2020-05-01 08:59:05 +02: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 14:20:06 +01: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 14:20:06 +01: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 14:20:06 +01: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 14:20:06 +01: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 14:20:06 +01: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 14:20:06 +01: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 14:58:20 +01:00
										 |  |  | } |