aboutsummaryrefslogtreecommitdiff
path: root/libbutl/multi-index.hxx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2017-09-22 23:32:28 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2017-09-22 23:32:28 +0200
commitc09cd7512491cee1e82c1ad8128ce9fd4bc3f79b (patch)
treea659ed768d849130ab5780a11b7f791a463a1a91 /libbutl/multi-index.hxx
parent2a00871f07067f8f9e2de08bb9c8f50e1bf6a650 (diff)
Initial modularization with both Clang and VC hacks
Note: gave up on VC about half way though.
Diffstat (limited to 'libbutl/multi-index.hxx')
-rw-r--r--libbutl/multi-index.hxx59
1 files changed, 0 insertions, 59 deletions
diff --git a/libbutl/multi-index.hxx b/libbutl/multi-index.hxx
deleted file mode 100644
index 448e1f7..0000000
--- a/libbutl/multi-index.hxx
+++ /dev/null
@@ -1,59 +0,0 @@
-// file : libbutl/multi-index.hxx -*- C++ -*-
-// copyright : Copyright (c) 2014-2017 Code Synthesis Ltd
-// license : MIT; see accompanying LICENSE file
-
-#ifndef LIBBUTL_MULTI_INDEX_HXX
-#define LIBBUTL_MULTI_INDEX_HXX
-
-#include <utility> // declval()
-#include <functional> // hash
-
-namespace butl
-{
- // Google the "Emulating Boost.MultiIndex with Standard Containers" blog
- // post for details.
- //
-
- template <typename T>
- struct map_key
- {
- mutable const T* p;
-
- map_key (const T* v = 0): p (v) {}
- bool operator< (const map_key& x) const {return *p < *x.p;}
- bool operator== (const map_key& x) const {return *p == *x.p;}
- };
-
- template <typename I>
- struct map_iterator_adapter: I
- {
- typedef const typename I::value_type::second_type value_type;
- typedef value_type* pointer;
- typedef value_type& reference;
-
- map_iterator_adapter () {}
- map_iterator_adapter (I i): I (i) {}
-
- map_iterator_adapter&
- operator= (I i) {static_cast<I&> (*this) = i; return *this;}
-
- reference operator* () const {return I::operator* ().second;}
- pointer operator-> () const {return &I::operator-> ()->second;}
- };
-}
-
-namespace std
-{
- template <typename T>
- struct hash<butl::map_key<T>>: hash<T>
- {
- size_t
- operator() (butl::map_key<T> x) const
- noexcept (noexcept (declval<hash<T>> () (*x.p)))
- {
- return hash<T>::operator() (*x.p);
- }
- };
-}
-
-#endif // LIBBUTL_MULTI_INDEX_HXX