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

Side by Side Diff: mojo/public/tools/bindings/generators/cpp_templates/struct_declaration.tmpl

Issue 289333002: Mojo cpp bindings: validation logic for incoming messages (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: simplify BoundsChecker Created 6 years, 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 {%- import "struct_macros.tmpl" as struct_macros %} 1 {%- import "struct_macros.tmpl" as struct_macros %}
2 {%- set class_name = struct.name ~ "_Data" -%} 2 {%- set class_name = struct.name ~ "_Data" -%}
3 3
4 class {{class_name}} { 4 class {{class_name}} {
5 public: 5 public:
6 typedef {{struct.name}} Wrapper; 6 typedef {{struct.name}} Wrapper;
7 7
8 static {{class_name}}* New(mojo::Buffer* buf, mojo::Buffer::Destructor dtor = NULL); 8 static {{class_name}}* New(mojo::Buffer* buf, mojo::Buffer::Destructor dtor = NULL);
9 9
10 static bool Validate(const void* data,
11 mojo::internal::BoundsChecker* bounds_checker);
12
10 {#--- Setters -#} 13 {#--- Setters -#}
11 {{ struct_macros.setters(struct) }} 14 {{ struct_macros.setters(struct) }}
12 15
13 {#--- Getters -#} 16 {#--- Getters -#}
14 {{ struct_macros.getters(struct) }} 17 {{ struct_macros.getters(struct) }}
15 18
16 size_t ComputeSize() const; 19 size_t ComputeSize() const;
17 {{class_name}}* Clone(mojo::Buffer* buf) const; 20 {{class_name}}* Clone(mojo::Buffer* buf) const;
18 void CloseHandles(); 21 void CloseHandles();
19 void EncodePointersAndHandles(std::vector<mojo::Handle>* handles); 22 void EncodePointersAndHandles(std::vector<mojo::Handle>* handles);
20 bool DecodePointersAndHandles(mojo::Message* message); 23 bool DecodePointersAndHandles(mojo::Message* message);
21 24
22 private: 25 private:
23 {{class_name}}(); 26 {{class_name}}();
24 ~{{class_name}}(); // NOT IMPLEMENTED 27 ~{{class_name}}(); // NOT IMPLEMENTED
25 28
26 mojo::internal::StructHeader _header_; 29 mojo::internal::StructHeader _header_;
27 {{ struct_macros.fields(struct) }} 30 {{ struct_macros.fields(struct) }}
28 }; 31 };
29 MOJO_COMPILE_ASSERT(sizeof({{class_name}}) == {{struct.packed|struct_size}}, 32 MOJO_COMPILE_ASSERT(sizeof({{class_name}}) == {{struct.packed|struct_size}},
30 bad_sizeof_{{class_name}}); 33 bad_sizeof_{{class_name}});
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698