Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(221)

Unified Diff: third_party/boost/boost/fusion/adapted/struct/detail/at_impl.hpp

Issue 113163: Add gmock into our dependencies. (Closed)
Patch Set: Making gmock work with windows. Requires adding boost. Created 11 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/boost/boost/fusion/adapted/struct/detail/at_impl.hpp
diff --git a/third_party/boost/boost/fusion/adapted/struct/detail/at_impl.hpp b/third_party/boost/boost/fusion/adapted/struct/detail/at_impl.hpp
new file mode 100644
index 0000000000000000000000000000000000000000..809902ae567305d454d2ada0e2ff1cb030662674
--- /dev/null
+++ b/third_party/boost/boost/fusion/adapted/struct/detail/at_impl.hpp
@@ -0,0 +1,63 @@
+/*=============================================================================
+ Copyright (c) 2001-2006 Joel de Guzman
+ Copyright (c) 2005-2006 Dan Marsden
+
+ Distributed under the Boost Software License, Version 1.0. (See accompanying
+ file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
+==============================================================================*/
+#if !defined(BOOST_FUSION_AT_IMPL_24122005_1807)
+#define BOOST_FUSION_AT_IMPL_24122005_1807
+
+#include <boost/fusion/support/detail/access.hpp>
+#include <boost/mpl/assert.hpp>
+#include <boost/mpl/int.hpp>
+
+namespace boost { namespace fusion
+{
+ struct struct_tag;
+
+ namespace extension
+ {
+ template<typename T>
+ struct at_impl;
+
+ template <typename Struct, int N>
+ struct struct_member;
+
+ template <typename Struct>
+ struct struct_size;
+
+ template <>
+ struct at_impl<struct_tag>
+ {
+ template <typename Sequence, typename N>
+ struct apply
+ {
+ static int const n_value = N::value;
+ BOOST_MPL_ASSERT_RELATION(
+ n_value, <=, extension::struct_size<Sequence>::value);
+
+ typedef typename
+ extension::struct_member<Sequence, N::value>
+ element;
+
+ typedef typename
+ mpl::eval_if<
+ is_const<Sequence>
+ , detail::cref_result<element>
+ , detail::ref_result<element>
+ >::type
+ type;
+
+ static type
+ call(Sequence& seq)
+ {
+ return extension::
+ struct_member<Sequence, N::value>::call(seq);
+ }
+ };
+ };
+ }
+}}
+
+#endif

Powered by Google App Engine
This is Rietveld 408576698