#ifndef MOJO_PUBLIC_CPP_BINDINGS_MAP_TRAITS_STL_H_
#define MOJO_PUBLIC_CPP_BINDINGS_MAP_TRAITS_STL_H_
#include <map>
#include <unordered_map>
#include "mojo/public/cpp/bindings/map_traits.h"
namespace mojo {
template <typename K, typename V, typename Compare>
struct MapTraits<std::map<K, V, Compare>> {
using Key = K;
using Value = V;
using Iterator = typename std::map<K, V, Compare>::iterator;
using ConstIterator = typename std::map<K, V, Compare>::const_iterator;
static bool IsNull(const std::map<K, V, Compare>& input) {
return false;
}
static void SetToNull(std::map<K, V, Compare>* output) {
output->clear();
}
static size_t GetSize(const std::map<K, V, Compare>& input) {
return input.size();
}
static ConstIterator GetBegin(const std::map<K, V, Compare>& input) {
return input.begin();
}
static Iterator GetBegin(std::map<K, V, Compare>& input) {
return input.begin();
}
static void AdvanceIterator(ConstIterator& iterator) { ++iterator; }
static void AdvanceIterator(Iterator& iterator) { ++iterator; }
static const K& GetKey(Iterator& iterator) { return iterator->first; }
static const K& GetKey(ConstIterator& iterator) { return iterator->first; }
static V& GetValue(Iterator& iterator) { return iterator->second; }
static const V& GetValue(ConstIterator& iterator) { return iterator->second; }
static bool Insert(std::map<K, V, Compare>& input, const K& key, V&& value) {
input.insert(std::make_pair(key, std::forward<V>(value)));
return true;
}
static bool Insert(std::map<K, V, Compare>& input,
const K& key,
const V& value) {
input.insert(std::make_pair(key, value));
return true;
}
static void SetToEmpty(std::map<K, V, Compare>* output) { output->clear(); }
};
template <typename K, typename V>
struct MapTraits<std::unordered_map<K, V>> {
using Key = K;
using Value = V;
using Iterator = typename std::unordered_map<K, V>::iterator;
using ConstIterator = typename std::unordered_map<K, V>::const_iterator;
static bool IsNull(const std::unordered_map<K, V>& input) {
return false;
}
static void SetToNull(std::unordered_map<K, V>* output) {
output->clear();
}
static size_t GetSize(const std::unordered_map<K, V>& input) {
return input.size();
}
static ConstIterator GetBegin(const std::unordered_map<K, V>& input) {
return input.begin();
}
static Iterator GetBegin(std::unordered_map<K, V>& input) {
return input.begin();
}
static void AdvanceIterator(ConstIterator& iterator) { ++iterator; }
static void AdvanceIterator(Iterator& iterator) { ++iterator; }
static const K& GetKey(Iterator& iterator) { return iterator->first; }
static const K& GetKey(ConstIterator& iterator) { return iterator->first; }
static V& GetValue(Iterator& iterator) { return iterator->second; }
static const V& GetValue(ConstIterator& iterator) { return iterator->second; }
template <typename IK, typename IV>
static bool Insert(std::unordered_map<K, V>& input, IK&& key, IV&& value) {
input.insert(
std::make_pair(std::forward<IK>(key), std::forward<IV>(value)));
return true;
}
static void SetToEmpty(std::unordered_map<K, V>* output) { output->clear(); }
};
template <typename K, typename V>
struct MapTraits<std::vector<std::pair<K, V>>> {
using Key = K;
using Value = V;
using Container = std::vector<std::pair<K, V>>;
using ConstIterator = typename Container::const_iterator;
static bool IsNull(const Container& input) {
return false;
}
static size_t GetSize(const Container& input) { return input.size(); }
static ConstIterator GetBegin(const Container& input) {
return input.begin();
}
static void AdvanceIterator(ConstIterator& iterator) { ++iterator; }
static const K& GetKey(const ConstIterator& iterator) {
return iterator->first;
}
static const V& GetValue(const ConstIterator& iterator) {
return iterator->second;
}
};
}
#endif