diff options
Diffstat (limited to 'Userland/Utilities/js.cpp')
-rw-r--r-- | Userland/Utilities/js.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/Userland/Utilities/js.cpp b/Userland/Utilities/js.cpp index ff6525b7d0..afa44cdfbe 100644 --- a/Userland/Utilities/js.cpp +++ b/Userland/Utilities/js.cpp @@ -73,6 +73,7 @@ #include <LibJS/Runtime/TypedArray.h> #include <LibJS/Runtime/Value.h> #include <LibJS/Runtime/WeakMap.h> +#include <LibJS/Runtime/WeakSet.h> #include <LibJS/SourceTextModule.h> #include <LibLine/Editor.h> #include <LibMain/Main.h> @@ -421,6 +422,13 @@ static void print_weak_map(JS::WeakMap const& weak_map, HashTable<JS::Object*>&) // Note: We could tell you what's actually inside, but not in insertion order. } +static void print_weak_set(JS::WeakSet const& weak_set, HashTable<JS::Object*>&) +{ + print_type("WeakSet"); + js_out(" ({})", weak_set.values().size()); + // Note: We could tell you what's actually inside, but not in insertion order. +} + static void print_promise(JS::Promise const& promise, HashTable<JS::Object*>& seen_objects) { print_type("Promise"); @@ -992,6 +1000,8 @@ static void print_value(JS::Value value, HashTable<JS::Object*>& seen_objects) return print_set(static_cast<JS::Set&>(object), seen_objects); if (is<JS::WeakMap>(object)) return print_weak_map(static_cast<JS::WeakMap&>(object), seen_objects); + if (is<JS::WeakSet>(object)) + return print_weak_set(static_cast<JS::WeakSet&>(object), seen_objects); if (is<JS::DataView>(object)) return print_data_view(static_cast<JS::DataView&>(object), seen_objects); if (is<JS::ProxyObject>(object)) |