// Part of the Carbon Language project, under the Apache License v2.0 with LLVM // Exceptions. See /LICENSE for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception #ifndef EXECUTABLE_SEMANTICS_INTERPRETER_DICTIONARY_H_ #define EXECUTABLE_SEMANTICS_INTERPRETER_DICTIONARY_H_ #include #include #include #include "executable_semantics/common/arena.h" #include "executable_semantics/interpreter/list_node.h" namespace Carbon { // A persistent dictionary with a simple implementation. // Copying the dictionary is O(1) time. template class Dictionary { public: // Create an empty dictionary. Dictionary() { head = nullptr; } // Return the value associated with the given key. // Time complexity: O(n) where n is the number of times // any value has been set across all keys. auto Get(const K& key) -> std::optional { for (auto kv : *this) { if (kv.first == key) { return kv.second; } } return std::nullopt; } // Associate the value v with key k in the dictionary. // Time complexity: O(1). auto Set(const K& k, const V& v) -> void { head = global_arena->New>>(std::make_pair(k, v), head); } typedef ListNodeIterator> Iterator; // The position of the first element of the dictionary // or `end()` if the dictionary is empty. auto begin() const -> Iterator { return Iterator(head); } // The position one past that of the last element. auto end() const -> Iterator { return Iterator(nullptr); } private: Dictionary(ListNode>* h) : head(h) {} ListNode>* head; }; } // namespace Carbon #endif // EXECUTABLE_SEMANTICS_INTERPRETER_DICTIONARY_H_