diff --git a/Userland/Libraries/LibJS/Runtime/Map.h b/Userland/Libraries/LibJS/Runtime/Map.h index c154011349..77f7b486da 100644 --- a/Userland/Libraries/LibJS/Runtime/Map.h +++ b/Userland/Libraries/LibJS/Runtime/Map.h @@ -22,13 +22,13 @@ public: explicit Map(Object& prototype); virtual ~Map() override; - HashMap const& entries() const { return m_entries; }; - HashMap& entries() { return m_entries; }; + OrderedHashMap const& entries() const { return m_entries; }; + OrderedHashMap& entries() { return m_entries; }; private: virtual void visit_edges(Visitor& visitor) override; - HashMap m_entries; // FIXME: Replace with a HashMap that maintains a linked list of insertion order for correct iteration order + OrderedHashMap m_entries; }; } diff --git a/Userland/Libraries/LibJS/Runtime/MapIterator.h b/Userland/Libraries/LibJS/Runtime/MapIterator.h index 39674b37d1..c1cb75aa04 100644 --- a/Userland/Libraries/LibJS/Runtime/MapIterator.h +++ b/Userland/Libraries/LibJS/Runtime/MapIterator.h @@ -33,7 +33,7 @@ private: Map& m_map; bool m_done { false }; Object::PropertyKind m_iteration_kind; - HashMap::IteratorType m_iterator; + OrderedHashMap::IteratorType m_iterator; }; }