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

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

Issue 99623010: Add support for enums within structs and interfaces to mojom. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 11 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 class {{class_name}} { 3 class {{class_name}} {
4 public: 4 public:
5 typedef {{struct.name}} Wrapper; 5 typedef {{struct.name}} Wrapper;
6 6
7 {#--- Enums #}
8 {%- for enum in struct.enums %}
9 {% macro enum_def() %}{% include "enum_declaration.tmpl" %}{% endmacro %}
10 {{enum_def()|indent(2)}}
11 {%- endfor %}
12
7 static {{class_name}}* New(mojo::Buffer* buf, mojo::Buffer::Destructor dtor = NULL); 13 static {{class_name}}* New(mojo::Buffer* buf, mojo::Buffer::Destructor dtor = NULL);
8 14
9 {#--- Setters -#} 15 {#--- Setters -#}
10 {{ struct_macros.setters(struct) }} 16 {{ struct_macros.setters(struct) }}
11 17
12 {#--- Getters -#} 18 {#--- Getters -#}
13 {{ struct_macros.getters(struct) }} 19 {{ struct_macros.getters(struct) }}
14 20
15 private: 21 private:
16 friend class mojo::internal::ObjectTraits<{{class_name}}>; 22 friend class mojo::internal::ObjectTraits<{{class_name}}>;
17 23
18 {{class_name}}(); 24 {{class_name}}();
19 ~{{class_name}}(); // NOT IMPLEMENTED 25 ~{{class_name}}(); // NOT IMPLEMENTED
20 26
21 mojo::internal::StructHeader _header_; 27 mojo::internal::StructHeader _header_;
22 {{ struct_macros.fields(struct) }} 28 {{ struct_macros.fields(struct) }}
23 }; 29 };
24 MOJO_COMPILE_ASSERT(sizeof({{class_name}}) == {{struct.packed|struct_size}}, 30 MOJO_COMPILE_ASSERT(sizeof({{class_name}}) == {{struct.packed|struct_size}},
25 bad_sizeof_{{class_name}}); 31 bad_sizeof_{{class_name}});
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698