blob: 0c621647cc73ac5dec41788427a962a2ae15a177 [file] [log] [blame]
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#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) {
// std::map<> is always converted to non-null mojom map.
return false;
}
static void SetToNull(std::map<K, V, Compare>* output) {
// std::map<> doesn't support null state. Set it to empty instead.
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) {
// std::unordered_map<> is always converted to non-null mojom map.
return false;
}
static void SetToNull(std::unordered_map<K, V>* output) {
// std::unordered_map<> doesn't support null state. Set it to empty instead.
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(); }
};
// Note: this is only used for serialization.
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) {
// std::vector<> has no built-in concept of nullness.
// TODO(dcheng): Why are we even calling this?
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;
}
};
} // namespace mojo
#endif // MOJO_PUBLIC_CPP_BINDINGS_MAP_TRAITS_STL_H_