Skip to content

Files

Latest commit

 

History

History
50 lines (35 loc) · 1.37 KB

README.md

File metadata and controls

50 lines (35 loc) · 1.37 KB

ordered-dictionary-luau

A dictionary that remembers the order in which keys were first inserted.

Get it here:

Examples

There are two constructors that this module provides for creating ordered dictionaries.

The first is a standard luau OOP object that provides a number of useful methods for manipulating the contents of the ordered dictionary.

local booksBorrowed = OrderedDictionary.new()

booksBorrowed:set("Tom", 2)
booksBorrowed:set("Sarah", 4)
booksBorrowed:set("John", 1)
booksBorrowed:set("Emily", 6)
booksBorrowed:set("Marcus", 0)

for person, books in booksBorrowed:iterate() do
	print(person, books)
end

local name, books = booksBorrowed:popFront() -- "Tom", 2

The second is wrapped within metatables allowing access much like a built-in dictionary. The trade off however is that less methods are accessible.

local booksBorrowed = OrderedDictionary.meta()

booksBorrowed["Tom"] = 2
booksBorrowed["Sarah"] = 4
booksBorrowed["John"] = 1
booksBorrowed["Emily"] = 6
booksBorrowed["Marcus"] = 0

for person, books in booksBorrowed do
	print(person, books)
end

-- can get the object by calling like a function
local booksBorrowedObject = booksBorrowed()
local name, books = booksBorrowedObject:popBack() -- "Marcus", 0