Chromium Code Reviews| Index: mojo/public/cpp/bindings/struct_traits.h | 
| diff --git a/mojo/public/cpp/bindings/struct_traits.h b/mojo/public/cpp/bindings/struct_traits.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..fb7290b20ab7c4effc89177a64250606d6868dca | 
| --- /dev/null | 
| +++ b/mojo/public/cpp/bindings/struct_traits.h | 
| @@ -0,0 +1,35 @@ | 
| +// Copyright 2015 The Chromium Authors. All rights reserved. | 
| +// 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_STRUCT_TRAITS_H_ | 
| +#define MOJO_PUBLIC_CPP_BINDINGS_STRUCT_TRAITS_H_ | 
| + | 
| +namespace mojo { | 
| + | 
| +// This must be specialized for any type |T| to be serialized/deserialized as | 
| +// a mojom struct of type |MojomType|. | 
| +// | 
| +// Each specialization must implement a few things: | 
| +// | 
| +// 1. Static getters for each field in the Mojom type. These should be | 
| +// of the form: | 
| +// | 
| +// static <return type> <field name>(const T&) | 
| +// | 
| +// and should return a serializable form of the named field as extracted | 
| +// from the referenced |T| instance. | 
| +// | 
| +// 2. A static Read method to initialize a new |T| from a MojomType::Reader: | 
| +// | 
| +// static bool Read(MojomType::Reader r, T* out); | 
| 
 
Jeffrey Yasskin
2016/01/28 18:01:40
Could you document whether a 'true' or 'false' ret
 
 | 
| +// | 
| +// The generated MojomType::Reader type provides a convenient, inexpensive | 
| +// view of a serialized struct's field data. | 
| +// | 
| +template <typename MojomType, typename T> | 
| +struct StructTraits; | 
| + | 
| +} // namespace mojo | 
| + | 
| +#endif // MOJO_PUBLIC_CPP_BINDINGS_STRUCT_TRAITS_H_ |